]> xenbits.xensource.com Git - people/liuw/libxenctrl-split/xen.git/commitdiff
x86/MSI-X: use qword MMIO access for address writes
authorJan Beulich <jbeulich@suse.com>
Thu, 11 Jun 2015 09:53:20 +0000 (11:53 +0200)
committerJan Beulich <jbeulich@suse.com>
Thu, 11 Jun 2015 09:53:20 +0000 (11:53 +0200)
Now that we support it for our guests, let's do so ourselves too.

Signed-off-by: Jan Beulich <jbeulich@suse.com>
Reviewed-by: Andrew Cooper <andrew.cooper3@citrix.com>
xen/arch/x86/msi.c
xen/include/asm-x86/msi.h
xen/include/xen/pci_regs.h

index e89f326cf9dd40604573d30624ba7975ef0f1a59..3527518e0c92bb8fa552cb3830c2827369e82072 100644 (file)
@@ -198,8 +198,7 @@ static void read_msi_msg(struct msi_desc *entry, struct msi_msg *msg)
         void __iomem *base;
         base = entry->mask_base;
 
-        msg->address_lo = readl(base + PCI_MSIX_ENTRY_LOWER_ADDR_OFFSET);
-        msg->address_hi = readl(base + PCI_MSIX_ENTRY_UPPER_ADDR_OFFSET);
+        msg->address = readq(base + PCI_MSIX_ENTRY_ADDRESS_OFFSET);
         msg->data = readl(base + PCI_MSIX_ENTRY_DATA_OFFSET);
         break;
     }
@@ -260,10 +259,7 @@ static int write_msi_msg(struct msi_desc *entry, struct msi_msg *msg)
         void __iomem *base;
         base = entry->mask_base;
 
-        writel(msg->address_lo,
-               base + PCI_MSIX_ENTRY_LOWER_ADDR_OFFSET);
-        writel(msg->address_hi,
-               base + PCI_MSIX_ENTRY_UPPER_ADDR_OFFSET);
+        writeq(msg->address, base + PCI_MSIX_ENTRY_ADDRESS_OFFSET);
         writel(msg->data, base + PCI_MSIX_ENTRY_DATA_OFFSET);
         break;
     }
index 4c62a3a9fdcfc60b1600b2fc1a6297ab7401ec4a..abbecf81056d1995401b89235edfa5af9227af30 100644 (file)
@@ -65,8 +65,13 @@ struct msi_info {
 };
 
 struct msi_msg {
-       u32     address_lo;     /* low 32 bits of msi message address */
-       u32     address_hi;     /* high 32 bits of msi message address */
+       union {
+               u64     address; /* message address */
+               struct {
+                       u32     address_lo; /* message address low 32 bits */
+                       u32     address_hi; /* message address high 32 bits */
+               };
+       };
        u32     data;           /* 16 bits of msi message data */
        u32     dest32;         /* used when Interrupt Remapping with EIM is enabled */
 };
index ecd6124d91072543768b14c40a8c3d3702e3111e..2de7847a8028b7da87c8b0b780ec91773b314104 100644 (file)
 #define  PCI_MSIX_BIRMASK      (7 << 0)
 
 #define PCI_MSIX_ENTRY_SIZE                    16
+#define  PCI_MSIX_ENTRY_ADDRESS_OFFSET         0
 #define  PCI_MSIX_ENTRY_LOWER_ADDR_OFFSET      0
 #define  PCI_MSIX_ENTRY_UPPER_ADDR_OFFSET      4
 #define  PCI_MSIX_ENTRY_DATA_OFFSET            8