Add signal number conversions for OpenBSD.
authorMark Kettenis <kettenis@gnu.org>
Wed, 12 Feb 2014 11:08:28 +0000 (12:08 +0100)
committerMark Kettenis <kettenis@gnu.org>
Wed, 12 Feb 2014 11:08:28 +0000 (12:08 +0100)
gdb/ChangeLog:

        * obsd-tdep.h (obsd_init_abi): New prototype.
        * obsd-tdep.c: Define enum with OpenBSD signal numbers.
        (obsd_gdb_signal_from_target, obsd_gdb_signal_to_target)
        (obsd_init_abi): New functions.
        * i386obsd-tdep.c: Include "obsd-tdep.h".
        (i386obsd_init_abi): Call obsd_init_abi.
        * amd64obsd-tdep.c: Include "obsd-tdep.h".
        (amd64obsd_init_abi): Call obsd_init_abi.
        * configure.tgt (i[34567]86-*-openbsd*, x86_64-*-openbsd*): Add
        obsd-tdep.c to gdb_target_obs.

gdb/ChangeLog
gdb/amd64obsd-tdep.c
gdb/configure.tgt
gdb/i386obsd-tdep.c
gdb/obsd-tdep.c
gdb/obsd-tdep.h

index b2cd4513dcb5375acf99da50e0081b1e12e5599e..89ccbe60fcc3f1753790d57765b3c465b069f73b 100644 (file)
@@ -1,3 +1,16 @@
+2014-02-12  Mark Kettenis  <kettenis@gnu.org>
+
+       * obsd-tdep.h (obsd_init_abi): New prototype.
+       * obsd-tdep.c: Define enum with OpenBSD signal numbers.
+       (obsd_gdb_signal_from_target, obsd_gdb_signal_to_target)
+       (obsd_init_abi): New functions.
+       * i386obsd-tdep.c: Include "obsd-tdep.h".
+       (i386obsd_init_abi): Call obsd_init_abi.
+       * amd64obsd-tdep.c: Include "obsd-tdep.h".
+       (amd64obsd_init_abi): Call obsd_init_abi.
+       * configure.tgt (i[34567]86-*-openbsd*, x86_64-*-openbsd*): Add
+       obsd-tdep.c to gdb_target_obs.
+
 2014-02-11  Jose E. Marchesi  <jose.marchesi@oracle.com>
 
         * sparc64-tdep.c (sparc64_store_arguments): Do not align complex
index d9cea9c3a5408635e112e35e59e202a24e6fa0f6..94463180b488e8543054fd863a136cdebdbca490 100644 (file)
@@ -32,6 +32,7 @@
 #include "gdb_assert.h"
 #include <string.h>
 
+#include "obsd-tdep.h"
 #include "amd64-tdep.h"
 #include "i387-tdep.h"
 #include "solib-svr4.h"
@@ -459,6 +460,7 @@ amd64obsd_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch)
   struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
 
   amd64_init_abi (info, gdbarch);
+  obsd_init_abi (info, gdbarch);
 
   /* Initialize general-purpose register set details.  */
   tdep->gregset_reg_offset = amd64obsd_r_reg_offset;
index 7fe0807c418ed94c3f4257eafd20389715e109f6..6706f8455014fad7662be12d7f02ea6894f7fc53 100644 (file)
@@ -199,7 +199,7 @@ i[34567]86-*-netbsd* | i[34567]86-*-knetbsd*-gnu)
 i[34567]86-*-openbsd*)
        # Target: OpenBSD/i386
        gdb_target_obs="i386-tdep.o i387-tdep.o i386bsd-tdep.o i386obsd-tdep.o \
-                       bsd-uthread.o solib-svr4.o"
+                       obsd-tdep.o bsd-uthread.o solib-svr4.o"
        ;;
 i[34567]86-*-nto*)
        # Target: Intel 386 running qnx6.
@@ -685,7 +685,7 @@ x86_64-*-openbsd*)
        # Target: OpenBSD/amd64
        gdb_target_obs="amd64-tdep.o amd64obsd-tdep.o i386-tdep.o \
                        i387-tdep.o i386bsd-tdep.o i386obsd-tdep.o \
-                       bsd-uthread.o solib-svr4.o"
+                       obsd-tdep.o bsd-uthread.o solib-svr4.o"
        ;;
 xtensa*-*-linux*)      gdb_target=linux
        # Target: GNU/Linux Xtensa
index 9868b768e3ca40ec1d2ebe618858145be66a9104..cf19c5007b1939c68058ade48e51f54a5d658f06 100644 (file)
@@ -33,6 +33,7 @@
 #include "gdb_assert.h"
 #include <string.h>
 
+#include "obsd-tdep.h"
 #include "i386-tdep.h"
 #include "i387-tdep.h"
 #include "solib-svr4.h"
