X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=tests%2Ftest_urcu_lfs.c;h=a7f9af3abd5086ee21e73aa0f3269530e612886a;hb=7618919ae496bda84a2efa4f2ad0abe569892a9e;hp=834c72ea1abd22a42980ad0e8f324b1a4fa9c073;hpb=9bfaf0cab9a326b89b9ee83e0bb0679918a3023a;p=userspace-rcu.git diff --git a/tests/test_urcu_lfs.c b/tests/test_urcu_lfs.c index 834c72e..a7f9af3 100644 --- a/tests/test_urcu_lfs.c +++ b/tests/test_urcu_lfs.c @@ -34,12 +34,15 @@ #include #include #include -#include #include #include #include +#ifdef __linux__ +#include +#endif + /* hardcoded number of CPUs */ #define NR_CPUS 16384 @@ -62,7 +65,7 @@ static inline pid_t gettid(void) #define _LGPL_SOURCE #endif #include -#include +#include #include static volatile int test_go, test_stop; @@ -177,6 +180,7 @@ void *thr_enqueuer(void *_count) if (!node) goto fail; cds_lfs_node_init_rcu(node); + /* No rcu read-side is needed for push */ cds_lfs_push_rcu(&s, node); nr_successful_enqueues++; @@ -223,13 +227,13 @@ void *thr_dequeuer(void *_count) cmm_smp_mb(); for (;;) { - struct cds_lfs_node_rcu *node = cds_lfs_pop_rcu(&s); + struct cds_lfs_node_rcu *node; + node = cds_lfs_pop_rcu(&s); if (node) { defer_rcu(free, node); nr_successful_dequeues++; } - nr_dequeues++; if (unlikely(!test_duration_dequeue())) break;