diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2007-12-19 22:55:04 -0500 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2007-12-20 00:18:15 -0500 |
commit | be8cbcd8896670a01ead7a29e33ffe29604ed734 (patch) | |
tree | c4253a4191279a74d7896099dab13fb57b1a9d27 /arch/powerpc/kernel/pci-common.c | |
parent | d0264ce796e4e3d77fdadf72d6625f8e6c1c96bd (diff) |
[POWERPC] Fixup skipping of PowerMac PCI<->PCI bridge "closed" resources
Apple firmware has a strange way to "close" bridge resources by setting
them to some bogus values that overlap RAM (strangely, I haven't seen it
conflicting with DMA so far...). This explicitely closes them to avoid
problems. Previously, they would be closed as a consequence of failing
to be allocated, but this makes it more explicit, and thus the log
message is more explicit too.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/powerpc/kernel/pci-common.c')
-rw-r--r-- | arch/powerpc/kernel/pci-common.c | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/arch/powerpc/kernel/pci-common.c b/arch/powerpc/kernel/pci-common.c index b6d4767e4e27..1037b3a093ee 100644 --- a/arch/powerpc/kernel/pci-common.c +++ b/arch/powerpc/kernel/pci-common.c | |||
@@ -776,6 +776,7 @@ DECLARE_PCI_FIXUP_HEADER(PCI_ANY_ID, PCI_ANY_ID, pcibios_fixup_resources); | |||
776 | 776 | ||
777 | static void __devinit __pcibios_fixup_bus(struct pci_bus *bus) | 777 | static void __devinit __pcibios_fixup_bus(struct pci_bus *bus) |
778 | { | 778 | { |
779 | struct pci_controller *hose = pci_bus_to_host(bus); | ||
779 | struct pci_dev *dev = bus->self; | 780 | struct pci_dev *dev = bus->self; |
780 | 781 | ||
781 | pr_debug("PCI: Fixup bus %d (%s)\n", bus->number, dev ? pci_name(dev) : "PHB"); | 782 | pr_debug("PCI: Fixup bus %d (%s)\n", bus->number, dev ? pci_name(dev) : "PHB"); |
@@ -793,6 +794,27 @@ static void __devinit __pcibios_fixup_bus(struct pci_bus *bus) | |||
793 | if (!res->flags || bus->self->transparent) | 794 | if (!res->flags || bus->self->transparent) |
794 | continue; | 795 | continue; |
795 | 796 | ||
797 | /* On PowerMac, Apple leaves bridge windows open over | ||
798 | * an inaccessible region of memory space (0...fffff) | ||
799 | * which is somewhat bogus, but that's what they think | ||
800 | * means disabled... | ||
801 | * | ||
802 | * We clear those to force them to be reallocated later | ||
803 | * | ||
804 | * We detect such regions by the fact that the base is | ||
805 | * equal to the pci_mem_offset of the host bridge and | ||
806 | * their size is smaller than 1M. | ||
807 | */ | ||
808 | if (res->start == hose->pci_mem_offset && | ||
809 | res->end < 0x100000) { | ||
810 | printk(KERN_INFO | ||
811 | "PCI: Closing bogus Apple Firmware" | ||
812 | " region %d on bus 0x%02x\n", | ||
813 | i, bus->number); | ||
814 | res->flags = 0; | ||
815 | continue; | ||
816 | } | ||
817 | |||
796 | pr_debug("PCI:%s Bus rsrc %d %016llx-%016llx [%x] fixup...\n", | 818 | pr_debug("PCI:%s Bus rsrc %d %016llx-%016llx [%x] fixup...\n", |
797 | pci_name(dev), i, | 819 | pci_name(dev), i, |
798 | (unsigned long long)res->start,\ | 820 | (unsigned long long)res->start,\ |