2013-04-17 00:00:59 -04:00
/* -*- mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- */
// vim: ft=cpp:expandtab:ts=8:sw=4:softtabstop=4:
# ident "$Id$"
# ident "Copyright (c) 2007-2012 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."
2008-05-22 21:23:56 +00:00
/* Scan the bench.tokudb/bench.db over and over. */
2013-04-16 23:57:41 -04:00
# define DONT_DEPRECATE_MALLOC
2008-05-22 21:23:56 +00:00
2013-04-16 23:57:29 -04:00
# include <toku_portability.h>
2013-04-16 23:59:06 -04:00
# include "tokudb_common_funcs.h"
2013-04-16 23:57:57 -04:00
# include <toku_assert.h>
2013-04-16 23:57:17 -04:00
# include <db.h>
# include <errno.h>
2013-04-17 00:01:07 -04:00
# include <stdbool.h>
2013-04-16 23:57:17 -04:00
# include <stdlib.h>
2008-05-22 21:23:56 +00:00
# include <string.h>
2013-04-16 23:57:28 -04:00
# include <fcntl.h>
2008-05-27 21:08:31 +00:00
# include <unistd.h>
2013-04-16 23:57:41 -04:00
# ifdef TOKUDB
2013-04-17 00:00:35 -04:00
# include <ft/key.h>
# include <ft/cachetable.h>
2013-04-16 23:57:41 -04:00
# endif
2008-05-22 21:23:56 +00:00
2013-04-16 23:59:47 -04:00
static const char * pname ;
2013-04-17 00:00:10 -04:00
static enum run_mode { RUN_HWC , RUN_LWC , RUN_VERIFY , RUN_RANGE } run_mode = RUN_HWC ;
2013-04-16 23:59:47 -04:00
static int do_txns = 1 , prelock = 0 , prelockflag = 0 ;
2013-04-16 23:59:55 -04:00
static int cleaner_period = 0 , cleaner_iterations = 0 ;
2013-04-17 00:01:01 -04:00
static uint32_t lock_flag = 0 ;
2013-04-16 23:59:47 -04:00
static long limitcount = - 1 ;
2013-04-17 00:01:01 -04:00
static uint32_t cachesize = 127 * 1024 * 1024 ;
static uint64_t start_range = 0 , end_range = 0 ;
2013-04-16 23:57:44 -04:00
static int n_experiments = 2 ;
2013-04-16 23:59:47 -04:00
static int bulk_fetch = 1 ;
2013-04-16 23:58:06 -04:00
2013-04-16 23:57:59 -04:00
static int verbose = 0 ;
2013-04-16 23:59:56 -04:00
static int engine_status = 0 ;
2013-04-16 23:58:04 -04:00
static const char * log_dir = NULL ;
2008-06-10 16:37:56 +00:00
2013-04-16 23:58:06 -04:00
2013-04-16 23:57:43 -04:00
static int print_usage ( const char * argv0 ) {
2013-04-16 23:58:06 -04:00
fprintf ( stderr , " Usage: \n %s [--verify-lwc | --lwc | --nohwc] [--prelock] [--prelockflag] [--prelockwriteflag] [--env DIR] [--verbose] \n " , argv0 ) ;
2013-04-16 23:59:55 -04:00
fprintf ( stderr , " --verify-lwc means to run the light weight cursor and the heavyweight cursor to verify that they get the same answer. \n " ) ;
fprintf ( stderr , " --lwc run light weight cursors instead of heavy weight cursors \n " ) ;
fprintf ( stderr , " --prelock acquire a read lock on the entire table before running \n " ) ;
fprintf ( stderr , " --prelockflag pass DB_PRELOCKED to the the cursor get operation whenever the locks have been acquired \n " ) ;
fprintf ( stderr , " --prelockwriteflag pass DB_PRELOCKED_WRITE to the cursor get operation \n " ) ;
fprintf ( stderr , " --nox no transactions (no locking) \n " ) ;
fprintf ( stderr , " --count <count> read the first COUNT rows and then stop. \n " ) ;
fprintf ( stderr , " --cachesize <n> set the env cachesize to <n> \n " ) ;
fprintf ( stderr , " --cleaner-period <n> set the cleaner period to <n> \n " ) ;
fprintf ( stderr , " --cleaner-iterations <n> set the cleaner iterations to <n> \n " ) ;
fprintf ( stderr , " --env DIR put db files in DIR instead of default \n " ) ;
fprintf ( stderr , " --log_dir LOGDIR put the logs in LOGDIR \n " ) ;
fprintf ( stderr , " --range LOW HIGH set the LOW and HIGH key boundaries in which random range queries are made \n " ) ;
fprintf ( stderr , " --experiments N run N experiments (default:%d) \n " , n_experiments ) ;
fprintf ( stderr , " --srandom N srandom(N) \n " ) ;
fprintf ( stderr , " --recover run recovery \n " ) ;
fprintf ( stderr , " --verbose print verbose information \n " ) ;
fprintf ( stderr , " --bulk_fetch 0|1 do bulk fetch on lwc operations (default: 1) \n " ) ;
2013-04-16 23:59:56 -04:00
fprintf ( stderr , " --engine_status print engine status at end of test \n " ) ;
2013-04-16 23:57:43 -04:00
return 1 ;
}
2013-04-16 23:59:47 -04:00
static DB_ENV * env ;
static DB * db ;
static DB_TXN * tid = NULL ;
2013-04-16 23:57:43 -04:00
# define STRINGIFY2(s) #s
# define STRINGIFY(s) STRINGIFY2(s)
2013-04-16 23:59:47 -04:00
static const char * dbdir = " ./bench. " STRINGIFY ( DIRSUF ) ; /* DIRSUF is passed in as a -D argument to the compiler. */
static int env_open_flags_yesx = DB_CREATE | DB_PRIVATE | DB_INIT_MPOOL | DB_INIT_TXN | DB_INIT_LOG | DB_INIT_LOCK ;
static int env_open_flags_nox = DB_CREATE | DB_PRIVATE | DB_INIT_MPOOL ;
2013-04-17 00:00:58 -04:00
static const char * dbfilename = " bench.db " ;
2013-04-16 23:57:43 -04:00
2013-04-16 23:57:59 -04:00
static double gettime ( void ) {
struct timeval tv ;
int r = gettimeofday ( & tv , 0 ) ;
assert ( r = = 0 ) ;
return tv . tv_sec + 1e-6 * tv . tv_usec ;
}
2013-04-16 23:57:43 -04:00
2013-04-16 23:59:06 -04:00
static void parse_args ( int argc , char * const argv [ ] ) {
2008-06-10 16:37:56 +00:00
pname = argv [ 0 ] ;
2013-04-16 23:57:44 -04:00
argc - - ; argv + + ;
2008-06-11 18:02:43 +00:00
int specified_run_mode = 0 ;
2008-06-10 16:37:56 +00:00
while ( argc > 0 ) {
2013-04-16 23:57:59 -04:00
if ( strcmp ( * argv , " --verbose " ) = = 0 ) {
verbose + + ;
} else if ( strcmp ( * argv , " --verify-lwc " ) = = 0 ) {
2008-06-11 18:02:43 +00:00
if ( specified_run_mode & & run_mode ! = RUN_VERIFY ) { two_modes : fprintf ( stderr , " You specified two run modes \n " ) ; exit ( 1 ) ; }
run_mode = RUN_VERIFY ;
} else if ( strcmp ( * argv , " --lwc " ) = = 0 ) {
if ( specified_run_mode & & run_mode ! = RUN_LWC ) goto two_modes ;
run_mode = RUN_LWC ;
} else if ( strcmp ( * argv , " --hwc " ) = = 0 ) {
if ( specified_run_mode & & run_mode ! = RUN_VERIFY ) goto two_modes ;
run_mode = RUN_HWC ;
} else if ( strcmp ( * argv , " --prelock " ) = = 0 ) prelock = 1 ;
2013-04-16 23:57:31 -04:00
# ifdef TOKUDB
2013-04-16 23:57:28 -04:00
else if ( strcmp ( * argv , " --prelockflag " ) = = 0 ) { prelockflag = 1 ; lock_flag = DB_PRELOCKED ; }
2008-06-11 06:08:13 +00:00
else if ( strcmp ( * argv , " --prelockwriteflag " ) = = 0 ) { prelockflag = 1 ; lock_flag = DB_PRELOCKED_WRITE ; }
2013-04-16 23:57:31 -04:00
# endif
2008-06-11 18:02:43 +00:00
else if ( strcmp ( * argv , " --nox " ) = = 0 ) { do_txns = 0 ; }
2013-04-16 23:57:17 -04:00
else if ( strcmp ( * argv , " --count " ) = = 0 ) {
char * end ;
2013-04-16 23:57:44 -04:00
argc - - ; argv + + ;
2013-04-16 23:57:17 -04:00
errno = 0 ; limitcount = strtol ( * argv , & end , 10 ) ; assert ( errno = = 0 ) ;
printf ( " Limiting count to %ld \n " , limitcount ) ;
2013-04-16 23:57:25 -04:00
} else if ( strcmp ( * argv , " --cachesize " ) = = 0 & & argc > 0 ) {
char * end ;
2013-04-16 23:57:44 -04:00
argc - - ; argv + + ;
2013-04-17 00:01:01 -04:00
cachesize = ( uint32_t ) strtol ( * argv , & end , 10 ) ;
2013-04-16 23:59:55 -04:00
} else if ( strcmp ( * argv , " --cleaner-period " ) = = 0 & & argc > 0 ) {
char * end ;
argc - - ; argv + + ;
2013-04-17 00:01:01 -04:00
cleaner_period = ( uint32_t ) strtol ( * argv , & end , 10 ) ;
2013-04-16 23:59:55 -04:00
} else if ( strcmp ( * argv , " --cleaner-iterations " ) = = 0 & & argc > 0 ) {
char * end ;
argc - - ; argv + + ;
2013-04-17 00:01:01 -04:00
cleaner_iterations = ( uint32_t ) strtol ( * argv , & end , 10 ) ;
2013-04-16 23:57:43 -04:00
} else if ( strcmp ( * argv , " --env " ) = = 0 ) {
2013-04-16 23:57:44 -04:00
argc - - ; argv + + ;
2013-04-16 23:57:43 -04:00
if ( argc = = 0 ) exit ( print_usage ( pname ) ) ;
dbdir = * argv ;
2013-04-16 23:58:04 -04:00
} else if ( strcmp ( * argv , " --log_dir " ) = = 0 ) {
argc - - ; argv + + ;
if ( argc = = 0 ) exit ( print_usage ( pname ) ) ;
log_dir = * argv ;
2013-04-16 23:58:06 -04:00
} else if ( strcmp ( * argv , " --verbose " ) = = 0 ) {
verbose = 1 ;
2013-04-16 23:57:44 -04:00
} else if ( strcmp ( * argv , " --range " ) = = 0 & & argc > 2 ) {
run_mode = RUN_RANGE ;
argc - - ; argv + + ;
start_range = strtoll ( * argv , NULL , 10 ) ;
argc - - ; argv + + ;
end_range = strtoll ( * argv , NULL , 10 ) ;
} else if ( strcmp ( * argv , " --experiments " ) = = 0 & & argc > 1 ) {
argc - - ; argv + + ;
n_experiments = strtol ( * argv , NULL , 10 ) ;
2013-04-16 23:59:05 -04:00
} else if ( strcmp ( * argv , " --srandom " ) = = 0 & & argc > 1 ) {
argc - - ; argv + + ;
srandom ( atoi ( * argv ) ) ;
2013-04-16 23:57:59 -04:00
} else if ( strcmp ( * argv , " --recover " ) = = 0 ) {
env_open_flags_yesx | = DB_RECOVER ;
env_open_flags_nox | = DB_RECOVER ;
2013-04-16 23:59:47 -04:00
} else if ( strcmp ( * argv , " --bulk_fetch " ) = = 0 & & argc > 1 ) {
argc - - ; argv + + ;
bulk_fetch = atoi ( * argv ) ;
2013-04-16 23:59:56 -04:00
} else if ( strcmp ( * argv , " --engine_status " ) = = 0 ) {
engine_status = 1 ;
2013-04-16 23:57:17 -04:00
} else {
2013-04-16 23:57:43 -04:00
exit ( print_usage ( pname ) ) ;
2008-06-10 16:37:56 +00:00
}
2013-04-16 23:57:44 -04:00
argc - - ; argv + + ;
2008-06-10 16:37:56 +00:00
}
2013-04-16 23:57:43 -04:00
//Prelocking is meaningless without transactions
if ( do_txns = = 0 ) {
2013-04-16 23:59:46 -04:00
//prelockflag=0;
2013-04-16 23:57:43 -04:00
lock_flag = 0 ;
2013-04-16 23:59:46 -04:00
//prelock=0;
2013-04-16 23:57:43 -04:00
}
2008-06-10 16:37:56 +00:00
}
2013-04-16 23:57:28 -04:00
static void scanscan_setup ( void ) {
2008-05-22 21:23:56 +00:00
int r ;
2008-06-11 18:02:43 +00:00
r = db_env_create ( & env , 0 ) ; assert ( r = = 0 ) ;
2013-04-16 23:57:25 -04:00
r = env - > set_cachesize ( env , 0 , cachesize , 1 ) ; assert ( r = = 0 ) ;
2013-04-16 23:58:04 -04:00
if ( log_dir ) {
r = env - > set_lg_dir ( env , log_dir ) ; assert ( r = = 0 ) ;
}
2013-04-16 23:57:59 -04:00
double tstart = gettime ( ) ;
2013-04-16 23:57:28 -04:00
r = env - > open ( env , dbdir , do_txns ? env_open_flags_yesx : env_open_flags_nox , S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH ) ; assert ( r = = 0 ) ;
2013-04-16 23:57:59 -04:00
double tend = gettime ( ) ;
if ( verbose )
printf ( " env open %f seconds \n " , tend - tstart ) ;
2013-04-16 23:59:55 -04:00
# ifdef TOKUDB
if ( cleaner_period ) {
r = env - > cleaner_set_period ( env , cleaner_period ) ; assert ( r = = 0 ) ;
}
if ( cleaner_iterations ) {
r = env - > cleaner_set_iterations ( env , cleaner_iterations ) ; assert ( r = = 0 ) ;
}
# endif
2008-06-11 18:02:43 +00:00
r = db_create ( & db , env , 0 ) ; assert ( r = = 0 ) ;
if ( do_txns ) {
r = env - > txn_begin ( env , 0 , & tid , 0 ) ; assert ( r = = 0 ) ;
}
2013-04-16 23:57:28 -04:00
r = db - > open ( db , tid , dbfilename , NULL , DB_BTREE , 0 , S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH ) ; assert ( r = = 0 ) ;
2013-04-16 23:57:31 -04:00
# ifdef TOKUDB
2008-06-10 16:37:56 +00:00
if ( prelock ) {
2013-04-16 23:59:22 -04:00
r = db - > pre_acquire_table_lock ( db ,
tid ) ;
2008-06-10 16:37:56 +00:00
assert ( r = = 0 ) ;
}
2013-04-16 23:57:31 -04:00
# endif
2008-05-22 21:23:56 +00:00
}
2013-04-16 23:57:28 -04:00
static void scanscan_shutdown ( void ) {
2008-05-22 21:23:56 +00:00
int r ;
2013-04-16 23:57:28 -04:00
r = db - > close ( db , 0 ) ; assert ( r = = 0 ) ;
2008-06-11 18:02:43 +00:00
if ( do_txns ) {
r = tid - > commit ( tid , 0 ) ; assert ( r = = 0 ) ;
}
2013-04-16 23:59:56 -04:00
if ( verbose | | engine_status )
print_engine_status ( env ) ;
2008-05-22 21:23:56 +00:00
r = env - > close ( env , 0 ) ; assert ( r = = 0 ) ;
2013-04-16 23:58:06 -04:00
env = NULL ;
2008-05-22 21:23:56 +00:00
}
2013-04-16 23:58:06 -04:00
2013-04-16 23:57:26 -04:00
static void scanscan_hwc ( void ) {
2008-05-22 21:23:56 +00:00
int r ;
int counter = 0 ;
2013-04-16 23:57:44 -04:00
for ( counter = 0 ; counter < n_experiments ; counter + + ) {
2008-06-08 15:53:50 +00:00
long long totalbytes = 0 ;
int rowcounter = 0 ;
double prevtime = gettime ( ) ;
2008-05-22 21:23:56 +00:00
DBT k , v ;
2008-06-10 15:39:31 +00:00
DBC * dbc ;
r = db - > cursor ( db , tid , & dbc , 0 ) ; assert ( r = = 0 ) ;
2008-05-22 21:23:56 +00:00
memset ( & k , 0 , sizeof ( k ) ) ;
memset ( & v , 0 , sizeof ( v ) ) ;
2013-04-17 00:01:01 -04:00
uint32_t c_get_flags = DB_NEXT ;
2008-06-11 06:08:13 +00:00
if ( prelockflag & & ( counter | | prelock ) ) {
c_get_flags | = lock_flag ;
}
while ( 0 = = ( r = dbc - > c_get ( dbc , & k , & v , c_get_flags ) ) ) {
2008-06-08 15:53:50 +00:00
totalbytes + = k . size + v . size ;
rowcounter + + ;
2013-04-16 23:57:17 -04:00
if ( limitcount > 0 & & rowcounter > = limitcount ) break ;
2008-05-22 21:23:56 +00:00
}
2013-04-16 23:57:57 -04:00
assert ( r = = DB_NOTFOUND ) ; // complain about things like lock-not-found
2008-06-10 15:39:31 +00:00
r = dbc - > c_close ( dbc ) ; assert ( r = = 0 ) ;
2008-06-08 15:53:50 +00:00
double thistime = gettime ( ) ;
double tdiff = thistime - prevtime ;
2008-06-10 15:39:31 +00:00
printf ( " Scan %lld bytes (%d rows) in %9.6fs at %9fMB/s \n " , totalbytes , rowcounter , tdiff , 1e-6 * totalbytes / tdiff ) ;
2008-05-22 21:23:56 +00:00
}
}
2013-04-16 23:57:31 -04:00
# ifdef TOKUDB
2008-06-10 15:39:31 +00:00
struct extra_count {
long long totalbytes ;
int rowcounter ;
} ;
2013-04-16 23:57:26 -04:00
2013-04-16 23:57:41 -04:00
static int counttotalbytes ( DBT const * key , DBT const * data , void * extrav ) {
2013-04-17 00:00:59 -04:00
struct extra_count * CAST_FROM_VOIDP ( e , extrav ) ;
2008-06-10 15:39:31 +00:00
e - > totalbytes + = key - > size + data - > size ;
e - > rowcounter + + ;
2013-04-16 23:59:47 -04:00
return bulk_fetch ? TOKUDB_CURSOR_CONTINUE : 0 ;
2008-06-10 15:39:31 +00:00
}
2013-04-16 23:57:26 -04:00
static void scanscan_lwc ( void ) {
2008-06-10 15:39:31 +00:00
int r ;
int counter = 0 ;
2013-04-16 23:57:44 -04:00
for ( counter = 0 ; counter < n_experiments ; counter + + ) {
2008-06-10 15:39:31 +00:00
struct extra_count e = { 0 , 0 } ;
double prevtime = gettime ( ) ;
DBC * dbc ;
r = db - > cursor ( db , tid , & dbc , 0 ) ; assert ( r = = 0 ) ;
2013-04-16 23:59:46 -04:00
if ( prelock ) {
r = dbc - > c_pre_acquire_range_lock ( dbc , db - > dbt_neg_infty ( ) , db - > dbt_pos_infty ( ) ) ; assert ( r = = 0 ) ;
}
2013-04-17 00:01:01 -04:00
uint32_t f_flags = 0 ;
2008-06-11 06:08:13 +00:00
if ( prelockflag & & ( counter | | prelock ) ) {
f_flags | = lock_flag ;
}
2013-04-16 23:57:17 -04:00
long rowcounter = 0 ;
while ( 0 = = ( r = dbc - > c_getf_next ( dbc , f_flags , counttotalbytes , & e ) ) ) {
rowcounter + + ;
if ( limitcount > 0 & & rowcounter > = limitcount ) break ;
}
2013-04-16 23:59:46 -04:00
//assert(r==DB_NOTFOUND);
2008-06-10 15:39:31 +00:00
r = dbc - > c_close ( dbc ) ; assert ( r = = 0 ) ;
double thistime = gettime ( ) ;
double tdiff = thistime - prevtime ;
printf ( " LWC Scan %lld bytes (%d rows) in %9.6fs at %9fMB/s \n " , e . totalbytes , e . rowcounter , tdiff , 1e-6 * e . totalbytes / tdiff ) ;
}
}
2013-04-16 23:57:59 -04:00
2013-04-16 23:57:45 -04:00
# endif
2008-06-10 15:39:31 +00:00
2013-04-16 23:57:44 -04:00
static void scanscan_range ( void ) {
int r ;
2013-04-16 23:58:56 -04:00
double texperiments [ n_experiments ] ;
2013-04-17 00:01:01 -04:00
uint64_t k = 0 ;
2013-04-16 23:59:05 -04:00
char kv [ 8 ] ;
DBT key , val ;
for ( int counter = 0 ; counter < n_experiments ; counter + + ) {
if ( 1 ) { //if ((counter&1) == 0) {
makekey :
// generate a random key in the key range
k = ( start_range + ( random ( ) % ( end_range - start_range ) ) ) * ( 1 < < 6 ) ;
for ( int i = 0 ; i < 8 ; i + + )
kv [ i ] = k > > ( 56 - 8 * i ) ;
}
memset ( & key , 0 , sizeof key ) ; key . data = & kv , key . size = sizeof kv ;
memset ( & val , 0 , sizeof val ) ;
2013-04-16 23:57:44 -04:00
2013-04-16 23:58:56 -04:00
double tstart = gettime ( ) ;
DBC * dbc ;
r = db - > cursor ( db , tid , & dbc , 0 ) ; assert ( r = = 0 ) ;
2013-04-16 23:57:44 -04:00
// set the cursor to the random key
2013-04-16 23:58:56 -04:00
r = dbc - > c_get ( dbc , & key , & val , DB_SET_RANGE + lock_flag ) ;
if ( r ! = 0 ) {
assert ( r = = DB_NOTFOUND ) ;
2013-04-17 00:00:58 -04:00
//printf("%s:%d %" PRIu64 "\n", __FUNCTION__, __LINE__, k);
2013-04-16 23:58:56 -04:00
goto makekey ;
}
2013-04-16 23:57:44 -04:00
2013-04-16 23:58:56 -04:00
# ifdef TOKUDB
2013-04-16 23:58:56 -04:00
// do the range scan
2013-04-16 23:58:56 -04:00
long rowcounter = 0 ;
2013-04-16 23:58:56 -04:00
struct extra_count e = { 0 , 0 } ;
2013-04-16 23:58:56 -04:00
while ( limitcount > 0 & & rowcounter < limitcount ) {
r = dbc - > c_getf_next ( dbc , prelockflag ? lock_flag : 0 , counttotalbytes , & e ) ;
if ( r ! = 0 )
2013-04-16 23:58:56 -04:00
break ;
2013-04-16 23:58:56 -04:00
rowcounter + + ;
2013-04-16 23:57:44 -04:00
}
2013-04-16 23:58:56 -04:00
# endif
2013-04-16 23:57:44 -04:00
2013-04-16 23:58:56 -04:00
r = dbc - > c_close ( dbc ) ;
assert ( r = = 0 ) ;
2013-04-16 23:57:44 -04:00
2013-04-16 23:58:56 -04:00
texperiments [ counter ] = gettime ( ) - tstart ;
2013-04-17 00:00:58 -04:00
printf ( " % " PRIu64 " %f \n " , k , texperiments [ counter ] ) ; fflush ( stdout ) ;
2013-04-16 23:58:56 -04:00
}
2013-04-16 23:57:44 -04:00
2013-04-16 23:58:56 -04:00
// print the times
double tsum = 0.0 , tmin = 0.0 , tmax = 0.0 ;
2013-04-16 23:59:05 -04:00
for ( int counter = 0 ; counter < n_experiments ; counter + + ) {
2013-04-16 23:58:57 -04:00
if ( counter = = 0 | | texperiments [ counter ] < tmin )
2013-04-16 23:58:56 -04:00
tmin = texperiments [ counter ] ;
2013-04-16 23:58:57 -04:00
if ( counter = = 0 | | texperiments [ counter ] > tmax )
2013-04-16 23:58:56 -04:00
tmax = texperiments [ counter ] ;
tsum + = texperiments [ counter ] ;
}
printf ( " %f %f %f/%d = %f \n " , tmin , tmax , tsum , n_experiments , tsum / n_experiments ) ;
2013-04-16 23:57:44 -04:00
}
2013-04-16 23:57:45 -04:00
# ifdef TOKUDB
2013-04-16 23:57:41 -04:00
2008-06-10 15:39:31 +00:00
struct extra_verify {
long long totalbytes ;
int rowcounter ;
DBT k , v ; // the k and v are gotten using the old cursor
} ;
2013-04-16 23:57:26 -04:00
2013-04-16 23:57:41 -04:00
static int
checkbytes ( DBT const * key , DBT const * data , void * extrav ) {
2013-04-17 00:00:59 -04:00
struct extra_verify * CAST_FROM_VOIDP ( e , extrav ) ;
2008-06-10 15:39:31 +00:00
e - > totalbytes + = key - > size + data - > size ;
e - > rowcounter + + ;
assert ( e - > k . size = = key - > size ) ;
assert ( e - > v . size = = data - > size ) ;
assert ( memcmp ( e - > k . data , key - > data , key - > size ) = = 0 ) ;
assert ( memcmp ( e - > v . data , data - > data , data - > size ) = = 0 ) ;
assert ( e - > k . data ! = key - > data ) ;
assert ( e - > v . data ! = data - > data ) ;
2013-04-16 23:57:41 -04:00
return 0 ;
2008-06-10 15:39:31 +00:00
}
2013-04-16 23:57:26 -04:00
static void scanscan_verify ( void ) {
2008-06-10 15:39:31 +00:00
int r ;
int counter = 0 ;
2013-04-16 23:57:44 -04:00
for ( counter = 0 ; counter < n_experiments ; counter + + ) {
2008-06-10 15:39:31 +00:00
struct extra_verify v ;
v . totalbytes = 0 ;
v . rowcounter = 0 ;
double prevtime = gettime ( ) ;
DBC * dbc1 , * dbc2 ;
r = db - > cursor ( db , tid , & dbc1 , 0 ) ; assert ( r = = 0 ) ;
r = db - > cursor ( db , tid , & dbc2 , 0 ) ; assert ( r = = 0 ) ;
memset ( & v . k , 0 , sizeof ( v . k ) ) ;
memset ( & v . v , 0 , sizeof ( v . v ) ) ;
2013-04-17 00:01:01 -04:00
uint32_t f_flags = 0 ;
uint32_t c_get_flags = DB_NEXT ;
2008-06-11 06:08:13 +00:00
if ( prelockflag & & ( counter | | prelock ) ) {
f_flags | = lock_flag ;
c_get_flags | = lock_flag ;
}
2008-06-10 15:39:31 +00:00
while ( 1 ) {
2013-04-16 23:57:28 -04:00
int r1 , r2 ;
r2 = dbc1 - > c_get ( dbc1 , & v . k , & v . v , c_get_flags ) ;
r1 = dbc2 - > c_getf_next ( dbc2 , f_flags , checkbytes , & v ) ;
2008-06-10 15:39:31 +00:00
assert ( r1 = = r2 ) ;
if ( r1 ) break ;
}
r = dbc1 - > c_close ( dbc1 ) ; assert ( r = = 0 ) ;
r = dbc2 - > c_close ( dbc2 ) ; assert ( r = = 0 ) ;
double thistime = gettime ( ) ;
double tdiff = thistime - prevtime ;
printf ( " verify %lld bytes (%d rows) in %9.6fs at %9fMB/s \n " , v . totalbytes , v . rowcounter , tdiff , 1e-6 * v . totalbytes / tdiff ) ;
}
}
2013-04-16 23:57:31 -04:00
# endif
2008-06-10 15:39:31 +00:00
2013-04-16 23:59:06 -04:00
static int test_main ( int argc , char * const argv [ ] ) {
2008-06-10 15:39:31 +00:00
parse_args ( argc , argv ) ;
2013-04-16 23:57:28 -04:00
scanscan_setup ( ) ;
2008-06-11 18:02:43 +00:00
switch ( run_mode ) {
2013-04-16 23:57:31 -04:00
case RUN_HWC : scanscan_hwc ( ) ; break ;
# ifdef TOKUDB
case RUN_LWC : scanscan_lwc ( ) ; break ;
case RUN_VERIFY : scanscan_verify ( ) ; break ;
2013-04-16 23:57:46 -04:00
# endif
2013-04-16 23:57:45 -04:00
case RUN_RANGE : scanscan_range ( ) ; break ;
2013-04-16 23:57:31 -04:00
default : assert ( 0 ) ; break ;
2008-06-10 15:39:31 +00:00
}
2013-04-16 23:57:28 -04:00
scanscan_shutdown ( ) ;
2008-06-10 15:39:31 +00:00
2008-05-22 21:23:56 +00:00
return 0 ;
}