diff options
| -rw-r--r-- | drivers/pci/quirks.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 338a3f94b4d..eb97564316d 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c | |||
| @@ -1363,6 +1363,36 @@ DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, 0x2609, quirk_intel_pcie_pm); | |||
| 1363 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, 0x260a, quirk_intel_pcie_pm); | 1363 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, 0x260a, quirk_intel_pcie_pm); |
| 1364 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, 0x260b, quirk_intel_pcie_pm); | 1364 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, 0x260b, quirk_intel_pcie_pm); |
| 1365 | 1365 | ||
| 1366 | #ifdef CONFIG_X86_IO_APIC | ||
| 1367 | /* | ||
| 1368 | * On some chipsets we can disable the generation of legacy INTx boot | ||
| 1369 | * interrupts. | ||
| 1370 | */ | ||
| 1371 | |||
| 1372 | /* | ||
| 1373 | * IO-APIC1 on 6300ESB generates boot interrupts, see intel order no | ||
| 1374 | * 300641-004US, section 5.7.3. | ||
| 1375 | */ | ||
| 1376 | #define INTEL_6300_IOAPIC_ABAR 0x40 | ||
| 1377 | #define INTEL_6300_DISABLE_BOOT_IRQ (1<<14) | ||
| 1378 | |||
| 1379 | static void quirk_disable_intel_boot_interrupt(struct pci_dev *dev) | ||
| 1380 | { | ||
| 1381 | u16 pci_config_word; | ||
| 1382 | |||
| 1383 | if (noioapicquirk) | ||
| 1384 | return; | ||
| 1385 | |||
| 1386 | pci_read_config_word(dev, INTEL_6300_IOAPIC_ABAR, &pci_config_word); | ||
| 1387 | pci_config_word |= INTEL_6300_DISABLE_BOOT_IRQ; | ||
| 1388 | pci_write_config_word(dev, INTEL_6300_IOAPIC_ABAR, pci_config_word); | ||
| 1389 | |||
| 1390 | printk(KERN_INFO "disabled boot interrupt on device 0x%04x:0x%04x\n", | ||
| 1391 | dev->vendor, dev->device); | ||
| 1392 | } | ||
| 1393 | DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ESB_10, quirk_disable_intel_boot_interrupt); | ||
| 1394 | #endif /* CONFIG_X86_IO_APIC */ | ||
| 1395 | |||
| 1366 | /* | 1396 | /* |
| 1367 | * Toshiba TC86C001 IDE controller reports the standard 8-byte BAR0 size | 1397 | * Toshiba TC86C001 IDE controller reports the standard 8-byte BAR0 size |
| 1368 | * but the PIO transfers won't work if BAR0 falls at the odd 8 bytes. | 1398 | * but the PIO transfers won't work if BAR0 falls at the odd 8 bytes. |
