(TRAP_REMOVE_SYSCALL_FLAG): New macro.
authorDoug Evans <dje@google.com>
Mon, 28 Sep 2009 21:09:15 +0000 (21:09 +0000)
committerDoug Evans <dje@google.com>
Mon, 28 Sep 2009 21:09:15 +0000 (21:09 +0000)
(linux_nat_wait_1): Mask off is-syscall bit in wait status for
TRAP_IS_SYSCALL before passing value to caller.

gdb/ChangeLog
gdb/linux-nat.c

index 347582829d120b40a85cca26e3ccd72d1f4e1316..06271505dad1a3bf5205da55909cdc48fb712d32 100644 (file)
@@ -1,6 +1,9 @@
 2009-09-28  Doug Evans  <dje@google.com>
 
        * linux-nat.c (status_to_str): Handle TRAP_IS_SYSCALL.
+       (TRAP_REMOVE_SYSCALL_FLAG): New macro.
+       (linux_nat_wait_1): Mask off is-syscall bit in wait status for
+       TRAP_IS_SYSCALL before passing value to caller.
 
 2009-09-28  Ulrich Weigand  <uweigand@de.ibm.com>
 
index 48affdb1ffef33c4b1e85ea45ec6b3367c59000f..9b8cf480866edf8f877b3671d6bd329a78eb92a7 100644 (file)
@@ -70,6 +70,7 @@
 /* To be used when one needs to know wether a
    WSTOPSIG (status) is a syscall */
 #define TRAP_IS_SYSCALL (SIGTRAP | 0x80)
+#define TRAP_REMOVE_SYSCALL_FLAG(status) ((status) & ~(0x80 << 8))
 
 /* This comment documents high-level logic of this file. 
 
@@ -3012,6 +3013,12 @@ retry:
 
          lp = linux_nat_filter_event (lwpid, status, options);
 
+         /* If this was a syscall trap, we no longer need or want
+            the 0x80 flag, remove it.  */
+         if (WIFSTOPPED (status)
+             && WSTOPSIG (status) == TRAP_IS_SYSCALL)
+           status = TRAP_REMOVE_SYSCALL_FLAG (status);
+
          if (lp
              && ptid_is_pid (ptid)
              && ptid_get_pid (lp->ptid) != ptid_get_pid (ptid))