(__longjmp): Xor %r14 with THREAD_GET_POINTER_GUARD () if PTR_DEMANGLE
authordrepper <drepper>
Tue, 20 Dec 2005 06:50:59 +0000 (06:50 +0000)
committerdrepper <drepper>
Tue, 20 Dec 2005 06:50:59 +0000 (06:50 +0000)
is defined.

sysdeps/s390/s390-32/__longjmp.c

index c1b977c..07814e0 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2000, 2001 Free Software Foundation, Inc.
+/* Copyright (C) 2000, 2001, 2005 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Martin Schwidefsky (schwidefsky@de.ibm.com).
 
 void
 __longjmp (__jmp_buf env, int val)
 {
-   /* Restore registers and jump back.  */
-   asm volatile ("lr   %%r2,%0\n\t"      /* PUT val in grp 2.  */
-                "ld   %%f6,48(%1)\n\t"
-                "ld   %%f4,40(%1)\n\t"
-                "lm   %%r6,%%r15,0(%1)\n\t"
-                "br   %%r14"
-                : : "r" (val == 0 ? 1 : val),
-                "a" (env) : "2" );
+#ifdef PTR_DEMANGLE
+  register uintptr_t r5 __asm ("%r5") = THREAD_GET_POINTER_GUARD ();
+#endif
+  /* Restore registers and jump back.  */
+  asm volatile ("lr   %%r2,%0\n\t"       /* PUT val in grp 2.  */
+               "ld   %%f6,48(%1)\n\t"
+               "ld   %%f4,40(%1)\n\t"
+               "lm   %%r6,%%r15,0(%1)\n\t"
+#ifdef PTR_DEMANGLE
+               "xr   %%r14,%2\n\t"
+#endif
+               "br   %%r14"
+               : : "r" (val == 0 ? 1 : val),
+                   "a" (env)
+#ifdef PTR_DEMANGLE
+                   , "r" (r5)
+#endif
+               : "2" );
 
   /* Avoid `volatile function does return' warnings.  */
   for (;;);