2013-04-16 23:57:20 -04:00
# ifndef LOG_INTERNAL_H
# define LOG_INTERNAL_H
2013-04-16 23:57:48 -04:00
# ident "$Id$"
2013-04-16 23:57:48 -04:00
# ident "Copyright (c) 2007, 2008, 2009 Tokutek Inc. All rights reserved."
# ident "The technology is licensed by the Massachusetts Institute of Technology, Rutgers State University of New Jersey, and the Research Foundation of State University of New York at Stony Brook under United States of America Serial No. 11 / 760379 and to the patents and / or patent applications resulting from it."
2007-11-29 14:18:54 +00:00
2008-04-25 13:45:55 +00:00
# include "brt-internal.h"
2008-02-08 03:17:38 +00:00
# include "log.h"
# include "toku_assert.h"
2013-04-16 23:58:05 -04:00
# include "toku_list.h"
2008-07-11 22:00:06 +00:00
# include "memarena.h"
2013-04-16 23:58:01 -04:00
# include "logfilemgr.h"
2007-08-10 21:15:17 +00:00
# include <stdio.h>
2013-04-16 23:57:27 -04:00
# include <toku_pthread.h>
2007-09-28 17:11:22 +00:00
# include <sys/types.h>
2008-04-02 23:40:36 +00:00
# include <string.h>
2007-09-28 17:11:22 +00:00
2008-03-12 17:55:11 +00:00
// Locking for the logger
// For most purposes we use the big ydb lock.
// To log: grab the buf lock
// If the buf would overflow, then grab the file lock, swap file&buf, release buf lock, write the file, write the entry, release the file lock
// else append to buf & release lock
2013-04-16 23:58:04 -04:00
# define LOGGER_MIN_BUF_SIZE (1<<24)
2008-03-12 17:55:11 +00:00
struct mylock {
2013-04-16 23:57:27 -04:00
toku_pthread_mutex_t lock ;
2008-03-12 17:55:11 +00:00
int is_locked ;
} ;
static inline int ml_init ( struct mylock * l ) {
l - > is_locked = 0 ;
2013-04-16 23:57:32 -04:00
memset ( & l - > lock , 0 , sizeof ( l - > lock ) ) ;
2013-04-16 23:57:27 -04:00
return toku_pthread_mutex_init ( & l - > lock , 0 ) ;
2008-03-12 17:55:11 +00:00
}
static inline int ml_lock ( struct mylock * l ) {
2013-04-16 23:57:27 -04:00
int r = toku_pthread_mutex_lock ( & l - > lock ) ;
2008-03-12 17:55:11 +00:00
assert ( l - > is_locked = = 0 ) ;
l - > is_locked = 1 ;
return r ;
}
static inline int ml_unlock ( struct mylock * l ) {
assert ( l - > is_locked = = 1 ) ;
l - > is_locked = 0 ;
2013-04-16 23:57:27 -04:00
return toku_pthread_mutex_unlock ( & l - > lock ) ;
2008-03-12 17:55:11 +00:00
}
static inline int ml_destroy ( struct mylock * l ) {
assert ( l - > is_locked = = 0 ) ;
2013-04-16 23:57:27 -04:00
return toku_pthread_mutex_destroy ( & l - > lock ) ;
2008-03-12 17:55:11 +00:00
}
2013-04-16 23:58:04 -04:00
struct logbuf {
int n_in_buf ;
int buf_size ;
char * buf ;
LSN max_lsn_in_buf ;
} ;
2008-03-12 17:55:11 +00:00
2007-08-10 19:24:45 +00:00
struct tokulogger {
2008-03-12 17:55:11 +00:00
enum typ_tag tag ; // must be first
struct mylock input_lock , output_lock ; // acquired in that order
2013-04-16 23:58:04 -04:00
BOOL is_open ;
BOOL is_panicked ;
2013-04-16 23:57:59 -04:00
BOOL write_log_files ;
2013-04-16 23:58:02 -04:00
BOOL trim_log_files ; // for test purposes
2008-01-08 22:18:42 +00:00
int panic_errno ;
2013-04-16 23:58:04 -04:00
char * directory ; // file system directory
2007-08-10 21:39:55 +00:00
int fd ;
2008-01-11 22:24:43 +00:00
CACHETABLE ct ;
2008-03-08 13:02:32 +00:00
int lg_max ; // The size of the single file in the log. Default is 100MB in TokuDB
2008-03-12 17:55:11 +00:00
// To access these, you must have the input lock
LSN lsn ; // the next available lsn
2013-04-16 23:57:56 -04:00
OMT live_txns ; // a sorted tree. Old comment said should be a hashtable. Do we still want that?
2013-04-16 23:58:04 -04:00
struct logbuf inbuf ; // data being accumulated for the write
2008-03-12 17:55:11 +00:00
// To access these, you must have the output lock
LSN written_lsn ; // the last lsn written
LSN fsynced_lsn ; // What is the LSN of the highest fsynced log entry
2013-04-16 23:57:47 -04:00
LSN checkpoint_lsn ; // What is the LSN of the most recent completed checkpoint.
2008-03-12 17:55:11 +00:00
long long next_log_file_number ;
2013-04-16 23:58:04 -04:00
struct logbuf outbuf ; // data being written to the file
int n_in_file ; // The amount of data in the current file
2008-03-12 17:55:11 +00:00
2013-04-16 23:58:01 -04:00
TOKULOGFILEMGR logfilemgr ;
2013-04-16 23:57:38 -04:00
u_int32_t write_block_size ; // How big should the blocks be written to various logs?
2013-04-16 23:57:56 -04:00
TXNID oldest_living_xid ;
2013-04-16 23:58:04 -04:00
void ( * remove_finalize_callback ) ( int , void * ) ; // ydb-level callback to be called when a transaction that ...
void * remove_finalize_callback_extra ; // ... deletes a file is committed or when one that creates a file is aborted.
2007-08-10 19:24:45 +00:00
} ;
2007-08-10 21:15:17 +00:00
2007-11-29 18:14:40 +00:00
int toku_logger_find_next_unused_log_file ( const char * directory , long long * result ) ;
2013-04-16 23:57:53 -04:00
int toku_logger_find_logfiles ( const char * directory , char * * * resultp , int * n_logfiles ) ;
2007-09-28 17:11:22 +00:00
2008-04-25 13:45:55 +00:00
struct brtcachefile_pair {
BRT brt ;
CACHEFILE cf ;
} ;
2007-09-28 17:11:22 +00:00
struct tokutxn {
2008-02-14 19:23:25 +00:00
enum typ_tag tag ;
2008-03-21 21:02:30 +00:00
u_int64_t txnid64 ; /* this happens to be the first lsn */
2007-09-28 17:11:22 +00:00
TOKULOGGER logger ;
2007-10-19 17:05:10 +00:00
TOKUTXN parent ;
2007-11-24 03:50:28 +00:00
LSN last_lsn ; /* Everytime anything is logged, update the LSN. (We need to atomically record the LSN along with writing into the log.) */
2008-03-21 21:02:30 +00:00
LSN first_lsn ; /* The first lsn in the transaction. */
2008-02-26 15:51:15 +00:00
struct roll_entry * oldest_logentry , * newest_logentry ; /* Only logentries with rollbacks are here. There is a list going from newest to oldest. */
2008-07-11 22:00:06 +00:00
MEMARENA rollentry_arena ;
2008-04-21 04:22:45 +00:00
size_t rollentry_resident_bytecount ; // How many bytes for the rollentries that are stored in main memory.
char * rollentry_filename ;
int rollentry_fd ; // If we spill the roll_entries, we write them into this fd.
2013-04-16 23:57:38 -04:00
toku_off_t rollentry_filesize ; // How many bytes are in the rollentry file (this is the uncompressed bytes. If the file is compressed it may actually be smaller (or even larger with header information))
2013-04-16 23:57:38 -04:00
u_int64_t rollentry_raw_count ; // the total count of every byte in the transaction and all its children.
2008-04-26 03:16:30 +00:00
OMT open_brts ; // a collection of the brts that we touched. Indexed by filenum.
Addresses #1125 Merged nested transactions from temporary merge branch into main.
Current tests fail (not regressions, they fail as of 13461)
* {{{x1.tdbrun}}}
* {{{test_log(2,3,4,5,6,7,8,9,10).recover}}}
* {{{test-recover(1,2,3).tdbrun}}}
* {{{test1324.tdbrun}}}
ULE_DEBUG disabled (defined to 0) Can be re-enabled for test purposes (set to 1).
refs [t:1125]
Merging into the temp branch (tokudb.main_13461+1125)
{{{svn merge --accept=postpone -r 12527:13461 ../tokudb.1125 ./}}}
Merging into main
{{{svn merge --accept=postpone -r13462:13463 ../tokudb.main_13461+1125/ ./}}}
git-svn-id: file:///svn/toku/tokudb@13464 c7de825b-a66e-492c-adef-691d508d4ae1
2013-04-16 23:57:56 -04:00
XIDS xids ; //Represents the xid list
2013-04-16 23:58:53 -04:00
BOOL force_fsync_on_commit ; //This transaction NEEDS an fsync once (if) it commits. (commit means root txn)
BOOL has_done_work ; //If this transaction has not done work, there is no need to fsync.
2007-09-28 17:11:22 +00:00
} ;
2007-11-22 07:13:08 +00:00
2007-11-23 17:16:26 +00:00
static inline int toku_logsizeof_u_int8_t ( u_int32_t v __attribute__ ( ( __unused__ ) ) ) {
return 1 ;
}
2007-11-22 18:45:22 +00:00
static inline int toku_logsizeof_u_int32_t ( u_int32_t v __attribute__ ( ( __unused__ ) ) ) {
return 4 ;
}
2013-04-16 23:57:55 -04:00
static inline int toku_logsizeof_u_int64_t ( u_int32_t v __attribute__ ( ( __unused__ ) ) ) {
return 8 ;
}
2007-11-22 18:45:22 +00:00
static inline int toku_logsizeof_FILENUM ( FILENUM v __attribute__ ( ( __unused__ ) ) ) {
return 4 ;
}
static inline int toku_logsizeof_DISKOFF ( DISKOFF v __attribute__ ( ( __unused__ ) ) ) {
return 8 ;
}
2013-04-16 23:57:18 -04:00
static inline int toku_logsizeof_BLOCKNUM ( BLOCKNUM v __attribute__ ( ( __unused__ ) ) ) {
return 8 ;
}
2007-11-22 18:45:22 +00:00
static inline int toku_logsizeof_TXNID ( TXNID txnid __attribute__ ( ( __unused__ ) ) ) {
return 8 ;
}
static inline int toku_logsizeof_BYTESTRING ( BYTESTRING bs ) {
2007-11-22 20:30:38 +00:00
return 4 + bs . len ;
2007-11-22 18:45:22 +00:00
}
2008-03-14 19:14:31 +00:00
static inline char * fixup_fname ( BYTESTRING * f ) {
assert ( f - > len > 0 ) ;
2013-04-16 23:58:04 -04:00
char * fname = toku_xmalloc ( f - > len + 1 ) ;
2008-03-14 19:14:31 +00:00
memcpy ( fname , f - > data , f - > len ) ;
fname [ f - > len ] = 0 ;
return fname ;
}
2008-04-21 04:22:45 +00:00
2008-07-11 22:00:06 +00:00
int toku_read_rollback_backwards ( BREAD , struct roll_entry * * item , MEMARENA ) ;
2013-04-16 23:57:20 -04:00
# endif