aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
Diffstat (limited to 'gdb')
-rw-r--r--gdb/gdbserver/ChangeLog6
-rw-r--r--gdb/gdbserver/server.c15
2 files changed, 13 insertions, 8 deletions
diff --git a/gdb/gdbserver/ChangeLog b/gdb/gdbserver/ChangeLog
index 0af0bb8..f050bfa 100644
--- a/gdb/gdbserver/ChangeLog
+++ b/gdb/gdbserver/ChangeLog
@@ -1,3 +1,9 @@
+2013-05-24 Pedro Alves <palves@redhat.com>
+
+ * server.c (handle_v_cont) <vCont;r>: Use unpack_varlen_hex
+ instead of strchr/decode_address. Error if the range isn't split
+ with a ','. Don't assume there's be a ':' in the action.
+
2013-05-23 Yao Qi <yao@codesourcery.com>
Pedro Alves <palves@redhat.com>
diff --git a/gdb/gdbserver/server.c b/gdb/gdbserver/server.c
index 1083aa9..d9daf84 100644
--- a/gdb/gdbserver/server.c
+++ b/gdb/gdbserver/server.c
@@ -2069,17 +2069,16 @@ handle_v_cont (char *own_buf)
}
else if (p[0] == 'r')
{
- char *p1;
+ ULONGEST addr;
- p = p + 1;
- p1 = strchr (p, ',');
- decode_address (&resume_info[i].step_range_start, p, p1 - p);
+ p = unpack_varlen_hex (p + 1, &addr);
+ resume_info[i].step_range_start = addr;
- p = p1 + 1;
- p1 = strchr (p, ':');
- decode_address (&resume_info[i].step_range_end, p, p1 - p);
+ if (*p != ',')
+ goto err;
- p = p1;
+ p = unpack_varlen_hex (p + 1, &addr);
+ resume_info[i].step_range_end = addr;
}
else
{