@@ -447,6 +448,7 @@ i386obsd_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch)
 
   /* Obviously OpenBSD is BSD-based.  */
   i386bsd_init_abi (info, gdbarch);
+  obsd_init_abi (info, gdbarch);
 
   /* OpenBSD has a different `struct reg'.  */
   tdep->gregset_reg_offset = i386obsd_r_reg_offset;
index 829c1c23f0bf95eb99075e296d04c4d5a654da87..830dd750555c9c183ab487043f2a6a8880ddf329 100644 (file)
@@ -34,3 +34,266 @@ obsd_skip_solib_resolver (struct gdbarch *gdbarch, CORE_ADDR pc)
   else
     return find_solib_trampoline_target (get_current_frame (), pc);
 }
+
+/* OpenBSD signal numbers.  From <sys/signal.h>. */
+
+enum
+  {
+    OBSD_SIGHUP = 1,
+    OBSD_SIGINT = 2,
+    OBSD_SIGQUIT = 3,
+    OBSD_SIGILL = 4,
+    OBSD_SIGTRAP = 5,
+    OBSD_SIGABRT = 6,
+    OBSD_SIGEMT = 7,
+    OBSD_SIGFPE = 8,
+    OBSD_SIGKILL = 9,
+    OBSD_SIGBUS = 10,
+    OBSD_SIGSEGV = 11,
+    OBSD_SIGSYS = 12,
+    OBSD_SIGPIPE = 13,
+    OBSD_SIGALRM = 14,
+    OBSD_SIGTERM = 15,
+    OBSD_SIGURG = 16,
+    OBSD_SIGSTOP = 17,
+    OBSD_SIGTSTP = 18,
+    OBSD_SIGCONT = 19,
+    OBSD_SIGCHLD = 20,
+    OBSD_SIGTTIN = 21,
+    OBSD_SIGTTOU = 22,
+    OBSD_SIGIO = 23,
+    OBSD_SIGXCPU = 24,
+    OBSD_SIGXFSZ = 25,
+    OBSD_SIGVTALRM = 26,
+    OBSD_SIGPROF = 27,
+    OBSD_SIGWINCH = 28,
+    OBSD_SIGINFO = 29,
+    OBSD_SIGUSR1 = 30,
+    OBSD_SIGUSR2 = 31,
+    OBSD_SIGTHR = 32,
+  };
+
+/* Implement the "gdb_signal_from_target" gdbarch method.  */
+
+static enum gdb_signal
+obsd_gdb_signal_from_target (struct gdbarch *gdbarch, int signal)
+{
+  switch (signal)
+    {
+    case 0:
+      return GDB_SIGNAL_0;
+
+    case OBSD_SIGHUP:
+      return GDB_SIGNAL_HUP;
+
+    case OBSD_SIGINT:
+      return GDB_SIGNAL_INT;
+
+    case OBSD_SIGQUIT:
+      return GDB_SIGNAL_QUIT;
+
+    case OBSD_SIGILL:
+      return GDB_SIGNAL_ILL;
+
+    case OBSD_SIGTRAP:
+      return GDB_SIGNAL_TRAP;
+
+    case OBSD_SIGABRT:
+      return GDB_SIGNAL_ABRT;
+
+    case OBSD_SIGEMT:
+      return GDB_SIGNAL_EMT;
+
+    case OBSD_SIGFPE:
+      return GDB_SIGNAL_FPE;
+
+    case OBSD_SIGKILL:
+      return GDB_SIGNAL_KILL;
+
+    case OBSD_SIGBUS:
+      return GDB_SIGNAL_BUS;
+
+    case OBSD_SIGSEGV:
+      return GDB_SIGNAL_SEGV;
+
+    case OBSD_SIGSYS:
+      return GDB_SIGNAL_SYS;
+
+    case OBSD_SIGPIPE:
+      return GDB_SIGNAL_PIPE;
+
+    case OBSD_SIGALRM:
+      return GDB_SIGNAL_ALRM;
+
+    case OBSD_SIGTERM:
+      return GDB_SIGNAL_TERM;
+
+    case OBSD_SIGURG:
+      return GDB_SIGNAL_URG;
+
+    case OBSD_SIGSTOP:
+      return GDB_SIGNAL_STOP;
+
+    case OBSD_SIGTSTP:
+      return GDB_SIGNAL_TSTP;
+
+    case OBSD_SIGCONT:
+      return GDB_SIGNAL_CONT;
+
+    case OBSD_SIGCHLD:
+      return GDB_SIGNAL_CHLD;
+
+    case OBSD_SIGTTIN:
+      return GDB_SIGNAL_TTIN;
+
+    case OBSD_SIGTTOU:
+      return GDB_SIGNAL_TTOU;
+
+    case OBSD_SIGIO:
+      return GDB_SIGNAL_IO;
+
+    case OBSD_SIGXCPU:
+      return GDB_SIGNAL_XCPU;
+
+    case OBSD_SIGXFSZ:
+      return GDB_SIGNAL_XFSZ;
+
+    case OBSD_SIGVTALRM:
+      return GDB_SIGNAL_VTALRM;
+
+    case OBSD_SIGPROF:
+      return GDB_SIGNAL_PROF;
+
+    case OBSD_SIGWINCH:
+      return GDB_SIGNAL_WINCH;
+
+    case OBSD_SIGINFO:
+      return GDB_SIGNAL_INFO;
+
+    case OBSD_SIGUSR1:
+      return GDB_SIGNAL_USR1;
+
+    case OBSD_SIGUSR2:
+      return GDB_SIGNAL_USR2;
+    }
+
+  return GDB_SIGNAL_UNKNOWN;
+}
+
+/* Implement the "gdb_signal_to_target" gdbarch method.  */
+
+static int
+obsd_gdb_signal_to_target (struct gdbarch *gdbarch,
+                          enum gdb_signal signal)
+{
+  switch (signal)
+    {
+    case GDB_SIGNAL_0:
+      return 0;
+
+    case GDB_SIGNAL_HUP:
+      return OBSD_SIGHUP;
+
+    case GDB_SIGNAL_INT:
+      return OBSD_SIGINT;
+
+    case GDB_SIGNAL_QUIT:
+      return OBSD_SIGQUIT;
+
+    case GDB_SIGNAL_ILL:
+      return OBSD_SIGILL;
+
+    case GDB_SIGNAL_TRAP:
+      return OBSD_SIGTRAP;
+
+    case GDB_SIGNAL_ABRT:
+      return OBSD_SIGABRT;
+
+    case GDB_SIGNAL_EMT:
+      return OBSD_SIGEMT;
+
+    case GDB_SIGNAL_FPE:
+      return OBSD_SIGFPE;
+
+    case GDB_SIGNAL_KILL:
+      return OBSD_SIGKILL;
+
+    case GDB_SIGNAL_BUS:
+      return OBSD_SIGBUS;
+
+    case GDB_SIGNAL_SEGV:
+      return OBSD_SIGSEGV;
+
+    case GDB_SIGNAL_SYS:
+      return OBSD_SIGSYS;
+
+    case GDB_SIGNAL_PIPE:
+      return OBSD_SIGPIPE;
+
+    case GDB_SIGNAL_ALRM:
+      return OBSD_SIGALRM;
+
+    case GDB_SIGNAL_TERM:
+      return OBSD_SIGTERM;
+
+    case GDB_SIGNAL_URG:
+      return OBSD_SIGURG;
+
+    case GDB_SIGNAL_STOP:
+      return OBSD_SIGSTOP;
+
+    case GDB_SIGNAL_TSTP:
+      return OBSD_SIGTSTP;
+
+    case GDB_SIGNAL_CONT:
+      return OBSD_SIGCONT;
+
+    case GDB_SIGNAL_CHLD:
+      return OBSD_SIGCHLD;
+
+    case GDB_SIGNAL_TTIN:
+      return OBSD_SIGTTIN;
+
+    case GDB_SIGNAL_TTOU:
+      return OBSD_SIGTTOU;
+
+    case GDB_SIGNAL_IO:
+      return OBSD_SIGIO;
+
+    case GDB_SIGNAL_XCPU:
+      return OBSD_SIGXCPU;
+
+    case GDB_SIGNAL_XFSZ:
+      return OBSD_SIGXFSZ;
+
+    case GDB_SIGNAL_VTALRM:
+      return OBSD_SIGVTALRM;
+
+    case GDB_SIGNAL_PROF:
+      return OBSD_SIGPROF;
+
+    case GDB_SIGNAL_WINCH:
+      return OBSD_SIGWINCH;
+
+    case GDB_SIGNAL_USR1:
+      return OBSD_SIGUSR1;
+
+    case GDB_SIGNAL_USR2:
+      return OBSD_SIGUSR2;
+
+    case GDB_SIGNAL_INFO:
+      return OBSD_SIGINFO;
+    }
+
+  return -1;
+}
+
+
+void
+obsd_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch)
+{
+  set_gdbarch_gdb_signal_from_target (gdbarch,
+                                     obsd_gdb_signal_from_target);
+  set_gdbarch_gdb_signal_to_target (gdbarch,
+                                   obsd_gdb_signal_to_target);
+}
index 24e380e2937e71a2a1bd43c78d25b9bdb229e12f..0f89277282ae54f1ffa884b8b10496da64915165 100644 (file)
@@ -23,5 +23,6 @@
 struct gdbarch;
 
 CORE_ADDR obsd_skip_solib_resolver (struct gdbarch *, CORE_ADDR);
+void obsd_init_abi (struct gdbarch_info, struct gdbarch *);
 
 #endif /* obsd-tdep.h */