]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Fix exc2signal.c template
authorSamuel Thibault <samuel.thibault@ens-lyon.org>
Tue, 20 Sep 2016 19:58:36 +0000 (21:58 +0200)
committerSamuel Thibault <samuel.thibault@ens-lyon.org>
Tue, 20 Sep 2016 19:58:36 +0000 (21:58 +0200)
As a follow-up to 0e3426bbcf2ff61d06d580fc9362fde79953a281

* hurd/exc2signal.c: #include <hurd/signal.h>
(_hurd_exception2signal): Replace 'exception', 'code', 'subcode',
'sigcode', 'error' parameters with 'detail' parameter.  Fix code
accordingly.

ChangeLog
hurd/exc2signal.c

index 338777b9c6d4141c3d8584716b3cee1dbc312cbc..7f960669a7d3c73f0dc8222777807ff75cd3774c 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2016-09-20  Samuel Thibault  <samuel.thibault@ens-lyon.org>
+
+       * hurd/exc2signal.c: #include <hurd/signal.h>
+       (_hurd_exception2signal): Replace 'exception', 'code', 'subcode',
+       'sigcode', 'error' parameters with 'detail' parameter.  Fix code
+       accordingly.
+
 2016-09-20  Paul E. Murphy  <murphyp@linux.vnet.ibm.com>
 
        * math/Makefile (libm-calls): Remove s_nanF.
index 3a2ec0812410d4f51facf9b7496c910a2ab1fe42..2527d83bf19cd0b8a4e9920ba6caf33a313903d9 100644 (file)
@@ -17,6 +17,7 @@
    <http://www.gnu.org/licenses/>.  */
 
 #include <hurd.h>
+#include <hurd/signal.h>
 
 /* This file must be modified with machine-dependent details.  */
 #error "need to write sysdeps/mach/hurd/MACHINE/exc2signal.c"
    into a signal number and signal subcode.  */
 
 void
-_hurd_exception2signal (int exception, int code, int subcode,
-                       int *signo, 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 = 0;
+      detail->code = 0;
       break;
 
     case EXC_ARITHMETIC:
       *signo = SIGFPE;
-      *sigcode = 0;
+      detail->code = 0;
       break;
 
     case EXC_EMULATION:
     case EXC_SOFTWARE:
       *signo = SIGEMT;
-      *sigcode = 0;
+      detail->code = 0;
       break;
 
     case EXC_BREAKPOINT:
       *signo = SIGTRAP;
-      *sigcode = 0;
+      detail->code = 0;
       break;
     }
 }