diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2005-12-13 21:10:10 -0500 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2006-01-08 23:03:17 -0500 |
commit | 1beb6a7d6cbed3ac03500ce9b5b9bb632c512039 (patch) | |
tree | 727aa76da5a82fca449dadf3cebbadc414ad6555 /arch/powerpc/platforms/powermac/setup.c | |
parent | cd0c7f06803be06a5cf4564aa5a900f4b6aea603 (diff) |
[PATCH] powerpc: Experimental support for new G5 Macs (#2)
This adds some very basic support for the new machines, including the
Quad G5 (tested), and other new dual core based machines and iMac G5
iSight (untested). This is still experimental ! There is no thermal
control yet, there is no proper handing of MSIs, etc.. but it
boots, I have all 4 cores up on my machine. Compared to the previous
version of this patch, this one adds DART IOMMU support for the U4
chipset and thus should work fine on setups with more than 2Gb of RAM.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/powerpc/platforms/powermac/setup.c')
-rw-r--r-- | arch/powerpc/platforms/powermac/setup.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/arch/powerpc/platforms/powermac/setup.c b/arch/powerpc/platforms/powermac/setup.c index 18c5620f87fa..1daa5a06e9ea 100644 --- a/arch/powerpc/platforms/powermac/setup.c +++ b/arch/powerpc/platforms/powermac/setup.c | |||
@@ -345,7 +345,7 @@ void __init pmac_setup_arch(void) | |||
345 | 345 | ||
346 | #ifdef CONFIG_SMP | 346 | #ifdef CONFIG_SMP |
347 | /* Check for Core99 */ | 347 | /* Check for Core99 */ |
348 | if (find_devices("uni-n") || find_devices("u3")) | 348 | if (find_devices("uni-n") || find_devices("u3") || find_devices("u4")) |
349 | smp_ops = &core99_smp_ops; | 349 | smp_ops = &core99_smp_ops; |
350 | #ifdef CONFIG_PPC32 | 350 | #ifdef CONFIG_PPC32 |
351 | else | 351 | else |
@@ -635,7 +635,7 @@ static void __init pmac_init_early(void) | |||
635 | /* Setup interrupt mapping options */ | 635 | /* Setup interrupt mapping options */ |
636 | ppc64_interrupt_controller = IC_OPEN_PIC; | 636 | ppc64_interrupt_controller = IC_OPEN_PIC; |
637 | 637 | ||
638 | iommu_init_early_u3(); | 638 | iommu_init_early_dart(); |
639 | #endif | 639 | #endif |
640 | } | 640 | } |
641 | 641 | ||
@@ -711,7 +711,7 @@ static int __init pmac_probe(int platform) | |||
711 | * occupies having to be broken up so the DART itself is not | 711 | * occupies having to be broken up so the DART itself is not |
712 | * part of the cacheable linar mapping | 712 | * part of the cacheable linar mapping |
713 | */ | 713 | */ |
714 | alloc_u3_dart_table(); | 714 | alloc_dart_table(); |
715 | #endif | 715 | #endif |
716 | 716 | ||
717 | #ifdef CONFIG_PMAC_SMU | 717 | #ifdef CONFIG_PMAC_SMU |
@@ -733,10 +733,11 @@ static int pmac_pci_probe_mode(struct pci_bus *bus) | |||
733 | struct device_node *node = bus->sysdata; | 733 | struct device_node *node = bus->sysdata; |
734 | 734 | ||
735 | /* We need to use normal PCI probing for the AGP bus, | 735 | /* We need to use normal PCI probing for the AGP bus, |
736 | since the device for the AGP bridge isn't in the tree. */ | 736 | * since the device for the AGP bridge isn't in the tree. |
737 | if (bus->self == NULL && device_is_compatible(node, "u3-agp")) | 737 | */ |
738 | if (bus->self == NULL && (device_is_compatible(node, "u3-agp") || | ||
739 | device_is_compatible(node, "u4-pcie"))) | ||
738 | return PCI_PROBE_NORMAL; | 740 | return PCI_PROBE_NORMAL; |
739 | |||
740 | return PCI_PROBE_DEVTREE; | 741 | return PCI_PROBE_DEVTREE; |
741 | } | 742 | } |
742 | #endif | 743 | #endif |