blob: 4a9f726ada139b47d4c45edff3b71b04cbd5f024 [file] [log] [blame]
Josh Boyer8852ab72007-09-07 07:50:50 -05001/*
2 * Device Tree Source for IBM Walnut
3 *
4 * Copyright 2007 IBM Corp.
5 * Josh Boyer <jwboyer@linux.vnet.ibm.com>
6 *
7 * This file is licensed under the terms of the GNU General Public
8 * License version 2. This program is licensed "as is" without
9 * any warranty of any kind, whether express or implied.
10 */
11
David Gibson71f34972008-05-15 16:46:39 +100012/dts-v1/;
13
Josh Boyer8852ab72007-09-07 07:50:50 -050014/ {
15 #address-cells = <1>;
16 #size-cells = <1>;
17 model = "ibm,walnut";
18 compatible = "ibm,walnut";
David Gibson71f34972008-05-15 16:46:39 +100019 dcr-parent = <&{/cpus/cpu@0}>;
Josh Boyer8852ab72007-09-07 07:50:50 -050020
Stefan Roese8aaed982007-12-15 18:55:16 +110021 aliases {
22 ethernet0 = &EMAC;
23 serial0 = &UART0;
24 serial1 = &UART1;
25 };
26
Josh Boyer8852ab72007-09-07 07:50:50 -050027 cpus {
28 #address-cells = <1>;
29 #size-cells = <0>;
30
Josh Boyer72fda112007-12-06 13:20:05 -060031 cpu@0 {
Josh Boyer8852ab72007-09-07 07:50:50 -050032 device_type = "cpu";
Josh Boyer72fda112007-12-06 13:20:05 -060033 model = "PowerPC,405GP";
David Gibson71f34972008-05-15 16:46:39 +100034 reg = <0x00000000>;
35 clock-frequency = <200000000>; /* Filled in by zImage */
Josh Boyer8852ab72007-09-07 07:50:50 -050036 timebase-frequency = <0>; /* Filled in by zImage */
David Gibson71f34972008-05-15 16:46:39 +100037 i-cache-line-size = <32>;
38 d-cache-line-size = <32>;
39 i-cache-size = <16384>;
40 d-cache-size = <16384>;
Josh Boyer8852ab72007-09-07 07:50:50 -050041 dcr-controller;
42 dcr-access-method = "native";
43 };
44 };
45
46 memory {
47 device_type = "memory";
David Gibson71f34972008-05-15 16:46:39 +100048 reg = <0x00000000 0x00000000>; /* Filled in by zImage */
Josh Boyer8852ab72007-09-07 07:50:50 -050049 };
50
51 UIC0: interrupt-controller {
52 compatible = "ibm,uic";
53 interrupt-controller;
54 cell-index = <0>;
David Gibson71f34972008-05-15 16:46:39 +100055 dcr-reg = <0x0c0 0x009>;
Josh Boyer8852ab72007-09-07 07:50:50 -050056 #address-cells = <0>;
57 #size-cells = <0>;
58 #interrupt-cells = <2>;
59 };
60
61 plb {
62 compatible = "ibm,plb3";
63 #address-cells = <1>;
64 #size-cells = <1>;
65 ranges;
66 clock-frequency = <0>; /* Filled in by zImage */
67
68 SDRAM0: memory-controller {
69 compatible = "ibm,sdram-405gp";
David Gibson71f34972008-05-15 16:46:39 +100070 dcr-reg = <0x010 0x002>;
Josh Boyer8852ab72007-09-07 07:50:50 -050071 };
72
73 MAL: mcmal {
74 compatible = "ibm,mcmal-405gp", "ibm,mcmal";
David Gibson71f34972008-05-15 16:46:39 +100075 dcr-reg = <0x180 0x062>;
Josh Boyerb3af7a52007-10-20 00:53:11 +100076 num-tx-chans = <1>;
Josh Boyer8852ab72007-09-07 07:50:50 -050077 num-rx-chans = <1>;
78 interrupt-parent = <&UIC0>;
Josh Boyerb3af7a52007-10-20 00:53:11 +100079 interrupts = <
David Gibson71f34972008-05-15 16:46:39 +100080 0xb 0x4 /* TXEOB */
81 0xc 0x4 /* RXEOB */
82 0xa 0x4 /* SERR */
83 0xd 0x4 /* TXDE */
84 0xe 0x4 /* RXDE */>;
Josh Boyer8852ab72007-09-07 07:50:50 -050085 };
86
87 POB0: opb {
88 compatible = "ibm,opb-405gp", "ibm,opb";
89 #address-cells = <1>;
90 #size-cells = <1>;
David Gibson71f34972008-05-15 16:46:39 +100091 ranges = <0xef600000 0xef600000 0x00a00000>;
92 dcr-reg = <0x0a0 0x005>;
Josh Boyer8852ab72007-09-07 07:50:50 -050093 clock-frequency = <0>; /* Filled in by zImage */
94
95 UART0: serial@ef600300 {
96 device_type = "serial";
97 compatible = "ns16550";
David Gibson71f34972008-05-15 16:46:39 +100098 reg = <0xef600300 0x00000008>;
99 virtual-reg = <0xef600300>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500100 clock-frequency = <0>; /* Filled in by zImage */
David Gibson71f34972008-05-15 16:46:39 +1000101 current-speed = <9600>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500102 interrupt-parent = <&UIC0>;
David Gibson71f34972008-05-15 16:46:39 +1000103 interrupts = <0x0 0x4>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500104 };
105
106 UART1: serial@ef600400 {
107 device_type = "serial";
108 compatible = "ns16550";
David Gibson71f34972008-05-15 16:46:39 +1000109 reg = <0xef600400 0x00000008>;
110 virtual-reg = <0xef600400>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500111 clock-frequency = <0>; /* Filled in by zImage */
David Gibson71f34972008-05-15 16:46:39 +1000112 current-speed = <9600>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500113 interrupt-parent = <&UIC0>;
David Gibson71f34972008-05-15 16:46:39 +1000114 interrupts = <0x1 0x4>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500115 };
116
117 IIC: i2c@ef600500 {
118 compatible = "ibm,iic-405gp", "ibm,iic";
David Gibson71f34972008-05-15 16:46:39 +1000119 reg = <0xef600500 0x00000011>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500120 interrupt-parent = <&UIC0>;
David Gibson71f34972008-05-15 16:46:39 +1000121 interrupts = <0x2 0x4>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500122 };
123
124 GPIO: gpio@ef600700 {
125 compatible = "ibm,gpio-405gp";
David Gibson71f34972008-05-15 16:46:39 +1000126 reg = <0xef600700 0x00000020>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500127 };
128
129 EMAC: ethernet@ef600800 {
Josh Boyer8852ab72007-09-07 07:50:50 -0500130 device_type = "network";
131 compatible = "ibm,emac-405gp", "ibm,emac";
132 interrupt-parent = <&UIC0>;
Steven A. Falco29273152007-11-01 04:52:53 +1100133 interrupts = <
David Gibson71f34972008-05-15 16:46:39 +1000134 0xf 0x4 /* Ethernet */
135 0x9 0x4 /* Ethernet Wake Up */>;
Josh Boyerb3af7a52007-10-20 00:53:11 +1000136 local-mac-address = [000000000000]; /* Filled in by zImage */
David Gibson71f34972008-05-15 16:46:39 +1000137 reg = <0xef600800 0x00000070>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500138 mal-device = <&MAL>;
Josh Boyerb3af7a52007-10-20 00:53:11 +1000139 mal-tx-channel = <0>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500140 mal-rx-channel = <0>;
141 cell-index = <0>;
David Gibson71f34972008-05-15 16:46:39 +1000142 max-frame-size = <1500>;
143 rx-fifo-size = <4096>;
144 tx-fifo-size = <2048>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500145 phy-mode = "rmii";
David Gibson71f34972008-05-15 16:46:39 +1000146 phy-map = <0x00000001>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500147 };
148
149 };
150
151 EBC0: ebc {
152 compatible = "ibm,ebc-405gp", "ibm,ebc";
David Gibson71f34972008-05-15 16:46:39 +1000153 dcr-reg = <0x012 0x002>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500154 #address-cells = <2>;
155 #size-cells = <1>;
Josh Boyerbf07f322007-09-15 04:54:13 +1000156 /* The ranges property is supplied by the bootwrapper
157 * and is based on the firmware's configuration of the
158 * EBC bridge
159 */
Josh Boyer8852ab72007-09-07 07:50:50 -0500160 clock-frequency = <0>; /* Filled in by zImage */
161
162 sram@0,0 {
David Gibson71f34972008-05-15 16:46:39 +1000163 reg = <0x00000000 0x00000000 0x00080000>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500164 };
165
166 flash@0,80000 {
Josh Boyerbf07f322007-09-15 04:54:13 +1000167 compatible = "jedec-flash";
Josh Boyer8852ab72007-09-07 07:50:50 -0500168 bank-width = <1>;
David Gibson71f34972008-05-15 16:46:39 +1000169 reg = <0x00000000 0x00080000 0x00080000>;
Josh Boyerbf07f322007-09-15 04:54:13 +1000170 #address-cells = <1>;
171 #size-cells = <1>;
172 partition@0 {
173 label = "OpenBIOS";
David Gibson71f34972008-05-15 16:46:39 +1000174 reg = <0x00000000 0x00080000>;
Josh Boyerbf07f322007-09-15 04:54:13 +1000175 read-only;
176 };
Josh Boyer8852ab72007-09-07 07:50:50 -0500177 };
178
David Gibson22258fa2008-01-11 14:25:34 +1100179 nvram@1,0 {
Josh Boyer8852ab72007-09-07 07:50:50 -0500180 /* NVRAM and RTC */
David Gibson22258fa2008-01-11 14:25:34 +1100181 compatible = "ds1743-nvram";
David Gibson71f34972008-05-15 16:46:39 +1000182 #bytes = <0x2000>;
183 reg = <0x00000001 0x00000000 0x00002000>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500184 };
185
186 keyboard@2,0 {
187 compatible = "intel,82C42PC";
David Gibson71f34972008-05-15 16:46:39 +1000188 reg = <0x00000002 0x00000000 0x00000002>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500189 };
190
191 ir@3,0 {
192 compatible = "ti,TIR2000PAG";
David Gibson71f34972008-05-15 16:46:39 +1000193 reg = <0x00000003 0x00000000 0x00000010>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500194 };
195
196 fpga@7,0 {
197 compatible = "Walnut-FPGA";
David Gibson71f34972008-05-15 16:46:39 +1000198 reg = <0x00000007 0x00000000 0x00000010>;
199 virtual-reg = <0xf0300005>;
Josh Boyer8852ab72007-09-07 07:50:50 -0500200 };
201 };
Benjamin Herrenschmidt379865d2007-12-21 15:39:28 +1100202
203 PCI0: pci@ec000000 {
204 device_type = "pci";
205 #interrupt-cells = <1>;
206 #size-cells = <2>;
207 #address-cells = <3>;
208 compatible = "ibm,plb405gp-pci", "ibm,plb-pci";
209 primary;
David Gibson71f34972008-05-15 16:46:39 +1000210 reg = <0xeec00000 0x00000008 /* Config space access */
211 0xeed80000 0x00000004 /* IACK */
212 0xeed80000 0x00000004 /* Special cycle */
213 0xef480000 0x00000040>; /* Internal registers */
Benjamin Herrenschmidt379865d2007-12-21 15:39:28 +1100214
215 /* Outbound ranges, one memory and one IO,
216 * later cannot be changed. Chip supports a second
217 * IO range but we don't use it for now
218 */
David Gibson71f34972008-05-15 16:46:39 +1000219 ranges = <0x02000000 0x00000000 0x80000000 0x80000000 0x00000000 0x20000000
220 0x01000000 0x00000000 0x00000000 0xe8000000 0x00000000 0x00010000>;
Benjamin Herrenschmidt379865d2007-12-21 15:39:28 +1100221
222 /* Inbound 2GB range starting at 0 */
David Gibson71f34972008-05-15 16:46:39 +1000223 dma-ranges = <0x42000000 0x0 0x0 0x0 0x0 0x80000000>;
Benjamin Herrenschmidt379865d2007-12-21 15:39:28 +1100224
225 /* Walnut has all 4 IRQ pins tied together per slot */
David Gibson71f34972008-05-15 16:46:39 +1000226 interrupt-map-mask = <0xf800 0x0 0x0 0x0>;
Benjamin Herrenschmidt379865d2007-12-21 15:39:28 +1100227 interrupt-map = <
228 /* IDSEL 1 */
David Gibson71f34972008-05-15 16:46:39 +1000229 0x800 0x0 0x0 0x0 &UIC0 0x1c 0x8
Benjamin Herrenschmidt379865d2007-12-21 15:39:28 +1100230
231 /* IDSEL 2 */
David Gibson71f34972008-05-15 16:46:39 +1000232 0x1000 0x0 0x0 0x0 &UIC0 0x1d 0x8
Benjamin Herrenschmidt379865d2007-12-21 15:39:28 +1100233
234 /* IDSEL 3 */
David Gibson71f34972008-05-15 16:46:39 +1000235 0x1800 0x0 0x0 0x0 &UIC0 0x1e 0x8
Benjamin Herrenschmidt379865d2007-12-21 15:39:28 +1100236
237 /* IDSEL 4 */
David Gibson71f34972008-05-15 16:46:39 +1000238 0x2000 0x0 0x0 0x0 &UIC0 0x1f 0x8
Benjamin Herrenschmidt379865d2007-12-21 15:39:28 +1100239 >;
240 };
Josh Boyer8852ab72007-09-07 07:50:50 -0500241 };
242
243 chosen {
244 linux,stdout-path = "/plb/opb/serial@ef600300";
245 };
246};