summaryrefslogtreecommitdiff
path: root/test/tls/tst-tlsmod-at-ctor.c
diff options
context:
space:
mode:
authorCarmelo Amoroso <carmelo.amoroso@st.com>2009-12-03 13:07:54 +0100
committerCarmelo Amoroso <carmelo.amoroso@st.com>2009-12-03 13:07:54 +0100
commitac08946e0c09c25143d4cc49abdf0281bb81bd8d (patch)
tree47c7d87fb31c2c778a3709d60a4791c19d00cf5d /test/tls/tst-tlsmod-at-ctor.c
parent247367948e9cb629126422ce2ea60c67c08bff70 (diff)
test_tls: Rename tst-tls16 to tst-tls-at-ctor
Rename tst-tls16 to tst-tls-at-ctor (including main and related shared object) to avoid name clashing with new tests ported from glibc. Signed-off-by: Carmelo Amoroso <carmelo.amoroso@st.com>
Diffstat (limited to 'test/tls/tst-tlsmod-at-ctor.c')
-rw-r--r--test/tls/tst-tlsmod-at-ctor.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/test/tls/tst-tlsmod-at-ctor.c b/test/tls/tst-tlsmod-at-ctor.c
new file mode 100644
index 000000000..bd04b5081
--- /dev/null
+++ b/test/tls/tst-tlsmod-at-ctor.c
@@ -0,0 +1,25 @@
+#include <stdio.h>
+#include <tls.h>
+
+#define TLS_VAR_INIT_VALUE 99
+
+#ifdef USE_TLS
+__thread int tls_var __attribute__((tls_model("global-dynamic")));
+static __thread int local_tls_var __attribute__((tls_model("local-dynamic")));
+#endif
+
+void __attribute__((constructor)) libtls_ctor(void);
+void libtls_ctor(void)
+{
+ printf("libtls: constructor!\n");
+#ifdef USE_TLS
+ local_tls_var = TLS_VAR_INIT_VALUE;
+ tls_var = local_tls_var;
+#endif
+}
+
+void __attribute__((destructor)) libtls_dtor(void);
+void libtls_dtor(void)
+{
+ printf("libtls: destructor!\n");
+}