diff --git a/include/db.h b/include/db.h index 2dc22a669e1..b7013dfc87e 100644 --- a/include/db.h +++ b/include/db.h @@ -6,8 +6,8 @@ extern "C" { #endif #define DB_VERSION_MAJOR 4 -#define DB_VERSION_MINOR 3 -#define DB_VERSION_PATCH 29 +#define DB_VERSION_MINOR 1 +#define DB_VERSION_PATCH 24 #ifndef _TOKUDB_WRAP_H #define DB_VERSION_STRING "Tokutek: TokuDB" #else @@ -26,10 +26,10 @@ typedef struct __toku_dbt DBT; typedef enum { DB_BTREE=1 } DBTYPE; -#define DB_VERB_DEADLOCK 1 -#define DB_VERB_RECOVERY 2 -#define DB_VERB_REPLICATION 4 -#define DB_VERB_WAITSFOR 8 +#define DB_VERB_DEADLOCK 2 +#define DB_VERB_RECOVERY 4 +#define DB_VERB_REPLICATION 8 +#define DB_VERB_WAITSFOR 16 #define DB_DBT_MALLOC 4 #define DB_DBT_REALLOC 16 #define DB_DBT_USERMEM 32 @@ -37,34 +37,34 @@ typedef enum { #define DB_ARCH_ABS 1 #define DB_ARCH_LOG 4 #define DB_CREATE 1 -#define DB_PRIVATE 1048576 +#define DB_PRIVATE 262144 #define DB_RDONLY 16 #define DB_RECOVER 32 #define DB_THREAD 64 #define DB_TXN_NOSYNC 256 #define DB_LOCK_DEFAULT 1 -#define DB_LOCK_OLDEST 7 -#define DB_LOCK_RANDOM 8 +#define DB_LOCK_OLDEST 6 +#define DB_LOCK_RANDOM 7 #define DB_DUP 2 -#define DB_NOOVERWRITE 22 -#define DB_INIT_LOCK 8192 -#define DB_INIT_LOG 16384 -#define DB_INIT_MPOOL 32768 -#define DB_INIT_TXN 131072 -#define DB_KEYEMPTY -30997 -#define DB_KEYEXIST -30996 -#define DB_LOCK_DEADLOCK -30995 -#define DB_NOTFOUND -30989 +#define DB_NOOVERWRITE 23 +#define DB_INIT_LOCK 4096 +#define DB_INIT_LOG 8192 +#define DB_INIT_MPOOL 16384 +#define DB_INIT_TXN 32768 +#define DB_KEYEMPTY -30998 +#define DB_KEYEXIST -30997 +#define DB_LOCK_DEADLOCK -30996 +#define DB_NOTFOUND -30991 #define DB_BADFORMAT -30500 -#define DB_FIRST 9 -#define DB_GET_BOTH 10 -#define DB_LAST 17 -#define DB_NEXT 18 -#define DB_NEXT_DUP 19 -#define DB_PREV 25 -#define DB_SET 28 -#define DB_SET_RANGE 30 -#define DB_RMW 536870912 +#define DB_FIRST 10 +#define DB_GET_BOTH 11 +#define DB_LAST 18 +#define DB_NEXT 19 +#define DB_NEXT_DUP 20 +#define DB_PREV 27 +#define DB_SET 30 +#define DB_SET_RANGE 32 +#define DB_RMW 1073741824 /* in wrap mode, top-level function txn_begin is renamed, but the field isn't renamed, so we have to hack it here.*/ #ifdef _TOKUDB_WRAP_H #undef txn_begin @@ -73,58 +73,55 @@ struct __toku_db_btree_stat { char __toku_dummy0[12]; u_int32_t bt_nkeys; /* 32-bit offset=12 size=4, 64=bit offset=12 size=4 */ u_int32_t bt_ndata; /* 32-bit offset=16 size=4, 64=bit offset=16 size=4 */ - char __toku_dummy1[64]; /* Padding at the end */ + char __toku_dummy1[60]; /* Padding at the end */ }; struct __toku_db_env { struct __toku_db_env_internal *i; - void* __toku_dummy0[44]; - char __toku_dummy1[96]; - int (*close) (DB_ENV *, u_int32_t); /* 32-bit offset=276 size=4, 64=bit offset=456 size=8 */ + void* __toku_dummy0[45]; + char __toku_dummy1[64]; + int (*close) (DB_ENV *, u_int32_t); /* 32-bit offset=248 size=4, 64=bit offset=432 size=8 */ void* __toku_dummy2[2]; - void (*err) (const DB_ENV *, int, const char *, ...); /* 32-bit offset=288 size=4, 64=bit offset=480 size=8 */ + void (*err) (const DB_ENV *, int, const char *, ...); /* 32-bit offset=260 size=4, 64=bit offset=456 size=8 */ void* __toku_dummy3[1]; - int (*open) (DB_ENV *, const char *, u_int32_t, int); /* 32-bit offset=296 size=4, 64=bit offset=496 size=8 */ - void* __toku_dummy4[9]; - int (*set_data_dir) (DB_ENV *, const char *); /* 32-bit offset=336 size=4, 64=bit offset=576 size=8 */ - void* __toku_dummy5[2]; - void (*set_errcall) (DB_ENV *, void (*)(const char *, char *)); /* 32-bit offset=348 size=4, 64=bit offset=600 size=8 */ - void* __toku_dummy6[3]; - void (*set_errpfx) (DB_ENV *, const char *); /* 32-bit offset=364 size=4, 64=bit offset=632 size=8 */ - void* __toku_dummy7[2]; - int (*set_flags) (DB_ENV *, u_int32_t, int); /* 32-bit offset=376 size=4, 64=bit offset=656 size=8 */ - void* __toku_dummy8[13]; - int (*set_tmp_dir) (DB_ENV *, const char *); /* 32-bit offset=432 size=4, 64=bit offset=768 size=8 */ + int (*open) (DB_ENV *, const char *, u_int32_t, int); /* 32-bit offset=268 size=4, 64=bit offset=472 size=8 */ + void* __toku_dummy4[1]; + int (*set_data_dir) (DB_ENV *, const char *); /* 32-bit offset=276 size=4, 64=bit offset=488 size=8 */ + void* __toku_dummy5[3]; + void (*set_errcall) (DB_ENV *, void (*)(const char *, char *)); /* 32-bit offset=292 size=4, 64=bit offset=520 size=8 */ + void* __toku_dummy6[1]; + void (*set_errpfx) (DB_ENV *, const char *); /* 32-bit offset=300 size=4, 64=bit offset=536 size=8 */ + void* __toku_dummy7[1]; + int (*set_flags) (DB_ENV *, u_int32_t, int); /* 32-bit offset=308 size=4, 64=bit offset=552 size=8 */ + void* __toku_dummy8[5]; + int (*set_tmp_dir) (DB_ENV *, const char *); /* 32-bit offset=332 size=4, 64=bit offset=600 size=8 */ + int (*set_verbose) (DB_ENV *, u_int32_t, int); /* 32-bit offset=336 size=4, 64=bit offset=608 size=8 */ void* __toku_dummy9[1]; - int (*set_verbose) (DB_ENV *, u_int32_t, int); /* 32-bit offset=440 size=4, 64=bit offset=784 size=8 */ - void* __toku_dummy10[2]; - int (*set_lg_bsize) (DB_ENV *, u_int32_t); /* 32-bit offset=452 size=4, 64=bit offset=808 size=8 */ - void* __toku_dummy11[1]; - int (*set_lg_dir) (DB_ENV *, const char *); /* 32-bit offset=460 size=4, 64=bit offset=824 size=8 */ - void* __toku_dummy12[1]; - int (*set_lg_max) (DB_ENV *, u_int32_t); /* 32-bit offset=468 size=4, 64=bit offset=840 size=8 */ - void* __toku_dummy13[2]; - int (*log_archive) (DB_ENV *, char **[], u_int32_t); /* 32-bit offset=480 size=4, 64=bit offset=864 size=8 */ - void* __toku_dummy14[2]; - int (*log_flush) (DB_ENV *, const DB_LSN *); /* 32-bit offset=492 size=4, 64=bit offset=888 size=8 */ - void* __toku_dummy15[7]; - int (*set_lk_detect) (DB_ENV *, u_int32_t); /* 32-bit offset=524 size=4, 64=bit offset=952 size=8 */ - int (*set_lk_max) (DB_ENV *, u_int32_t); /* 32-bit offset=528 size=4, 64=bit offset=960 size=8 */ - void* __toku_dummy16[16]; - int (*set_cachesize) (DB_ENV *, u_int32_t, u_int32_t, int); /* 32-bit offset=596 size=4, 64=bit offset=1096 size=8 */ - void* __toku_dummy17[28]; - int (*txn_begin) (DB_ENV *, DB_TXN *, DB_TXN **, u_int32_t); /* 32-bit offset=712 size=4, 64=bit offset=1328 size=8 */ - int (*txn_checkpoint) (DB_ENV *, u_int32_t, u_int32_t, u_int32_t); /* 32-bit offset=716 size=4, 64=bit offset=1336 size=8 */ - void* __toku_dummy18[1]; - int (*txn_stat) (DB_ENV *, DB_TXN_STAT **, u_int32_t); /* 32-bit offset=724 size=4, 64=bit offset=1352 size=8 */ - void* __toku_dummy19[3]; /* Padding at the end */ - char __toku_dummy20[16]; /* Padding at the end */ + int (*set_lg_bsize) (DB_ENV *, u_int32_t); /* 32-bit offset=344 size=4, 64=bit offset=624 size=8 */ + int (*set_lg_dir) (DB_ENV *, const char *); /* 32-bit offset=348 size=4, 64=bit offset=632 size=8 */ + int (*set_lg_max) (DB_ENV *, u_int32_t); /* 32-bit offset=352 size=4, 64=bit offset=640 size=8 */ + void* __toku_dummy10[1]; + int (*log_archive) (DB_ENV *, char **[], u_int32_t); /* 32-bit offset=360 size=4, 64=bit offset=656 size=8 */ + void* __toku_dummy11[2]; + int (*log_flush) (DB_ENV *, const DB_LSN *); /* 32-bit offset=372 size=4, 64=bit offset=680 size=8 */ + void* __toku_dummy12[4]; + int (*set_lk_detect) (DB_ENV *, u_int32_t); /* 32-bit offset=392 size=4, 64=bit offset=720 size=8 */ + int (*set_lk_max) (DB_ENV *, u_int32_t); /* 32-bit offset=396 size=4, 64=bit offset=728 size=8 */ + void* __toku_dummy13[15]; + int (*set_cachesize) (DB_ENV *, u_int32_t, u_int32_t, int); /* 32-bit offset=460 size=4, 64=bit offset=856 size=8 */ + void* __toku_dummy14[21]; + int (*txn_begin) (DB_ENV *, DB_TXN *, DB_TXN **, u_int32_t); /* 32-bit offset=548 size=4, 64=bit offset=1032 size=8 */ + int (*txn_checkpoint) (DB_ENV *, u_int32_t, u_int32_t, u_int32_t); /* 32-bit offset=552 size=4, 64=bit offset=1040 size=8 */ + void* __toku_dummy15[2]; + int (*txn_stat) (DB_ENV *, DB_TXN_STAT **, u_int32_t); /* 32-bit offset=564 size=4, 64=bit offset=1064 size=8 */ + void* __toku_dummy16[2]; /* Padding at the end */ + char __toku_dummy17[8]; /* Padding at the end */ }; struct __toku_db_key_range { double less; /* 32-bit offset=0 size=8, 64=bit offset=0 size=8 */ double equal; /* 32-bit offset=8 size=8, 64=bit offset=8 size=8 */ double greater; /* 32-bit offset=16 size=8, 64=bit offset=16 size=8 */ - void* __toku_dummy0[161]; /* Padding at the end */ - char __toku_dummy1[88]; /* Padding at the end */ + void* __toku_dummy0[128]; /* Padding at the end */ + char __toku_dummy1[48]; /* Padding at the end */ }; struct __toku_db_lsn { char __toku_dummy0[8]; /* Padding at the end */ @@ -138,38 +135,37 @@ struct __toku_db { int (*close) (DB*, u_int32_t); /* 32-bit offset=272 size=4, 64=bit offset=448 size=8 */ int (*cursor) (DB *, DB_TXN *, DBC **, u_int32_t); /* 32-bit offset=276 size=4, 64=bit offset=456 size=8 */ int (*del) (DB *, DB_TXN *, DBT *, u_int32_t); /* 32-bit offset=280 size=4, 64=bit offset=464 size=8 */ - void* __toku_dummy3[4]; - int (*get) (DB *, DB_TXN *, DBT *, DBT *, u_int32_t); /* 32-bit offset=300 size=4, 64=bit offset=504 size=8 */ - void* __toku_dummy4[15]; - int (*key_range) (DB *, DB_TXN *, DBT *, DB_KEY_RANGE *, u_int32_t); /* 32-bit offset=364 size=4, 64=bit offset=632 size=8 */ - int (*open) (DB *, DB_TXN *, const char *, const char *, DBTYPE, u_int32_t, int); /* 32-bit offset=368 size=4, 64=bit offset=640 size=8 */ - int (*put) (DB *, DB_TXN *, DBT *, DBT *, u_int32_t); /* 32-bit offset=372 size=4, 64=bit offset=648 size=8 */ - int (*remove) (DB *, const char *, const char *, u_int32_t); /* 32-bit offset=376 size=4, 64=bit offset=656 size=8 */ - int (*rename) (DB *, const char *, const char *, const char *, u_int32_t); /* 32-bit offset=380 size=4, 64=bit offset=664 size=8 */ - void* __toku_dummy5[10]; - int (*set_flags) (DB *, u_int32_t); /* 32-bit offset=424 size=4, 64=bit offset=752 size=8 */ - void* __toku_dummy6[6]; - int (*stat) (DB *, void *, u_int32_t); /* 32-bit offset=452 size=4, 64=bit offset=808 size=8 */ - void* __toku_dummy7[5]; - int (*set_bt_compare) (DB *, int (*)(DB *, const DBT *, const DBT *)); /* 32-bit offset=476 size=4, 64=bit offset=856 size=8 */ - void* __toku_dummy8[23]; /* Padding at the end */ + void* __toku_dummy3[3]; + int (*get) (DB *, DB_TXN *, DBT *, DBT *, u_int32_t); /* 32-bit offset=296 size=4, 64=bit offset=496 size=8 */ + void* __toku_dummy4[4]; + int (*key_range) (DB *, DB_TXN *, DBT *, DB_KEY_RANGE *, u_int32_t); /* 32-bit offset=316 size=4, 64=bit offset=536 size=8 */ + int (*open) (DB *, DB_TXN *, const char *, const char *, DBTYPE, u_int32_t, int); /* 32-bit offset=320 size=4, 64=bit offset=544 size=8 */ + int (*put) (DB *, DB_TXN *, DBT *, DBT *, u_int32_t); /* 32-bit offset=324 size=4, 64=bit offset=552 size=8 */ + int (*remove) (DB *, const char *, const char *, u_int32_t); /* 32-bit offset=328 size=4, 64=bit offset=560 size=8 */ + int (*rename) (DB *, const char *, const char *, const char *, u_int32_t); /* 32-bit offset=332 size=4, 64=bit offset=568 size=8 */ + void* __toku_dummy5[11]; + int (*set_flags) (DB *, u_int32_t); /* 32-bit offset=380 size=4, 64=bit offset=664 size=8 */ + void* __toku_dummy6[3]; + int (*stat) (DB *, void *, u_int32_t); /* 32-bit offset=396 size=4, 64=bit offset=696 size=8 */ + void* __toku_dummy7[3]; + int (*set_bt_compare) (DB *, int (*)(DB *, const DBT *, const DBT *)); /* 32-bit offset=412 size=4, 64=bit offset=728 size=8 */ + void* __toku_dummy8[15]; /* Padding at the end */ char __toku_dummy9[8]; /* Padding at the end */ }; struct __toku_db_txn_active { u_int32_t txnid; /* 32-bit offset=0 size=4, 64=bit offset=0 size=4 */ char __toku_dummy0[4]; DB_LSN lsn; /* 32-bit offset=8 size=8, 64=bit offset=8 size=8 */ - char __toku_dummy1[132]; /* Padding at the end */ }; struct __toku_db_txn { struct __toku_db_txn_internal *i; - void* __toku_dummy0[18]; + void* __toku_dummy0[12]; char __toku_dummy1[24]; - int (*abort) (DB_TXN *); /* 32-bit offset=100 size=4, 64=bit offset=176 size=8 */ - int (*commit) (DB_TXN*, u_int32_t); /* 32-bit offset=104 size=4, 64=bit offset=184 size=8 */ + int (*abort) (DB_TXN *); /* 32-bit offset=76 size=4, 64=bit offset=128 size=8 */ + int (*commit) (DB_TXN*, u_int32_t); /* 32-bit offset=80 size=4, 64=bit offset=136 size=8 */ void* __toku_dummy2[1]; - u_int32_t (*id) (DB_TXN *); /* 32-bit offset=112 size=4, 64=bit offset=200 size=8 */ - void* __toku_dummy3[4]; /* Padding at the end */ + u_int32_t (*id) (DB_TXN *); /* 32-bit offset=88 size=4, 64=bit offset=152 size=8 */ + void* __toku_dummy3[3]; /* Padding at the end */ }; struct __toku_db_txn_stat { void* __toku_dummy0[1]; @@ -182,21 +178,22 @@ struct __toku_db_txn_stat { }; struct __toku_dbc { struct __toku_dbc_internal *i; - void* __toku_dummy0[18]; - char __toku_dummy1[112]; - int (*c_close) (DBC *); /* 32-bit offset=188 size=4, 64=bit offset=264 size=8 */ + void* __toku_dummy0[24]; + char __toku_dummy1[104]; + int (*c_close) (DBC *); /* 32-bit offset=204 size=4, 64=bit offset=304 size=8 */ void* __toku_dummy2[1]; - int (*c_del) (DBC *, u_int32_t); /* 32-bit offset=196 size=4, 64=bit offset=280 size=8 */ + int (*c_del) (DBC *, u_int32_t); /* 32-bit offset=212 size=4, 64=bit offset=320 size=8 */ void* __toku_dummy3[1]; - int (*c_get) (DBC *, DBT *, DBT *, u_int32_t); /* 32-bit offset=204 size=4, 64=bit offset=296 size=8 */ - void* __toku_dummy4[10]; /* Padding at the end */ + int (*c_get) (DBC *, DBT *, DBT *, u_int32_t); /* 32-bit offset=220 size=4, 64=bit offset=336 size=8 */ + void* __toku_dummy4[11]; /* Padding at the end */ }; struct __toku_dbt { void*data; /* 32-bit offset=0 size=4, 64=bit offset=0 size=8 */ u_int32_t size; /* 32-bit offset=4 size=4, 64=bit offset=8 size=4 */ u_int32_t ulen; /* 32-bit offset=8 size=4, 64=bit offset=12 size=4 */ char __toku_dummy0[8]; - u_int32_t flags; /* 32-bit offset=20 size=4, 64=bit offset=24 size=4 */ + void*app_private; /* 32-bit offset=20 size=4, 64=bit offset=24 size=8 */ + u_int32_t flags; /* 32-bit offset=24 size=4, 64=bit offset=32 size=4 */ /* 4 more bytes of alignment in the 64-bit case. */ }; #ifdef _TOKUDB_WRAP_H