aboutsummaryrefslogtreecommitdiff
path: root/contrib/ivshmem-server
diff options
context:
space:
mode:
authorGonglei <arei.gonglei@huawei.com>2015-11-02 09:13:48 +0800
committerMichael Tokarev <mjt@tls.msk.ru>2015-11-06 15:42:38 +0300
commit258133bda9a6f22ba436ef9b63b7c086cc80190b (patch)
tree107c9ad242888b543457db4bedf893b2b91f0ad8 /contrib/ivshmem-server
parent6268520d7df9b3f183bb4397218c9287441bc04f (diff)
downloadqemu-258133bda9a6f22ba436ef9b63b7c086cc80190b.zip
qemu-258133bda9a6f22ba436ef9b63b7c086cc80190b.tar.gz
qemu-258133bda9a6f22ba436ef9b63b7c086cc80190b.tar.bz2
ivshmem-server: fix possible OVERRUN
>>> CID 1337991: Memory - illegal accesses (OVERRUN) >>> Decrementing "i". The value of "i" is now 65534. 218 while (i--) { 219 event_notifier_cleanup(&peer->vectors[i]); 220 } Signed-off-by: Gonglei <arei.gonglei@huawei.com> Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com> Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
Diffstat (limited to 'contrib/ivshmem-server')
-rw-r--r--contrib/ivshmem-server/ivshmem-server.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/contrib/ivshmem-server/ivshmem-server.c b/contrib/ivshmem-server/ivshmem-server.c
index 5e5239c..d9e26b0 100644
--- a/contrib/ivshmem-server/ivshmem-server.c
+++ b/contrib/ivshmem-server/ivshmem-server.c
@@ -168,7 +168,9 @@ ivshmem_server_handle_new_conn(IvshmemServer *server)
}
if (i == G_MAXUINT16) {
IVSHMEM_SERVER_DEBUG(server, "cannot allocate new client id\n");
- goto fail;
+ close(newfd);
+ g_free(peer);
+ return -1;
}
peer->id = server->cur_id++;