PR gdb/9346
authorDaniel Jacobowitz <drow@false.org>
Tue, 20 Jan 2009 15:33:14 +0000 (15:33 +0000)
committerDaniel Jacobowitz <drow@false.org>
Tue, 20 Jan 2009 15:33:14 +0000 (15:33 +0000)
* infcmd.c (signal_command): Do not specify a resume PC.

testsuite/
PR gdb/9346
* gdb.base/interrupt.c (sigint_handler): New.
(main): Install a SIGINT handler if SIGNALS is defined.  Exit
on error.
* gdb.base/interrupt.exp: Define SIGNALS unless gdb,nosignals.
Test "signal SIGINT".

gdb/ChangeLog
gdb/infcmd.c
gdb/testsuite/ChangeLog
gdb/testsuite/gdb.base/interrupt.c
gdb/testsuite/gdb.base/interrupt.exp

index 03c1159defba56611f33ce119f188b4252671ba0..a47439034016b964f7d1a25c147bb43bfcee8428 100644 (file)
@@ -1,3 +1,8 @@
+2008-01-20  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       PR gdb/9346
+       * infcmd.c (signal_command): Do not specify a resume PC.
+
 2009-01-19  Doug Evans  <dje@google.com>
 
        * dummy-frame.c (dummy_frame): Replace regcache member with
index 2cd583cdb8744151a58ac782b9859afb877f4760..3696f79b76ae63fe5864d25856467937f4d0340d 100644 (file)
@@ -1145,11 +1145,7 @@ signal_command (char *signum_exp, int from_tty)
     }
 
   clear_proceed_status ();
-  /* "signal 0" should not get stuck if we are stopped at a breakpoint.
-     FIXME: Neither should "signal foo" but when I tried passing
-     (CORE_ADDR)-1 unconditionally I got a testsuite failure which I haven't
-     tried to track down yet.  */
-  proceed (oursig == TARGET_SIGNAL_0 ? (CORE_ADDR) -1 : stop_pc, oursig, 0);
+  proceed ((CORE_ADDR) -1, oursig, 0);
 }
 
 /* Proceed until we reach a different source line with pc greater than
index 052c500dc68792392e12a4111d7816f9965e4e5f..2eb1ee078ff94eeb53567989f547e654d63bb610 100644 (file)
@@ -1,3 +1,12 @@
+2009-01-20  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       PR gdb/9346
+       * gdb.base/interrupt.c (sigint_handler): New.
+       (main): Install a SIGINT handler if SIGNALS is defined.  Exit
+       on error.
+       * gdb.base/interrupt.exp: Define SIGNALS unless gdb,nosignals.
+       Test "signal SIGINT".
+
 2009-01-19  Doug Evans  <dje@google.com>
 
        * gdb.base/break.exp: Update expected gdb output.
index a895d4b7d814adaa868b5f3211fdee1375302602..80b906099e666f00909171e7ab54c9799293c833 100644 (file)
@@ -2,6 +2,16 @@
 #include <stdio.h>
 #include <unistd.h>
 #include <stdlib.h>
+
+#ifdef SIGNALS
+#include <signal.h>
+
+static void
+sigint_handler (int signo)
+{
+}
+#endif
+
 int
 main ()
 {
@@ -10,6 +20,9 @@ main ()
 #ifdef usestubs
   set_debug_traps();
   breakpoint();
+#endif
+#ifdef SIGNALS
+  signal (SIGINT, sigint_handler);
 #endif
   printf ("talk to me baby\n");
   while (1)
@@ -20,7 +33,10 @@ main ()
 #ifdef EINTR
          if (errno != EINTR)
 #endif
-           perror ("");
+           {
+             perror ("");
+             return 1;
+           }
        }
       else if (nbytes == 0)
        {
index 037902b7217c669230b78bf2c12e711fca20493a..beee0cf6b06ec4c19f637395ee591cb1feec1c46 100644 (file)
@@ -34,7 +34,13 @@ set bug_id 0
 set testfile interrupt
 set srcfile ${testfile}.c
 set binfile ${objdir}/${subdir}/${testfile}
-if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
+
+set options { debug }
+if { ! [target_info exists gdb,nosignals] } {
+    lappend options "additional_flags=-DSIGNALS"
+}
+
+if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable $options] != "" } {
      untested interrupt.exp
      return -1
 }
@@ -165,7 +171,35 @@ if ![file exists $binfile] then {
            eof { fail "echo data (eof)" }
        }
 
-       setup_xfail "i*86-pc-linux*-gnu*"
+       if { ! [target_info exists gdb,nosignals] } {
+           # Wait until the program is in the read system call again.
+           sleep 2
+
+           # Stop the program for another test.
+           set msg "Send Control-C, second time"
+           send_gdb "\003"
+           gdb_test_multiple "" "$msg" {
+               -re "Program received signal SIGINT.*$gdb_prompt $" {
+                   pass "$msg"
+               }
+           }
+
+           # The "signal" command should deliver the correct signal and
+           # return to the loop.
+           set msg "signal SIGINT"
+           gdb_test_multiple "signal SIGINT" "$msg" {
+               -re "^signal SIGINT\r\nContinuing with signal SIGINT.\r\n(\r\n|)$" { pass "$msg" }
+           }
+
+           # We should be back in the loop.
+           send_gdb "more data\n"
+           gdb_expect {
+               -re "^(\r\n|)more data\r\n(|more data\r\n)$" { pass "echo more data" }
+               timeout { fail "echo more data (timeout)" }
+               eof { fail "echo more data (eof)" }
+           }
+       }
+
        send_gdb "\004"
        gdb_expect {
            -re "end of file.*Program exited normally.*$gdb_prompt $" {