aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/pci/quirks.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c
index 1d04ca02dd0f..47214fdfa6c8 100644
--- a/drivers/pci/quirks.c
+++ b/drivers/pci/quirks.c
@@ -1670,6 +1670,31 @@ static void __devinit quirk_p64h2_1k_io(struct pci_dev *dev)
1670} 1670}
1671DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, 0x1460, quirk_p64h2_1k_io); 1671DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, 0x1460, quirk_p64h2_1k_io);
1672 1672
1673/* Fix the IOBL_ADR for 1k I/O space granularity on the Intel P64H2
1674 * The IOBL_ADR gets re-written to 4k boundaries in pci_setup_bridge()
1675 * in drivers/pci/setup-bus.c
1676 */
1677static void __devinit quirk_p64h2_1k_io_fix_iobl(struct pci_dev *dev)
1678{
1679 u16 en1k, iobl_adr, iobl_adr_1k;
1680 struct resource *res = dev->resource + PCI_BRIDGE_RESOURCES;
1681
1682 pci_read_config_word(dev, 0x40, &en1k);
1683
1684 if (en1k & 0x200) {
1685 pci_read_config_word(dev, PCI_IO_BASE, &iobl_adr);
1686
1687 iobl_adr_1k = iobl_adr | (res->start >> 8) | (res->end & 0xfc00);
1688
1689 if (iobl_adr != iobl_adr_1k) {
1690 printk(KERN_INFO "PCI: Fixing P64H2 IOBL_ADR from 0x%x to 0x%x for 1 KB Granularity\n",
1691 iobl_adr,iobl_adr_1k);
1692 pci_write_config_word(dev, PCI_IO_BASE, iobl_adr_1k);
1693 }
1694 }
1695}
1696DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_INTEL, 0x1460, quirk_p64h2_1k_io_fix_iobl);
1697
1673/* Under some circumstances, AER is not linked with extended capabilities. 1698/* Under some circumstances, AER is not linked with extended capabilities.
1674 * Force it to be linked by setting the corresponding control bit in the 1699 * Force it to be linked by setting the corresponding control bit in the
1675 * config space. 1700 * config space.