ACPI: PCI: follow typical PCI INTx swizzling pattern
authorBjorn Helgaas <bjorn.helgaas@hp.com>
Tue, 9 Dec 2008 04:31:11 +0000 (21:31 -0700)
committerLen Brown <len.brown@intel.com>
Wed, 31 Dec 2008 02:39:22 +0000 (21:39 -0500)
No functional change; this just uses the typical pattern of
PCI INTx swizzling done on other architectures.

Signed-off-by: Bjorn Helgaas <bjorn.helgaas@hp.com>
Signed-off-by: Len Brown <len.brown@intel.com>
drivers/acpi/pci_irq.c

index e42481f64495af4dc51413926396ef9768f53c5b..b35e64d714098c0e0083aed09ba4e51ebadfa7d6 100644 (file)
@@ -399,7 +399,7 @@ static struct acpi_prt_entry *
 acpi_pci_irq_derive(struct pci_dev *dev, int pin)
 {
        struct acpi_prt_entry *entry = NULL;
-       struct pci_dev *bridge = dev;
+       struct pci_dev *bridge;
        u8 bridge_pin = 0, orig_pin = pin;
 
 
@@ -407,9 +407,9 @@ acpi_pci_irq_derive(struct pci_dev *dev, int pin)
         * Attempt to derive an IRQ for this device from a parent bridge's
         * PCI interrupt routing entry (eg. yenta bridge and add-in card bridge).
         */
-       while (bridge->bus->self) {
-               pin = (((pin - 1) + PCI_SLOT(bridge->devfn)) % 4) + 1;
-               bridge = bridge->bus->self;
+       bridge = dev->bus->self;
+       while (bridge) {
+               pin = (((pin - 1) + PCI_SLOT(dev->devfn)) % 4) + 1;
 
                if ((bridge->class >> 8) == PCI_CLASS_BRIDGE_CARDBUS) {
                        /* PC card has the same IRQ as its cardbridge */
@@ -431,6 +431,9 @@ acpi_pci_irq_derive(struct pci_dev *dev, int pin)
                                         pci_name(bridge)));
                        return entry;
                }
+
+               dev = bridge;
+               bridge = dev->bus->self;
        }
 
        dev_warn(&dev->dev, "can't derive routing for PCI INT %c\n",