X-Git-Url: https://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=doc%2Fexamples%2Furcu-flavors%2Fmb.c;h=e103e4f91f55f1d69078733136366d05145194a7;hp=62ad54bb7ff00309f7de7572116de1222bd8b7ee;hb=b9050d917ab84db192b5609ba6dd9973a82d215a;hpb=042e8cfe9b352b325a7350f345a3f2923606a2be diff --git a/doc/examples/urcu-flavors/mb.c b/doc/examples/urcu-flavors/mb.c index 62ad54b..e103e4f 100644 --- a/doc/examples/urcu-flavors/mb.c +++ b/doc/examples/urcu-flavors/mb.c @@ -22,8 +22,7 @@ #include #include -#define RCU_MB /* Memory barrier RCU flavor */ -#include +#include /* Memory barrier RCU flavor */ #include /* List example */ #include /* For CAA_ARRAY_SIZE */ @@ -75,7 +74,7 @@ int main(int argc, char **argv) * Each thread need using RCU read-side need to be explicitly * registered. */ - rcu_register_thread(); + urcu_mb_register_thread(); /* * Adding nodes to the linked-list. Safe against concurrent @@ -92,7 +91,7 @@ int main(int argc, char **argv) * with rcu_read_lock() and rcu_read_unlock(). They can be * nested. Those are no-ops for the QSBR flavor. */ - rcu_read_lock(); + urcu_mb_read_lock(); /* * RCU traversal of the linked list. @@ -100,7 +99,7 @@ int main(int argc, char **argv) cds_list_for_each_entry_rcu(node, &mylist, node) { printf("Value: %" PRIu64 "\n", node->value); } - rcu_read_unlock(); + urcu_mb_read_unlock(); /* * Removing nodes from linked list. Safe against concurrent RCU @@ -114,7 +113,7 @@ int main(int argc, char **argv) * call_rcu() can be called from RCU read-side critical * sections. */ - call_rcu(&node->rcu_head, rcu_free_node); + urcu_mb_call_rcu(&node->rcu_head, rcu_free_node); } /* @@ -124,7 +123,7 @@ int main(int argc, char **argv) * batch work. Moreover, call_rcu() can be called from a RCU * read-side critical section, but synchronize_rcu() should not. */ - synchronize_rcu(); + urcu_mb_synchronize_rcu(); sleep(1); @@ -133,9 +132,9 @@ int main(int argc, char **argv) * before program exits, or in library destructors, is a good * practice. */ - rcu_barrier(); + urcu_mb_barrier(); end: - rcu_unregister_thread(); + urcu_mb_unregister_thread(); return ret; }