diff options
author | Marc-André Lureau <marcandre.lureau@redhat.com> | 2015-06-23 14:07:11 +0200 |
---|---|---|
committer | Marc-André Lureau <marcandre.lureau@redhat.com> | 2015-10-24 18:02:49 +0200 |
commit | 1ee57de444ac7dd0cdb091fec318ba056ed173fd (patch) | |
tree | 65ce6e9c1e20ee35703d0ae83c76443a0432b22e /hw/misc | |
parent | f456179fae249a420dce38a02ad7e2efc6be37cf (diff) | |
download | qemu-1ee57de444ac7dd0cdb091fec318ba056ed173fd.zip qemu-1ee57de444ac7dd0cdb091fec318ba056ed173fd.tar.gz qemu-1ee57de444ac7dd0cdb091fec318ba056ed173fd.tar.bz2 |
ivshmem: error on too many eventfd received
The number of eventfd that can be handled per peer is limited by the
number of vectors. Return an error when receiving too many of them.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Reviewed-by: Claudio Fontana <claudio.fontana@huawei.com>
Diffstat (limited to 'hw/misc')
-rw-r--r-- | hw/misc/ivshmem.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/hw/misc/ivshmem.c b/hw/misc/ivshmem.c index 0e31d1d..d5207ee 100644 --- a/hw/misc/ivshmem.c +++ b/hw/misc/ivshmem.c @@ -571,6 +571,13 @@ static void ivshmem_read(void *opaque, const uint8_t *buf, int size) /* each peer has an associated array of eventfds, and we keep * track of how many eventfds received so far */ /* get a new eventfd: */ + if (peer->nb_eventfds >= s->vectors) { + error_report("Too many eventfd received, device has %d vectors", + s->vectors); + close(incoming_fd); + return; + } + new_eventfd = peer->nb_eventfds++; /* this is an eventfd for a particular peer VM */ |