diff options
author | Daniel Jacobowitz <dan@debian.org> | 2003-03-26 20:44:39 +0000 |
---|---|---|
committer | Daniel Jacobowitz <dan@debian.org> | 2003-03-26 20:44:39 +0000 |
commit | dd8ecb1e6f5c9f1ee4be84e17f3b4f12211355bb (patch) | |
tree | d46e471ac49d859dfc95b38cb121169102a803ae /gdb/signals | |
parent | b8b9be228d8e86c9fef922b37818041381e23cf0 (diff) | |
download | gdb-dd8ecb1e6f5c9f1ee4be84e17f3b4f12211355bb.tar.gz |
* signals/signals.c (do_target_signal_to_host): Correct realtime
signal range test.
Diffstat (limited to 'gdb/signals')
-rw-r--r-- | gdb/signals/signals.c | 21 |
1 files changed, 9 insertions, 12 deletions
diff --git a/gdb/signals/signals.c b/gdb/signals/signals.c index ba5e7eac59a..ca46a9ed1c7 100644 --- a/gdb/signals/signals.c +++ b/gdb/signals/signals.c @@ -518,6 +518,8 @@ static int do_target_signal_to_host (enum target_signal oursig, int *oursig_ok) { + int retsig; + *oursig_ok = 1; switch (oursig) { @@ -742,36 +744,31 @@ do_target_signal_to_host (enum target_signal oursig, default: #if defined (REALTIME_LO) - if (oursig < REALTIME_LO || oursig >= REALTIME_HI) - { - *oursig_ok = 0; - return 0; - } + retsig = 0; if (oursig >= TARGET_SIGNAL_REALTIME_33 && oursig <= TARGET_SIGNAL_REALTIME_63) { /* This block of signals is continuous, and TARGET_SIGNAL_REALTIME_33 is 33 by definition. */ - int retsig = - (int) oursig - (int) TARGET_SIGNAL_REALTIME_33 + 33; - return retsig; + retsig = (int) oursig - (int) TARGET_SIGNAL_REALTIME_33 + 33; } else if (oursig == TARGET_SIGNAL_REALTIME_32) { /* TARGET_SIGNAL_REALTIME_32 isn't contiguous with TARGET_SIGNAL_REALTIME_33. It is 32 by definition. */ - return 32; + retsig = 32; } else if (oursig >= TARGET_SIGNAL_REALTIME_64 && oursig <= TARGET_SIGNAL_REALTIME_127) { /* This block of signals is continuous, and TARGET_SIGNAL_REALTIME_64 is 64 by definition. */ - int retsig = - (int) oursig - (int) TARGET_SIGNAL_REALTIME_64 + 64; - return retsig; + retsig = (int) oursig - (int) TARGET_SIGNAL_REALTIME_64 + 64; } + + if (retsig >= REALTIME_LO && retsig < REALTIME_HI) + return retsig; #endif *oursig_ok = 0; |