tdbInt.h 4.0 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
more  
Hongze Cheng 已提交
22
// #include "tdb.h"
H
refact  
Hongze Cheng 已提交
23

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

H
more  
Hongze Cheng 已提交
28 29 30 31 32 33 34 35 36
typedef int8_t   i8;
typedef int16_t  i16;
typedef int32_t  i32;
typedef int64_t  i64;
typedef uint8_t  u8;
typedef uint16_t u16;
typedef uint32_t u32;
typedef uint64_t u64;

H
more  
Hongze Cheng 已提交
37
// SPgno
H
more  
Hongze Cheng 已提交
38
typedef u32 SPgno;
H
Hongze Cheng 已提交
39
#define TDB_IVLD_PGNO ((pgno_t)0)
H
Hongze Cheng 已提交
40

H
Hongze Cheng 已提交
41
// fileid
H
Hongze Cheng 已提交
42
#define TDB_FILE_ID_LEN 24
H
Hongze Cheng 已提交
43 44 45

// pgid_t
typedef struct {
H
Hongze Cheng 已提交
46
  uint8_t fileid[TDB_FILE_ID_LEN];
H
more  
Hongze Cheng 已提交
47
  SPgno   pgno;
H
more  
Hongze Cheng 已提交
48
} pgid_t, SPgid;
H
Hongze Cheng 已提交
49

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

H
Hongze Cheng 已提交
52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
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
more  
Hongze Cheng 已提交
71 72
#define TDB_IS_SAME_PAGE(pPgid1, pPgid2) (tdbCmprPgId(pPgid1, pPgid2) == 0)

H
Hongze Cheng 已提交
73
// pgsz_t
H
more  
Hongze Cheng 已提交
74 75 76
#define TDB_MIN_PGSIZE       512
#define TDB_MAX_PGSIZE       65536
#define TDB_DEFAULT_PGSIZE   4096
H
Hongze Cheng 已提交
77 78
#define TDB_IS_PGSIZE_VLD(s) (((s) >= TDB_MIN_PGSIZE) && ((s) <= TDB_MAX_PGSIZE))

H
Hongze Cheng 已提交
79
// cache
H
Hongze Cheng 已提交
80
#define TDB_DEFAULT_CACHE_SIZE (256 * 4096)  // 1M
H
Hongze Cheng 已提交
81

H
Hongze Cheng 已提交
82 83 84
// dbname
#define TDB_MAX_DBNAME_LEN 24

H
Hongze Cheng 已提交
85 86
// tdb_log
#define tdbError(var)
H
more  
Hongze Cheng 已提交
87

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

#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 已提交
106
#define TDB_VARIANT_LEN ((int)-1)
H
Hongze Cheng 已提交
107

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

H
more  
Hongze Cheng 已提交
121 122
typedef int (*FKeyComparator)(const void *pKey1, int kLen1, const void *pKey2, int kLen2);

H
Hongze Cheng 已提交
123
#define TDB_JOURNAL_NAME "tdb.journal"
H
Hongze Cheng 已提交
124

H
Hongze Cheng 已提交
125
#define TDB_FILENAME_LEN 128
H
Hongze Cheng 已提交
126

H
Hongze Cheng 已提交
127 128
#define TDB_DEFAULT_FANOUT 6

H
Hongze Cheng 已提交
129 130
#define BTREE_MAX_DEPTH 20

H
Hongze Cheng 已提交
131
#define TDB_FLAG_IS(flags, flag)     ((flags) == (flag))
H
Hongze Cheng 已提交
132 133 134 135 136
#define TDB_FLAG_HAS(flags, flag)    (((flags) & (flag)) != 0)
#define TDB_FLAG_NO(flags, flag)     ((flags) & (flag) == 0)
#define TDB_FLAG_ADD(flags, flag)    ((flags) |= (flag))
#define TDB_FLAG_REMOVE(flags, flag) ((flags) &= (~(flag)))

H
refact  
Hongze Cheng 已提交
137 138 139
typedef struct SPager  SPager;
typedef struct SPCache SPCache;

H
Hongze Cheng 已提交
140 141
#include "tdbUtil.h"

H
Hongze Cheng 已提交
142 143
#include "tdbPage.h"

H
refact  
Hongze Cheng 已提交
144
#include "tdbPCache.h"
H
Hongze Cheng 已提交
145

H
Hongze Cheng 已提交
146
#include "tdbPager.h"
H
Hongze Cheng 已提交
147

H
Hongze Cheng 已提交
148 149
#include "tdbBtree.h"

H
Hongze Cheng 已提交
150
#include "tdbEnv.h"
H
Hongze Cheng 已提交
151

H
Hongze Cheng 已提交
152 153
#include "tdbDb.h"

H
more  
Hongze Cheng 已提交
154 155 156 157
#ifdef __cplusplus
}
#endif

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