2007-09-28 17:11:22 +00:00
|
|
|
#ifndef TOKULOGGGER_H
|
|
|
|
#define TOKULOGGGER_H
|
2007-11-29 14:18:54 +00:00
|
|
|
|
2008-01-24 15:10:32 +00:00
|
|
|
#ident "Copyright (c) 2007, 2008 Tokutek Inc. All rights reserved."
|
2007-11-29 14:18:54 +00:00
|
|
|
|
2008-01-11 22:24:43 +00:00
|
|
|
#include <errno.h>
|
|
|
|
|
2007-10-15 03:32:32 +00:00
|
|
|
#include "../include/db.h"
|
|
|
|
#include "brttypes.h"
|
2008-04-02 23:40:36 +00:00
|
|
|
#include "memory.h"
|
2008-01-09 19:58:46 +00:00
|
|
|
|
2008-03-12 17:55:11 +00:00
|
|
|
struct logbytes;
|
|
|
|
struct logbytes {
|
|
|
|
struct logbytes *next;
|
|
|
|
int nbytes;
|
|
|
|
LSN lsn;
|
|
|
|
char bytes[0];
|
|
|
|
};
|
|
|
|
|
|
|
|
#define MALLOC_LOGBYTES(n) toku_malloc(sizeof(struct logbytes)+n)
|
|
|
|
|
2008-01-08 22:18:42 +00:00
|
|
|
int toku_logger_create(TOKULOGGER */*resultp*/);
|
2008-01-11 22:24:43 +00:00
|
|
|
void toku_logger_set_cachetable (TOKULOGGER, CACHETABLE);
|
2008-05-19 16:42:38 +00:00
|
|
|
void toku_logger_write_log_files (TOKULOGGER, int do_write_log_files);
|
2008-01-08 22:18:42 +00:00
|
|
|
int toku_logger_open(const char */*directory*/, TOKULOGGER);
|
2008-03-12 17:55:11 +00:00
|
|
|
int toku_logger_log_bytes(TOKULOGGER logger, struct logbytes *bytes, int do_fsync);
|
2008-01-08 22:18:42 +00:00
|
|
|
int toku_logger_close(TOKULOGGER *logger);
|
2008-03-21 19:40:32 +00:00
|
|
|
int toku_logger_log_checkpoint (TOKULOGGER);
|
2008-01-08 22:18:42 +00:00
|
|
|
void toku_logger_panic(TOKULOGGER, int/*err*/);
|
|
|
|
int toku_logger_panicked(TOKULOGGER /*logger*/);
|
2008-01-09 19:58:46 +00:00
|
|
|
int toku_logger_is_open(TOKULOGGER);
|
2008-02-08 19:54:00 +00:00
|
|
|
LSN toku_logger_last_lsn(TOKULOGGER);
|
2007-09-28 17:11:22 +00:00
|
|
|
|
2008-03-08 13:02:32 +00:00
|
|
|
int toku_logger_set_lg_max (TOKULOGGER logger, u_int32_t);
|
|
|
|
int toku_logger_get_lg_max (TOKULOGGER logger, u_int32_t *);
|
|
|
|
|
2007-12-22 18:40:22 +00:00
|
|
|
int toku_logger_commit (TOKUTXN txn, int no_sync);
|
2007-09-28 17:11:22 +00:00
|
|
|
|
2008-03-21 21:02:30 +00:00
|
|
|
int toku_logger_txn_begin (TOKUTXN /*parent*/,TOKUTXN *, TOKULOGGER /*logger*/);
|
2007-09-28 17:11:22 +00:00
|
|
|
|
2007-11-29 18:14:40 +00:00
|
|
|
int toku_logger_log_fcreate (TOKUTXN, const char */*fname*/, int /*mode*/);
|
2007-11-18 12:48:36 +00:00
|
|
|
|
2007-11-29 18:14:40 +00:00
|
|
|
int toku_logger_log_fopen (TOKUTXN, const char * /*fname*/, FILENUM);
|
2007-11-20 21:20:05 +00:00
|
|
|
|
2007-11-29 18:14:40 +00:00
|
|
|
int toku_logger_log_header (TOKUTXN, FILENUM, struct brt_header *);
|
2007-11-21 13:07:49 +00:00
|
|
|
|
2007-11-29 18:14:40 +00:00
|
|
|
int toku_logger_log_newbrtnode (TOKUTXN txn, FILENUM filenum, DISKOFF offset, u_int32_t height, u_int32_t nodesize, char is_dup_sort_mode, u_int32_t rand4fingerprint);
|
2007-11-21 19:06:32 +00:00
|
|
|
|
2007-11-29 18:14:40 +00:00
|
|
|
int toku_logger_fsync (TOKULOGGER logger);
|
2007-11-22 18:45:22 +00:00
|
|
|
|
2007-11-23 17:16:26 +00:00
|
|
|
int toku_fread_u_int8_t (FILE *f, u_int8_t *v, u_int32_t *crc, u_int32_t *len);
|
|
|
|
|
2007-11-22 18:45:22 +00:00
|
|
|
int toku_fread_u_int32_t_nocrclen (FILE *f, u_int32_t *v);
|
|
|
|
int toku_fread_u_int32_t (FILE *f, u_int32_t *v, u_int32_t *crc, u_int32_t *len);
|
|
|
|
int toku_fread_LSN (FILE *f, LSN *lsn, u_int32_t *crc, u_int32_t *len);
|
|
|
|
int toku_fread_FILENUM (FILE *f, FILENUM *filenum, u_int32_t *crc, u_int32_t *len);
|
|
|
|
int toku_fread_DISKOFF (FILE *f, DISKOFF *diskoff, u_int32_t *crc, u_int32_t *len);
|
|
|
|
int toku_fread_TXNID (FILE *f, TXNID *txnid, u_int32_t *crc, u_int32_t *len);
|
|
|
|
// fills in the bs with malloced data.
|
|
|
|
int toku_fread_BYTESTRING (FILE *f, BYTESTRING *bs, u_int32_t *crc, u_int32_t *len);
|
2007-11-22 21:11:21 +00:00
|
|
|
int toku_fread_LOGGEDBRTHEADER(FILE *f, LOGGEDBRTHEADER *v, u_int32_t *crc, u_int32_t *len);
|
2007-12-04 10:02:59 +00:00
|
|
|
int toku_fread_INTPAIRARRAY (FILE *f, INTPAIRARRAY *v, u_int32_t *crc, u_int32_t *len);
|
2007-11-22 21:11:21 +00:00
|
|
|
|
2007-11-27 10:48:31 +00:00
|
|
|
int toku_logprint_LSN (FILE *outf, FILE *inf, const char *fieldname, u_int32_t *crc, u_int32_t *len, const char *);
|
|
|
|
int toku_logprint_TXNID (FILE *outf, FILE *inf, const char *fieldname, u_int32_t *crc, u_int32_t *len, const char *);
|
|
|
|
int toku_logprint_BYTESTRING (FILE *outf, FILE *inf, const char *fieldname, u_int32_t *crc, u_int32_t *len, const char *);
|
|
|
|
int toku_logprint_FILENUM (FILE *outf, FILE *inf, const char *fieldname, u_int32_t *crc, u_int32_t *len, const char *);
|
|
|
|
int toku_logprint_DISKOFF (FILE *outf, FILE *inf, const char *fieldname, u_int32_t *crc, u_int32_t *len, const char *);
|
|
|
|
int toku_logprint_u_int8_t (FILE *outf, FILE *inf, const char *fieldname, u_int32_t *crc, u_int32_t *len, const char *);
|
|
|
|
int toku_logprint_u_int32_t (FILE *outf, FILE *inf, const char *fieldname, u_int32_t *crc, u_int32_t *len, const char *);
|
|
|
|
int toku_logprint_LOGGEDBRTHEADER (FILE *outf, FILE *inf, const char *fieldname, u_int32_t *crc, u_int32_t *len, const char *);
|
2007-12-04 10:02:59 +00:00
|
|
|
int toku_logprint_INTPAIRARRAY (FILE *outf, FILE *inf, const char *fieldname, u_int32_t *crc, u_int32_t *len, const char *);
|
2007-11-22 18:45:22 +00:00
|
|
|
|
2008-04-07 01:30:25 +00:00
|
|
|
// Useful thing for printing a bytestring.
|
|
|
|
void toku_print_BYTESTRING (FILE *outf, u_int32_t len, char *data);
|
|
|
|
|
2007-11-28 19:09:24 +00:00
|
|
|
int toku_read_and_print_logmagic (FILE *f, u_int32_t *version);
|
2007-11-23 18:27:50 +00:00
|
|
|
|
2007-11-24 03:50:28 +00:00
|
|
|
TXNID toku_txn_get_txnid (TOKUTXN);
|
|
|
|
LSN toku_txn_get_last_lsn (TOKUTXN);
|
2008-02-08 19:54:00 +00:00
|
|
|
TOKULOGGER toku_txn_logger (TOKUTXN txn);
|
|
|
|
|
2008-01-09 19:58:46 +00:00
|
|
|
static inline int toku_copy_FILENUM(FILENUM *target, FILENUM val) { *target = val; return 0; }
|
|
|
|
static inline void toku_free_FILENUM(FILENUM val __attribute__((__unused__))) {}
|
|
|
|
|
|
|
|
static inline int toku_copy_DISKOFF(DISKOFF *target, DISKOFF val) { *target = val; return 0; }
|
|
|
|
static inline void toku_free_DISKOFF(DISKOFF val __attribute__((__unused__))) {}
|
|
|
|
|
|
|
|
static inline int toku_copy_TXNID(TXNID *target, TXNID val) { *target = val; return 0; }
|
|
|
|
static inline void toku_free_TXNID(TXNID val __attribute__((__unused__))) {}
|
|
|
|
|
|
|
|
static inline int toku_copy_u_int8_t(u_int8_t *target, u_int8_t val) { *target = val; return 0; }
|
|
|
|
static inline void toku_free_u_int8_t(u_int8_t val __attribute__((__unused__))) {}
|
|
|
|
|
|
|
|
static inline int toku_copy_u_int32_t(u_int32_t *target, u_int32_t val) { *target = val; return 0; }
|
|
|
|
static inline void toku_free_u_int32_t(u_int32_t val __attribute__((__unused__))) {}
|
|
|
|
|
|
|
|
static inline int toku_copy_INTPAIRARRAY(INTPAIRARRAY *target, INTPAIRARRAY val) {
|
|
|
|
target->size = val.size;
|
|
|
|
target->array = toku_memdup(val.array, val.size*sizeof(val.array[0]));
|
|
|
|
if (target->array==0) return errno;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
static inline void toku_free_INTPAIRARRAY(INTPAIRARRAY val) {
|
|
|
|
toku_free(val.array);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int toku_copy_BYTESTRING(BYTESTRING *target, BYTESTRING val) {
|
|
|
|
target->len = val.len;
|
2008-02-01 13:47:22 +00:00
|
|
|
target->data = toku_memdup(val.data, (size_t)val.len);
|
2008-01-09 19:58:46 +00:00
|
|
|
if (target->data==0) return errno;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
static inline void toku_free_BYTESTRING(BYTESTRING val) {
|
|
|
|
toku_free(val.data);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int toku_copy_LOGGEDBRTHEADER(LOGGEDBRTHEADER *target, LOGGEDBRTHEADER val) {
|
|
|
|
*target = val;
|
|
|
|
if ((int32_t)val.n_named_roots!=-1) {
|
|
|
|
int r;
|
|
|
|
target->u.many.names = toku_memdup(target->u.many.names, val.n_named_roots*sizeof(target->u.many.names[0]));
|
|
|
|
if (target->u.many.names==0) { r=errno; if (0) { died0: toku_free(target->u.many.names); } return r; }
|
|
|
|
target->u.many.roots = toku_memdup(target->u.many.roots, val.n_named_roots*sizeof(target->u.many.roots[0]));
|
|
|
|
if (target->u.many.roots==0) { r=errno; if (0) { died1: toku_free(target->u.many.names); } goto died0; }
|
2008-03-21 19:40:32 +00:00
|
|
|
int32_t i;
|
2008-01-09 19:58:46 +00:00
|
|
|
for (i=0; i<val.n_named_roots; i++) {
|
|
|
|
target->u.many.names[i] = toku_strdup(target->u.many.names[i]);
|
|
|
|
if (target->u.many.names[i]==0) {
|
2008-03-21 19:40:32 +00:00
|
|
|
int32_t j;
|
2008-01-09 19:58:46 +00:00
|
|
|
r=errno;
|
|
|
|
for (j=0; j<i; j++) toku_free(target->u.many.names[j]);
|
|
|
|
goto died1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
static inline void toku_free_LOGGEDBRTHEADER(LOGGEDBRTHEADER val) {
|
|
|
|
if ((int32_t)val.n_named_roots==-1) return;
|
2008-03-21 19:40:32 +00:00
|
|
|
int32_t i;
|
2008-01-09 19:58:46 +00:00
|
|
|
for (i=0; i<val.n_named_roots; i++) {
|
|
|
|
toku_free(val.u.many.names[i]);
|
|
|
|
}
|
|
|
|
toku_free(val.u.many.names);
|
|
|
|
toku_free(val.u.many.roots);
|
|
|
|
}
|
|
|
|
|
2008-01-11 03:09:14 +00:00
|
|
|
int toku_recover_init(void);
|
|
|
|
void toku_recover_cleanup(void);
|
2008-01-11 03:44:21 +00:00
|
|
|
int toku_logger_abort(TOKUTXN);
|
2008-01-11 03:09:14 +00:00
|
|
|
|
2008-02-14 19:23:25 +00:00
|
|
|
// Find the txn that belongs to a txnid.
|
|
|
|
// Return nonzero if no such txn is live (either didn't exist ever, or it is committed or aborted.)
|
|
|
|
// Return 0 if there is a live txn with that txnid.
|
|
|
|
int toku_txnid2txn (TOKULOGGER logger, TXNID txnid, TOKUTXN *result);
|
|
|
|
|
2008-03-12 19:40:38 +00:00
|
|
|
int tokudb_recover(const char *datadir, const char *logdir);
|
2008-03-21 19:40:32 +00:00
|
|
|
int toku_logger_log_archive (TOKULOGGER logger, char ***logs_p, int flags);
|
2008-03-12 19:40:38 +00:00
|
|
|
|
2008-04-21 04:22:45 +00:00
|
|
|
int toku_maybe_spill_rollbacks (TOKUTXN txn);
|
|
|
|
|
2008-04-22 17:09:24 +00:00
|
|
|
struct roll_entry;
|
|
|
|
int toku_rollback_fileentries (int fd, off_t filesize, TOKUTXN txn);
|
|
|
|
int toku_commit_fileentries (int fd, off_t filesize, TOKUTXN txn);
|
|
|
|
int toku_commit_rollback_item (TOKUTXN txn, struct roll_entry *item);
|
|
|
|
int toku_abort_rollback_item (TOKUTXN txn, struct roll_entry *item);
|
|
|
|
|
2008-04-26 03:16:30 +00:00
|
|
|
int toku_txn_note_brt (TOKUTXN txn, BRT brt);
|
|
|
|
int toku_txn_note_close_brt (BRT brt);
|
|
|
|
|
2008-06-12 13:53:39 +00:00
|
|
|
// find the TOKUTXN object by xid
|
|
|
|
// if found then return 0 and set txnptr to the address of the TOKUTXN object
|
|
|
|
int toku_txn_find_by_xid (BRT brt, TXNID xid, TOKUTXN *txnptr);
|
|
|
|
|
2007-09-28 17:11:22 +00:00
|
|
|
#endif
|