diff options
author | Yao Qi <yao@codesourcery.com> | 2013-12-10 21:59:20 +0800 |
---|---|---|
committer | Yao Qi <yao@codesourcery.com> | 2013-12-11 09:38:58 +0800 |
commit | e7f0d979dd5cc4f8b658df892e93db69d6d660b7 (patch) | |
tree | f28c280285bb95f105e5e9ea4312caccbc15816e /gdb/gdbserver/notif.c | |
parent | 7b3fd68b73e17e7e2441b4bb208040e3ea480698 (diff) | |
download | binutils-e7f0d979dd5cc4f8b658df892e93db69d6d660b7.zip binutils-e7f0d979dd5cc4f8b658df892e93db69d6d660b7.tar.gz binutils-e7f0d979dd5cc4f8b658df892e93db69d6d660b7.tar.bz2 |
Fix a bug in matching notifications.
Due to copy-n-paste, the problem caused PR remote/15974 also exists
in gdbserver. This patch fixes it in the same way. Patch to fix
remote/15974 can be found:
https://sourceware.org/ml/gdb-patches/2013-12/msg00014.html
gdb/gdbserver:
2013-12-11 Yao Qi <yao@codesourcery.com>
* notif.c (handle_notif_ack): Return 0 if no notification
matches.
Diffstat (limited to 'gdb/gdbserver/notif.c')
-rw-r--r-- | gdb/gdbserver/notif.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/gdb/gdbserver/notif.c b/gdb/gdbserver/notif.c index e27746e..6da2c5c 100644 --- a/gdb/gdbserver/notif.c +++ b/gdb/gdbserver/notif.c @@ -78,20 +78,23 @@ notif_write_event (struct notif_server *notif, char *own_buf) int handle_notif_ack (char *own_buf, int packet_len) { - int i = 0; - struct notif_server *np = NULL; + size_t i; + struct notif_server *np; for (i = 0; i < ARRAY_SIZE (notifs); i++) { - np = notifs[i]; - if (strncmp (own_buf, np->ack_name, strlen (np->ack_name)) == 0 - && packet_len == strlen (np->ack_name)) + const char *ack_name = notifs[i]->ack_name; + + if (strncmp (own_buf, ack_name, strlen (ack_name)) == 0 + && packet_len == strlen (ack_name)) break; } - if (np == NULL) + if (i == ARRAY_SIZE (notifs)) return 0; + np = notifs[i]; + /* If we're waiting for GDB to acknowledge a pending event, consider that done. */ if (!QUEUE_is_empty (notif_event_p, np->queue)) |