tdbInt.h 3.6 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 74 75
// framd_id_t
typedef int32_t frame_id_t;

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

H
Hongze Cheng 已提交
82
// cache
H
Hongze Cheng 已提交
83
#define TDB_DEFAULT_CACHE_SIZE (256 * 4096)  // 1M
H
Hongze Cheng 已提交
84

H
Hongze Cheng 已提交
85 86 87
// dbname
#define TDB_MAX_DBNAME_LEN 24

H
Hongze Cheng 已提交
88 89
// tdb_log
#define tdbError(var)
H
more  
Hongze Cheng 已提交
90

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

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

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

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

H
Hongze Cheng 已提交
126
#define TDB_JOURNAL_NAME "tdb.journal"
H
Hongze Cheng 已提交
127

H
Hongze Cheng 已提交
128
#define TDB_FILENAME_LEN 128
H
Hongze Cheng 已提交
129

H
Hongze Cheng 已提交
130 131
#define TDB_DEFAULT_FANOUT 6

H
Hongze Cheng 已提交
132 133
#define BTREE_MAX_DEPTH 20

H
Hongze Cheng 已提交
134 135
#include "tdbUtil.h"

H
refact  
Hongze Cheng 已提交
136
#include "tdbPCache.h"
H
Hongze Cheng 已提交
137

H
Hongze Cheng 已提交
138
#include "tdbPager.h"
H
Hongze Cheng 已提交
139

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

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

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

H
more  
Hongze Cheng 已提交
146 147 148 149
#ifdef __cplusplus
}
#endif

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