virtio: validate num_sg when mapping
authorMichael S. Tsirkin <mst@redhat.com>
Thu, 3 Apr 2014 16:51:53 +0000 (19:51 +0300)
committerJuan Quintela <quintela@redhat.com>
Mon, 5 May 2014 20:15:02 +0000 (22:15 +0200)
commit36cf2a37132c7f01fa9adb5f95f5312b27742fd4
treea8e8acc36af8e26822915f3a919c858f09bb6d77
parent4b53c2c72cb5541cf394033b528a6fe2a86c0ac1
virtio: validate num_sg when mapping

CVE-2013-4535
CVE-2013-4536

Both virtio-block and virtio-serial read,
VirtQueueElements are read in as buffers, and passed to
virtqueue_map_sg(), where num_sg is taken from the wire and can force
writes to indicies beyond VIRTQUEUE_MAX_SIZE.

To fix, validate num_sg.

Reported-by: Michael Roth <mdroth@linux.vnet.ibm.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Cc: Amit Shah <amit.shah@redhat.com>
Signed-off-by: Juan Quintela <quintela@redhat.com>
hw/virtio/virtio.c