Commit cda602c7 authored by Dave Wells's avatar Dave Wells Committed by Yoni Fogel

change routines to be more callback friendly - refs[t:1977]

git-svn-id: file:///svn/toku/tokudb@15129 c7de825b-a66e-492c-adef-691d508d4ae1
parent 633ef6b5
...@@ -23,7 +23,7 @@ typedef enum __recovery_stress_steps ...@@ -23,7 +23,7 @@ typedef enum __recovery_stress_steps
POST_POST_STEP POST_POST_STEP
} STEP; } STEP;
//const int OPER_PER_STEP = 331; //const int OPER_PER_STEP = 331;
const int OPER_PER_STEP = 3; const int OPER_PER_STEP = 43;
#define OPER_PER_ITER ( OPER_STEPS * OPER_PER_STEP ) #define OPER_PER_ITER ( OPER_STEPS * OPER_PER_STEP )
#define DBG(str) if (verbose) printf("%s:%25s: %s\n", __FILE__, __FUNCTION__, str) #define DBG(str) if (verbose) printf("%s:%25s: %s\n", __FILE__, __FUNCTION__, str)
...@@ -81,6 +81,7 @@ static void verify (DICTIONARY dictionaries, int iter) { ...@@ -81,6 +81,7 @@ static void verify (DICTIONARY dictionaries, int iter) {
} }
struct iteration_spec { struct iteration_spec {
DICTIONARY dictionaries;
int iter; int iter;
STEP step; STEP step;
DB_TXN *pre_pre_insert_commit; DB_TXN *pre_pre_insert_commit;
...@@ -121,9 +122,10 @@ struct iteration_spec { ...@@ -121,9 +122,10 @@ struct iteration_spec {
}; };
typedef struct iteration_spec *ITER_SPEC; typedef struct iteration_spec *ITER_SPEC;
static void pre_checkpoint_acts(DICTIONARY dictionaries, ITER_SPEC spec) { static void pre_checkpoint_acts(ITER_SPEC spec) {
int i; int i;
DB *db; DB *db;
DICTIONARY dictionaries = spec->dictionaries;
int iter = spec->iter; int iter = spec->iter;
assert(spec->step == PRE_PRE_STEP); assert(spec->step == PRE_PRE_STEP);
int key; int key;
...@@ -218,10 +220,11 @@ static void pre_checkpoint_acts(DICTIONARY dictionaries, ITER_SPEC spec) { ...@@ -218,10 +220,11 @@ static void pre_checkpoint_acts(DICTIONARY dictionaries, ITER_SPEC spec) {
return; return;
} }
static void checkpoint_acts(DICTIONARY dictionaries, ITER_SPEC spec) { static void checkpoint_acts(ITER_SPEC spec) {
int i, r, key; int i, r, key;
DB *db; DB *db;
int iter = spec->iter; int iter = spec->iter;
DICTIONARY dictionaries = spec->dictionaries;
assert(spec->step == CP_CP_STEP); assert(spec->step == CP_CP_STEP);
// iDBG(iter); // iDBG(iter);
for (i=0;i<NUM_DICTIONARIES;i++) { for (i=0;i<NUM_DICTIONARIES;i++) {
...@@ -306,19 +309,11 @@ static void checkpoint_acts(DICTIONARY dictionaries, ITER_SPEC spec) { ...@@ -306,19 +309,11 @@ static void checkpoint_acts(DICTIONARY dictionaries, ITER_SPEC spec) {
return; return;
} }
struct checkpoint_callback_args { static void post_checkpoint_acts(ITER_SPEC spec) {
DICTIONARY dictionaries;
ITER_SPEC spec;
};
static void checkpoint_callback_1(void *a){
struct checkpoint_callback_args *args = (struct checkpoint_callback_args *)a;
checkpoint_acts(args->dictionaries, args->spec);
}
static void post_checkpoint_acts(DICTIONARY dictionaries, ITER_SPEC spec) {
int i, r, key; int i, r, key;
DB *db; DB *db;
int iter = spec->iter; int iter = spec->iter;
DICTIONARY dictionaries = spec->dictionaries;
assert(spec->step == POST_POST_STEP); assert(spec->step == POST_POST_STEP);
// iDBG(iter); // iDBG(iter);
for (i=0;i<NUM_DICTIONARIES;i++) { for (i=0;i<NUM_DICTIONARIES;i++) {
...@@ -437,28 +432,25 @@ static void run_test (int iter, int die UU()) { ...@@ -437,28 +432,25 @@ static void run_test (int iter, int die UU()) {
struct iteration_spec spec; struct iteration_spec spec;
spec.iter = iter; spec.iter = iter;
spec.dictionaries = dictionaries;
spec.step = PRE_PRE_STEP; spec.step = PRE_PRE_STEP;
// perform pre-checkpoint actions // perform pre-checkpoint actions
pre_checkpoint_acts(dictionaries, &spec); pre_checkpoint_acts(&spec);
// perform checkpoint acts // perform checkpoint acts
spec.step = CP_CP_STEP; spec.step = CP_CP_STEP;
struct checkpoint_callback_args cp_args;
cp_args.dictionaries = dictionaries;
cp_args.spec = &spec;
if ( iter & 1 ) if ( iter & 1 )
db_env_set_checkpoint_callback(checkpoint_callback_1, &cp_args); db_env_set_checkpoint_callback((void (*)(void*))checkpoint_acts, &spec);
else else
db_env_set_checkpoint_callback2(checkpoint_callback_1, &cp_args); db_env_set_checkpoint_callback2((void (*)(void*))checkpoint_acts, &spec);
r = env->txn_checkpoint(env, 0, 0, 0); r = env->txn_checkpoint(env, 0, 0, 0);
CKERR(r); CKERR(r);
db_env_set_checkpoint_callback(NULL, NULL); db_env_set_checkpoint_callback(NULL, NULL);
db_env_set_checkpoint_callback2(NULL, NULL); db_env_set_checkpoint_callback2(NULL, NULL);
// post checkpoint acts // post checkpoint acts
spec.step = POST_POST_STEP; spec.step = POST_POST_STEP;
post_checkpoint_acts(dictionaries, &spec); post_checkpoint_acts(&spec);
// if requesting crash, randomly do other non-committed acts, then "drop_dead" // if requesting crash, randomly do other non-committed acts, then "drop_dead"
if (die && (iter > 0)) { if (die && (iter > 0)) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment