From: Jan Beulich Date: Thu, 11 Jun 2015 09:53:20 +0000 (+0200) Subject: x86/MSI-X: use qword MMIO access for address writes X-Git-Tag: archive/raspbian/4.8.0-1+rpi1~1^2~3112 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=73cb5d43a8;p=xen.git x86/MSI-X: use qword MMIO access for address writes Now that we support it for our guests, let's do so ourselves too. Signed-off-by: Jan Beulich Reviewed-by: Andrew Cooper --- diff --git a/xen/arch/x86/msi.c b/xen/arch/x86/msi.c index e89f326cf9..3527518e0c 100644 --- a/xen/arch/x86/msi.c +++ b/xen/arch/x86/msi.c @@ -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; } diff --git a/xen/include/asm-x86/msi.h b/xen/include/asm-x86/msi.h index 4c62a3a9fd..abbecf8105 100644 --- a/xen/include/asm-x86/msi.h +++ b/xen/include/asm-x86/msi.h @@ -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 */ }; diff --git a/xen/include/xen/pci_regs.h b/xen/include/xen/pci_regs.h index ecd6124d91..2de7847a80 100644 --- a/xen/include/xen/pci_regs.h +++ b/xen/include/xen/pci_regs.h @@ -307,6 +307,7 @@ #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