Blame SOURCES/gcc48-pr78796.patch

25c7f1
2016-12-14  Wilco Dijkstra  <wdijkstr@arm.com>
25c7f1
	    Jakub Jelinek  <jakub@redhat.com>
25c7f1
25c7f1
	PR target/78796
25c7f1
	* config/aarch64/aarch64.c (aarch64_classify_symbol): Merge large
25c7f1
	model checks into switch.
25c7f1
25c7f1
	* gcc.dg/tls/pr78796.c: New test.
25c7f1
25c7f1
--- gcc/config/aarch64/aarch64.c	(revision 243645)
25c7f1
+++ gcc/config/aarch64/aarch64.c	(revision 243646)
25c7f1
@@ -4986,6 +4986,9 @@ aarch64_classify_symbol (rtx x,
25c7f1
   switch (aarch64_cmodel)
25c7f1
     {
25c7f1
     case AARCH64_CMODEL_LARGE:
25c7f1
+      if (aarch64_tls_symbol_p (x))
25c7f1
+	return aarch64_classify_tls_symbol (x);
25c7f1
+
25c7f1
       return SYMBOL_FORCE_TO_MEM;
25c7f1
 
25c7f1
     case AARCH64_CMODEL_TINY:
25c7f1
--- gcc/testsuite/gcc.dg/tls/pr78796.c	(nonexistent)
25c7f1
+++ gcc/testsuite/gcc.dg/tls/pr78796.c	(revision 243646)
25c7f1
@@ -0,0 +1,32 @@
25c7f1
+/* PR target/78796 */
25c7f1
+/* { dg-do run } */
25c7f1
+/* { dg-options "-O2" } */
25c7f1
+/* { dg-additional-options "-mcmodel=large" { target aarch64-*-* } } */
25c7f1
+/* { dg-require-effective-target tls } */
25c7f1
+
25c7f1
+struct S { int a, b, c, d, e; };
25c7f1
+struct S t;
25c7f1
+__thread struct S s;
25c7f1
+
25c7f1
+__attribute__((used, noinline, noclone)) void
25c7f1
+foo (int *x, int *y)
25c7f1
+{
25c7f1
+  asm volatile ("" : : "g" (x), "g" (y) : "memory");
25c7f1
+  if (*x != 1 || *y != 2)
25c7f1
+    __builtin_abort ();
25c7f1
+}
25c7f1
+
25c7f1
+__attribute__((used, noinline, noclone)) void
25c7f1
+bar (void)
25c7f1
+{
25c7f1
+  foo (&t.c, &s.c);
25c7f1
+}
25c7f1
+
25c7f1
+int
25c7f1
+main ()
25c7f1
+{
25c7f1
+  t.c = 1;
25c7f1
+  s.c = 2;
25c7f1
+  bar ();
25c7f1
+  return 0;
25c7f1
+}