+2011-07-06 Hui Zhu <teawater@gmail.com>
+
+ * remote.c (remote_start_remote): Add TRY_CATCH for
+ remote_get_trace_status.
+ * tracepoint.c (disconnect_tracing): Ditto.
+
2011-07-05 Tom Tromey <tromey@redhat.com>
* symtab.c (operator_chars): Now static.
struct remote_state *rs = get_remote_state ();
struct packet_config *noack_config;
char *wait_status = NULL;
+ int ret = 0;
+ volatile struct gdb_exception ex;
immediate_quit++; /* Allow user to interrupt it. */
/* Possibly the target has been engaged in a trace run started
previously; find out where things are at. */
- if (remote_get_trace_status (current_trace_status ()) != -1)
+ TRY_CATCH (ex, RETURN_MASK_ERROR)
+ {
+ ret = remote_get_trace_status (current_trace_status ());
+ }
+ if (ex.reason < 0)
+ {
+ warning (_("%s"), ex.message);
+ ret = -1;
+ }
+ if (ret != -1)
{
struct uploaded_tp *uploaded_tps = NULL;
struct uploaded_tsv *uploaded_tsvs = NULL;
void
disconnect_tracing (int from_tty)
{
+ int ret = 0;
+ volatile struct gdb_exception ex;
+
/* It can happen that the target that was tracing went away on its
own, and we didn't notice. Get a status update, and if the
current target doesn't even do tracing, then assume it's not
running anymore. */
- if (target_get_trace_status (current_trace_status ()) < 0)
+ TRY_CATCH (ex, RETURN_MASK_ERROR)
+ {
+ ret = target_get_trace_status (current_trace_status ());
+ }
+ if (ex.reason < 0)
+ {
+ warning (_("%s"), ex.message);
+ ret = -1;
+ }
+ if (ret < 0)
current_trace_status ()->running = 0;
/* If running interactively, give the user the option to cancel and