]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
* sysdeps/s390/jmpbuf-unwind.h: Include bits/wordsize.h.
authorJakub Jelinek <jakub@redhat.com>
Wed, 6 Oct 2004 09:22:13 +0000 (09:22 +0000)
committerJakub Jelinek <jakub@redhat.com>
Wed, 6 Oct 2004 09:22:13 +0000 (09:22 +0000)
(JMPBUF_CFA_UNWINDS_ADJ): Subtract 96 resp. 160 bytes from
CFA.

nptl/ChangeLog
nptl/sysdeps/s390/jmpbuf-unwind.h

index 287e8b6b2a43417238d583ac86caa3ea2aa91487..f48085822c2332a99e14b52edca239e748ca30f1 100644 (file)
@@ -1,3 +1,9 @@
+2004-10-06  Jakub Jelinek  <jakub@redhat.com>
+
+       * sysdeps/s390/jmpbuf-unwind.h: Include bits/wordsize.h.
+       (JMPBUF_CFA_UNWINDS_ADJ): Subtract 96 resp. 160 bytes from
+       CFA.
+
 2004-10-06  Ulrich Drepper  <drepper@redhat.com>
 
        * tst-cancel4.c (tf_msgrcv): Check for failure in msgget.  If the
index 19d0729a947add412367f5df3035b24c7edf2072..9f7e1ad5839130886a885f4ce1c7d6ae9ba70ea3 100644 (file)
 #include <setjmp.h>
 #include <stdint.h>
 #include <unwind.h>
+#include <bits/wordsize.h>
 
+/* On s390{,x}, CFA is always 96 (resp. 160) bytes above actual
+   %r15.  */
 #define _JMPBUF_CFA_UNWINDS_ADJ(_jmpbuf, _context, _adj) \
-  _JMPBUF_UNWINDS_ADJ (_jmpbuf, (void *) _Unwind_GetCFA (_context), _adj)
+  _JMPBUF_UNWINDS_ADJ (_jmpbuf,                                        \
+                      (void *) (_Unwind_GetCFA (_context)      \
+                                - 32 - 2 * __WORDSIZE), _adj)
 
-#define _JMPBUF_UNWINDS_ADJ(_jmpbuf, _address, _adj)    \
-  ((uintptr_t) (_address) - (_adj)                      \
+#define _JMPBUF_UNWINDS_ADJ(_jmpbuf, _address, _adj)           \
+  ((uintptr_t) (_address) - (_adj)                             \
    < (uintptr_t) (_jmpbuf)->__gregs[__JB_GPR15] - (_adj))
 
-/* We use the normal lobngjmp for unwinding.  */
+/* We use the normal longjmp for unwinding.  */
 #define __libc_unwind_longjmp(buf, val) __libc_longjmp (buf, val)