提交 2a639123 编写于 作者: M Michael S. Tsirkin

virtio-pci: don't crash on illegal length

Some guests seem to access cfg with an illegal length value.
It's worth fixing them but debugging is easier if
qemu does not crash.
Signed-off-by: NMichael S. Tsirkin <mst@redhat.com>
上级 8aedc369
...@@ -546,7 +546,8 @@ static void virtio_write_config(PCIDevice *pci_dev, uint32_t address, ...@@ -546,7 +546,8 @@ static void virtio_write_config(PCIDevice *pci_dev, uint32_t address,
off = le32_to_cpu(cfg->cap.offset); off = le32_to_cpu(cfg->cap.offset);
len = le32_to_cpu(cfg->cap.length); len = le32_to_cpu(cfg->cap.length);
if (len <= sizeof cfg->pci_cfg_data) { if (len == 1 || len == 2 || len == 4) {
assert(len <= sizeof cfg->pci_cfg_data);
virtio_address_space_write(&proxy->modern_as, off, virtio_address_space_write(&proxy->modern_as, off,
cfg->pci_cfg_data, len); cfg->pci_cfg_data, len);
} }
...@@ -570,7 +571,8 @@ static uint32_t virtio_read_config(PCIDevice *pci_dev, ...@@ -570,7 +571,8 @@ static uint32_t virtio_read_config(PCIDevice *pci_dev,
off = le32_to_cpu(cfg->cap.offset); off = le32_to_cpu(cfg->cap.offset);
len = le32_to_cpu(cfg->cap.length); len = le32_to_cpu(cfg->cap.length);
if (len <= sizeof cfg->pci_cfg_data) { if (len == 1 || len == 2 || len == 4) {
assert(len <= sizeof cfg->pci_cfg_data);
virtio_address_space_read(&proxy->modern_as, off, virtio_address_space_read(&proxy->modern_as, off,
cfg->pci_cfg_data, len); cfg->pci_cfg_data, len);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册