diff options
author | Theo de Raadt <deraadt@cvs.openbsd.org> | 1997-04-01 20:14:44 +0000 |
---|---|---|
committer | Theo de Raadt <deraadt@cvs.openbsd.org> | 1997-04-01 20:14:44 +0000 |
commit | bad5c14300f84cd21de1a78a942bdf2660441abf (patch) | |
tree | 3db0ad36fffe4b820b2ac5291cf5ece4725750a3 /sys/arch/sparc | |
parent | 5924810f0db8b0465a2153b8dfe075a9ae0e05cc (diff) |
svr4 siginfo; I cannot test this
Diffstat (limited to 'sys/arch/sparc')
-rw-r--r-- | sys/arch/sparc/sparc/svr4_machdep.c | 174 |
1 files changed, 75 insertions, 99 deletions
diff --git a/sys/arch/sparc/sparc/svr4_machdep.c b/sys/arch/sparc/sparc/svr4_machdep.c index 859362405fc..0100d8bf9bb 100644 --- a/sys/arch/sparc/sparc/svr4_machdep.c +++ b/sys/arch/sparc/sparc/svr4_machdep.c @@ -53,7 +53,7 @@ #include <machine/trap.h> #include <machine/svr4_machdep.h> -static void svr4_getsiginfo __P((union svr4_siginfo *, int, u_long, caddr_t)); +static void svr4_getsiginfo __P((union svr4_siginfo *, int, u_long, int, caddr_t)); #ifdef DEBUG extern int sigdebug; @@ -330,13 +330,14 @@ svr4_setcontext(p, uc) } /* - * map the trap code into the svr4 siginfo as best we can + * map the native sig/type code into the svr4 siginfo as best we can */ static void -svr4_getsiginfo(si, sig, code, addr) +svr4_getsiginfo(si, sig, code, type, addr) union svr4_siginfo *si; int sig; u_long code; + int type; caddr_t addr; { si->svr4_si_signo = bsd_to_svr4_sig[sig]; @@ -348,106 +349,81 @@ svr4_getsiginfo(si, sig, code, addr) */ si->svr4_si_trap = code; - switch (code) { - case T_RESET: - si->svr4_si_code = 0; - break; - - case T_TEXTFAULT: - si->svr4_si_code = SVR4_BUS_ADRALN; - break; - - case T_ILLINST: - si->svr4_si_code = SVR4_ILL_ILLOPC; - break; - - case T_PRIVINST: - si->svr4_si_code = SVR4_ILL_PRVOPC; - break; - - case T_FPDISABLED: - si->svr4_si_code = SVR4_FPE_FLTINV; - break; - - case T_ALIGN: - si->svr4_si_code = SVR4_BUS_ADRALN; - break; - - case T_FPE: - si->svr4_si_code = SVR4_FPE_FLTINV; - break; - - case T_DATAFAULT: - si->svr4_si_code = SVR4_BUS_ADRALN; - break; - - case T_TAGOF: - si->svr4_si_code = SVR4_EMT_TAGOVF; - break; - - case T_CPDISABLED: - si->svr4_si_code = SVR4_FPE_FLTINV; - break; - - case T_CPEXCEPTION: - si->svr4_si_code = SVR4_FPE_FLTINV; - break; - - case T_DIV0: - si->svr4_si_code = SVR4_FPE_INTDIV; + si->svr4_si_code = 0; + si->svr4_si_trap = 0; + + switch (sig) { + case SIGSEGV: + switch (type) { + case SEGV_ACCERR: + si->svr4_si_code = SVR4_SEGV_ACCERR; + si->svr4_si_trap = SVR4_T_PROTFLT; + break; + case SEGV_MAPERR: + si->svr4_si_code = SVR4_SEGV_MAPERR; + si->svr4_si_trap = SVR4_T_SEGNPFLT; + break; + } break; - - case T_INTOF: - si->svr4_si_code = SVR4_FPE_INTOVF; + case SIGBUS: + switch (type) { + case BUS_ADRALN: + si->svr4_si_code = SVR4_BUS_ADRALN; + si->svr4_si_trap = SVR4_T_ALIGNFLT; + break; + } break; - - case T_BREAKPOINT: - si->svr4_si_code = SVR4_TRAP_BRKPT; + case SIGTRAP: + switch (type) { + case TRAP_BRKPT: + si->svr4_si_code = SVR4_TRAP_BRKPT; + si->svr4_si_trap = SVR4_T_BPTFLT; + break; + case TRAP_TRACE: + si->svr4_si_code = SVR4_TRAP_TRACE; + si->svr4_si_trap = SVR4_T_TRCTRAP; + break; + } break; - - /* - * XXX - hardware traps with unknown code - */ - case T_WINOF: - case T_WINUF: - case T_L1INT: - case T_L2INT: - case T_L3INT: - case T_L4INT: - case T_L5INT: - case T_L6INT: - case T_L7INT: - case T_L8INT: - case T_L9INT: - case T_L10INT: - case T_L11INT: - case T_L12INT: - case T_L13INT: - case T_L14INT: - case T_L15INT: - si->svr4_si_code = 0; + case SIGEMT: + switch (type) { + } break; - - /* - * XXX - software traps with unknown code - */ - case T_SUN_SYSCALL: - case T_FLUSHWIN: - case T_CLEANWIN: - case T_RANGECHECK: - case T_FIXALIGN: - case T_SVR4_SYSCALL: - case T_BSD_SYSCALL: - case T_KGDB_EXEC: - si->svr4_si_code = 0; + case SIGILL: + switch (type) { + case ILL_PRVOPC: + si->svr4_si_code = SVR4_ILL_PRVOPC; + si->svr4_si_trap = SVR4_T_PRIVINFLT; + break; + case ILL_BADSTK: + si->svr4_si_code = SVR4_ILL_BADSTK; + si->svr4_si_trap = SVR4_T_STKFLT; + break; + } break; - - default: - si->svr4_si_code = 0; -#ifdef DIAGNOSTIC - printf("sig %d code %ld\n", sig, code); - panic("svr4_getsiginfo"); -#endif + case SIGFPE: + switch (type) { + case FPE_INTOVF: + si->svr4_si_code = SVR4_FPE_INTOVF; + si->svr4_si_trap = SVR4_T_DIVIDE; + break; + case FPE_FLTDIV: + si->svr4_si_code = SVR4_FPE_FLTDIV; + si->svr4_si_trap = SVR4_T_DIVIDE; + break; + case FPE_FLTOVF: + si->svr4_si_code = SVR4_FPE_FLTOVF; + si->svr4_si_trap = SVR4_T_DIVIDE; + break; + case FPE_FLTSUB: + si->svr4_si_code = SVR4_FPE_FLTSUB; + si->svr4_si_trap = SVR4_T_BOUND; + break; + case FPE_FLTINV: + si->svr4_si_code = SVR4_FPE_FLTINV; + si->svr4_si_trap = SVR4_T_FPOPFLT; + break; + } break; } } @@ -501,7 +477,7 @@ svr4_sendsig(catcher, sig, mask, code, type, val) /* * Build the argument list for the signal handler. */ - svr4_getsiginfo(&frame.sf_si, sig, code, val.sival_ptr); + svr4_getsiginfo(&frame.sf_si, sig, code, type, val.sival_ptr); svr4_getcontext(p, &frame.sf_uc, mask, oonstack); frame.sf_signum = frame.sf_si.svr4_si_signo; frame.sf_sip = &fp->sf_si; |