diff --git a/buildheader/Makefile b/buildheader/Makefile index 9ac6cdcfe65..2a9acc8f795 100644 --- a/buildheader/Makefile +++ b/buildheader/Makefile @@ -1,30 +1,38 @@ CFLAGS = -Wall -W -O2 -Werror -g +MYSQL_H = -I../../mysql-5.0.27/mysql-5.0.27/bdb/build_unix/ runs: runs_mysql runs_installed # the mysql versions use the header in the mysql distribution. runs_mysql: ./sample_offsets_mysql ./sample_offsets_mysql runs_installed: sample_offsets ./sample_offsets -sample_offsets_mysql: CPPFLAGS=-I../../mysql-5.0.27/mysql-5.0.27/bdb/build_unix/ +sample_offsets_mysql: CPPFLAGS=$(MYSQL_H) sample_offsets_mysql: sample_offsets.c $(CC) $(CFLAGS) $(CPPFLAGS) $< -o $@ -make_db_h.o: make_db_h.c sample_offsets_32.h sample_offsets_64.h +make_db_h_4_1.o: make_db_h.c sample_offsets_32_4_1.h sample_offsets_64_4_1.h + $(CC) $(CFLAGS) -I. $(MYSQL_H) $< -c -o $@ -DUSE_MAJOR=4 -DUSE_MINOR=1 +db.h_4_1: make_db_h_4_1 + ./make_db_h_4_1 > $@ + +make_db_h_4_3.o: make_db_h.c sample_offsets_32_4_3.h sample_offsets_64_4_3.h + $(CC) $(CFLAGS) -I. $< -c -o $@ -DUSE_MAJOR=4 -DUSE_MINOR=3 +db.h_4_3: make_db_h_4_3 + ./make_db_h_4_3 > $@ + sample_offsets: sample_offsets_local: ./db.h sample_offsets_local: sample_offsets.c $(CC) $(CFLAGS) -I. -DLOCAL $< -o $@ -db.h: make_db_h - ./make_db_h > db.h check32: sample_offsets_local ./sample_offsets_local diff sample_offsets_local.h sample_offsets_32.h clean: rm sample_offsets_mysql sample_offsets -install: db.h - cp db.h ../include/ +install_4_1: db.h_4_1 + cp db.h_4_1 ../include/db.h # Note: To make the ompile work, you must cd to the ../../mysql-5.0.27/mysql-5.0.27/bdb/build_unix # and do ../dist/configure diff --git a/buildheader/db.h_4_1 b/buildheader/db.h_4_1 new file mode 100644 index 00000000000..b7013dfc87e --- /dev/null +++ b/buildheader/db.h_4_1 @@ -0,0 +1,209 @@ +#ifndef _DB_H +#define _DB_H +/* This code generated by make_db_h. Copyright (c) 2007 Tokutek */ +#include +#if defined(__cplusplus) +extern "C" { +#endif +#define DB_VERSION_MAJOR 4 +#define DB_VERSION_MINOR 1 +#define DB_VERSION_PATCH 24 +#ifndef _TOKUDB_WRAP_H +#define DB_VERSION_STRING "Tokutek: TokuDB" +#else +#define DB_VERSION_STRING "Tokutek: TokuDB (wrapped bdb)" +#endif +typedef struct __toku_db_btree_stat DB_BTREE_STAT; +typedef struct __toku_db_env DB_ENV; +typedef struct __toku_db_key_range DB_KEY_RANGE; +typedef struct __toku_db_lsn DB_LSN; +typedef struct __toku_db DB; +typedef struct __toku_db_txn DB_TXN; +typedef struct __toku_db_txn_active DB_TXN_ACTIVE; +typedef struct __toku_db_txn_stat DB_TXN_STAT; +typedef struct __toku_dbc DBC; +typedef struct __toku_dbt DBT; +typedef enum { + DB_BTREE=1 +} DBTYPE; +#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 +#define DB_DBT_DUPOK 64 +#define DB_ARCH_ABS 1 +#define DB_ARCH_LOG 4 +#define DB_CREATE 1 +#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 6 +#define DB_LOCK_RANDOM 7 +#define DB_DUP 2 +#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 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 +#endif +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[60]; /* Padding at the end */ +}; +struct __toku_db_env { + struct __toku_db_env_internal *i; + 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=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=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_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[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 */ +}; +struct __toku_db { + struct __toku_db_internal *i; + void* __toku_dummy0[3]; + void *app_private; /* 32-bit offset=16 size=4, 64=bit offset=32 size=8 */ + void* __toku_dummy1[39]; + char __toku_dummy2[96]; + 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[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 */ +}; +struct __toku_db_txn { + struct __toku_db_txn_internal *i; + void* __toku_dummy0[12]; + char __toku_dummy1[24]; + 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=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]; + char __toku_dummy1[28]; + u_int32_t st_nactive; /* 32-bit offset=32 size=4, 64=bit offset=36 size=4 */ + char __toku_dummy2[8]; + DB_TXN_ACTIVE *st_txnarray; /* 32-bit offset=44 size=4, 64=bit offset=48 size=8 */ + void* __toku_dummy3[1]; /* Padding at the end */ + char __toku_dummy4[8]; /* Padding at the end */ +}; +struct __toku_dbc { + struct __toku_dbc_internal *i; + 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=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=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]; + 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 +#define txn_begin txn_begin_tokudb +#endif +int db_env_create(DB_ENV **, u_int32_t); +int db_create(DB **, DB_ENV *, u_int32_t); +char *db_strerror(int); +int log_compare (const DB_LSN*, const DB_LSN *); +#if defined(__cplusplus) +} +#endif +#endif diff --git a/buildheader/db.h b/buildheader/db.h_4_3 similarity index 98% rename from buildheader/db.h rename to buildheader/db.h_4_3 index 8602a1139c7..4b8580171d1 100644 --- a/buildheader/db.h +++ b/buildheader/db.h_4_3 @@ -9,7 +9,7 @@ extern "C" { #define DB_VERSION_MINOR 3 #define DB_VERSION_PATCH 29 #ifndef _TOKUDB_WRAP_H -#define DB_VERSION_STRING "Tokutek: TokuDB" +#define DB_VERSION_STRING "Tokutek: TokuDB 4.3.29" #else #define DB_VERSION_STRING "Tokutek: TokuDB (wrapped bdb)" #endif @@ -165,7 +165,7 @@ struct __toku_db_txn { struct __toku_db_txn_internal *i; void* __toku_dummy0[18]; char __toku_dummy1[24]; - int (*abort) __P((DB_TXN *); /* 32-bit offset=100 size=4, 64=bit offset=176 size=8 */ + 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 */ void* __toku_dummy2[1]; u_int32_t (*id) (DB_TXN *); /* 32-bit offset=112 size=4, 64=bit offset=200 size=8 */ diff --git a/buildheader/make_db_h.c b/buildheader/make_db_h.c index ec226f1d1c3..90e60d5c3c8 100644 --- a/buildheader/make_db_h.c +++ b/buildheader/make_db_h.c @@ -82,8 +82,15 @@ struct fieldinfo { unsigned int size; }; -#include "sample_offsets_32.h" -#include "sample_offsets_64.h" +#if USE_MAJOR==4 && USE_MINOR==1 +#include "sample_offsets_32_4_1.h" +#include "sample_offsets_64_4_1.h" +#elif USE_MAJOR==4 && USE_MINOR==3 +#include "sample_offsets_32_4_3.h" +#include "sample_offsets_64_4_3.h" +#else +#error +#endif void print_struct (const char *structname, int need_internal, struct fieldinfo *fields32, struct fieldinfo *fields64, unsigned int N) { unsigned int i; @@ -166,11 +173,13 @@ int main (int argc __attribute__((__unused__)), char *argv[] __attribute__((__un //printf("#include \n"); printf("#if defined(__cplusplus)\nextern \"C\" {\n#endif\n"); + assert(DB_VERSION_MAJOR==DB_VERSION_MAJOR_32); + assert(DB_VERSION_MINOR==DB_VERSION_MINOR_32); dodefine(DB_VERSION_MAJOR); dodefine(DB_VERSION_MINOR); dodefine(DB_VERSION_PATCH); printf("#ifndef _TOKUDB_WRAP_H\n"); - printf("#define DB_VERSION_STRING \"Tokutek: TokuDB\"\n"); + printf("#define DB_VERSION_STRING \"Tokutek: TokuDB %d.%d.%d\"\n", DB_VERSION_MAJOR, DB_VERSION_MINOR, DB_VERSION_PATCH); printf("#else\n"); printf("#define DB_VERSION_STRING \"Tokutek: TokuDB (wrapped bdb)\"\n"); printf("#endif\n");