tdbInt.h 3.3 KB
Newer Older
H
more  
Hongze Cheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */

H
Hongze Cheng 已提交
16 17
#ifndef _TD_TDB_INTERNAL_H_
#define _TD_TDB_INTERNAL_H_
H
Hongze Cheng 已提交
18

H
refact  
Hongze Cheng 已提交
19
#include "tlist.h"
H
refact  
Hongze Cheng 已提交
20
#include "tlockfree.h"
H
more  
Hongze Cheng 已提交
21

H
refact  
Hongze Cheng 已提交
22 23
#include "tdb.h"

H
more  
Hongze Cheng 已提交
24 25 26 27
#ifdef __cplusplus
extern "C" {
#endif

H
Hongze Cheng 已提交
28 29
typedef struct SPgFile SPgFile;

H
more  
Hongze Cheng 已提交
30 31
// SPgno
typedef int32_t SPgno;
H
Hongze Cheng 已提交
32
#define TDB_IVLD_PGNO ((pgno_t)0)
H
Hongze Cheng 已提交
33

H
Hongze Cheng 已提交
34
// fileid
H
Hongze Cheng 已提交
35
#define TDB_FILE_ID_LEN 24
H
Hongze Cheng 已提交
36 37 38

// pgid_t
typedef struct {
H
Hongze Cheng 已提交
39
  uint8_t fileid[TDB_FILE_ID_LEN];
H
more  
Hongze Cheng 已提交
40
  SPgno  pgno;
H
more  
Hongze Cheng 已提交
41
} pgid_t, SPgid;
H
Hongze Cheng 已提交
42

H
Hongze Cheng 已提交
43
#define TDB_IVLD_PGID (pgid_t){0, TDB_IVLD_PGNO};
H
Hongze Cheng 已提交
44

H
Hongze Cheng 已提交
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
static FORCE_INLINE int tdbCmprPgId(const void *p1, const void *p2) {
  pgid_t *pgid1 = (pgid_t *)p1;
  pgid_t *pgid2 = (pgid_t *)p2;
  int     rcode;

  rcode = memcmp(pgid1->fileid, pgid2->fileid, TDB_FILE_ID_LEN);
  if (rcode) {
    return rcode;
  } else {
    if (pgid1->pgno > pgid2->pgno) {
      return 1;
    } else if (pgid1->pgno < pgid2->pgno) {
      return -1;
    } else {
      return 0;
    }
  }
}

H
Hongze Cheng 已提交
64 65 66
// framd_id_t
typedef int32_t frame_id_t;

H
Hongze Cheng 已提交
67
// pgsz_t
H
more  
Hongze Cheng 已提交
68 69 70
#define TDB_MIN_PGSIZE       512
#define TDB_MAX_PGSIZE       65536
#define TDB_DEFAULT_PGSIZE   4096
H
Hongze Cheng 已提交
71 72
#define TDB_IS_PGSIZE_VLD(s) (((s) >= TDB_MIN_PGSIZE) && ((s) <= TDB_MAX_PGSIZE))

H
Hongze Cheng 已提交
73 74 75
// pgoff_t
typedef pgsz_t pgoff_t;

H
Hongze Cheng 已提交
76
// cache
H
Hongze Cheng 已提交
77
#define TDB_DEFAULT_CACHE_SIZE (256 * 4096)  // 1M
H
Hongze Cheng 已提交
78

H
Hongze Cheng 已提交
79 80 81
// dbname
#define TDB_MAX_DBNAME_LEN 24

H
Hongze Cheng 已提交
82 83
// tdb_log
#define tdbError(var)
H
more  
Hongze Cheng 已提交
84

H
Hongze Cheng 已提交
85 86
typedef TD_DLIST(STDb) STDbList;
typedef TD_DLIST(SPgFile) SPgFileList;
H
Hongze Cheng 已提交
87
typedef TD_DLIST_NODE(SPgFile) SPgFileListNode;
H
Hongze Cheng 已提交
88 89 90 91 92 93 94 95 96 97 98 99 100 101 102

#define TERR_A(val, op, flag)  \
  do {                         \
    if (((val) = (op)) != 0) { \
      goto flag;               \
    }                          \
  } while (0)

#define TERR_B(val, op, flag)     \
  do {                            \
    if (((val) = (op)) == NULL) { \
      goto flag;                  \
    }                             \
  } while (0)

H
Hongze Cheng 已提交
103
#define TDB_VARIANT_LEN (int)-1
H
Hongze Cheng 已提交
104

H
Hongze Cheng 已提交
105 106
// page payload format
// <keyLen> + <valLen> + [key] + [value]
H
Hongze Cheng 已提交
107 108 109
#define TDB_DECODE_PAYLOAD(pPayload, keyLen, pKey, valLen, pVal) \
  do {                                                           \
    if ((keyLen) == TDB_VARIANT_LEN) {                           \
H
Hongze Cheng 已提交
110
      /* TODO: decode the keyLen */                              \
H
Hongze Cheng 已提交
111 112
    }                                                            \
    if ((valLen) == TDB_VARIANT_LEN) {                           \
H
Hongze Cheng 已提交
113
      /* TODO: decode the valLen */                              \
H
Hongze Cheng 已提交
114 115 116 117
    }                                                            \
    /* TODO */                                                   \
  } while (0)

H
Hongze Cheng 已提交
118 119
#define TDB_JOURNAL_NAME "tdb.journal"

H
Hongze Cheng 已提交
120 121
#include "tdbUtil.h"

H
more  
Hongze Cheng 已提交
122
// #include "tdbBtree.h"
H
Hongze Cheng 已提交
123

H
refact  
Hongze Cheng 已提交
124
#include "tdbPCache.h"
H
Hongze Cheng 已提交
125

H
refact  
Hongze Cheng 已提交
126
#include "tdbPFile.h"
H
Hongze Cheng 已提交
127

H
more  
Hongze Cheng 已提交
128
// #include "tdbEnv.h"
H
Hongze Cheng 已提交
129

H
more  
Hongze Cheng 已提交
130 131 132 133
#ifdef __cplusplus
}
#endif

H
Hongze Cheng 已提交
134
#endif /*_TD_TDB_INTERNAL_H_*/