summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>1996-03-12 10:01:41 +0000
committerRoland McGrath <roland@gnu.org>1996-03-12 10:01:41 +0000
commit6c46dada59a56f8748f6d956ef5d318155195840 (patch)
treee3811ee4b324730a87c0e77552ba8261ed117557
parent1177c8babf74c7335c5f3bf09c45961bebeed6c6 (diff)
Tue Mar 12 04:57:57 1996 Roland McGrath <roland@charlie-brown.gnu.ai.mit.edu>cvs/libc-960314cvs/libc-960313cvs/libc-960312
* setjmp/Makefile (tests): Add jmpbug. * setjmp/jmpbug.c: New file.
-rw-r--r--ChangeLog5
-rw-r--r--setjmp/Makefile2
-rw-r--r--setjmp/jmpbug.c32
-rw-r--r--sysdeps/sparc/__longjmp.S1
-rw-r--r--sysdeps/sparc/jmp_buf.h22
-rw-r--r--sysdeps/sparc/setjmp.S2
6 files changed, 53 insertions, 11 deletions
diff --git a/ChangeLog b/ChangeLog
index e94bfeea0b..b31a0fbcc7 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Tue Mar 12 04:57:57 1996 Roland McGrath <roland@charlie-brown.gnu.ai.mit.edu>
+
+ * setjmp/Makefile (tests): Add jmpbug.
+ * setjmp/jmpbug.c: New file.
+
Tue Mar 12 04:42:01 1996 Roland McGrath <roland@charlie-brown.gnu.ai.mit.edu>
* sysdeps/sparc/jmp_buf.h: Rewritten; use array of ints, not struct.
diff --git a/setjmp/Makefile b/setjmp/Makefile
index 4773b617e1..3d004852c8 100644
--- a/setjmp/Makefile
+++ b/setjmp/Makefile
@@ -26,7 +26,7 @@ headers := setjmp.h jmp_buf.h
routines := setjmp sigjmp bsd-setjmp bsd-_setjmp \
longjmp __longjmp jmp-unwind
-tests := tst-setjmp
+tests := tst-setjmp jmpbug
include ../Rules
diff --git a/setjmp/jmpbug.c b/setjmp/jmpbug.c
new file mode 100644
index 0000000000..57a1de0978
--- /dev/null
+++ b/setjmp/jmpbug.c
@@ -0,0 +1,32 @@
+/* setjmp vs alloca test case. Exercised bug on sparc. */
+
+#include <stdio.h>
+#include <setjmp.h>
+#include <alloca.h>
+
+void
+sub5 (jmp_buf buf)
+{
+ longjmp (buf, 1);
+}
+
+int
+main (void)
+{
+ jmp_buf buf;
+ char *foo;
+ int arr[100];
+
+ arr[77] = 76;
+ if (setjmp (buf))
+ {
+ printf ("made it ok; %d\n", arr[77]);
+ exit (0);
+ }
+
+ foo = (char *) alloca (128);
+ sub5 (buf);
+
+ /* NOTREACHED */
+ return 1;
+}
diff --git a/sysdeps/sparc/__longjmp.S b/sysdeps/sparc/__longjmp.S
index 38bc7bbac8..5424300fe5 100644
--- a/sysdeps/sparc/__longjmp.S
+++ b/sysdeps/sparc/__longjmp.S
@@ -18,6 +18,7 @@ Cambridge, MA 02139, USA. */
#include <sysdep.h>
+#define _ASM 1
#include <jmp_buf.h>
#define ENV(reg) [%g1 + (reg * 4)]
diff --git a/sysdeps/sparc/jmp_buf.h b/sysdeps/sparc/jmp_buf.h
index a5a592fd47..43bae1a496 100644
--- a/sysdeps/sparc/jmp_buf.h
+++ b/sysdeps/sparc/jmp_buf.h
@@ -1,14 +1,16 @@
/* Define the machine-dependent type `jmp_buf'. SPARC version. */
-/* NOTE: The assembly code in __longjmp.S and setjmp.S knows the layout
- of this structure. You must hack the assembly code if you want to change
- the order of the members. */
+#if defined (__USE_MISC) || defined (_ASM)
+#define JB_SP 0
+#define JB_FP 1
+#define JB_PC 2
+#endif
-typedef struct
- {
- /* Return PC (register o7). */
- __ptr_t __pc;
+#ifndef _ASM
+typedef int __jmp_buf[3];
+#endif
- /* Saved FP. */
- __ptr_t __fp;
- } __jmp_buf[1];
+/* Test if longjmp to JMPBUF would unwind the frame
+ containing a local variable at ADDRESS. */
+#define _JMPBUF_UNWINDS(jmpbuf, address) \
+ ((int) (address) < (jmpbuf)[JB_SP])
diff --git a/sysdeps/sparc/setjmp.S b/sysdeps/sparc/setjmp.S
index 2cf92cddd7..db8a3c2916 100644
--- a/sysdeps/sparc/setjmp.S
+++ b/sysdeps/sparc/setjmp.S
@@ -17,6 +17,8 @@ not, write to the Free Software Foundation, Inc., 675 Mass Ave,
Cambridge, MA 02139, USA. */
#include <sysdep.h>
+
+#define _ASM 1
#include <jmp_buf.h>
ENTRY (__sigsetjmp)