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 device_type = "ethernet-phy";
176 };
177 phy2: ethernet-phy@2 {
178 interrupt-parent = <&mpic>;
179 interrupts = <8 1>;
180 reg = <2>;
181 device_type = "ethernet-phy";
182 };
183 phy3: ethernet-phy@3 {
184 interrupt-parent = <&mpic>;
185 interrupts = <8 1>;
186 reg = <3>;
187 device_type = "ethernet-phy";
188 };
189 tbi0: tbi-phy@11 {
190 reg = <0x11>;
191 device_type = "tbi-phy";
192 };
193 };
194 };
195
196 enet1: ethernet@25000 {
197 #address-cells = <1>;
198 #size-cells = <1>;
199 cell-index = <1>;
200 device_type = "network";
201 model = "TSEC";
202 compatible = "gianfar";
203 reg = <0x25000 0x1000>;
204 ranges = <0x0 0x25000 0x1000>;
205 local-mac-address = [ 00 00 00 00 00 00 ];
206 interrupts = <35 2 36 2 40 2>;
207 interrupt-parent = <&mpic>;
208 phy-handle = <&phy1>;
209
210 mdio@520 {
211 #address-cells = <1>;
212 #size-cells = <0>;
213 compatible = "fsl,gianfar-tbi";
214 reg = <0x520 0x20>;
215
216 tbi1: tbi-phy@11 {
217 reg = <0x11>;
218 device_type = "tbi-phy";
219 };
220 };
221 };
222
223 enet2: ethernet@26000 {
224 #address-cells = <1>;
225 #size-cells = <1>;
226 cell-index = <2>;
227 device_type = "network";
228 model = "FEC";
229 compatible = "gianfar";
230 reg = <0x26000 0x1000>;
231 ranges = <0x0 0x26000 0x1000>;
232 local-mac-address = [ 00 00 00 00 00 00 ];
233 interrupts = <41 2>;
234 interrupt-parent = <&mpic>;
235 phy-handle = <&phy3>;
236
237 mdio@520 {
238 #address-cells = <1>;
239 #size-cells = <0>;
240 compatible = "fsl,gianfar-tbi";
241 reg = <0x520 0x20>;
242
243 tbi2: tbi-phy@11 {
244 reg = <0x11>;
245 device_type = "tbi-phy";
246 };
247 };
248 };
249
250 serial0: serial@4500 {
251 cell-index = <0>;
252 device_type = "serial";
253 compatible = "ns16550";
254 reg = <0x4500 0x100>; // reg base, size
255 clock-frequency = <0>; // should we fill in in uboot?
256 interrupts = <42 2>;
257 interrupt-parent = <&mpic>;
258 };
259
260 serial1: serial@4600 {
261 cell-index = <1>;
262 device_type = "serial";
263 compatible = "ns16550";
264 reg = <0x4600 0x100>; // reg base, size
265 clock-frequency = <0>; // should we fill in in uboot?
266 interrupts = <42 2>;
267 interrupt-parent = <&mpic>;
268 };
269
270 mpic: pic@40000 {
271 interrupt-controller;
272 #address-cells = <0>;
273 #interrupt-cells = <2>;
274 reg = <0x40000 0x40000>;
275 device_type = "open-pic";
276 compatible = "chrp,open-pic";
277 };
278 };
279
280 localbus@e0005000 {
281 #address-cells = <2>;
282 #size-cells = <1>;
283 compatible = "fsl,mpc8540-localbus", "fsl,pq3-localbus",
284 "simple-bus";
285 reg = <0xe0005000 0x1000>;
286 interrupt-parent = <&mpic>;
287 interrupts = <19 2>;
288
289 ranges = <0x0 0x0 0xfe000000 0x02000000>;
290
291 nor@0,0 {
292 #address-cells = <1>;
293 #size-cells = <1>;
294 compatible = "cfi-flash";
295 reg = <0x0 0x0 0x02000000>;
296 bank-width = <4>;
297 device-width = <2>;
298 partition@0 {
299 label = "kernel";
300 reg = <0x00000000 0x00180000>;
301 };
302 partition@180000 {
303 label = "root";
304 reg = <0x00180000 0x01dc0000>;
305 };
306 partition@1f40000 {
307 label = "env1";
308 reg = <0x01f40000 0x00040000>;
309 };
310 partition@1f80000 {
311 label = "env2";
312 reg = <0x01f80000 0x00040000>;
313 };
314 partition@1fc0000 {
315 label = "u-boot";
316 reg = <0x01fc0000 0x00040000>;
317 read-only;
318 };
319 };
320 };
321
322 pci0: pci@e0008000 {
323 #interrupt-cells = <1>;
324 #size-cells = <2>;
325 #address-cells = <3>;
326 compatible = "fsl,mpc8540-pcix", "fsl,mpc8540-pci";
327 device_type = "pci";
328 reg = <0xe0008000 0x1000>;
329 clock-frequency = <66666666>;
330 interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
331 interrupt-map = <
332 /* IDSEL 28 */
333 0xe000 0 0 1 &mpic 2 1
334 0xe000 0 0 2 &mpic 3 1
335 0xe000 0 0 3 &mpic 6 1
336 0xe000 0 0 4 &mpic 5 1
337
338 /* IDSEL 11 */
339 0x5800 0 0 1 &mpic 6 1
340 0x5800 0 0 2 &mpic 5 1
341 >;
342
343 interrupt-parent = <&mpic>;
344 interrupts = <24 2>;
345 bus-range = <0 0>;
346 ranges = <0x02000000 0 0x80000000 0x80000000 0 0x20000000
347 0x01000000 0 0x00000000 0xe2000000 0 0x01000000>;
348 };
349};
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};