Loading...
1/*
2 * TQM 8540 Device Tree Source
3 *
4 * Copyright 2008 Freescale Semiconductor Inc.
5 *
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2 of the License, or (at your
9 * option) any later version.
10 */
11
12/dts-v1/;
13
14/ {
15 model = "tqc,tqm8540";
16 compatible = "tqc,tqm8540";
17 #address-cells = <1>;
18 #size-cells = <1>;
19
20 aliases {
21 ethernet0 = &enet0;
22 ethernet1 = &enet1;
23 ethernet2 = &enet2;
24 serial0 = &serial0;
25 serial1 = &serial1;
26 pci0 = &pci0;
27 };
28
29 cpus {
30 #address-cells = <1>;
31 #size-cells = <0>;
32
33 PowerPC,8540@0 {
34 device_type = "cpu";
35 reg = <0>;
36 d-cache-line-size = <32>;
37 i-cache-line-size = <32>;
38 d-cache-size = <32768>;
39 i-cache-size = <32768>;
40 timebase-frequency = <0>;
41 bus-frequency = <0>;
42 clock-frequency = <0>;
43 next-level-cache = <&L2>;
44 };
45 };
46
47 memory {
48 device_type = "memory";
49 reg = <0x00000000 0x10000000>;
50 };
51
52 soc@e0000000 {
53 #address-cells = <1>;
54 #size-cells = <1>;
55 device_type = "soc";
56 ranges = <0x0 0xe0000000 0x100000>;
57 bus-frequency = <0>;
58 compatible = "fsl,mpc8540-immr", "simple-bus";
59
60 ecm-law@0 {
61 compatible = "fsl,ecm-law";
62 reg = <0x0 0x1000>;
63 fsl,num-laws = <8>;
64 };
65
66 ecm@1000 {
67 compatible = "fsl,mpc8540-ecm", "fsl,ecm";
68 reg = <0x1000 0x1000>;
69 interrupts = <17 2>;
70 interrupt-parent = <&mpic>;
71 };
72
73 memory-controller@2000 {
74 compatible = "fsl,mpc8540-memory-controller";
75 reg = <0x2000 0x1000>;
76 interrupt-parent = <&mpic>;
77 interrupts = <18 2>;
78 };
79
80 L2: l2-cache-controller@20000 {
81 compatible = "fsl,mpc8540-l2-cache-controller";
82 reg = <0x20000 0x1000>;
83 cache-line-size = <32>;
84 cache-size = <0x40000>; // L2, 256K
85 interrupt-parent = <&mpic>;
86 interrupts = <16 2>;
87 };
88
89 i2c@3000 {
90 #address-cells = <1>;
91 #size-cells = <0>;
92 cell-index = <0>;
93 compatible = "fsl-i2c";
94 reg = <0x3000 0x100>;
95 interrupts = <43 2>;
96 interrupt-parent = <&mpic>;
97 dfsrr;
98
99 dtt@48 {
100 compatible = "national,lm75";
101 reg = <0x48>;
102 };
103
104 rtc@68 {
105 compatible = "dallas,ds1337";
106 reg = <0x68>;
107 };
108 };
109
110 dma@21300 {
111 #address-cells = <1>;
112 #size-cells = <1>;
113 compatible = "fsl,mpc8540-dma", "fsl,eloplus-dma";
114 reg = <0x21300 0x4>;
115 ranges = <0x0 0x21100 0x200>;
116 cell-index = <0>;
117 dma-channel@0 {
118 compatible = "fsl,mpc8540-dma-channel",
119 "fsl,eloplus-dma-channel";
120 reg = <0x0 0x80>;
121 cell-index = <0>;
122 interrupt-parent = <&mpic>;
123 interrupts = <20 2>;
124 };
125 dma-channel@80 {
126 compatible = "fsl,mpc8540-dma-channel",
127 "fsl,eloplus-dma-channel";
128 reg = <0x80 0x80>;
129 cell-index = <1>;
130 interrupt-parent = <&mpic>;
131 interrupts = <21 2>;
132 };
133 dma-channel@100 {
134 compatible = "fsl,mpc8540-dma-channel",
135 "fsl,eloplus-dma-channel";
136 reg = <0x100 0x80>;
137 cell-index = <2>;
138 interrupt-parent = <&mpic>;
139 interrupts = <22 2>;
140 };
141 dma-channel@180 {
142 compatible = "fsl,mpc8540-dma-channel",
143 "fsl,eloplus-dma-channel";
144 reg = <0x180 0x80>;
145 cell-index = <3>;
146 interrupt-parent = <&mpic>;
147 interrupts = <23 2>;
148 };
149 };
150
151 enet0: ethernet@24000 {
152 #address-cells = <1>;
153 #size-cells = <1>;
154 cell-index = <0>;
155 device_type = "network";
156 model = "TSEC";
157 compatible = "gianfar";
158 reg = <0x24000 0x1000>;
159 ranges = <0x0 0x24000 0x1000>;
160 local-mac-address = [ 00 00 00 00 00 00 ];
161 interrupts = <29 2 30 2 34 2>;
162 interrupt-parent = <&mpic>;
163 phy-handle = <&phy2>;
164
165 mdio@520 {
166 #address-cells = <1>;
167 #size-cells = <0>;
168 compatible = "fsl,gianfar-mdio";
169 reg = <0x520 0x20>;
170
171 phy1: ethernet-phy@1 {
172 interrupt-parent = <&mpic>;
173 interrupts = <8 1>;
174 reg = <1>;
175 };
176 phy2: ethernet-phy@2 {
177 interrupt-parent = <&mpic>;
178 interrupts = <8 1>;
179 reg = <2>;
180 };
181 phy3: ethernet-phy@3 {
182 interrupt-parent = <&mpic>;
183 interrupts = <8 1>;
184 reg = <3>;
185 };
186 tbi0: tbi-phy@11 {
187 reg = <0x11>;
188 device_type = "tbi-phy";
189 };
190 };
191 };
192
193 enet1: ethernet@25000 {
194 #address-cells = <1>;
195 #size-cells = <1>;
196 cell-index = <1>;
197 device_type = "network";
198 model = "TSEC";
199 compatible = "gianfar";
200 reg = <0x25000 0x1000>;
201 ranges = <0x0 0x25000 0x1000>;
202 local-mac-address = [ 00 00 00 00 00 00 ];
203 interrupts = <35 2 36 2 40 2>;
204 interrupt-parent = <&mpic>;
205 phy-handle = <&phy1>;
206
207 mdio@520 {
208 #address-cells = <1>;
209 #size-cells = <0>;
210 compatible = "fsl,gianfar-tbi";
211 reg = <0x520 0x20>;
212
213 tbi1: tbi-phy@11 {
214 reg = <0x11>;
215 device_type = "tbi-phy";
216 };
217 };
218 };
219
220 enet2: ethernet@26000 {
221 #address-cells = <1>;
222 #size-cells = <1>;
223 cell-index = <2>;
224 device_type = "network";
225 model = "FEC";
226 compatible = "gianfar";
227 reg = <0x26000 0x1000>;
228 ranges = <0x0 0x26000 0x1000>;
229 local-mac-address = [ 00 00 00 00 00 00 ];
230 interrupts = <41 2>;
231 interrupt-parent = <&mpic>;
232 phy-handle = <&phy3>;
233
234 mdio@520 {
235 #address-cells = <1>;
236 #size-cells = <0>;
237 compatible = "fsl,gianfar-tbi";
238 reg = <0x520 0x20>;
239
240 tbi2: tbi-phy@11 {
241 reg = <0x11>;
242 device_type = "tbi-phy";
243 };
244 };
245 };
246
247 serial0: serial@4500 {
248 cell-index = <0>;
249 device_type = "serial";
250 compatible = "fsl,ns16550", "ns16550";
251 reg = <0x4500 0x100>; // reg base, size
252 clock-frequency = <0>; // should we fill in in uboot?
253 interrupts = <42 2>;
254 interrupt-parent = <&mpic>;
255 };
256
257 serial1: serial@4600 {
258 cell-index = <1>;
259 device_type = "serial";
260 compatible = "fsl,ns16550", "ns16550";
261 reg = <0x4600 0x100>; // reg base, size
262 clock-frequency = <0>; // should we fill in in uboot?
263 interrupts = <42 2>;
264 interrupt-parent = <&mpic>;
265 };
266
267 mpic: pic@40000 {
268 interrupt-controller;
269 #address-cells = <0>;
270 #interrupt-cells = <2>;
271 reg = <0x40000 0x40000>;
272 device_type = "open-pic";
273 compatible = "chrp,open-pic";
274 };
275 };
276
277 localbus@e0005000 {
278 #address-cells = <2>;
279 #size-cells = <1>;
280 compatible = "fsl,mpc8540-localbus", "fsl,pq3-localbus",
281 "simple-bus";
282 reg = <0xe0005000 0x1000>;
283 interrupt-parent = <&mpic>;
284 interrupts = <19 2>;
285
286 ranges = <0x0 0x0 0xfe000000 0x02000000>;
287
288 nor@0,0 {
289 #address-cells = <1>;
290 #size-cells = <1>;
291 compatible = "cfi-flash";
292 reg = <0x0 0x0 0x02000000>;
293 bank-width = <4>;
294 device-width = <2>;
295 partition@0 {
296 label = "kernel";
297 reg = <0x00000000 0x00180000>;
298 };
299 partition@180000 {
300 label = "root";
301 reg = <0x00180000 0x01dc0000>;
302 };
303 partition@1f40000 {
304 label = "env1";
305 reg = <0x01f40000 0x00040000>;
306 };
307 partition@1f80000 {
308 label = "env2";
309 reg = <0x01f80000 0x00040000>;
310 };
311 partition@1fc0000 {
312 label = "u-boot";
313 reg = <0x01fc0000 0x00040000>;
314 read-only;
315 };
316 };
317 };
318
319 pci0: pci@e0008000 {
320 #interrupt-cells = <1>;
321 #size-cells = <2>;
322 #address-cells = <3>;
323 compatible = "fsl,mpc8540-pcix", "fsl,mpc8540-pci";
324 device_type = "pci";
325 reg = <0xe0008000 0x1000>;
326 clock-frequency = <66666666>;
327 interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
328 interrupt-map = <
329 /* IDSEL 28 */
330 0xe000 0 0 1 &mpic 2 1
331 0xe000 0 0 2 &mpic 3 1
332 0xe000 0 0 3 &mpic 6 1
333 0xe000 0 0 4 &mpic 5 1
334
335 /* IDSEL 11 */
336 0x5800 0 0 1 &mpic 6 1
337 0x5800 0 0 2 &mpic 5 1
338 >;
339
340 interrupt-parent = <&mpic>;
341 interrupts = <24 2>;
342 bus-range = <0 0>;
343 ranges = <0x02000000 0 0x80000000 0x80000000 0 0x20000000
344 0x01000000 0 0x00000000 0xe2000000 0 0x01000000>;
345 };
346};
1// SPDX-License-Identifier: GPL-2.0-or-later
2/*
3 * TQM 8540 Device Tree Source
4 *
5 * Copyright 2008 Freescale Semiconductor Inc.
6 */
7
8/dts-v1/;
9
10/include/ "fsl/e500v1_power_isa.dtsi"
11
12/ {
13 model = "tqc,tqm8540";
14 compatible = "tqc,tqm8540";
15 #address-cells = <1>;
16 #size-cells = <1>;
17
18 aliases {
19 ethernet0 = &enet0;
20 ethernet1 = &enet1;
21 ethernet2 = &enet2;
22 serial0 = &serial0;
23 serial1 = &serial1;
24 pci0 = &pci0;
25 };
26
27 cpus {
28 #address-cells = <1>;
29 #size-cells = <0>;
30
31 PowerPC,8540@0 {
32 device_type = "cpu";
33 reg = <0>;
34 d-cache-line-size = <32>;
35 i-cache-line-size = <32>;
36 d-cache-size = <32768>;
37 i-cache-size = <32768>;
38 timebase-frequency = <0>;
39 bus-frequency = <0>;
40 clock-frequency = <0>;
41 next-level-cache = <&L2>;
42 };
43 };
44
45 memory {
46 device_type = "memory";
47 reg = <0x00000000 0x10000000>;
48 };
49
50 soc@e0000000 {
51 #address-cells = <1>;
52 #size-cells = <1>;
53 device_type = "soc";
54 ranges = <0x0 0xe0000000 0x100000>;
55 bus-frequency = <0>;
56 compatible = "fsl,mpc8540-immr", "simple-bus";
57
58 ecm-law@0 {
59 compatible = "fsl,ecm-law";
60 reg = <0x0 0x1000>;
61 fsl,num-laws = <8>;
62 };
63
64 ecm@1000 {
65 compatible = "fsl,mpc8540-ecm", "fsl,ecm";
66 reg = <0x1000 0x1000>;
67 interrupts = <17 2>;
68 interrupt-parent = <&mpic>;
69 };
70
71 memory-controller@2000 {
72 compatible = "fsl,mpc8540-memory-controller";
73 reg = <0x2000 0x1000>;
74 interrupt-parent = <&mpic>;
75 interrupts = <18 2>;
76 };
77
78 L2: l2-cache-controller@20000 {
79 compatible = "fsl,mpc8540-l2-cache-controller";
80 reg = <0x20000 0x1000>;
81 cache-line-size = <32>;
82 cache-size = <0x40000>; // L2, 256K
83 interrupt-parent = <&mpic>;
84 interrupts = <16 2>;
85 };
86
87 i2c@3000 {
88 #address-cells = <1>;
89 #size-cells = <0>;
90 cell-index = <0>;
91 compatible = "fsl-i2c";
92 reg = <0x3000 0x100>;
93 interrupts = <43 2>;
94 interrupt-parent = <&mpic>;
95 dfsrr;
96
97 dtt@48 {
98 compatible = "national,lm75";
99 reg = <0x48>;
100 };
101
102 rtc@68 {
103 compatible = "dallas,ds1337";
104 reg = <0x68>;
105 };
106 };
107
108 dma@21300 {
109 #address-cells = <1>;
110 #size-cells = <1>;
111 compatible = "fsl,mpc8540-dma", "fsl,eloplus-dma";
112 reg = <0x21300 0x4>;
113 ranges = <0x0 0x21100 0x200>;
114 cell-index = <0>;
115 dma-channel@0 {
116 compatible = "fsl,mpc8540-dma-channel",
117 "fsl,eloplus-dma-channel";
118 reg = <0x0 0x80>;
119 cell-index = <0>;
120 interrupt-parent = <&mpic>;
121 interrupts = <20 2>;
122 };
123 dma-channel@80 {
124 compatible = "fsl,mpc8540-dma-channel",
125 "fsl,eloplus-dma-channel";
126 reg = <0x80 0x80>;
127 cell-index = <1>;
128 interrupt-parent = <&mpic>;
129 interrupts = <21 2>;
130 };
131 dma-channel@100 {
132 compatible = "fsl,mpc8540-dma-channel",
133 "fsl,eloplus-dma-channel";
134 reg = <0x100 0x80>;
135 cell-index = <2>;
136 interrupt-parent = <&mpic>;
137 interrupts = <22 2>;
138 };
139 dma-channel@180 {
140 compatible = "fsl,mpc8540-dma-channel",
141 "fsl,eloplus-dma-channel";
142 reg = <0x180 0x80>;
143 cell-index = <3>;
144 interrupt-parent = <&mpic>;
145 interrupts = <23 2>;
146 };
147 };
148
149 enet0: ethernet@24000 {
150 #address-cells = <1>;
151 #size-cells = <1>;
152 cell-index = <0>;
153 device_type = "network";
154 model = "TSEC";
155 compatible = "gianfar";
156 reg = <0x24000 0x1000>;
157 ranges = <0x0 0x24000 0x1000>;
158 local-mac-address = [ 00 00 00 00 00 00 ];
159 interrupts = <29 2 30 2 34 2>;
160 interrupt-parent = <&mpic>;
161 phy-handle = <&phy2>;
162
163 mdio@520 {
164 #address-cells = <1>;
165 #size-cells = <0>;
166 compatible = "fsl,gianfar-mdio";
167 reg = <0x520 0x20>;
168
169 phy1: ethernet-phy@1 {
170 interrupt-parent = <&mpic>;
171 interrupts = <8 1>;
172 reg = <1>;
173 };
174 phy2: ethernet-phy@2 {
175 interrupt-parent = <&mpic>;
176 interrupts = <8 1>;
177 reg = <2>;
178 };
179 phy3: ethernet-phy@3 {
180 interrupt-parent = <&mpic>;
181 interrupts = <8 1>;
182 reg = <3>;
183 };
184 tbi0: tbi-phy@11 {
185 reg = <0x11>;
186 device_type = "tbi-phy";
187 };
188 };
189 };
190
191 enet1: ethernet@25000 {
192 #address-cells = <1>;
193 #size-cells = <1>;
194 cell-index = <1>;
195 device_type = "network";
196 model = "TSEC";
197 compatible = "gianfar";
198 reg = <0x25000 0x1000>;
199 ranges = <0x0 0x25000 0x1000>;
200 local-mac-address = [ 00 00 00 00 00 00 ];
201 interrupts = <35 2 36 2 40 2>;
202 interrupt-parent = <&mpic>;
203 phy-handle = <&phy1>;
204
205 mdio@520 {
206 #address-cells = <1>;
207 #size-cells = <0>;
208 compatible = "fsl,gianfar-tbi";
209 reg = <0x520 0x20>;
210
211 tbi1: tbi-phy@11 {
212 reg = <0x11>;
213 device_type = "tbi-phy";
214 };
215 };
216 };
217
218 enet2: ethernet@26000 {
219 #address-cells = <1>;
220 #size-cells = <1>;
221 cell-index = <2>;
222 device_type = "network";
223 model = "FEC";
224 compatible = "gianfar";
225 reg = <0x26000 0x1000>;
226 ranges = <0x0 0x26000 0x1000>;
227 local-mac-address = [ 00 00 00 00 00 00 ];
228 interrupts = <41 2>;
229 interrupt-parent = <&mpic>;
230 phy-handle = <&phy3>;
231
232 mdio@520 {
233 #address-cells = <1>;
234 #size-cells = <0>;
235 compatible = "fsl,gianfar-tbi";
236 reg = <0x520 0x20>;
237
238 tbi2: tbi-phy@11 {
239 reg = <0x11>;
240 device_type = "tbi-phy";
241 };
242 };
243 };
244
245 serial0: serial@4500 {
246 cell-index = <0>;
247 device_type = "serial";
248 compatible = "fsl,ns16550", "ns16550";
249 reg = <0x4500 0x100>; // reg base, size
250 clock-frequency = <0>; // should we fill in in uboot?
251 interrupts = <42 2>;
252 interrupt-parent = <&mpic>;
253 };
254
255 serial1: serial@4600 {
256 cell-index = <1>;
257 device_type = "serial";
258 compatible = "fsl,ns16550", "ns16550";
259 reg = <0x4600 0x100>; // reg base, size
260 clock-frequency = <0>; // should we fill in in uboot?
261 interrupts = <42 2>;
262 interrupt-parent = <&mpic>;
263 };
264
265 mpic: pic@40000 {
266 interrupt-controller;
267 #address-cells = <0>;
268 #interrupt-cells = <2>;
269 reg = <0x40000 0x40000>;
270 device_type = "open-pic";
271 compatible = "chrp,open-pic";
272 };
273 };
274
275 localbus@e0005000 {
276 #address-cells = <2>;
277 #size-cells = <1>;
278 compatible = "fsl,mpc8540-localbus", "fsl,pq3-localbus",
279 "simple-bus";
280 reg = <0xe0005000 0x1000>;
281 interrupt-parent = <&mpic>;
282 interrupts = <19 2>;
283
284 ranges = <0x0 0x0 0xfe000000 0x02000000>;
285
286 nor@0,0 {
287 #address-cells = <1>;
288 #size-cells = <1>;
289 compatible = "cfi-flash";
290 reg = <0x0 0x0 0x02000000>;
291 bank-width = <4>;
292 device-width = <2>;
293 partition@0 {
294 label = "kernel";
295 reg = <0x00000000 0x00180000>;
296 };
297 partition@180000 {
298 label = "root";
299 reg = <0x00180000 0x01dc0000>;
300 };
301 partition@1f40000 {
302 label = "env1";
303 reg = <0x01f40000 0x00040000>;
304 };
305 partition@1f80000 {
306 label = "env2";
307 reg = <0x01f80000 0x00040000>;
308 };
309 partition@1fc0000 {
310 label = "u-boot";
311 reg = <0x01fc0000 0x00040000>;
312 read-only;
313 };
314 };
315 };
316
317 pci0: pci@e0008000 {
318 #interrupt-cells = <1>;
319 #size-cells = <2>;
320 #address-cells = <3>;
321 compatible = "fsl,mpc8540-pcix", "fsl,mpc8540-pci";
322 device_type = "pci";
323 reg = <0xe0008000 0x1000>;
324 clock-frequency = <66666666>;
325 interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
326 interrupt-map = <
327 /* IDSEL 28 */
328 0xe000 0 0 1 &mpic 2 1
329 0xe000 0 0 2 &mpic 3 1
330 0xe000 0 0 3 &mpic 6 1
331 0xe000 0 0 4 &mpic 5 1
332
333 /* IDSEL 11 */
334 0x5800 0 0 1 &mpic 6 1
335 0x5800 0 0 2 &mpic 5 1
336 >;
337
338 interrupt-parent = <&mpic>;
339 interrupts = <24 2>;
340 bus-range = <0 0>;
341 ranges = <0x02000000 0 0x80000000 0x80000000 0 0x20000000
342 0x01000000 0 0x00000000 0xe2000000 0 0x01000000>;
343 };
344};