diff options
Diffstat (limited to 'drivers/pci/msi.c')
-rw-r--r-- | drivers/pci/msi.c | 18 |
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 | } |