X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=tests%2Ftest_urcu_hash.c;h=414948c8b501251ca1d92cbed6565446e5325cd2;hb=01dbfa62037e08aa2d08ab0e721267ccdd99b947;hp=3a87d483f9a15ad981b0af52e0198a70ea55db1c;hpb=151e7a93d1cb77c3f7c78370ce1eee2c6a49e690;p=urcu.git diff --git a/tests/test_urcu_hash.c b/tests/test_urcu_hash.c index 3a87d48..414948c 100644 --- a/tests/test_urcu_hash.c +++ b/tests/test_urcu_hash.c @@ -46,6 +46,21 @@ /* hardcoded number of CPUs */ #define NR_CPUS 16384 +/* For testing */ +#define POISON_FREE + +#ifdef POISON_FREE +#define poison_free(ptr) \ + do { \ + memset(ptr, 0x42, sizeof(*(ptr))); \ + free(ptr); \ + } while (0) +#else +#define poison_free(ptr) free(ptr) +#endif + + + #if defined(_syscall0) _syscall0(pid_t, gettid) #elif defined(__NR_gettid) @@ -704,7 +719,8 @@ int main(int argc, char **argv) test_ht = cds_lfht_new(test_hash, test_compare, 0x42UL, init_hash_size, opt_auto_resize ? CDS_LFHT_AUTO_RESIZE : 0, - call_rcu, synchronize_rcu); + call_rcu, synchronize_rcu, rcu_read_lock, + rcu_read_unlock); ret = populate_hash(); assert(!ret); err = create_all_cpu_call_rcu_data(0);