aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pci/msi.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/pci/msi.c')
-rw-r--r--drivers/pci/msi.c18
1 files changed, 8 insertions, 10 deletions
diff --git a/drivers/pci/msi.c b/drivers/pci/msi.c
index 628c14150d49..a088fc6f5838 100644
--- a/drivers/pci/msi.c
+++ b/drivers/pci/msi.c
@@ -151,7 +151,7 @@ static void msix_mask_irq(struct msi_desc *desc, u32 flag)
151{ 151{
152 u32 mask_bits = desc->masked; 152 u32 mask_bits = desc->masked;
153 unsigned offset = desc->msi_attrib.entry_nr * PCI_MSIX_ENTRY_SIZE + 153 unsigned offset = desc->msi_attrib.entry_nr * PCI_MSIX_ENTRY_SIZE +
154 PCI_MSIX_ENTRY_VECTOR_CTRL_OFFSET; 154 PCI_MSIX_ENTRY_VECTOR_CTRL;
155 mask_bits &= ~1; 155 mask_bits &= ~1;
156 mask_bits |= flag; 156 mask_bits |= flag;
157 writel(mask_bits, desc->mask_base + offset); 157 writel(mask_bits, desc->mask_base + offset);
@@ -188,9 +188,9 @@ void read_msi_msg_desc(struct irq_desc *desc, struct msi_msg *msg)
188 void __iomem *base = entry->mask_base + 188 void __iomem *base = entry->mask_base +
189 entry->msi_attrib.entry_nr * PCI_MSIX_ENTRY_SIZE; 189 entry->msi_attrib.entry_nr * PCI_MSIX_ENTRY_SIZE;
190 190
191 msg->address_lo = readl(base + PCI_MSIX_ENTRY_LOWER_ADDR_OFFSET); 191 msg->address_lo = readl(base + PCI_MSIX_ENTRY_LOWER_ADDR);
192 msg->address_hi = readl(base + PCI_MSIX_ENTRY_UPPER_ADDR_OFFSET); 192 msg->address_hi = readl(base + PCI_MSIX_ENTRY_UPPER_ADDR);
193 msg->data = readl(base + PCI_MSIX_ENTRY_DATA_OFFSET); 193 msg->data = readl(base + PCI_MSIX_ENTRY_DATA);
194 } else { 194 } else {
195 struct pci_dev *dev = entry->dev; 195 struct pci_dev *dev = entry->dev;
196 int pos = entry->msi_attrib.pos; 196 int pos = entry->msi_attrib.pos;
@@ -225,11 +225,9 @@ void write_msi_msg_desc(struct irq_desc *desc, struct msi_msg *msg)
225 base = entry->mask_base + 225 base = entry->mask_base +
226 entry->msi_attrib.entry_nr * PCI_MSIX_ENTRY_SIZE; 226 entry->msi_attrib.entry_nr * PCI_MSIX_ENTRY_SIZE;
227 227
228 writel(msg->address_lo, 228 writel(msg->address_lo, base + PCI_MSIX_ENTRY_LOWER_ADDR);
229 base + PCI_MSIX_ENTRY_LOWER_ADDR_OFFSET); 229 writel(msg->address_hi, base + PCI_MSIX_ENTRY_UPPER_ADDR);
230 writel(msg->address_hi, 230 writel(msg->data, base + PCI_MSIX_ENTRY_DATA);
231 base + PCI_MSIX_ENTRY_UPPER_ADDR_OFFSET);
232 writel(msg->data, base + PCI_MSIX_ENTRY_DATA_OFFSET);
233 } else { 231 } else {
234 struct pci_dev *dev = entry->dev; 232 struct pci_dev *dev = entry->dev;
235 int pos = entry->msi_attrib.pos; 233 int pos = entry->msi_attrib.pos;
@@ -493,7 +491,7 @@ static int msix_capability_init(struct pci_dev *dev,
493 set_irq_msi(entry->irq, entry); 491 set_irq_msi(entry->irq, entry);
494 j = entries[i].entry; 492 j = entries[i].entry;
495 entry->masked = readl(base + j * PCI_MSIX_ENTRY_SIZE + 493 entry->masked = readl(base + j * PCI_MSIX_ENTRY_SIZE +
496 PCI_MSIX_ENTRY_VECTOR_CTRL_OFFSET); 494 PCI_MSIX_ENTRY_VECTOR_CTRL);
497 msix_mask_irq(entry, 1); 495 msix_mask_irq(entry, 1);
498 i++; 496 i++;
499 } 497 }