diff options
author | Roland McGrath <roland@gnu.org> | 2002-04-08 02:16:43 +0000 |
---|---|---|
committer | Roland McGrath <roland@gnu.org> | 2002-04-08 02:16:43 +0000 |
commit | 7ce93726fb9f02c45e45df15d923faabaa8951d3 (patch) | |
tree | 8a3c8ca67f54134b2de37cf6d135042e717288db /sysdeps/mach/hurd/alpha/exc2signal.c | |
parent | 14906e37fed856d51451b5bc2ac3c68d1e29e1a6 (diff) | |
download | glibc-7ce93726fb9f02c45e45df15d923faabaa8951d3.tar.gz glibc-7ce93726fb9f02c45e45df15d923faabaa8951d3.tar.xz glibc-7ce93726fb9f02c45e45df15d923faabaa8951d3.zip |
* mach/setup-thread.c (__mach_setup_thread): int -> natural_t
* sysdeps/mach/hurd/dl-sysdep.c: Use ElfW(TYPE) in place of Elf32_TYPE. (__mmap): Use MAP_FAILED instead of widening __hurd_fail value. * sysdeps/mach/hurd/bind.c: Use prototype definition. * sysdeps/mach/hurd/connect.c: Likewise. * sysdeps/mach/hurd/getsockopt.c: Likewise. * sysdeps/mach/hurd/setsockopt.c: Likewise. * sysdeps/mach/hurd/alpha/sigreturn.c: Pass missing argument to __msg_sig_post RPC. * hurd/catch-exc.c: Use integer_t instead of int. * hurd/hurdfault.c: Likewise. * sysdeps/mach/hurd/alpha/exc2signal.c (_hurd_exception2signal): Rewritten. * sysdeps/mach/hurd/alpha/longjmp-ts.c (_hurd_longjmp_thread_state): Rewritten.
Diffstat (limited to 'sysdeps/mach/hurd/alpha/exc2signal.c')
-rw-r--r-- | sysdeps/mach/hurd/alpha/exc2signal.c | 27 |
1 files changed, 13 insertions, 14 deletions
diff --git a/sysdeps/mach/hurd/alpha/exc2signal.c b/sysdeps/mach/hurd/alpha/exc2signal.c index 3bceb64b22..5f3fbbbbb1 100644 --- a/sysdeps/mach/hurd/alpha/exc2signal.c +++ b/sysdeps/mach/hurd/alpha/exc2signal.c @@ -1,5 +1,5 @@ /* Translate Mach exception codes into signal numbers. Alpha version. - Copyright (C) 1994, 1997 Free Software Foundation, Inc. + Copyright (C) 1994,97,2002 Free Software Foundation, Inc. This file is part of the GNU C Library. The GNU C Library is free software; you can redistribute it and/or @@ -25,52 +25,51 @@ into a signal number and signal subcode. */ void -_hurd_exception2signal (int exception, int code, int subcode, - int *signo, long int *sigcode, int *error) +_hurd_exception2signal (struct hurd_signal_detail *detail, int *signo) { - *error = 0; + detail->error = 0; - switch (exception) + switch (detail->exc) { default: *signo = SIGIOT; - *sigcode = exception; + detail->code = detail->exc; break; case EXC_BAD_ACCESS: - if (code == KERN_PROTECTION_FAILURE) + if (detail->exc_code == KERN_PROTECTION_FAILURE) *signo = SIGSEGV; else *signo = SIGBUS; - *sigcode = subcode; - *error = code; + detail->code = detail->exc_subcode; + detail->error = detail->exc_code; break; case EXC_BAD_INSTRUCTION: *signo = SIGILL; - *sigcode = code; + detail->code = detail->exc_code; break; case EXC_ARITHMETIC: *signo = SIGFPE; - *sigcode = code; + detail->code = detail->exc_code; break; break; case EXC_EMULATION: /* 3.0 doesn't give this one, why, I don't know. */ *signo = SIGEMT; - *sigcode = code; + detail->code = detail->exc_code; break; case EXC_SOFTWARE: *signo = SIGEMT; - *sigcode = code; + detail->code = detail->exc_code; break; case EXC_BREAKPOINT: *signo = SIGTRAP; - *sigcode = code; + detail->code = detail->exc_code; break; } } |