diff options
| -rw-r--r-- | src/regress/lib/libc/setjmp-fpu/Makefile | 4 | ||||
| -rw-r--r-- | src/regress/lib/libc/setjmp-fpu/_setjmp.c | 5 | ||||
| -rw-r--r-- | src/regress/lib/libc/setjmp-fpu/main.c | 11 | ||||
| -rw-r--r-- | src/regress/lib/libc/setjmp-fpu/setjmp-fpu.c | 28 | ||||
| -rw-r--r-- | src/regress/lib/libc/setjmp-fpu/setjmp.c | 5 | ||||
| -rw-r--r-- | src/regress/lib/libc/setjmp-fpu/sigsetjmp.c | 5 |
6 files changed, 48 insertions, 10 deletions
diff --git a/src/regress/lib/libc/setjmp-fpu/Makefile b/src/regress/lib/libc/setjmp-fpu/Makefile index 471de4821c..33d0f7e88a 100644 --- a/src/regress/lib/libc/setjmp-fpu/Makefile +++ b/src/regress/lib/libc/setjmp-fpu/Makefile | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | # $OpenBSD: Makefile,v 1.1 2013/12/29 01:39:44 martynas Exp $ | 1 | # $OpenBSD: Makefile,v 1.2 2013/12/29 05:46:43 martynas Exp $ |
| 2 | 2 | ||
| 3 | PROG= setjmp-fpu | 3 | PROG= setjmp-fpu |
| 4 | SRCS= setjmp-fpu.c | 4 | SRCS= _setjmp.c main.c setjmp.c sigsetjmp.c |
| 5 | 5 | ||
| 6 | LDADD= -lm | 6 | LDADD= -lm |
| 7 | 7 | ||
diff --git a/src/regress/lib/libc/setjmp-fpu/_setjmp.c b/src/regress/lib/libc/setjmp-fpu/_setjmp.c new file mode 100644 index 0000000000..a10b582f3f --- /dev/null +++ b/src/regress/lib/libc/setjmp-fpu/_setjmp.c | |||
| @@ -0,0 +1,5 @@ | |||
| 1 | #define SETJMP(env, savemask) _setjmp(env) | ||
| 2 | #define LONGJMP(env, val) _longjmp(env, val) | ||
| 3 | #define TEST_SETJMP test__setjmp | ||
| 4 | |||
| 5 | #include "setjmp-fpu.c" | ||
diff --git a/src/regress/lib/libc/setjmp-fpu/main.c b/src/regress/lib/libc/setjmp-fpu/main.c new file mode 100644 index 0000000000..43f9b6216c --- /dev/null +++ b/src/regress/lib/libc/setjmp-fpu/main.c | |||
| @@ -0,0 +1,11 @@ | |||
| 1 | int test__setjmp(void); | ||
| 2 | int test_setjmp(void); | ||
| 3 | int test_sigsetjmp(void); | ||
| 4 | |||
| 5 | int | ||
| 6 | main(int argc, char *argv[]) | ||
| 7 | { | ||
| 8 | return (test__setjmp() | ||
| 9 | | test_setjmp() | ||
| 10 | | test_sigsetjmp()); | ||
| 11 | } | ||
diff --git a/src/regress/lib/libc/setjmp-fpu/setjmp-fpu.c b/src/regress/lib/libc/setjmp-fpu/setjmp-fpu.c index bbc562d6bd..45b3c1ee0e 100644 --- a/src/regress/lib/libc/setjmp-fpu/setjmp-fpu.c +++ b/src/regress/lib/libc/setjmp-fpu/setjmp-fpu.c | |||
| @@ -2,7 +2,7 @@ | |||
| 2 | #include <setjmp.h> | 2 | #include <setjmp.h> |
| 3 | 3 | ||
| 4 | int | 4 | int |
| 5 | main(int argc, char *argv[]) | 5 | TEST_SETJMP(int argc, char *argv[]) |
| 6 | { | 6 | { |
| 7 | jmp_buf env; | 7 | jmp_buf env; |
| 8 | int rv; | 8 | int rv; |
| @@ -12,23 +12,35 @@ main(int argc, char *argv[]) | |||
| 12 | fedisableexcept(FE_ALL_EXCEPT); | 12 | fedisableexcept(FE_ALL_EXCEPT); |
| 13 | feenableexcept(FE_DIVBYZERO); | 13 | feenableexcept(FE_DIVBYZERO); |
| 14 | 14 | ||
| 15 | rv = setjmp(env); | 15 | rv = SETJMP(env, 0); |
| 16 | 16 | ||
| 17 | /* Mess with the FPU control word. */ | ||
| 18 | if (rv == 0) { | 17 | if (rv == 0) { |
| 18 | fexcept_t flag = FE_OVERFLOW; | ||
| 19 | |||
| 20 | /* Mess with the FPU control word. */ | ||
| 19 | fesetround(FE_DOWNWARD); | 21 | fesetround(FE_DOWNWARD); |
| 20 | fedisableexcept(FE_DIVBYZERO); | 22 | fedisableexcept(FE_DIVBYZERO); |
| 21 | longjmp(env, 1); | 23 | |
| 22 | /* Verify that the FPU control word is preserved. */ | 24 | /* Set the FPU exception flags. */ |
| 25 | fesetexceptflag(&flag, FE_ALL_EXCEPT); | ||
| 26 | |||
| 27 | LONGJMP(env, 1); | ||
| 23 | } else if (rv == 1) { | 28 | } else if (rv == 1) { |
| 29 | fexcept_t flag = 0; | ||
| 30 | |||
| 31 | /* Verify that the FPU control word is preserved. */ | ||
| 24 | if (fegetround() != FE_UPWARD | 32 | if (fegetround() != FE_UPWARD |
| 25 | || fegetexcept() != FE_DIVBYZERO) | 33 | || fegetexcept() != FE_DIVBYZERO) |
| 26 | return (1); | 34 | return (1); |
| 35 | |||
| 36 | /* Verify that the FPU exception flags weren't clobbered. */ | ||
| 37 | fegetexceptflag(&flag, FE_ALL_EXCEPT); | ||
| 38 | if (flag != FE_OVERFLOW) | ||
| 39 | return (1); | ||
| 40 | |||
| 27 | return (0); | 41 | return (0); |
| 28 | /* This is not supposed to happen. */ | ||
| 29 | } else { | ||
| 30 | return (1); | ||
| 31 | } | 42 | } |
| 32 | 43 | ||
| 44 | /* This is not supposed to happen. */ | ||
| 33 | return (1); | 45 | return (1); |
| 34 | } | 46 | } |
diff --git a/src/regress/lib/libc/setjmp-fpu/setjmp.c b/src/regress/lib/libc/setjmp-fpu/setjmp.c new file mode 100644 index 0000000000..04de1df302 --- /dev/null +++ b/src/regress/lib/libc/setjmp-fpu/setjmp.c | |||
| @@ -0,0 +1,5 @@ | |||
| 1 | #define SETJMP(env, savemask) setjmp(env) | ||
| 2 | #define LONGJMP(env, val) longjmp(env, val) | ||
| 3 | #define TEST_SETJMP test_setjmp | ||
| 4 | |||
| 5 | #include "setjmp-fpu.c" | ||
diff --git a/src/regress/lib/libc/setjmp-fpu/sigsetjmp.c b/src/regress/lib/libc/setjmp-fpu/sigsetjmp.c new file mode 100644 index 0000000000..8ba80e2612 --- /dev/null +++ b/src/regress/lib/libc/setjmp-fpu/sigsetjmp.c | |||
| @@ -0,0 +1,5 @@ | |||
| 1 | #define SETJMP(env, savemask) sigsetjmp(env, savemask) | ||
| 2 | #define LONGJMP(env, val) siglongjmp(env, val) | ||
| 3 | #define TEST_SETJMP test_sigsetjmp | ||
| 4 | |||
| 5 | #include "setjmp-fpu.c" | ||
