X-Git-Url: http://git.lttng.org/?a=blobdiff_plain;f=tests%2Funit%2Ftest_build.c;h=f6b667ce2b3d9ab08dc64704337f9960d923ab68;hb=2d466a6397dbc7af397d0fc10e327cc6cac76a5a;hp=b2786c55c00253d8d51ab6e1ae8ed90329755f85;hpb=c8292aa76bf23db3b6031cd49c0e6c469d0c889d;p=userspace-rcu.git diff --git a/tests/unit/test_build.c b/tests/unit/test_build.c index b2786c5..f6b667c 100644 --- a/tests/unit/test_build.c +++ b/tests/unit/test_build.c @@ -59,6 +59,15 @@ #include "tap.h" +struct my_tls_struct { + int int1; + char char1; + void *void1; +}; + +static DEFINE_URCU_TLS(int, my_tls_int); +static DEFINE_URCU_TLS(struct my_tls_struct, my_tls_struct); + static void test_lfstack(void) { struct cds_lfs_stack s; @@ -97,6 +106,35 @@ void test_build_cds_list_head_init(void) }; } +static +void test_urcu_tls(void) +{ + URCU_TLS(my_tls_int) = 1; + URCU_TLS(my_tls_struct).int1 = 1; + URCU_TLS(my_tls_struct).char1 = 'a'; + URCU_TLS(my_tls_struct).void1 = NULL; +} + +struct an_opaque_struct; +struct a_clear_struct +{ + int x; +}; + +static +void test_build_rcu_dereference(void) +{ + static struct an_opaque_struct *opaque = NULL; + static struct an_opaque_struct *const opaque_const = NULL; + static struct a_clear_struct *clear = NULL; + static struct a_clear_struct *const clear_const = NULL; + + rcu_dereference(opaque); + rcu_dereference(opaque_const); + rcu_dereference(clear); + rcu_dereference(clear_const); +} + int main(void) { plan_tests(3); @@ -105,6 +143,8 @@ int main(void) test_wfstack(); test_wfcqueue(); test_build_cds_list_head_init(); + test_urcu_tls(); + test_build_rcu_dereference(); return exit_status(); }