]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
sim: d10v: fix signal updates
authorMike Frysinger <vapier@gentoo.org>
Fri, 3 Apr 2015 00:15:43 +0000 (20:15 -0400)
committerMike Frysinger <vapier@gentoo.org>
Fri, 3 Apr 2015 00:40:11 +0000 (20:40 -0400)
Way back in aba6488e0b73756f31f154d12a228baa82a68d8a, a bunch of signal
defines were changed to TARGET_SIGNAL_xxx.  For d10v, the transition was
incomplete which lead to sim_stop_reason using the new set but sim_resume
still using the old set.  Which meant in some cases, the sim would never
actually stop.

Convert all the remaining SIGxxx defines in here to TARGET_SIGNAL_xxx.
This has the nice side effect of fixing the testsuite.

sim/d10v/ChangeLog
sim/d10v/interp.c

index e34b91888dc19cfaaa47216dc77b47783e110b00..e09a14f22f235dff1d33f1a416e920f4a2fc4641 100644 (file)
@@ -1,3 +1,9 @@
+2015-04-02  Mike Frysinger  <vapier@gentoo.org>
+
+       * interp.c (lookup_hash): Change SIGILL to GDB_SIGNAL_ILL.
+       (sim_resume): Change SIGBUS/SIGSEGV to GDB_SIGNAL_BUS, SIGILL to
+       GDB_SIGNAL_ILL, and SIGTRAP to GDB_SIGNAL_TRAP.
+
 2015-04-01  Mike Frysinger  <vapier@gentoo.org>
 
        * interp.c (sim_set_profile, sim_set_profile_size): Delete.
index 1aae3e40deb9513df26c20224e0a5c2757e4969c..7fc0745e35bd8c3c0fe0cda719158c9fbf5c7765 100644 (file)
@@ -80,7 +80,7 @@ lookup_hash (uint32 ins, int size)
     {
       if (h->next == NULL)
        {
-         State.exception = SIGILL;
+         State.exception = GDB_SIGNAL_ILL;
          State.pc_changed = 1; /* Don't increment the PC. */
          return NULL;
        }
@@ -936,17 +936,14 @@ sim_resume (SIM_DESC sd, int step, int siggnal)
     {
     case 0:
       break;
-#ifdef SIGBUS
-    case SIGBUS:
-#endif
-    case SIGSEGV:
+    case GDB_SIGNAL_BUS:
       SET_BPC (PC);
       SET_BPSW (PSW);
       SET_HW_PSW ((PSW & (PSW_F0_BIT | PSW_F1_BIT | PSW_C_BIT)));
       JMP (AE_VECTOR_START);
       SLOT_FLUSH ();
       break;
-    case SIGILL:
+    case GDB_SIGNAL_ILL:
       SET_BPC (PC);
       SET_BPSW (PSW);
       SET_HW_PSW ((PSW & (PSW_F0_BIT | PSW_F1_BIT | PSW_C_BIT)));
@@ -963,7 +960,7 @@ sim_resume (SIM_DESC sd, int step, int siggnal)
       iaddr = imem_addr ((uint32)PC << 2);
       if (iaddr == State.mem.fault)
        {
-         State.exception = SIGBUS;
+         State.exception = GDB_SIGNAL_BUS;
          break;
        }
  
@@ -1035,7 +1032,7 @@ sim_resume (SIM_DESC sd, int step, int siggnal)
   while ( !State.exception && !stop_simulator);
   
   if (step && !State.exception)
-    State.exception = SIGTRAP;
+    State.exception = GDB_SIGNAL_TRAP;
 }
 
 void