This wires up the 4xx PCI support & device tree bits for 440GP based Ebony platform.
Signed-off-by: Benjamin Herrenschmidt <[EMAIL PROTECTED]> --- arch/powerpc/boot/dts/ebony.dts | 41 ++++++++++++++++++++++++++++++++----- arch/powerpc/platforms/44x/ebony.c | 7 ++++++ 2 files changed, 43 insertions(+), 5 deletions(-) Index: linux-work/arch/powerpc/boot/dts/ebony.dts =================================================================== --- linux-work.orig/arch/powerpc/boot/dts/ebony.dts 2007-11-21 16:19:04.000000000 +1100 +++ linux-work/arch/powerpc/boot/dts/ebony.dts 2007-11-21 16:21:40.000000000 +1100 @@ -284,12 +284,43 @@ }; - PCIX0: [EMAIL PROTECTED] { + PCIX0: [EMAIL PROTECTED] { device_type = "pci"; - /* FIXME */ - reg = <2 0ec00000 8 - 2 0ec80000 f0 - 2 0ec80100 fc>; + #interrupt-cells = <1>; + #size-cells = <2>; + #address-cells = <3>; + compatible = "ibm,plb440gp-pcix", "ibm,plb-pcix"; + primary; + reg = <2 0ec00000 8 /* Config space access */ + 0 0 0 /* no IACK cycles */ + 2 0ed00000 4 /* Special cycles */ + 2 0ec80000 f0 /* Internal registers */ + 2 0ec80100 fc>; /* Internal messaging registers */ + + /* Outbound ranges, one memory and one IO, + * later cannot be changed + */ + ranges = <02000000 0 80000000 00000003 80000000 0 80000000 + 01000000 0 00000000 00000002 08000000 0 00010000>; + + /* Inbound 2GB range starting at 0 */ + dma-window = <42000000 0 0 0 80000000>; + + /* Ebony has all 4 IRQ pins tied together per slot */ + interrupt-map-mask = <f800 0 0 0>; + interrupt-map = < + /* IDSEL 1 */ + 0800 0 0 0 &UIC0 17 8 + + /* IDSEL 2 */ + 1000 0 0 0 &UIC0 18 8 + + /* IDSEL 3 */ + 1800 0 0 0 &UIC0 19 8 + + /* IDSEL 4 */ + 2000 0 0 0 &UIC0 1a 8 + >; }; }; Index: linux-work/arch/powerpc/platforms/44x/ebony.c =================================================================== --- linux-work.orig/arch/powerpc/platforms/44x/ebony.c 2007-11-21 16:19:04.000000000 +1100 +++ linux-work/arch/powerpc/platforms/44x/ebony.c 2007-11-21 16:21:40.000000000 +1100 @@ -23,6 +23,7 @@ #include <asm/time.h> #include <asm/uic.h> #include <asm/of_platform.h> +#include <asm/pci-bridge.h> #include "44x.h" @@ -44,6 +45,11 @@ static int __init ebony_device_probe(voi } device_initcall(ebony_device_probe); +static void __init ebony_setup_arch(void) +{ + ppc4xx_pci_find_bridges(); +} + /* * Called very early, MMU is off, device-tree isn't unflattened */ @@ -60,6 +66,7 @@ static int __init ebony_probe(void) define_machine(ebony) { .name = "Ebony", .probe = ebony_probe, + .setup_arch = ebony_setup_arch, .progress = udbg_progress, .init_IRQ = uic_init_tree, .get_irq = uic_get_irq, _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev