From mboxrd@z Thu Jan 1 00:00:00 1970 From: arnd@arndb.de (Arnd Bergmann) Date: Mon, 02 Feb 2015 18:02:16 +0100 Subject: [PATCH] PCI: Fix pcibios_update_irq misuse of irq number In-Reply-To: <1422456683-797-1-git-send-email-marc.zyngier@arm.com> References: <1422456683-797-1-git-send-email-marc.zyngier@arm.com> Message-ID: <4145359.V8A0ARGtXz@wuerfel> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On Wednesday 28 January 2015 14:51:23 Marc Zyngier wrote: > void __weak pcibios_update_irq(struct pci_dev *dev, int irq) > { > - dev_dbg(&dev->dev, "assigning IRQ %02d\n", irq); > - pci_write_config_byte(dev, PCI_INTERRUPT_LINE, irq); > + struct irq_data *d; > + > + d = irq_get_irq_data(irq); > +#ifdef CONFIG_IRQ_DOMAIN_HIERARCHY > + while (d->parent_data) > + d = d->parent_data; > +#endif > + dev_dbg(&dev->dev, "assigning IRQ %02ld\n", d->hwirq); > + pci_write_config_byte(dev, PCI_INTERRUPT_LINE, d->hwirq); > } I'm puzzled by this. Why is it even important what we write into the config space? Isn't this just an interface between BIOS and OS for systems that rely on the interrupt numbers to be statically assigned before boot? Arnd