diff options
Diffstat (limited to 'arch/x86/kernel/acpi')
-rw-r--r-- | arch/x86/kernel/acpi/boot.c | 18 |
1 files changed, 2 insertions, 16 deletions
diff --git a/arch/x86/kernel/acpi/boot.c b/arch/x86/kernel/acpi/boot.c index 8019ecf66e9..dcfbc3ab9e4 100644 --- a/arch/x86/kernel/acpi/boot.c +++ b/arch/x86/kernel/acpi/boot.c | |||
@@ -904,10 +904,8 @@ extern int es7000_plat; | |||
904 | #endif | 904 | #endif |
905 | 905 | ||
906 | static struct { | 906 | static struct { |
907 | int apic_id; | ||
908 | int gsi_base; | 907 | int gsi_base; |
909 | int gsi_end; | 908 | int gsi_end; |
910 | DECLARE_BITMAP(pin_programmed, MP_MAX_IOAPIC_PIN + 1); | ||
911 | } mp_ioapic_routing[MAX_IO_APICS]; | 909 | } mp_ioapic_routing[MAX_IO_APICS]; |
912 | 910 | ||
913 | int mp_find_ioapic(int gsi) | 911 | int mp_find_ioapic(int gsi) |
@@ -996,7 +994,6 @@ void __init mp_register_ioapic(int id, u32 address, u32 gsi_base) | |||
996 | * Build basic GSI lookup table to facilitate gsi->io_apic lookups | 994 | * Build basic GSI lookup table to facilitate gsi->io_apic lookups |
997 | * and to prevent reprogramming of IOAPIC pins (PCI GSIs). | 995 | * and to prevent reprogramming of IOAPIC pins (PCI GSIs). |
998 | */ | 996 | */ |
999 | mp_ioapic_routing[idx].apic_id = mp_ioapics[idx].apicid; | ||
1000 | mp_ioapic_routing[idx].gsi_base = gsi_base; | 997 | mp_ioapic_routing[idx].gsi_base = gsi_base; |
1001 | mp_ioapic_routing[idx].gsi_end = gsi_base + | 998 | mp_ioapic_routing[idx].gsi_end = gsi_base + |
1002 | io_apic_get_redir_entries(idx); | 999 | io_apic_get_redir_entries(idx); |
@@ -1189,7 +1186,7 @@ static int mp_config_acpi_gsi(struct device *dev, u32 gsi, int triggering, | |||
1189 | mp_irq.srcbus = number; | 1186 | mp_irq.srcbus = number; |
1190 | mp_irq.srcbusirq = (((devfn >> 3) & 0x1f) << 2) | ((pin - 1) & 3); | 1187 | mp_irq.srcbusirq = (((devfn >> 3) & 0x1f) << 2) | ((pin - 1) & 3); |
1191 | ioapic = mp_find_ioapic(gsi); | 1188 | ioapic = mp_find_ioapic(gsi); |
1192 | mp_irq.dstapic = mp_ioapic_routing[ioapic].apic_id; | 1189 | mp_irq.dstapic = mp_ioapics[ioapic].apicid; |
1193 | mp_irq.dstirq = mp_find_ioapic_pin(ioapic, gsi); | 1190 | mp_irq.dstirq = mp_find_ioapic_pin(ioapic, gsi); |
1194 | 1191 | ||
1195 | save_mp_irq(&mp_irq); | 1192 | save_mp_irq(&mp_irq); |
@@ -1224,23 +1221,12 @@ int mp_register_gsi(struct device *dev, u32 gsi, int triggering, int polarity) | |||
1224 | 1221 | ||
1225 | if (ioapic_pin > MP_MAX_IOAPIC_PIN) { | 1222 | if (ioapic_pin > MP_MAX_IOAPIC_PIN) { |
1226 | printk(KERN_ERR "Invalid reference to IOAPIC pin " | 1223 | printk(KERN_ERR "Invalid reference to IOAPIC pin " |
1227 | "%d-%d\n", mp_ioapic_routing[ioapic].apic_id, | 1224 | "%d-%d\n", mp_ioapics[ioapic].apicid, |
1228 | ioapic_pin); | 1225 | ioapic_pin); |
1229 | return gsi; | 1226 | return gsi; |
1230 | } | 1227 | } |
1231 | mp_config_acpi_gsi(dev, gsi, triggering, polarity); | 1228 | mp_config_acpi_gsi(dev, gsi, triggering, polarity); |
1232 | 1229 | ||
1233 | /* | ||
1234 | * Avoid pin reprogramming. PRTs typically include entries | ||
1235 | * with redundant pin->gsi mappings (but unique PCI devices); | ||
1236 | * we only program the IOAPIC on the first. | ||
1237 | */ | ||
1238 | if (test_bit(ioapic_pin, mp_ioapic_routing[ioapic].pin_programmed)) { | ||
1239 | pr_debug("Pin %d-%d already programmed\n", | ||
1240 | mp_ioapic_routing[ioapic].apic_id, ioapic_pin); | ||
1241 | return gsi; | ||
1242 | } | ||
1243 | set_bit(ioapic_pin, mp_ioapic_routing[ioapic].pin_programmed); | ||
1244 | io_apic_set_pci_routing(dev, ioapic, ioapic_pin, gsi, | 1230 | io_apic_set_pci_routing(dev, ioapic, ioapic_pin, gsi, |
1245 | triggering == ACPI_EDGE_SENSITIVE ? 0 : 1, | 1231 | triggering == ACPI_EDGE_SENSITIVE ? 0 : 1, |
1246 | polarity == ACPI_ACTIVE_HIGH ? 0 : 1); | 1232 | polarity == ACPI_ACTIVE_HIGH ? 0 : 1); |