On Tue, 23 Sep 2014, Suravee Suthikulpanit wrote: > > > This patch implelments the ARM64 version of arch_setup_msi_irqs(), > > > which does not return 1 for when PCI_CAP_ID_MSI and nvec > 1. > > > > I can see that myself. What your changelog is missing is the reason > > WHY you think that copying that code from drivers/pci/msi.c and > > removing the "PCI_CAP_ID_MSI and nvec > 1" has any value. > > [Suravee] This is mainly be cause the weak version of arch_setup_msi_irqs() in > the drivers/pci/msi.c doesn't support multi-MSI. Sorry for not being clear in > the commit message. Groan. I asked you: > > WHY you think that copying that code from drivers/pci/msi.c and > > removing the "PCI_CAP_ID_MSI and nvec > 1" has any value. And your answer is that the function in drivers/pci/msi.c does not support Multi-MSI. Hell I know that myself. And there is a fricking good reason why allocating multi-MSI via for_each_msi() alloc_msi_irq(); is wrong. And while it might work by chance, there is no guarantee that it will work. It works for Multi-MSIX, but that has an additional X at the end and is a different beast when it comes to interrupts. I have no idea how crooked you are trying to work around that on the GIC side, but its going to be wrong and convoluted. Read and understand the MSI and MSI-X spec and the subtle differences of interrupt delivery. And if you groked that come back with a proper explanation why that patch makes sense or just go back to the drawing board and do it proper. Thanks, tglx -- To unsubscribe from this list: send the line "unsubscribe linux-pci" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html