Commit 1db40bfb authored by Bradley C. Kuszmaul's avatar Bradley C. Kuszmaul Committed by Yoni Fogel

Get rid of some compiler warnings. Addresses #1185.

git-svn-id: file:///svn/tokudb.1131b+1080a+1185@6376 c7de825b-a66e-492c-adef-691d508d4ae1
parent c772ca73
......@@ -675,7 +675,6 @@ static int cachetable_insert_at(CACHEFILE cachefile, u_int32_t fullhash, CACHEKE
enum { hash_histogram_max = 100 };
static unsigned long long hash_histogram[hash_histogram_max];
void print_hash_histogram (void) __attribute__((__visibility__("default")));
void print_hash_histogram (void) {
int i;
for (i=0; i<hash_histogram_max; i++)
......
......@@ -178,4 +178,7 @@ void toku_cachefile_verify (CACHEFILE cf);
// Verify the cachetable. Slow.
void toku_cachetable_verify (CACHETABLE t);
// Not for use in production, but useful for testing.
void print_hash_histogram (void) __attribute__((__visibility__("default")));
#endif
......@@ -57,7 +57,7 @@ void *toku_realloc(void *, size_t size);
#define REALLOC_N(n,v) v = toku_realloc(v, (n)*sizeof(*v))
// XMALLOC macros are like MALLOC except they abort if the operatoin fails
// XMALLOC macros are like MALLOC except they abort if the operation fails
#define XMALLOC(v) v = toku_xmalloc(sizeof(*v))
#define XMALLOC_N(n,v) v = toku_malloc((n)*sizeof(*v))
#define XREALLOC_N(n,v) v = toku_realloc(v, (n)*sizeof(*v))
......
......@@ -34,7 +34,7 @@ VISIBILITY=-fvisibility=hidden
endif
endif
CFLAGS = -Wall $(FORMAT) $(OPTFLAGS) $(GCOV_FLAGS) $(PROF_FLAGS) $(FPICFLAGS) $(SHADOW) $(VISIBILITY)
CFLAGS = -Werror -Wall $(FORMAT) $(OPTFLAGS) $(GCOV_FLAGS) $(PROF_FLAGS) $(FPICFLAGS) $(SHADOW) $(VISIBILITY)
ifneq ($(CC),icc)
CFLAGS += -Wextra -Wcast-align -Wbad-function-cast -Wmissing-noreturn -g3 -ggdb3
else
......
......@@ -12,7 +12,8 @@
#define RECORDS 2
void test (int seed) {
static void
test (int seed) {
srandom(seed);
unlink(FNAME);
int i;
......
......@@ -55,19 +55,21 @@ static void test4 (int nodesize, int count, int memcheck) {
static void brt_blackbox_test (void) {
test4(2048, 1<<14, 1);
return;
if (verbose) printf("test4 slow\n");
test4(2048, 1<<15, 1);
if (0) {
//if (verbose) toku_pma_show_stats();
if (verbose) printf("test4 slow\n");
test4(2048, 1<<15, 1);
test4(1<<15, 1024, 1);
//if (verbose) toku_pma_show_stats();
test4(1<<18, 1<<20, 0);
test4(1<<15, 1024, 1);
// Once upon a time srandom(8) caused this test to fail.
srandom(8); test4(2048, 1<<15, 1);
test4(1<<18, 1<<20, 0);
// Once upon a time srandom(8) caused this test to fail.
srandom(8); test4(2048, 1<<15, 1);
}
}
int main (int argc , const char *argv[]) {
......
......@@ -5,14 +5,34 @@
#include "test.h"
#include "cachetable.h"
void flush() {
static void
flush (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
void *v __attribute__((__unused__)),
void *e __attribute__((__unused__)),
long s __attribute__((__unused__)),
BOOL w __attribute__((__unused__)),
BOOL keep __attribute__((__unused__)),
LSN m __attribute__((__unused__)),
BOOL r __attribute__((__unused__))
) {
/* Do nothing */
}
int fetch() {
static int
fetch (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
u_int32_t fullhash __attribute__((__unused__)),
void **value __attribute__((__unused__)),
long *sizep __attribute__((__unused__)),
void *extraargs __attribute__((__unused__)),
LSN *written_lsn __attribute__((__unused__))
) {
return 0;
}
void cachetable_count_pinned_test(int n) {
static void
cachetable_count_pinned_test (int n) {
const int test_limit = 2*n;
int r;
CACHETABLE ct;
......
......@@ -5,14 +5,34 @@
#include "test.h"
#include "cachetable.h"
void flush() {
static void
flush (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
void *v __attribute__((__unused__)),
void *e __attribute__((__unused__)),
long s __attribute__((__unused__)),
BOOL w __attribute__((__unused__)),
BOOL keep __attribute__((__unused__)),
LSN m __attribute__((__unused__)),
BOOL r __attribute__((__unused__))
) {
/* Do nothing */
}
int fetch() {
static int
fetch (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
u_int32_t fullhash __attribute__((__unused__)),
void **value __attribute__((__unused__)),
long *sizep __attribute__((__unused__)),
void *extraargs __attribute__((__unused__)),
LSN *written_lsn __attribute__((__unused__))
) {
return 0;
}
void cachetable_debug_test(int n) {
static void
cachetable_debug_test (int n) {
const int test_limit = n;
int r;
CACHETABLE ct;
......@@ -57,7 +77,6 @@ void cachetable_debug_test(int n) {
}
toku_cachetable_verify(ct);
extern void print_hash_histogram();
print_hash_histogram();
r = toku_cachefile_close(&f1, NULL_LOGGER); assert(r == 0 && f1 == 0);
......
......@@ -6,7 +6,8 @@
#include "test.h"
#include "cachetable.h"
void cachetable_fd_test() {
static void
cachetable_fd_test (void) {
const int test_limit = 1;
int r;
CACHETABLE ct;
......
......@@ -5,14 +5,34 @@
#include "test.h"
#include "cachetable.h"
void flush() {
static void
flush (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
void *v __attribute__((__unused__)),
void *e __attribute__((__unused__)),
long s __attribute__((__unused__)),
BOOL w __attribute__((__unused__)),
BOOL keep __attribute__((__unused__)),
LSN m __attribute__((__unused__)),
BOOL r __attribute__((__unused__))
) {
/* Do nothing */
}
int fetch() {
static int
fetch (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
u_int32_t fullhash __attribute__((__unused__)),
void **value __attribute__((__unused__)),
long *sizep __attribute__((__unused__)),
void *extraargs __attribute__((__unused__)),
LSN *written_lsn __attribute__((__unused__))
) {
return 0;
}
void test_cachetable_flush(int n) {
static void
test_cachetable_flush (int n) {
const int test_limit = 2*n;
int r;
CACHETABLE ct;
......
......@@ -5,39 +5,43 @@
#include "test.h"
#include "cachetable.h"
void flush(CACHEFILE cf __attribute__((__unused__)),
CACHEKEY key __attribute__((__unused__)),
void *v __attribute__((__unused__)),
void *extraargs __attribute__((__unused__)),
long size __attribute__((__unused__)),
BOOL write_me __attribute__((__unused__)),
BOOL keep_me __attribute__((__unused__)),
LSN lsn __attribute__((__unused__)),
BOOL rename_p __attribute__((__unused__))
) {
static void
flush (CACHEFILE cf __attribute__((__unused__)),
CACHEKEY key __attribute__((__unused__)),
void *v __attribute__((__unused__)),
void *extraargs __attribute__((__unused__)),
long size __attribute__((__unused__)),
BOOL write_me __attribute__((__unused__)),
BOOL keep_me __attribute__((__unused__)),
LSN lsn __attribute__((__unused__)),
BOOL rename_p __attribute__((__unused__))
) {
assert((long) key.b == size);
if (!keep_me) free(v);
}
int fetch(CACHEFILE cf, CACHEKEY key, u_int32_t hash, void **vptr, long *sizep, void *extra, LSN *written_lsn) {
static int
fetch (CACHEFILE cf, CACHEKEY key, u_int32_t hash, void **vptr, long *sizep, void *extra, LSN *written_lsn) {
cf = cf; hash = hash; extra = extra; written_lsn = written_lsn;
*sizep = (long) key.b;
*vptr = malloc(*sizep);
return 0;
}
int fetch_error(CACHEFILE cf __attribute__((__unused__)),
CACHEKEY key __attribute__((__unused__)),
u_int32_t fullhash __attribute__((__unused__)),
void **value __attribute__((__unused__)),
long *sizep __attribute__((__unused__)),
void*extraargs __attribute__((__unused__)),
LSN *written_lsn __attribute__((__unused__))
) {
static int
fetch_error (CACHEFILE cf __attribute__((__unused__)),
CACHEKEY key __attribute__((__unused__)),
u_int32_t fullhash __attribute__((__unused__)),
void **value __attribute__((__unused__)),
long *sizep __attribute__((__unused__)),
void*extraargs __attribute__((__unused__)),
LSN *written_lsn __attribute__((__unused__))
) {
return -1;
}
void cachetable_getandpin_test(int n) {
static void
cachetable_getandpin_test (int n) {
const int test_limit = 1024*1024;
int r;
CACHETABLE ct;
......
......@@ -5,14 +5,34 @@
#include "test.h"
#include "cachetable.h"
void flush() {
static void
flush (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
void *v __attribute__((__unused__)),
void *e __attribute__((__unused__)),
long s __attribute__((__unused__)),
BOOL w __attribute__((__unused__)),
BOOL keep __attribute__((__unused__)),
LSN m __attribute__((__unused__)),
BOOL r __attribute__((__unused__))
) {
/* Do nothing */
}
int fetch() {
static int
fetch (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
u_int32_t fullhash __attribute__((__unused__)),
void **value __attribute__((__unused__)),
long *sizep __attribute__((__unused__)),
void *extraargs __attribute__((__unused__)),
LSN *written_lsn __attribute__((__unused__))
) {
return 0;
}
void cachetable_put_test(int n) {
static void
cachetable_put_test (int n) {
const int test_limit = 2*n;
int r;
CACHETABLE ct;
......
......@@ -12,7 +12,8 @@ int verbose = 0;
// test create and destroy
void test_create_destroy() {
static void
test_create_destroy (void) {
struct ctpair_rwlock the_rwlock, *rwlock = &the_rwlock;
ctpair_rwlock_init(rwlock);
......@@ -21,7 +22,8 @@ void test_create_destroy() {
// test read lock and unlock with no writers
void test_simple_read_lock(int n) {
static void
test_simple_read_lock (int n) {
struct ctpair_rwlock the_rwlock, *rwlock = &the_rwlock;
ctpair_rwlock_init(rwlock);
......@@ -42,7 +44,8 @@ void test_simple_read_lock(int n) {
// test write lock and unlock with no readers
void test_simple_write_lock() {
static void
test_simple_write_lock (void) {
struct ctpair_rwlock the_rwlock, *rwlock = &the_rwlock;
ctpair_rwlock_init(rwlock);
......@@ -61,18 +64,21 @@ struct rw_event {
pthread_mutex_t mutex;
};
void rw_event_init(struct rw_event *rwe) {
static void
rw_event_init (struct rw_event *rwe) {
rwe->e = 0;
ctpair_rwlock_init(&rwe->the_rwlock);
int r = pthread_mutex_init(&rwe->mutex, 0); assert(r == 0);
}
void rw_event_destroy(struct rw_event *rwe) {
static void
rw_event_destroy (struct rw_event *rwe) {
ctpair_rwlock_destroy(&rwe->the_rwlock);
int r = pthread_mutex_destroy(&rwe->mutex); assert(r == 0);
}
void *test_writer_priority_thread(void *arg) {
static void *
test_writer_priority_thread (void *arg) {
struct rw_event *rwe = arg;
int r;
......@@ -91,7 +97,8 @@ void *test_writer_priority_thread(void *arg) {
// test writer priority over new readers
void test_writer_priority() {
static void
test_writer_priority (void) {
struct rw_event rw_event, *rwe = &rw_event;
int r;
......@@ -131,7 +138,8 @@ void test_writer_priority() {
// test single writer
void *test_single_writer_thread(void *arg) {
static void *
test_single_writer_thread (void *arg) {
struct rw_event *rwe = arg;
int r;
......@@ -145,7 +153,8 @@ void *test_single_writer_thread(void *arg) {
return arg;
}
void test_single_writer() {
static void
test_single_writer (void) {
struct rw_event rw_event, *rwe = &rw_event;
int r;
......
......@@ -70,7 +70,7 @@ static void writeit (void) {
CACHEKEY key = make_blocknum(i*BLOCKSIZE);
u_int32_t fullhash = toku_cachetable_hash(f, key);
int j;
for (j=0; j<BLOCKSIZE; j++) ((char*)buf)[j]=(i+j)%256;
for (j=0; j<BLOCKSIZE; j++) ((char*)buf)[j]=(char)((i+j)%256);
r = toku_cachetable_put(f, key, fullhash, buf, BLOCKSIZE, f_flush, f_fetch, 0); assert(r==0);
r = toku_cachetable_unpin(f, key, fullhash, 0, BLOCKSIZE); assert(r==0);
}
......
......@@ -53,7 +53,8 @@ static void *my_malloc_always_fails(size_t n, const __malloc_ptr_t p) {
// verify that cachetable creation and close works
void test_cachetable_create() {
static void
test_cachetable_create(void) {
CACHETABLE ct = 0;
int r;
r = toku_create_cachetable(&ct, 0, ZERO_LSN, NULL_LOGGER);
......@@ -64,7 +65,8 @@ void test_cachetable_create() {
// verify that cachetable create with no memory returns ENOMEM
void test_cachetable_create_no_memory() {
static void
test_cachetable_create_no_memory (void) {
void *(*orig_malloc_hook)(size_t, const __malloc_ptr_t) = __malloc_hook;
__malloc_hook = my_malloc_always_fails;
CACHETABLE ct = 0;
......@@ -413,7 +415,7 @@ static void test_dirty_flush(CACHEFILE f,
BOOL keep,
LSN modified_lsn __attribute__((__unused__)),
BOOL rename_p __attribute__((__unused__))) {
if (verbose) printf("test_dirty_flush %p %" PRId64 " %p %ld %d %d\n", f, key.b, value, size, do_write, keep);
if (verbose) printf("test_dirty_flush %p %" PRId64 " %p %ld %u %u\n", f, key.b, value, size, do_write, keep);
}
static int test_dirty_fetch(CACHEFILE f, CACHEKEY key, u_int32_t fullhash, void **value_ptr, long *size_ptr, void *arg, LSN *written_lsn) {
......@@ -538,7 +540,7 @@ static void test_size_flush_callback(CACHEFILE f,
BOOL keep,
LSN modified_lsn __attribute__((__unused__)),
BOOL rename_p __attribute__((__unused__))) {
if (test_size_debug && verbose) printf("test_size_flush %p %" PRId64 " %p %ld %d %d\n", f, key.b, value, size, do_write, keep);
if (test_size_debug && verbose) printf("test_size_flush %p %" PRId64 " %p %ld %u %u\n", f, key.b, value, size, do_write, keep);
if (keep) {
assert(do_write != 0);
test_size_flush_key = key;
......
......@@ -240,7 +240,8 @@ static void test_chaining (void) {
test_mutex_destroy();
}
void __attribute__((__noreturn__)) usage (const char *progname) {
static void __attribute__((__noreturn__))
usage (const char *progname) {
fprintf(stderr, "Usage:\n %s [-v] [-q]\n", progname);
exit(1);
}
......
......@@ -5,14 +5,34 @@
#include "test.h"
#include "cachetable.h"
void flush() {
static void
flush (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
void *v __attribute__((__unused__)),
void *e __attribute__((__unused__)),
long s __attribute__((__unused__)),
BOOL w __attribute__((__unused__)),
BOOL keep __attribute__((__unused__)),
LSN m __attribute__((__unused__)),
BOOL r __attribute__((__unused__))
) {
/* Do nothing */
}
int fetch() {
static int
fetch (CACHEFILE f __attribute__((__unused__)),
CACHEKEY k __attribute__((__unused__)),
u_int32_t fullhash __attribute__((__unused__)),
void **value __attribute__((__unused__)),
long *sizep __attribute__((__unused__)),
void *extraargs __attribute__((__unused__)),
LSN *written_lsn __attribute__((__unused__))
) {
return 0;
}
void cachetable_unpin_test(int n) {
static void
cachetable_unpin_test (int n) {
const int test_limit = 2*n;
int r;
CACHETABLE ct;
......
......@@ -13,12 +13,14 @@ struct ctpair {
PAIR next_wq;
};
PAIR new_pair() {
static PAIR
new_pair (void) {
PAIR p = (PAIR) malloc(sizeof *p); assert(p);
return p;
}
void destroy_pair(PAIR p) {
static void
destroy_pair(PAIR p) {
free(p);
}
......@@ -26,7 +28,8 @@ void destroy_pair(PAIR p) {
// test simple create and destroy
void test_create_destroy() {
static void
test_create_destroy (void) {
struct writequeue writequeue, *wq = &writequeue;
writequeue_init(wq);
assert(writequeue_empty(wq));
......@@ -35,7 +38,8 @@ void test_create_destroy() {
// verify that the wq implements FIFO ordering
void test_simple_enq_deq(int n) {
static void
test_simple_enq_deq (int n) {
struct writequeue writequeue, *wq = &writequeue;
int r;
pthread_mutex_t mutex;
......@@ -63,7 +67,8 @@ void test_simple_enq_deq(int n) {
// setting the wq closed should cause deq to return EINVAL
void test_set_closed() {
static void
test_set_closed (void) {
struct writequeue writequeue, *wq = &writequeue;
writequeue_init(wq);
writequeue_set_closed(wq);
......@@ -79,17 +84,20 @@ struct writequeue_with_mutex {
pthread_mutex_t mutex;
};
void writequeue_with_mutex_init(struct writequeue_with_mutex *wqm) {
static void
writequeue_with_mutex_init (struct writequeue_with_mutex *wqm) {
writequeue_init(&wqm->writequeue);
int r = pthread_mutex_init(&wqm->mutex, 0); assert(r == 0);
}
void writequeue_with_mutex_destroy(struct writequeue_with_mutex *wqm) {
static void
writequeue_with_mutex_destroy (struct writequeue_with_mutex *wqm) {
writequeue_destroy(&wqm->writequeue);
int r = pthread_mutex_destroy(&wqm->mutex); assert(r == 0);
}
void *test_set_closed_waiter(void *arg) {
static void *
test_set_closed_waiter(void *arg) {
struct writequeue_with_mutex *wqm = arg;
int r;
......@@ -101,7 +109,8 @@ void *test_set_closed_waiter(void *arg) {
return arg;
}
void test_set_closed_thread() {
static void
test_set_closed_thread (void) {
struct writequeue_with_mutex writequeue_with_mutex, *wqm = &writequeue_with_mutex;
int r;
......@@ -128,20 +137,22 @@ struct rwfc {
int current, limit;
};
void rwfc_init(struct rwfc *rwfc, int limit) {
static void rwfc_init (struct rwfc *rwfc, int limit) {
int r;
r = pthread_mutex_init(&rwfc->mutex, 0); assert(r == 0);
writequeue_init(&rwfc->writequeue);
rwfc->current = 0; rwfc->limit = limit;
}
void rwfc_destroy(struct rwfc *rwfc) {
static void
rwfc_destroy (struct rwfc *rwfc) {
int r;
writequeue_destroy(&rwfc->writequeue);
r = pthread_mutex_destroy(&rwfc->mutex); assert(r == 0);
}
void *rwfc_reader(void *arg) {
static void *
rwfc_reader (void *arg) {
struct rwfc *rwfc = arg;
int r;
while (1) {
......@@ -162,7 +173,8 @@ void *rwfc_reader(void *arg) {
return arg;
}
void test_flow_control(int limit, int n) {
static void
test_flow_control (int limit, int n) {
struct rwfc my_rwfc, *rwfc = &my_rwfc;
int r;
rwfc_init(rwfc, limit);
......
......@@ -7,7 +7,8 @@
int verbose;
void test_fifo_create() {
static void
test_fifo_create (void) {
int r;
FIFO f;
......@@ -19,7 +20,8 @@ void test_fifo_create() {
assert(f == 0);
}
void test_fifo_enq(int n) {
static void
test_fifo_enq (int n) {
int r;
FIFO f;
......
......@@ -9,11 +9,13 @@ struct testlist {
int tag;
};
void testlist_init(struct testlist *tl, int tag) {
static void
testlist_init (struct testlist *tl, int tag) {
tl->tag = tag;
}
void test_push_pop(int n) {
static void
test_push_pop (int n) {
int i;
struct list head;
......@@ -43,7 +45,8 @@ void test_push_pop(int n) {
assert(list_empty(&head));
}
void test_push_pop_head(int n) {
static void
test_push_pop_head (int n) {
int i;
struct list head;
......@@ -74,7 +77,8 @@ void test_push_pop_head(int n) {
assert(list_empty(&head));
}
void test_push_head_pop(int n) {
static void
test_push_head_pop (int n) {
int i;
struct list head;
......@@ -106,7 +110,8 @@ void test_push_head_pop(int n) {
}
// cant move an empty list
void test_move_empty() {
static void
test_move_empty (void) {
struct list h1, h2;
list_init(&h1);
......@@ -116,7 +121,8 @@ void test_move_empty() {
assert(list_empty(&h1));
}
void test_move(int n) {
static void
test_move (int n) {
struct list h1, h2;
int i;
......
......@@ -7,7 +7,8 @@
#include "memory.h"
#include "mempool.h"
void test_mempool_limits(size_t size) {
static void
test_mempool_limits (size_t size) {
void *base = malloc(size);
struct mempool mempool;
toku_mempool_init(&mempool, base, size);
......@@ -24,7 +25,8 @@ void test_mempool_limits(size_t size) {
free(base);
}
void test_mempool_malloc_mfree(size_t size) {
static void
test_mempool_malloc_mfree (size_t size) {
void *base = malloc(size);
struct mempool mempool;
toku_mempool_init(&mempool, base, size);
......
......@@ -21,7 +21,8 @@ int verbose=0;
#define CKERR2s(r,r2,r3) ({ if (r!=r2 && r!=r3) fprintf(stderr, "%s:%d error %d %s, expected %d or %d\n", __FILE__, __LINE__, r, strerror(r), r2,r3); assert(r==r2||r==r3); })
#include <string.h>
void parse_args (int argc, const char *argv[]) {
static void
parse_args (int argc, const char *argv[]) {
const char *argv0=argv[0];
while (argc>1) {
int resultcode=0;
......@@ -68,7 +69,8 @@ TESTVALUE* values = NULL;
struct value* nums = NULL;
u_int32_t length;
void cleanup_globals(void) {
static void
cleanup_globals (void) {
assert(values);
toku_free(values);
values = NULL;
......@@ -79,7 +81,8 @@ void cleanup_globals(void) {
const unsigned int random_seed = 0xFEADACBA;
void init_init_values(unsigned int seed, u_int32_t num_elements) {
static void
init_init_values (unsigned int seed, u_int32_t num_elements) {
srandom(seed);
cleanup_globals();
......@@ -91,7 +94,8 @@ void init_init_values(unsigned int seed, u_int32_t num_elements) {
length = num_elements;
}
void init_identity_values(unsigned int seed, u_int32_t num_elements) {
static void
init_identity_values (unsigned int seed, u_int32_t num_elements) {
u_int32_t i;
init_init_values(seed, num_elements);
......@@ -102,7 +106,8 @@ void init_identity_values(unsigned int seed, u_int32_t num_elements) {
}
}
void init_distinct_sorted_values(unsigned int seed, u_int32_t num_elements) {
static void
init_distinct_sorted_values (unsigned int seed, u_int32_t num_elements) {
u_int32_t i;
init_init_values(seed, num_elements);
......@@ -116,7 +121,8 @@ void init_distinct_sorted_values(unsigned int seed, u_int32_t num_elements) {
}
}
void init_distinct_random_values(unsigned int seed, u_int32_t num_elements) {
static void
init_distinct_random_values (unsigned int seed, u_int32_t num_elements) {
init_distinct_sorted_values(seed, num_elements);
u_int32_t i;
......@@ -134,7 +140,8 @@ void init_distinct_random_values(unsigned int seed, u_int32_t num_elements) {
}
}
void init_globals(void) {
static void
init_globals (void) {
MALLOC_N(1, values);
assert(values);
MALLOC_N(1, nums);
......@@ -142,14 +149,16 @@ void init_globals(void) {
length = 1;
}
void test_close(enum close_when_done close) {
static void
test_close (enum close_when_done close) {
if (close == KEEP_WHEN_DONE) return;
assert(close == CLOSE_WHEN_DONE);
toku_omt_destroy(&omt);
assert(omt==NULL);
}
void test_create(enum close_when_done close) {
static void
test_create (enum close_when_done close) {
int r;
omt = NULL;
......@@ -159,13 +168,15 @@ void test_create(enum close_when_done close) {
test_close(close);
}
void test_create_size(enum close_when_done close) {
static void
test_create_size (enum close_when_done close) {
test_create(KEEP_WHEN_DONE);
assert(toku_omt_size(omt) == 0);
test_close(close);
}
void test_create_insert_at_almost_random(enum close_when_done close) {
static void
test_create_insert_at_almost_random (enum close_when_done close) {
u_int32_t i;
int r;
u_int32_t size = 0;
......@@ -192,7 +203,8 @@ void test_create_insert_at_almost_random(enum close_when_done close) {
test_close(close);
}
void test_create_insert_at_sequential(enum close_when_done close) {
static void
test_create_insert_at_sequential (enum close_when_done close) {
u_int32_t i;
int r;
u_int32_t size = 0;
......@@ -216,7 +228,8 @@ void test_create_insert_at_sequential(enum close_when_done close) {
test_close(close);
}
void test_create_from_sorted_array(enum create_type create_choice, enum close_when_done close) {
static void
test_create_from_sorted_array (enum create_type create_choice, enum close_when_done close) {
int r;
omt = NULL;
......@@ -236,13 +249,15 @@ void test_create_from_sorted_array(enum create_type create_choice, enum close_wh
test_close(close);
}
void test_create_from_sorted_array_size(enum create_type create_choice, enum close_when_done close) {
static void
test_create_from_sorted_array_size (enum create_type create_choice, enum close_when_done close) {
test_create_from_sorted_array(create_choice, KEEP_WHEN_DONE);
assert(toku_omt_size(omt)==length);
test_close(close);
}
void test_fetch_verify (OMT omtree, TESTVALUE* val, u_int32_t len ) {
static void
test_fetch_verify (OMT omtree, TESTVALUE* val, u_int32_t len ) {
u_int32_t i;
int j;
int r;
......@@ -335,7 +350,8 @@ void test_fetch_verify (OMT omtree, TESTVALUE* val, u_int32_t len ) {
toku_omt_cursor_destroy(&c);
}
void test_create_fetch_verify(enum create_type create_choice, enum close_when_done close) {
static void
test_create_fetch_verify (enum create_type create_choice, enum close_when_done close) {
test_create_from_sorted_array(create_choice, KEEP_WHEN_DONE);
test_fetch_verify(omt, values, length);
test_close(close);
......@@ -343,7 +359,8 @@ void test_create_fetch_verify(enum create_type create_choice, enum close_when_do
static int iterate_helper_error_return = 1;
int iterate_helper(TESTVALUE v, u_int32_t idx, void* extra) {
static int
iterate_helper (TESTVALUE v, u_int32_t idx, void* extra) {
if (extra == NULL) return iterate_helper_error_return;
TESTVALUE* vals = (TESTVALUE *)extra;
assert(v != NULL);
......@@ -352,7 +369,8 @@ int iterate_helper(TESTVALUE v, u_int32_t idx, void* extra) {
return 0;
}
void test_iterate_verify(OMT omtree, TESTVALUE* vals, u_int32_t len) {
static void
test_iterate_verify (OMT omtree, TESTVALUE* vals, u_int32_t len) {
int r;
iterate_helper_error_return = 0;
r = toku_omt_iterate(omtree, iterate_helper, (void*)vals);
......@@ -367,14 +385,16 @@ void test_iterate_verify(OMT omtree, TESTVALUE* vals, u_int32_t len) {
}
}
void test_create_iterate_verify(enum create_type create_choice, enum close_when_done close) {
static void
test_create_iterate_verify (enum create_type create_choice, enum close_when_done close) {
test_create_from_sorted_array(create_choice, KEEP_WHEN_DONE);
test_iterate_verify(omt, values, length);
test_close(close);
}
void permute_array(u_int32_t* arr, u_int32_t len) {
static void
permute_array (u_int32_t* arr, u_int32_t len) {
//
// create a permutation of 0...size-1
//
......@@ -393,7 +413,8 @@ void permute_array(u_int32_t* arr, u_int32_t len) {
}
}
void test_create_set_at(enum create_type create_choice, enum close_when_done close) {
static void
test_create_set_at (enum create_type create_choice, enum close_when_done close) {
u_int32_t i = 0;
struct value* old_nums = NULL;
......@@ -445,7 +466,8 @@ void test_create_set_at(enum create_type create_choice, enum close_when_done clo
test_close(close);
}
int insert_helper(TESTVALUE value, void* extra_insert) {
static int
insert_helper (TESTVALUE value, void* extra_insert) {
TESTVALUE to_insert = (OMTVALUE)extra_insert;
assert(to_insert);
......@@ -454,7 +476,8 @@ int insert_helper(TESTVALUE value, void* extra_insert) {
return 0;
}
void test_create_insert(enum close_when_done close) {
static void
test_create_insert (enum close_when_done close) {
u_int32_t i = 0;
u_int32_t* perm = NULL;
......@@ -508,7 +531,8 @@ void test_create_insert(enum close_when_done close) {
test_close(close);
}
void test_create_delete_at(enum create_type create_choice, enum close_when_done close) {
static void
test_create_delete_at (enum create_type create_choice, enum close_when_done close) {
u_int32_t i = 0;
int r = ENOSYS;
test_create_from_sorted_array(create_choice, KEEP_WHEN_DONE);
......@@ -541,7 +565,8 @@ void test_create_delete_at(enum create_type create_choice, enum close_when_done
test_close(close);
}
void test_split_merge(enum create_type create_choice, enum close_when_done close) {
static void
test_split_merge (enum create_type create_choice, enum close_when_done close) {
int r = ENOSYS;
u_int32_t i = 0;
OMT left_split = NULL;
......@@ -602,7 +627,8 @@ void test_split_merge(enum create_type create_choice, enum close_when_done close
}
void init_values(enum rand_type rand_choice) {
static void
init_values (enum rand_type rand_choice) {
const u_int32_t test_size = 100;
if (rand_choice == TEST_RANDOM) {
init_distinct_random_values(random_seed, test_size);
......@@ -616,7 +642,8 @@ void init_values(enum rand_type rand_choice) {
else assert(FALSE);
}
void test_create_array(enum create_type create_choice, enum rand_type rand_choice) {
static void
test_create_array (enum create_type create_choice, enum rand_type rand_choice) {
/* ********************************************************************** */
init_values(rand_choice);
test_create_from_sorted_array( create_choice, CLOSE_WHEN_DONE);
......@@ -646,7 +673,9 @@ typedef struct {
u_int32_t first_pos;
} h_extra;
int test_heaviside(OMTVALUE v_omt, void* x) {
static int
test_heaviside (OMTVALUE v_omt, void* x) {
TESTVALUE v = (OMTVALUE) v_omt;
h_extra* extra = (h_extra*)x;
assert(v && x);
......@@ -658,14 +687,16 @@ int test_heaviside(OMTVALUE v_omt, void* x) {
return 1;
}
void heavy_extra(h_extra* extra, u_int32_t first_zero, u_int32_t first_pos) {
static void
heavy_extra (h_extra* extra, u_int32_t first_zero, u_int32_t first_pos) {
extra->first_zero = first_zero;
extra->first_pos = first_pos;
}
void test_find_dir(int dir, void* extra, int (*h)(OMTVALUE, void*),
int r_expect, BOOL idx_will_change, u_int32_t idx_expect,
u_int32_t number_expect, BOOL cursor_valid) {
static void
test_find_dir (int dir, void* extra, int (*h)(OMTVALUE, void*),
int r_expect, BOOL idx_will_change, u_int32_t idx_expect,
u_int32_t number_expect, BOOL cursor_valid) {
u_int32_t idx = UINT32_MAX;
u_int32_t old_idx = idx;
TESTVALUE omt_val, omt_val_curs;
......@@ -770,7 +801,8 @@ void test_find_dir(int dir, void* extra, int (*h)(OMTVALUE, void*),
assert(omt_val == NULL);
}
void test_find(enum create_type create_choice, enum close_when_done close) {
static void
test_find (enum create_type create_choice, enum close_when_done close) {
h_extra extra;
init_identity_values(random_seed, 100);
test_create_from_sorted_array(create_choice, KEEP_WHEN_DONE);
......@@ -843,17 +875,20 @@ void test_find(enum create_type create_choice, enum close_when_done close) {
test_close(close);
}
void invalidate_callback_null(OMTCURSOR c, void *extra) {
static void
invalidate_callback_null (OMTCURSOR c, void *extra) {
assert(c && !extra);
}
void invalidate_callback_inc(OMTCURSOR c, void *extra) {
static void
invalidate_callback_inc (OMTCURSOR c, void *extra) {
assert(c);
int *num = extra;
(*num)++;
}
void test_invalidate(enum create_type create_choice, BOOL set_callback, BOOL invalidate_callback) {
static void
test_invalidate (enum create_type create_choice, BOOL set_callback, BOOL invalidate_callback) {
init_identity_values(random_seed, 100);
test_create_from_sorted_array(create_choice, KEEP_WHEN_DONE);
......@@ -924,7 +959,8 @@ void test_invalidate(enum create_type create_choice, BOOL set_callback, BOOL inv
else assert(invalidate_count==0);
}
void runtests_create_choice(enum create_type create_choice) {
static void
runtests_create_choice (enum create_type create_choice) {
test_create_array(create_choice, TEST_SORTED);
test_create_array(create_choice, TEST_RANDOM);
test_create_array(create_choice, TEST_IDENTITY);
......
......@@ -12,7 +12,8 @@
static TOKUTXN const null_txn = 0;
void doit (void) {
static void
doit (void) {
int r;
CACHETABLE ct;
BRT t;
......
......@@ -13,7 +13,8 @@ static const char fname[]= __FILE__ ".brt";
static TOKUTXN const null_txn = 0;
static DB * const null_db = 0;
void test_overflow (void) {
static void
test_overflow (void) {
BRT t;
CACHETABLE ct;
u_int32_t nodesize = 1<<20;
......@@ -28,7 +29,7 @@ void test_overflow (void) {
memset(buf, 'a', vsize);
int i;
for (i=0; i<8; i++) {
char key[]={'a'+i, 0};
char key[]={(char)('a'+i), 0};
toku_brt_insert(t, toku_fill_dbt(&k, key, 2), toku_fill_dbt(&v,buf,sizeof(buf)), null_txn);
}
r = toku_close_brt(t, 0); assert(r==0);
......
......@@ -21,7 +21,8 @@ BRT t;
int fnamelen;
char *fname;
void doit (void) {
static void
doit (void) {
BLOCKNUM nodea,nodeb;
u_int32_t fingerprinta=0;
......
......@@ -47,7 +47,8 @@ BRT t;
int fnamelen;
char *fname;
void doit (int ksize __attribute__((__unused__))) {
static void
doit (int ksize __attribute__((__unused__))) {
BLOCKNUM cnodes[BRT_FANOUT], bnode, anode;
u_int32_t fingerprints[BRT_FANOUT];
......
......@@ -17,7 +17,8 @@ struct my_threadpool {
int closed;
};
void my_threadpool_init(struct my_threadpool *my_threadpool, int max_threads) {
static void
my_threadpool_init (struct my_threadpool *my_threadpool, int max_threads) {
int r;
r = threadpool_create(&my_threadpool->threadpool, max_threads); assert(r == 0);
assert(my_threadpool != 0);
......@@ -26,7 +27,8 @@ void my_threadpool_init(struct my_threadpool *my_threadpool, int max_threads) {
my_threadpool->closed = 0;
}
void my_threadpool_destroy(struct my_threadpool *my_threadpool) {
static void
my_threadpool_destroy (struct my_threadpool *my_threadpool) {
int r;
r = pthread_mutex_lock(&my_threadpool->mutex); assert(r == 0);
my_threadpool->closed = 1;
......@@ -39,7 +41,8 @@ void my_threadpool_destroy(struct my_threadpool *my_threadpool) {
r = pthread_cond_destroy(&my_threadpool->wait); assert(r == 0);
}
void *fbusy(void *arg) {
static void *
fbusy (void *arg) {
struct my_threadpool *my_threadpool = arg;
int r;
......@@ -52,7 +55,8 @@ void *fbusy(void *arg) {
return arg;
}
void *fidle(void *arg) {
static void *
fidle (void *arg) {
struct my_threadpool *my_threadpool = arg;
int r;
......@@ -74,7 +78,8 @@ static void *my_malloc_always_fails(size_t n, const __malloc_ptr_t p) {
}
#endif
int usage() {
static int
usage (void) {
printf("threadpool-test: [-v] [-malloc-fail] [N]\n");
printf("-malloc-fail simulate malloc failures\n");
printf("N max number of threads in the thread pool\n");
......
......@@ -3,7 +3,8 @@
#include <stdio.h>
#include <stdlib.h>
void test0 (void) {
static void
test0 (void) {
u_int32_t c = x1764_memory("", 0);
assert(c==0);
struct x1764 cs;
......@@ -13,7 +14,8 @@ void test0 (void) {
assert(c==0);
}
void test1 (void) {
static void
test1 (void) {
u_int64_t v=0x123456789abcdef0ULL;
u_int32_t c;
int i;
......@@ -27,7 +29,8 @@ void test1 (void) {
}
// Compute checksums incrementally, using various strides
void test2 (void) {
static void
test2 (void) {
enum { N=200 };
char v[N];
int i;
......
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