diff options
author | Austin Foxley <austinf@cetoncorp.com> | 2009-10-17 12:39:59 -0700 |
---|---|---|
committer | Austin Foxley <austinf@cetoncorp.com> | 2009-10-17 12:39:59 -0700 |
commit | 8b7834d4008d10d8763d18b25580a4607a5e6607 (patch) | |
tree | b030bc2a953787804c11189e32c22f51fbabbbdc /test/tls/tst-tlsmod3.c | |
parent | 75accc3bc3c164ac6063c384c98f0dfa7d489dcc (diff) |
test/tls/: tests for thread local storage functionality
Signed-off-by: Austin Foxley <austinf@cetoncorp.com>
Diffstat (limited to 'test/tls/tst-tlsmod3.c')
-rw-r--r-- | test/tls/tst-tlsmod3.c | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/test/tls/tst-tlsmod3.c b/test/tls/tst-tlsmod3.c new file mode 100644 index 000000000..12505f623 --- /dev/null +++ b/test/tls/tst-tlsmod3.c @@ -0,0 +1,41 @@ +#include <stdio.h> + +#include <tls.h> + +#ifdef USE_TLS +# include "tls-macros.h" + +extern int in_dso (int n, int *caller_foop); + +COMMON_INT_DEF(comm_n); + + + + +int +in_dso2 (void) +{ + int *foop; + int result = 0; + static int n; + int *np; + + puts ("foo"); /* Make sure PLT is used before macros. */ + __asm__ ("" ::: "memory"); + + foop = TLS_GD (foo); + np = TLS_GD (comm_n); + + if (n != *np) + { + printf ("n = %d != comm_n = %d\n", n, *np); + result = 1; + } + + result |= in_dso (*foop = 42 + n++, foop); + + *foop = 16; + + return result; +} +#endif |