Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a690a4cb authored by Bjorn Helgaas's avatar Bjorn Helgaas
Browse files

Merge branch 'pci/shengzhou-irq' into next

* pci/shengzhou-irq:
  PCI: Use dev->irq instead of dev->pin to enable non MSI/INTx interrupt
parents 5aaa71cf e237d83f
Loading
Loading
Loading
Loading
+11 −4
Original line number Original line Diff line number Diff line
@@ -200,10 +200,13 @@ static int init_service_irqs(struct pci_dev *dev, int *irqs, int mask)
{
{
	int i, irq = -1;
	int i, irq = -1;


	/* We have to use INTx if MSI cannot be used for PCIe PME or pciehp. */
	/*
	 * If MSI cannot be used for PCIe PME or hotplug, we have to use
	 * INTx or other interrupts, e.g. system shared interrupt.
	 */
	if (((mask & PCIE_PORT_SERVICE_PME) && pcie_pme_no_msi()) ||
	if (((mask & PCIE_PORT_SERVICE_PME) && pcie_pme_no_msi()) ||
	    ((mask & PCIE_PORT_SERVICE_HP) && pciehp_no_msi())) {
	    ((mask & PCIE_PORT_SERVICE_HP) && pciehp_no_msi())) {
		if (dev->pin)
		if (dev->irq)
			irq = dev->irq;
			irq = dev->irq;
		goto no_msi;
		goto no_msi;
	}
	}
@@ -212,8 +215,12 @@ static int init_service_irqs(struct pci_dev *dev, int *irqs, int mask)
	if (!pcie_port_enable_msix(dev, irqs, mask))
	if (!pcie_port_enable_msix(dev, irqs, mask))
		return 0;
		return 0;


	/* We're not going to use MSI-X, so try MSI and fall back to INTx */
	/*
	if (!pci_enable_msi(dev) || dev->pin)
	 * We're not going to use MSI-X, so try MSI and fall back to INTx.
	 * If neither MSI/MSI-X nor INTx available, try other interrupt.  On
	 * some platforms, root port doesn't support MSI/MSI-X/INTx in RC mode.
	 */
	if (!pci_enable_msi(dev) || dev->irq)
		irq = dev->irq;
		irq = dev->irq;


 no_msi:
 no_msi: