On Monday 20 November 2017 01:31 PM, Roger Quadros wrote: [...] >> >> So, could you try reverting commit 8c934095fa2f3 and >> also apply below patch and let me know if that fixes the issue? >> >> ----------- >> >> diff --git a/drivers/pci/dwc/pci-dra7xx.c b/drivers/pci/dwc/pci-dra7xx.c >> index e77a4ceed74c..8280abc56f30 100644 >> --- a/drivers/pci/dwc/pci-dra7xx.c >> +++ b/drivers/pci/dwc/pci-dra7xx.c >> @@ -259,10 +259,17 @@ static irqreturn_t dra7xx_pcie_msi_irq_handler(int irq, void *arg) >> u32 reg; >> >> reg = dra7xx_pcie_readl(dra7xx, PCIECTRL_DRA7XX_CONF_IRQSTATUS_MSI); >> + dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_IRQSTATUS_MSI, reg); >> >> switch (reg) { >> case MSI: >> - dw_handle_msi_irq(pp); >> + /* >> + * Need to make sure no MSI IRQs are pending before >> + * exiting handler, else the wrapper will not catch new >> + * IRQs. So loop around till dw_handle_msi_irq() returns >> + * IRQ_NONE >> + */ >> + while (dw_handle_msi_irq(pp) != IRQ_NONE); > > To avoid this kind of looping, shouldn't we be disabling all IRQ events while > the interrupt handler is running and enable them just before we return from the hardirq > handler? IIUC, you are saying to disable all MSIs at PCIe designware core level, then call dw_handle_msi_irq() and then enable MSIs after hardirq returns. But, the problem is if PCIe EP raises another MSI after the call to EP's handler but before re-enabling MSIs, then it will be ignored as IRQs are not yet enabled. Ideally, EP's support Per Vector Masking(PVM) which allow RC to prevent EP from sending MSI messages for sometime. But, unfortunately, the cards mentioned here don't support this feature. > > >> break; >> case INTA: >> case INTB: >> @@ -273,8 +280,6 @@ static irqreturn_t dra7xx_pcie_msi_irq_handler(int irq, void *arg) >> break; >> } >> >> - dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_IRQSTATUS_MSI, reg); >> - >> return IRQ_HANDLED; >> } >> >> >> >> > -- Regards Vignesh -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html