diff options
Diffstat (limited to 'drivers/pci/controller')
-rw-r--r-- | drivers/pci/controller/dwc/pcie-designware-host.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/drivers/pci/controller/dwc/pcie-designware-host.c b/drivers/pci/controller/dwc/pcie-designware-host.c index 610a5e018d27..0fa9e8fdce66 100644 --- a/drivers/pci/controller/dwc/pcie-designware-host.c +++ b/drivers/pci/controller/dwc/pcie-designware-host.c | |||
@@ -99,9 +99,6 @@ irqreturn_t dw_handle_msi_irq(struct pcie_port *pp) | |||
99 | (i * MAX_MSI_IRQS_PER_CTRL) + | 99 | (i * MAX_MSI_IRQS_PER_CTRL) + |
100 | pos); | 100 | pos); |
101 | generic_handle_irq(irq); | 101 | generic_handle_irq(irq); |
102 | dw_pcie_wr_own_conf(pp, PCIE_MSI_INTR0_STATUS + | ||
103 | (i * MSI_REG_CTRL_BLOCK_SIZE), | ||
104 | 4, 1 << pos); | ||
105 | pos++; | 102 | pos++; |
106 | } | 103 | } |
107 | } | 104 | } |
@@ -200,14 +197,18 @@ static void dw_pci_bottom_unmask(struct irq_data *data) | |||
200 | 197 | ||
201 | static void dw_pci_bottom_ack(struct irq_data *d) | 198 | static void dw_pci_bottom_ack(struct irq_data *d) |
202 | { | 199 | { |
203 | struct msi_desc *msi = irq_data_get_msi_desc(d); | 200 | struct pcie_port *pp = irq_data_get_irq_chip_data(d); |
204 | struct pcie_port *pp; | 201 | unsigned int res, bit, ctrl; |
205 | unsigned long flags; | 202 | unsigned long flags; |
206 | 203 | ||
207 | pp = msi_desc_to_pci_sysdata(msi); | 204 | ctrl = d->hwirq / MAX_MSI_IRQS_PER_CTRL; |
205 | res = ctrl * MSI_REG_CTRL_BLOCK_SIZE; | ||
206 | bit = d->hwirq % MAX_MSI_IRQS_PER_CTRL; | ||
208 | 207 | ||
209 | raw_spin_lock_irqsave(&pp->lock, flags); | 208 | raw_spin_lock_irqsave(&pp->lock, flags); |
210 | 209 | ||
210 | dw_pcie_wr_own_conf(pp, PCIE_MSI_INTR0_STATUS + res, 4, 1 << bit); | ||
211 | |||
211 | if (pp->ops->msi_irq_ack) | 212 | if (pp->ops->msi_irq_ack) |
212 | pp->ops->msi_irq_ack(d->hwirq, pp); | 213 | pp->ops->msi_irq_ack(d->hwirq, pp); |
213 | 214 | ||