mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-11-27 03:51:15 +08:00
c9737c08e7
The other day while debugging something related to random signals, I got confused with "set debug infrun 1" output, for it said: infrun: TARGET_WAITKIND_STOPPED infrun: stop_pc = 0x323d4e8b94 infrun: random signal 20 On GNU/Linux, 20 is SIGTSTP. For some reason, it took me a few minutes to realize that 20 is actually a GDB signal number, not a target signal number (duh!). In any case, I propose making GDB's output clearer here: One way would be to use gdb_signal_to_name, like already used elsewhere: infrun: TARGET_WAITKIND_STOPPED infrun: stop_pc = 0x323d4e8b94 infrun: random signal SIGCHLD (20) but I think that might confuse someone too ("20? Why does GDB believe SIGCHLD is 20?"). So I thought of printing the enum string instead: infrun: TARGET_WAITKIND_STOPPED infrun: stop_pc = 0x323d4e8b94 infrun: random signal GDB_SIGNAL_CHLD (20) Looking at a more complete infrun debug log, we had actually printed the (POSIX) signal name name a bit before: infrun: target_wait (-1, status) = infrun: 9300 [Thread 0x7ffff7fcb740 (LWP 9300)], infrun: status->kind = stopped, signal = SIGCHLD ... infrun: TARGET_WAITKIND_STOPPED infrun: stop_pc = 0x323d4e8b94 infrun: random signal 20 So I'm now thinking that it'd be even better to make infrun output consistently use the enum symbol string, like so: infrun: clear_proceed_status_thread (Thread 0x7ffff7fca700 (LWP 25663)) infrun: clear_proceed_status_thread (Thread 0x7ffff7fcb740 (LWP 25659)) - infrun: proceed (addr=0xffffffffffffffff, signal=144, step=1) + infrun: proceed (addr=0xffffffffffffffff, signal=GDB_SIGNAL_DEFAULT, step=1) - infrun: resume (step=1, signal=0), trap_expected=0, current thread [Thread 0x7ffff7fcb740 (LWP 25659)] at 0x400700 + infrun: resume (step=1, signal=GDB_SIGNAL_0), trap_expected=0, current thread [Thread 0x7ffff7fcb740 (LWP 25659)] at 0x400700 infrun: wait_for_inferior () infrun: target_wait (-1, status) = infrun: 25659 [Thread 0x7ffff7fcb740 (LWP 25659)], - infrun: status->kind = stopped, signal = SIGCHLD + infrun: status->kind = stopped, signal = GDB_SIGNAL_CHLD infrun: infwait_normal_state infrun: TARGET_WAITKIND_STOPPED infrun: stop_pc = 0x400700 - infrun: random signal 20 + infrun: random signal (GDB_SIGNAL_CHLD) infrun: random signal, keep going - infrun: resume (step=1, signal=20), trap_expected=0, current thread [Thread 0x7ffff7fcb740 (LWP 25659)] at 0x400700 + infrun: resume (step=1, signal=GDB_SIGNAL_CHLD), trap_expected=0, current thread [Thread 0x7ffff7fcb740 (LWP 25659)] at 0x400700 infrun: prepare_to_wait infrun: target_wait (-1, status) = infrun: 25659 [Thread 0x7ffff7fcb740 (LWP 25659)], - infrun: status->kind = stopped, signal = SIGTRAP + infrun: status->kind = stopped, signal = GDB_SIGNAL_TRAP infrun: infwait_normal_state infrun: TARGET_WAITKIND_STOPPED infrun: stop_pc = 0x400704 infrun: stepi/nexti infrun: stop_stepping GDB's signal numbers are public and hardcoded (see include/gdb/signals.h), so there's really no need to clutter the output with numeric values in some places while others not. Replacing the magic "144" with GDB_SIGNAL_DEFAULT in "proceed"'s debug output (see above) I think is quite nice. I posit that all this makes it clearer to newcomers that GDB has its own signal numbering (and that there must be some mapping going on). Tested on x86_64 Fedora 17. gdb/ 2013-10-23 Pedro Alves <palves@redhat.com> * common/gdb_signals.h (gdb_signal_to_symbol_string): Declare. * common/signals.c: Include "gdb_assert.h". (signals): New field 'symbol'. (SET): Use the 'symbol' parameter. (gdb_signal_to_symbol_string): New function. * infrun.c (handle_inferior_event) <random signal>: In debug output, print the random signal enum as string in addition to its number. * target/waitstatus.c (target_waitstatus_to_string): Print the signal's enum value as string instead of the (POSIX) signal name.
75 lines
2.5 KiB
C
75 lines
2.5 KiB
C
/* Target waitstatus implementations.
|
|
|
|
Copyright (C) 1990-2013 Free Software Foundation, Inc.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
#ifdef GDBSERVER
|
|
#include "server.h"
|
|
#else
|
|
#include "defs.h"
|
|
#endif
|
|
|
|
#include "waitstatus.h"
|
|
|
|
/* Return a pretty printed form of target_waitstatus.
|
|
Space for the result is malloc'd, caller must free. */
|
|
|
|
char *
|
|
target_waitstatus_to_string (const struct target_waitstatus *ws)
|
|
{
|
|
const char *kind_str = "status->kind = ";
|
|
|
|
switch (ws->kind)
|
|
{
|
|
case TARGET_WAITKIND_EXITED:
|
|
return xstrprintf ("%sexited, status = %d",
|
|
kind_str, ws->value.integer);
|
|
case TARGET_WAITKIND_STOPPED:
|
|
return xstrprintf ("%sstopped, signal = %s",
|
|
kind_str,
|
|
gdb_signal_to_symbol_string (ws->value.sig));
|
|
case TARGET_WAITKIND_SIGNALLED:
|
|
return xstrprintf ("%ssignalled, signal = %s",
|
|
kind_str,
|
|
gdb_signal_to_symbol_string (ws->value.sig));
|
|
case TARGET_WAITKIND_LOADED:
|
|
return xstrprintf ("%sloaded", kind_str);
|
|
case TARGET_WAITKIND_FORKED:
|
|
return xstrprintf ("%sforked", kind_str);
|
|
case TARGET_WAITKIND_VFORKED:
|
|
return xstrprintf ("%svforked", kind_str);
|
|
case TARGET_WAITKIND_EXECD:
|
|
return xstrprintf ("%sexecd", kind_str);
|
|
case TARGET_WAITKIND_VFORK_DONE:
|
|
return xstrprintf ("%svfork-done", kind_str);
|
|
case TARGET_WAITKIND_SYSCALL_ENTRY:
|
|
return xstrprintf ("%sentered syscall", kind_str);
|
|
case TARGET_WAITKIND_SYSCALL_RETURN:
|
|
return xstrprintf ("%sexited syscall", kind_str);
|
|
case TARGET_WAITKIND_SPURIOUS:
|
|
return xstrprintf ("%sspurious", kind_str);
|
|
case TARGET_WAITKIND_IGNORE:
|
|
return xstrprintf ("%signore", kind_str);
|
|
case TARGET_WAITKIND_NO_HISTORY:
|
|
return xstrprintf ("%sno-history", kind_str);
|
|
case TARGET_WAITKIND_NO_RESUMED:
|
|
return xstrprintf ("%sno-resumed", kind_str);
|
|
default:
|
|
return xstrprintf ("%sunknown???", kind_str);
|
|
}
|
|
}
|