On Mon, 2009-02-02 at 22:39 +0100, Gerhard Pircher wrote: > This device tree does not provide the correct CPU name, as various CPU > models and revisions are used in AmigaOnes. Also the PCI root node does > not contain a interrupt mapping property, as all boards have different > interrupt routing. However the kernel can do a 1:1 mapping of all PCI > interrupts, as only i8259 legacy interrupts are used.
Looks ok for the purpose, but please remove the commented bits etc... Ben. > Signed-off-by: Gerhard Pircher <gerhard_pirc...@gmx.net> > --- > arch/powerpc/boot/dts/amigaone.dts | 183 > ++++++++++++++++++++++++++++++++++++ > 1 files changed, 183 insertions(+), 0 deletions(-) > create mode 100644 arch/powerpc/boot/dts/amigaone.dts > > diff --git a/arch/powerpc/boot/dts/amigaone.dts > b/arch/powerpc/boot/dts/amigaone.dts > new file mode 100644 > index 0000000..54d49e0 > --- /dev/null > +++ b/arch/powerpc/boot/dts/amigaone.dts > @@ -0,0 +1,183 @@ > +/* > + * AmigaOne Device Tree Source > + * > + * Copyright 2008 Gerhard Pircher (gerhard_pirc...@gmx.net) > + * > + * This program is free software; you can redistribute it and/or modify it > + * under the terms of the GNU General Public License as published by the > + * Free Software Foundation; either version 2 of the License, or (at your > + * option) any later version. > + */ > + > +/dts-v1/; > + > +/ { > + model = "AmigaOne"; > + compatible = "eyetech,amigaone"; > + coherency-off; > + #address-cells = <1>; > + #size-cells = <1>; > + > + cpus { > + #cpus = <1>; > + #address-cells = <1>; > + #size-cells = <0>; > + > + c...@0 { > + device_type = "cpu"; > + reg = <0>; > + d-cache-line-size = <32>; // 32 bytes > + i-cache-line-size = <32>; // 32 bytes > + d-cache-size = <32768>; // L1, 32K > + i-cache-size = <32768>; // L1, 32K > + timebase-frequency = <0>; // 33.3 MHz, from U-boot > + clock-frequency = <0>; // From U-boot > + bus-frequency = <0>; // From U-boot > + }; > + }; > + > + memory { > + device_type = "memory"; > + reg = <0 0>; // From U-boot > + }; > + > + p...@80000000 { > + device_type = "pci"; > + compatible = "mai-logic,articia-s"; > + bus-frequency = <33333333>; > + bus-range = <0 0xff>; > + ranges = <0x01000000 0 0x00000000 0xfe000000 0 0x00c00000 > // PCI I/O > + 0x02000000 0 0x80000000 0x80000000 0 0x7d000000 > // PCI memory > + 0x02000000 0 0x00000000 0xfd000000 0 0x01000000>; > // PCI alias memory (ISA) > + 8259-interrupt-acknowledge = <0xfef00000>; > + // Do not define a interrupt-parent here, if there is no > + // interrupt-map property. > + #address-cells = <3>; > + #size-cells = <2>; > + > + i...@7 { > + device_type = "isa"; > + compatible = "pciclass,0601"; > + vendor-id = <0x00001106>; > + device-id = <0x00000686>; > + revision-id = <0x00000010>; > + class-code = <0x00060100>; > + subsystem-id = <0>; > + subsystem-vendor-id = <0>; > + devsel-speed = <0x00000001>; > + min-grant = <0>; > + max-latency = <0>; > + /* First 64k for I/O at 0x0 on PCI mapped to 0x0 on > ISA. */ > + ranges = <0x00000001 0 0x01000000 0 0x00000000 > 0x00010000>; > + interrupt-parent = <&i8259>; > + #interrupt-cells = <2>; > + #address-cells = <2>; > + #size-cells = <1>; > + > + dma-control...@0 { > + compatible = "pnpPNP,200"; > + reg = <1 0x00000000 0x00000020 > + 1 0x00000080 0x00000010 > + 1 0x000000c0 0x00000020>; > + /* Channel 4 reserverd, cascade mode, 2x32k > transfer/counter > + * widths and bus master capability. > + */ > +/* dma = <0x4 0x4 0x20 0x20 0x1>; */ > + }; > + > + i8259: interrupt-control...@20 { > + device_type = "interrupt-controller"; > + compatible = "pnpPNP,000"; > + interrupt-controller; > + reg = <1 0x00000020 0x00000002 > + 1 0x000000a0 0x00000002 > + 1 0x000004d0 0x00000002>; > + reserved-interrupts = <2>; > + #interrupt-cells = <2>; > + }; > + > + ti...@40 { > + // Also adds pcspkr to platform devices. > + compatible = "pnpPNP,100"; > + reg = <1 0x00000040 0x00000020>; > + }; > + > + 8...@60 { > + device_type = "8042"; > + reg = <1 0x00000060 0x00000001 > + 1 0x00000064 0x00000001>; > + // IRQ1, IRQ12 (rising edge) > + interrupts = <1 3 12 3>; > + #address-cells = <1>; > + #size-cells = <0>; > + > + keybo...@0 { > + compatible = "pnpPNP,303"; > + reg = <0>; > + }; > + > + mo...@1 { > + compatible = "pnpPNP,f03"; > + reg = <1>; > + }; > + }; > + > + r...@70 { > + compatible = "pnpPNP,b00"; > + reg = <1 0x00000070 0x00000002>; > + interrupts = <8 3>; > + }; > + > + ser...@3f8 { > + device_type = "serial"; > + compatible = "pnpPNP,501","pnpPNP,500"; > + reg = <1 0x000003f8 0x00000008>; > + // IRQ4 (rising edge) > + interrupts = <4 3>; > + clock-frequency = <1843200>; > + current-speed = <115200>; > + }; > + > + ser...@2f8 { > + device_type = "serial"; > + compatible = "pnpPNP,501","pnpPNP,500"; > + reg = <1 0x000002f8 0x00000008>; > + // IRQ3 (rising edge) > + interrupts = <3 3>; > + clock-frequency = <1843200>; > + current-speed = <115200>; > + }; > + > + paral...@378 { > + device_type = "parallel"; > + // No ECP support for now, otherwise add > "pnpPNP,401". > + compatible = "pnpPNP,400"; > + reg = <1 0x00000378 0x00000003 > + 1 0x00000778 0x00000003>; > +/* interrupts = <7 0>; */ > + // Parallel port DMA mode unknown. > +/* dma = <0x3 0x0 0x0 0x0>; */ > + }; > + > + f...@3f0 { > + device_type = "fdc"; > + compatible = "pnpPNP,700"; > + reg = <1 0x000003f0 0x00000008>; > + // IRQ6 (rising edge) > + interrupts = <6 3>; > + // Floppy DMA mode unknown. > +/* dma = < >; */ > + #address-cells = <1>; > + #size-cells = <0>; > + > + d...@0 { > + reg = <0>; > + }; > + }; > + }; > + }; > + > + chosen { > + linux,stdout-path = "/p...@80000000/i...@7/ser...@3f8"; > + }; > +}; > -- > 1.5.3.4 > > _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@ozlabs.org https://ozlabs.org/mailman/listinfo/linuxppc-dev