From: Jan Kratochvil Date: Wed, 13 Jul 2011 17:07:16 +0000 (+0000) Subject: gdb/ X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=67f41397ce652a92b8160eb15de66c33b598a376;p=binutils-gdb.git gdb/ Work around kgdb. * remote.c (remote_get_trace_status): New variable ex. Put remote_get_noisy_reply into TRY_CATCH. Call exception_fprintf for it. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 4062bf9cefb..6d2ee2cfcf0 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2011-07-13 Jan Kratochvil + + Work around kgdb. + * remote.c (remote_get_trace_status): New variable ex. Put + remote_get_noisy_reply into TRY_CATCH. Call exception_fprintf for it. + 2011-07-13 Tom Tromey * dwarf2expr.c (execute_stack_op) : Use diff --git a/gdb/remote.c b/gdb/remote.c index 19cc0b67488..f9059e672d4 100644 --- a/gdb/remote.c +++ b/gdb/remote.c @@ -10045,11 +10045,21 @@ remote_get_trace_status (struct trace_status *ts) char *p; /* FIXME we need to get register block size some other way. */ extern int trace_regblock_size; + volatile struct gdb_exception ex; trace_regblock_size = get_remote_arch_state ()->sizeof_g_packet; putpkt ("qTStatus"); - p = remote_get_noisy_reply (&target_buf, &target_buf_size); + + TRY_CATCH (ex, RETURN_MASK_ERROR) + { + p = remote_get_noisy_reply (&target_buf, &target_buf_size); + } + if (ex.reason < 0) + { + exception_fprintf (gdb_stderr, ex, "qTStatus: "); + return -1; + } /* If the remote target doesn't do tracing, flag it. */ if (*p == '\0')