summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThorsten Kohfeldt2016-10-17 18:58:02 +0200
committerAlex Williamson2016-10-17 18:58:02 +0200
commit31e6a7b17b35711eb44f0e686b5ba68d15bfe4c1 (patch)
tree7d4ec5daa0e2024e6e7dd9b6bf095f0fe36a13df
parentvfio/pci: Handle host oversight (diff)
downloadqemu-31e6a7b17b35711eb44f0e686b5ba68d15bfe4c1.tar.gz
qemu-31e6a7b17b35711eb44f0e686b5ba68d15bfe4c1.tar.xz
qemu-31e6a7b17b35711eb44f0e686b5ba68d15bfe4c1.zip
vfio/pci: Fix vfio_rtl8168_quirk_data_read address offset
Introductory comment for rtl8168 VFIO MSI-X quirk states: At BAR2 offset 0x70 there is a dword data register, offset 0x74 is a dword address register. vfio: vfio_bar_read(0000:05:00.0:BAR2+0x70, 4) = 0xfee00398 // read data Thus, correct offset for data read is 0x70, but function vfio_rtl8168_quirk_data_read() wrongfully uses offset 0x74. Signed-off-by: Thorsten Kohfeldt <thorsten.kohfeldt@gmx.de> Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
-rw-r--r--hw/vfio/pci-quirks.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/hw/vfio/pci-quirks.c b/hw/vfio/pci-quirks.c
index 2cbda0844e..811eecd1b4 100644
--- a/hw/vfio/pci-quirks.c
+++ b/hw/vfio/pci-quirks.c
@@ -898,7 +898,7 @@ static uint64_t vfio_rtl8168_quirk_data_read(void *opaque,
{
VFIOrtl8168Quirk *rtl = opaque;
VFIOPCIDevice *vdev = rtl->vdev;
- uint64_t data = vfio_region_read(&vdev->bars[2].region, addr + 0x74, size);
+ uint64_t data = vfio_region_read(&vdev->bars[2].region, addr + 0x70, size);
if (rtl->enabled && (vdev->pdev.cap_present & QEMU_PCI_CAP_MSIX)) {
hwaddr offset = rtl->addr & 0xfff;