[PATCH 4/5] ARC/NPTL: Add tests

Vineet Gupta Vineet.Gupta1 at synopsys.com
Fri Jul 25 12:09:07 UTC 2014


Signed-off-by: Vineet Gupta <vgupta at synopsys.com>
---
 test/tls/tls-macros.h | 30 ++++++++++++++++++++++++++++++
 1 file changed, 30 insertions(+)

diff --git a/test/tls/tls-macros.h b/test/tls/tls-macros.h
index 3a9a21adcdf0..2787809f5b36 100644
--- a/test/tls/tls-macros.h
+++ b/test/tls/tls-macros.h
@@ -855,6 +855,36 @@ register void *__gp __asm__("$29");
       __result;  \
   })
 
+#elif defined __arc__
+
+/* For now */
+#define TLS_LD(x)	TLS_IE(x)
+
+#define TLS_GD(x)					\
+  ({ int *__result;					\
+     __asm__ ("add r0, pcl, @" #x "@tlsgd      \n"     	\
+	  ".tls_gd_ld " #x "`bl __tls_get_addr at plt \n"	\
+	  "mov %0, r0                    \n"		\
+	  : "=&r" (__result)				\
+	  ::"r0","r1","r2","r3","r4","r5","r6","r7",	\
+	    "r8","r9","r10","r11","r12");		\
+     __result; })
+
+#define TLS_LE(x)					\
+  ({ int *__result;					\
+     void *tp = __builtin_thread_pointer();		                \
+     __asm__ ("add %0, %1, @" #x "@tpoff   \n"		\
+	  : "=r" (__result) : "r"(tp));	        \
+     __result; })
+
+#define TLS_IE(x)					\
+  ({ int *__result;					\
+     void *tp = __builtin_thread_pointer();		                \
+     __asm__ ("ld %0, [pcl, @" #x "@tlsie]      \n"     \
+	  "add %0, %1, %0                       \n"				\
+	  : "=&r" (__result) : "r" (tp));		\
+     __result; })
+
 #elif !defined TLS_LE || !defined TLS_IE \
       || !defined TLS_LD || !defined TLS_GD
 # error "No support for this architecture so far."
-- 
1.8.3.2



More information about the uClibc mailing list