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

Commit 16b84e5a authored by Grant Likely's avatar Grant Likely
Browse files

of/irq: Create of_irq_parse_and_map_pci() to consolidate arch code.



Several architectures open code effectively the same code block for
finding and mapping PCI irqs. This patch consolidates it down to a
single function.

Signed-off-by: default avatarGrant Likely <grant.likely@linaro.org>
Acked-by: default avatarMichal Simek <monstr@monstr.eu>
Cc: Russell King <linux@arm.linux.org.uk>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
parent f7578496
Loading
Loading
Loading
Loading
+1 −16
Original line number Diff line number Diff line
@@ -835,21 +835,6 @@ static struct hw_pci pci_v3 __initdata = {

#ifdef CONFIG_OF

static int __init pci_v3_map_irq_dt(const struct pci_dev *dev, u8 slot, u8 pin)
{
	struct of_phandle_args oirq;
	int ret;

	ret = of_irq_parse_pci(dev, &oirq);
	if (ret) {
		dev_err(&dev->dev, "of_irq_parse_pci() %d\n", ret);
		/* Proper return code 0 == NO_IRQ */
		return 0;
	}

	return irq_create_of_mapping(&oirq);
}

static int __init pci_v3_dtprobe(struct platform_device *pdev,
				struct device_node *np)
{
@@ -918,7 +903,7 @@ static int __init pci_v3_dtprobe(struct platform_device *pdev,
		return -EINVAL;
	}

	pci_v3.map_irq = pci_v3_map_irq_dt;
	pci_v3.map_irq = of_irq_parse_and_map_pci;
	pci_common_init_dev(&pdev->dev, &pci_v3);

	return 0;
+1 −11
Original line number Diff line number Diff line
@@ -25,15 +25,5 @@ int pcibios_plat_dev_init(struct pci_dev *dev)

int __init pcibios_map_irq(const struct pci_dev *dev, u8 slot, u8 pin)
{
	struct of_phandle_args dev_irq;
	int irq;

	if (of_irq_parse_pci(dev, &dev_irq)) {
		dev_err(&dev->dev, "trying to map irq for unknown slot:%d pin:%d\n",
			slot, pin);
		return 0;
	}
	irq = irq_create_of_mapping(&dev_irq);
	dev_info(&dev->dev, "SLOT:%d PIN:%d IRQ:%d\n", slot, pin, irq);
	return irq;
	return of_irq_parse_and_map_pci(dev, slot, pin);
}
+1 −21
Original line number Diff line number Diff line
@@ -583,27 +583,7 @@ err_put_intc_node:

int __init pcibios_map_irq(const struct pci_dev *dev, u8 slot, u8 pin)
{
	struct of_phandle_args dev_irq;
	int err;
	int irq;

	err = of_irq_parse_pci(dev, &dev_irq);
	if (err) {
		pr_err("pci %s: unable to get irq map, err=%d\n",
		       pci_name((struct pci_dev *) dev), err);
		return 0;
	}

	irq = irq_create_of_mapping(&dev_irq);

	if (irq == 0)
		pr_crit("pci %s: no irq found for pin %u\n",
			pci_name((struct pci_dev *) dev), pin);
	else
		pr_info("pci %s: using irq %d for pin %u\n",
			pci_name((struct pci_dev *) dev), irq, pin);

	return irq;
	return of_irq_parse_and_map_pci(dev, slot, pin);
}

int pcibios_plat_dev_init(struct pci_dev *dev)
+1 −6
Original line number Diff line number Diff line
@@ -105,7 +105,6 @@ struct device_node *pcibios_get_phb_of_node(struct pci_bus *bus)

static int x86_of_pci_irq_enable(struct pci_dev *dev)
{
	struct of_phandle_args oirq;
	u32 virq;
	int ret;
	u8 pin;
@@ -116,11 +115,7 @@ static int x86_of_pci_irq_enable(struct pci_dev *dev)
	if (!pin)
		return 0;

	ret = of_irq_parse_pci(dev, &oirq);
	if (ret)
		return ret;

	virq = irq_create_of_mapping(&oirq);
	virq = of_irq_parse_and_map_pci(dev, 0, 0);
	if (virq == 0)
		return -EINVAL;
	dev->irq = virq;
+25 −0
Original line number Diff line number Diff line
@@ -94,3 +94,28 @@ int of_irq_parse_pci(const struct pci_dev *pdev, struct of_phandle_args *out_irq
	return of_irq_parse_raw(laddr, out_irq);
}
EXPORT_SYMBOL_GPL(of_irq_parse_pci);

/**
 * of_irq_parse_and_map_pci() - Decode a PCI irq from the device tree and map to a virq
 * @dev: The pci device needing an irq
 * @slot: PCI slot number; passed when used as map_irq callback. Unused
 * @pin: PCI irq pin number; passed when used as map_irq callback. Unused
 *
 * @slot and @pin are unused, but included in the function so that this
 * function can be used directly as the map_irq callback to pci_fixup_irqs().
 */
int of_irq_parse_and_map_pci(const struct pci_dev *dev, u8 slot, u8 pin)
{
	struct of_phandle_args oirq;
	int ret;

	ret = of_irq_parse_pci(dev, &oirq);
	if (ret) {
		dev_err(&dev->dev, "of_irq_parse_pci() failed with rc=%d\n", ret);
		return 0; /* Proper return code 0 == NO_IRQ */
	}

	return irq_create_of_mapping(&oirq);
}
EXPORT_SYMBOL_GPL(of_irq_parse_and_map_pci);
Loading