2013-04-16 23:57:47 -04:00
/* -*- mode: C; c-basic-offset: 4 -*- */
2013-04-16 23:59:09 -04:00
# ifndef TOKU_CHECKPOINT_H
# define TOKU_CHECKPOINT_H
# ident "Copyright (c) 2009-2010 Tokutek Inc. All rights reserved."
2013-04-16 23:57:47 -04:00
# 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."
# ident "$Id$"
2013-04-16 23:59:09 -04:00
# if defined(__cplusplus) || defined(__cilkplusplus)
extern " C " {
# endif
2013-04-16 23:57:49 -04:00
int toku_set_checkpoint_period ( CACHETABLE ct , u_int32_t new_period ) ;
u_int32_t toku_get_checkpoint_period ( CACHETABLE ct ) ;
//Effect: Change [end checkpoint (n) - begin checkpoint (n+1)] delay to
// new_period seconds. 0 means disable.
2013-04-16 23:57:47 -04:00
/******
*
2013-04-16 23:57:47 -04:00
* NOTE : multi_operation_lock is highest level lock
* checkpoint_safe_lock is next level lock
2013-04-16 23:57:47 -04:00
* ydb_big_lock is next level lock
*
* Locks must always be taken in this sequence ( highest level first ) .
*
*/
2013-04-16 23:57:47 -04:00
/******
2013-04-16 23:57:47 -04:00
* Client code must hold the checkpoint_safe lock during the following operations :
2013-04-16 23:57:47 -04:00
* - delete a dictionary via DB - > remove
* - delete a dictionary via DB_TXN - > abort ( txn ) ( where txn created a dictionary )
* - rename a dictionary //TODO: Handlerton rename needs to take this
* //TODO: Handlerton rename needs to be recoded for transaction recovery
2013-04-16 23:57:47 -04:00
* * * * */
void toku_checkpoint_safe_client_lock ( void ) ;
void toku_checkpoint_safe_client_unlock ( void ) ;
2013-04-16 23:57:47 -04:00
/******
* These functions are called from the ydb level .
2013-04-16 23:57:47 -04:00
* Client code must hold the multi_operation lock during the following operations :
* - insertion into multiple indexes
* - replace into ( simultaneous delete / insert on a single key )
* * * * */
void toku_multi_operation_client_lock ( void ) ;
void toku_multi_operation_client_unlock ( void ) ;
// Initialize the checkpoint mechanism, must be called before any client operations.
// Must pass in function pointers to take/release ydb lock.
2013-04-16 23:57:53 -04:00
int toku_checkpoint_init ( void ( * ydb_lock_callback ) ( void ) , void ( * ydb_unlock_callback ) ( void ) ) ;
2013-04-16 23:57:47 -04:00
2013-04-16 23:57:53 -04:00
int toku_checkpoint_destroy ( void ) ;
2013-04-16 23:57:47 -04:00
// Take a checkpoint of all currently open dictionaries
2013-04-16 23:58:00 -04:00
// Callbacks are called during checkpoint procedure while checkpoint_safe lock is still held.
// Callbacks are primarily intended for use in testing.
2013-04-16 23:58:06 -04:00
int toku_checkpoint ( CACHETABLE ct , TOKULOGGER logger ,
2013-04-16 23:58:00 -04:00
void ( * callback_f ) ( void * ) , void * extra ,
void ( * callback2_f ) ( void * ) , void * extra2 ) ;
2013-04-16 23:58:02 -04:00
/******
* These functions are called from the ydb level .
* They return status information and have no side effects .
* Some status information may be incorrect because no locks are taken to collect status .
* ( If checkpoint is in progress , it may overwrite status info while it is being read . )
* * * * */
2013-04-16 23:58:03 -04:00
typedef struct {
u_int32_t footprint ;
time_t time_last_checkpoint_begin_complete ;
time_t time_last_checkpoint_begin ;
time_t time_last_checkpoint_end ;
} CHECKPOINT_STATUS_S , * CHECKPOINT_STATUS ;
void toku_checkpoint_get_status ( CHECKPOINT_STATUS stat ) ;
2013-04-16 23:59:09 -04:00
# if defined(__cplusplus) || defined(__cilkplusplus)
} ;
# endif
# endif