diff options
author | Yao Qi <yao@codesourcery.com> | 2013-08-15 09:09:08 +0800 |
---|---|---|
committer | Yao Qi <yao@codesourcery.com> | 2013-12-02 14:44:14 +0800 |
commit | 62972e0b66f4247f56c795ee55bc0825933a7bed (patch) | |
tree | eda7005f3e1f7abcee6f0410243df61edecbd018 /gdb | |
parent | f9b0da3d5833ad5f809422f3084b0ef8fa5c5762 (diff) | |
download | binutils-62972e0b66f4247f56c795ee55bc0825933a7bed.zip binutils-62972e0b66f4247f56c795ee55bc0825933a7bed.tar.gz binutils-62972e0b66f4247f56c795ee55bc0825933a7bed.tar.bz2 |
Fix PR remote/15974
In remote-notif.c:handle_notification, we have a loop,
for (i = 0; i < ARRAY_SIZE (notifs); i++)
{
nc = notifs[i];
if (strncmp (buf, nc->name, strlen (nc->name)) == 0
&& buf[strlen (nc->name)] == ':')
break;
}
/* We ignore notifications we don't recognize, for compatibility
with newer stubs. */
if (nc == NULL)
return;
If the notification is not in the list 'notifs', the last entry is
used, which is wrong. It should be NULL. This patch fixes it.
gdb:
2013-12-02 Pedro Alves <palves@redhat.com>
PR remote/15974
* remote-notif.c (handle_notification): Return early if no
notification is found.
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 6 | ||||
-rw-r--r-- | gdb/remote-notif.c | 15 |
2 files changed, 15 insertions, 6 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 62abbac..e7998b9 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2013-12-02 Pedro Alves <palves@redhat.com> + + PR remote/15974 + * remote-notif.c (handle_notification): Return early if no + notification is found. + 2013-12-02 Joel Brobecker <brobecker@adacore.com> * common/filestuff.c (fdwalk): Add "defined(RLIMIT_NOFILE)" diff --git a/gdb/remote-notif.c b/gdb/remote-notif.c index 0d59279..163979d 100644 --- a/gdb/remote-notif.c +++ b/gdb/remote-notif.c @@ -127,22 +127,25 @@ remote_async_get_pending_events_handler (gdb_client_data data) void handle_notification (struct remote_notif_state *state, char *buf) { - struct notif_client *nc = NULL; - int i; + struct notif_client *nc; + size_t i; for (i = 0; i < ARRAY_SIZE (notifs); i++) { - nc = notifs[i]; - if (strncmp (buf, nc->name, strlen (nc->name)) == 0 - && buf[strlen (nc->name)] == ':') + const char *name = notifs[i]->name; + + if (strncmp (buf, name, strlen (name)) == 0 + && buf[strlen (name)] == ':') break; } /* We ignore notifications we don't recognize, for compatibility with newer stubs. */ - if (nc == NULL) + if (i == ARRAY_SIZE (notifs)) return; + nc = notifs[i]; + if (state->pending_event[nc->id] != NULL) { /* We've already parsed the in-flight reply, but the stub for some |