qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH] msix: allow qword MSI-X table accesses


From: Philippe Mathieu-Daudé
Subject: Re: [PATCH] msix: allow qword MSI-X table accesses
Date: Thu, 14 May 2020 20:42:39 +0200
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.5.0

On 5/14/20 5:16 PM, Michael S. Tsirkin wrote:
PCI spec says:

For all accesses to MSI-X Table and MSI-X PBA fields, software must use
aligned full DWORD or aligned full QWORD transactions; otherwise, the
result is undefined.

However, since MSI-X was converted to use memory API, QEMU
started blocking qword transactions, only allowing DWORD
ones. Guests do not seem to use QWORD accesses, but let's
be spec compliant.

Fixes: 95524ae8dc8f ("msix: convert to memory API")

9 years =)

Reviewed-by: Philippe Mathieu-Daudé <address@hidden>

Signed-off-by: Michael S. Tsirkin <address@hidden>
---
  hw/pci/msix.c | 6 ++++++
  1 file changed, 6 insertions(+)

diff --git a/hw/pci/msix.c b/hw/pci/msix.c
index 29187898f2..e6a5559038 100644
--- a/hw/pci/msix.c
+++ b/hw/pci/msix.c
@@ -199,6 +199,9 @@ static const MemoryRegionOps msix_table_mmio_ops = {
      .endianness = DEVICE_LITTLE_ENDIAN,
      .valid = {
          .min_access_size = 4,
+        .max_access_size = 8,
+    },
+    .impl = {
          .max_access_size = 4,
      },
  };
@@ -227,6 +230,9 @@ static const MemoryRegionOps msix_pba_mmio_ops = {
      .endianness = DEVICE_LITTLE_ENDIAN,
      .valid = {
          .min_access_size = 4,
+        .max_access_size = 8,
+    },
+    .impl = {
          .max_access_size = 4,
      },
  };





reply via email to

[Prev in Thread] Current Thread [Next in Thread]