提交 ed757e14 编写于 作者: Y Yan Vugenfirer 提交者: Anthony Liguori

VirtIO: Fix QEMU crash during Windows PNP tests

Hello,

In some cases bus driver can deassert "bus master" bit in PCI command
register. The driver will no longer be able to update related registers in
the device. Eventually it will cause QEMU to exit in "virtqueue_num_heads"
function.

Attached path that fixes the described issue.

Best regards,
Yan Vugenfirer.

>From 3fdafbdfad676ec8479dc073cff70bf356868bfe Mon Sep 17 00:00:00 2001
From: Yan Vugenfirer <yvugenfi@redhat.com>
Date: Tue, 8 Sep 2009 10:08:14 -0400
Subject: [PATCH] VirtIO: Fix QEMU crash during Windows PNP tests
Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
上级 aa659be3
...@@ -364,8 +364,17 @@ static void virtio_map(PCIDevice *pci_dev, int region_num, ...@@ -364,8 +364,17 @@ static void virtio_map(PCIDevice *pci_dev, int region_num,
static void virtio_write_config(PCIDevice *pci_dev, uint32_t address, static void virtio_write_config(PCIDevice *pci_dev, uint32_t address,
uint32_t val, int len) uint32_t val, int len)
{ {
VirtIOPCIProxy *proxy = DO_UPCAST(VirtIOPCIProxy, pci_dev, pci_dev);
if (PCI_COMMAND == address) {
if (!(val & PCI_COMMAND_MASTER)) {
proxy->vdev->status &= !VIRTIO_CONFIG_S_DRIVER_OK;
}
}
pci_default_write_config(pci_dev, address, val, len); pci_default_write_config(pci_dev, address, val, len);
msix_write_config(pci_dev, address, val, len); if(proxy->vdev->nvectors)
msix_write_config(pci_dev, address, val, len);
} }
static const VirtIOBindings virtio_pci_bindings = { static const VirtIOBindings virtio_pci_bindings = {
...@@ -407,11 +416,12 @@ static void virtio_init_pci(VirtIOPCIProxy *proxy, VirtIODevice *vdev, ...@@ -407,11 +416,12 @@ static void virtio_init_pci(VirtIOPCIProxy *proxy, VirtIODevice *vdev,
msix_bar_size(&proxy->pci_dev), msix_bar_size(&proxy->pci_dev),
PCI_ADDRESS_SPACE_MEM, PCI_ADDRESS_SPACE_MEM,
msix_mmio_map); msix_mmio_map);
proxy->pci_dev.config_write = virtio_write_config;
proxy->pci_dev.unregister = msix_uninit; proxy->pci_dev.unregister = msix_uninit;
} else } else
vdev->nvectors = 0; vdev->nvectors = 0;
proxy->pci_dev.config_write = virtio_write_config;
size = VIRTIO_PCI_REGION_SIZE(&proxy->pci_dev) + vdev->config_len; size = VIRTIO_PCI_REGION_SIZE(&proxy->pci_dev) + vdev->config_len;
if (size & (size-1)) if (size & (size-1))
size = 1 << qemu_fls(size); size = 1 << qemu_fls(size);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册