aboutsummaryrefslogtreecommitdiff
path: root/libjava/include
diff options
context:
space:
mode:
authorDavid Daney <ddaney@avtrex.com>2006-11-20 19:49:08 +0000
committerDavid Daney <daney@gcc.gnu.org>2006-11-20 19:49:08 +0000
commit9e0881604966a3cdc06db1b06630b0ce2fd5da2e (patch)
tree0b8b10e14ec8c024d773738fd4cddb0142e18a7e /libjava/include
parente9057fe4ee3c43a4f89d75dd104230f46103c1a6 (diff)
downloadgcc-9e0881604966a3cdc06db1b06630b0ce2fd5da2e.zip
gcc-9e0881604966a3cdc06db1b06630b0ce2fd5da2e.tar.gz
gcc-9e0881604966a3cdc06db1b06630b0ce2fd5da2e.tar.bz2
mips-signal.h (sys/syscall.h): Do not include.
2006-11-20 David Daney <ddaney@avtrex.com> * include/mips-signal.h (sys/syscall.h): Do not include. (sig_ucontext_t): Removed. (MAKE_THROW_FRAME): Changed to be a nop. (_INIT_SIG_HANDLER): New macro. (INIT_SEGV): Rewrote to use _INIT_SIG_HANDLER. (INIT_FPE): Same. 2006-11-20 David Daney <ddaney@avtrex.com> * config/mips/linux-unwind.h (mips_fallback_frame_state): Adjust PC to point to following instruction. From-SVN: r119024
Diffstat (limited to 'libjava/include')
-rw-r--r--libjava/include/mips-signal.h46
1 files changed, 6 insertions, 40 deletions
diff --git a/libjava/include/mips-signal.h b/libjava/include/mips-signal.h
index 63218ea..478e3a4 100644
--- a/libjava/include/mips-signal.h
+++ b/libjava/include/mips-signal.h
@@ -18,65 +18,31 @@ details. */
#include <signal.h>
#include <unistd.h>
-#include <sys/syscall.h>
-/* #include <asm/ucontext.h> structures we use are here but clash with
- sys/ucontext.h included by java-signal.h from prims.cc */
#define HANDLE_SEGV 1
#define HANDLE_FPE 1
-/* The third parameter to the signal handler points to something with
- * this structure defined in asm/ucontext.h, but the name clashes with
- * struct ucontext from sys/ucontext.h so this private copy is used. */
-typedef struct _sig_ucontext {
- unsigned long uc_flags;
- struct _sig_ucontext *uc_link;
- stack_t uc_stack;
- struct sigcontext uc_mcontext;
- sigset_t uc_sigmask;
-} sig_ucontext_t;
-
#define SIGNAL_HANDLER(_name) \
static void _name (int _dummy __attribute__ ((__unused__)), \
siginfo_t *_info __attribute__ ((__unused__)), \
void *_arg __attribute__ ((__unused__)))
-/*
- * MIPS leaves pc pointing at the faulting instruction, but the
- * unwinder expects it to point to the following instruction
- */
-
-#define MAKE_THROW_FRAME(_exception) \
-do \
-{ \
- ((sig_ucontext_t *)_arg)->uc_mcontext.sc_pc += 4; \
- (void)_dummy; \
- (void)_info; \
-} \
-while (0)
+#define MAKE_THROW_FRAME(_exception)
-#define INIT_SEGV \
+#define _INIT_SIG_HANDLER(_SIG, _ACTION) \
do \
{ \
struct sigaction act; \
- act.sa_sigaction = catch_segv; \
+ act.sa_sigaction = _ACTION; \
act.sa_flags = SA_SIGINFO | SA_NODEFER; \
sigemptyset (&act.sa_mask); \
- sigaction(SIGSEGV, &act, NULL); \
+ sigaction(_SIG, &act, NULL); \
} \
while (0)
-#define INIT_FPE \
-do \
- { \
- struct sigaction act; \
- act.sa_sigaction = catch_fpe; \
- act.sa_flags = SA_SIGINFO | SA_NODEFER; \
- sigemptyset (&act.sa_mask); \
- sigaction(SIGFPE, &act, NULL); \
- } \
-while (0)
+#define INIT_SEGV _INIT_SIG_HANDLER (SIGSEGV, catch_segv)
+#define INIT_FPE _INIT_SIG_HANDLER (SIGFPE, catch_fpe)
#undef HANDLE_DIVIDE_OVERFLOW
#endif /* JAVA_SIGNAL_H */