1/*
2 * Cavium Thunder DTS file - Thunder SoC description
3 *
4 * Copyright (C) 2014, Cavium Inc.
5 *
6 * This file is dual-licensed: you can use it either under the terms
7 * of the GPL or the X11 license, at your option. Note that this dual
8 * licensing only applies to this file, and not this project as a
9 * whole.
10 *
11 *  a) This library is free software; you can redistribute it and/or
12 *     modify it under the terms of the GNU General Public License as
13 *     published by the Free Software Foundation; either version 2 of the
14 *     License, or (at your option) any later version.
15 *
16 *     This library is distributed in the hope that it will be useful,
17 *     but WITHOUT ANY WARRANTY; without even the implied warranty of
18 *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19 *     GNU General Public License for more details.
20 *
21 *     You should have received a copy of the GNU General Public
22 *     License along with this library; if not, write to the Free
23 *     Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
24 *     MA 02110-1301 USA
25 *
26 * Or, alternatively,
27 *
28 *  b) Permission is hereby granted, free of charge, to any person
29 *     obtaining a copy of this software and associated documentation
30 *     files (the "Software"), to deal in the Software without
31 *     restriction, including without limitation the rights to use,
32 *     copy, modify, merge, publish, distribute, sublicense, and/or
33 *     sell copies of the Software, and to permit persons to whom the
34 *     Software is furnished to do so, subject to the following
35 *     conditions:
36 *
37 *     The above copyright notice and this permission notice shall be
38 *     included in all copies or substantial portions of the Software.
39 *
40 *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
41 *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
42 *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
43 *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
44 *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
45 *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
46 *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
47 *     OTHER DEALINGS IN THE SOFTWARE.
48 */
49
50/ {
51	compatible = "cavium,thunder-88xx";
52	interrupt-parent = <&gic0>;
53	#address-cells = <2>;
54	#size-cells = <2>;
55
56	psci {
57		compatible = "arm,psci-0.2";
58		method = "smc";
59	};
60
61	cpus {
62		#address-cells = <2>;
63		#size-cells = <0>;
64
65		cpu@000 {
66			device_type = "cpu";
67			compatible = "cavium,thunder", "arm,armv8";
68			reg = <0x0 0x000>;
69			enable-method = "psci";
70		};
71		cpu@001 {
72			device_type = "cpu";
73			compatible = "cavium,thunder", "arm,armv8";
74			reg = <0x0 0x001>;
75			enable-method = "psci";
76		};
77		cpu@002 {
78			device_type = "cpu";
79			compatible = "cavium,thunder", "arm,armv8";
80			reg = <0x0 0x002>;
81			enable-method = "psci";
82		};
83		cpu@003 {
84			device_type = "cpu";
85			compatible = "cavium,thunder", "arm,armv8";
86			reg = <0x0 0x003>;
87			enable-method = "psci";
88		};
89		cpu@004 {
90			device_type = "cpu";
91			compatible = "cavium,thunder", "arm,armv8";
92			reg = <0x0 0x004>;
93			enable-method = "psci";
94		};
95		cpu@005 {
96			device_type = "cpu";
97			compatible = "cavium,thunder", "arm,armv8";
98			reg = <0x0 0x005>;
99			enable-method = "psci";
100		};
101		cpu@006 {
102			device_type = "cpu";
103			compatible = "cavium,thunder", "arm,armv8";
104			reg = <0x0 0x006>;
105			enable-method = "psci";
106		};
107		cpu@007 {
108			device_type = "cpu";
109			compatible = "cavium,thunder", "arm,armv8";
110			reg = <0x0 0x007>;
111			enable-method = "psci";
112		};
113		cpu@008 {
114			device_type = "cpu";
115			compatible = "cavium,thunder", "arm,armv8";
116			reg = <0x0 0x008>;
117			enable-method = "psci";
118		};
119		cpu@009 {
120			device_type = "cpu";
121			compatible = "cavium,thunder", "arm,armv8";
122			reg = <0x0 0x009>;
123			enable-method = "psci";
124		};
125		cpu@00a {
126			device_type = "cpu";
127			compatible = "cavium,thunder", "arm,armv8";
128			reg = <0x0 0x00a>;
129			enable-method = "psci";
130		};
131		cpu@00b {
132			device_type = "cpu";
133			compatible = "cavium,thunder", "arm,armv8";
134			reg = <0x0 0x00b>;
135			enable-method = "psci";
136		};
137		cpu@00c {
138			device_type = "cpu";
139			compatible = "cavium,thunder", "arm,armv8";
140			reg = <0x0 0x00c>;
141			enable-method = "psci";
142		};
143		cpu@00d {
144			device_type = "cpu";
145			compatible = "cavium,thunder", "arm,armv8";
146			reg = <0x0 0x00d>;
147			enable-method = "psci";
148		};
149		cpu@00e {
150			device_type = "cpu";
151			compatible = "cavium,thunder", "arm,armv8";
152			reg = <0x0 0x00e>;
153			enable-method = "psci";
154		};
155		cpu@00f {
156			device_type = "cpu";
157			compatible = "cavium,thunder", "arm,armv8";
158			reg = <0x0 0x00f>;
159			enable-method = "psci";
160		};
161		cpu@100 {
162			device_type = "cpu";
163			compatible = "cavium,thunder", "arm,armv8";
164			reg = <0x0 0x100>;
165			enable-method = "psci";
166		};
167		cpu@101 {
168			device_type = "cpu";
169			compatible = "cavium,thunder", "arm,armv8";
170			reg = <0x0 0x101>;
171			enable-method = "psci";
172		};
173		cpu@102 {
174			device_type = "cpu";
175			compatible = "cavium,thunder", "arm,armv8";
176			reg = <0x0 0x102>;
177			enable-method = "psci";
178		};
179		cpu@103 {
180			device_type = "cpu";
181			compatible = "cavium,thunder", "arm,armv8";
182			reg = <0x0 0x103>;
183			enable-method = "psci";
184		};
185		cpu@104 {
186			device_type = "cpu";
187			compatible = "cavium,thunder", "arm,armv8";
188			reg = <0x0 0x104>;
189			enable-method = "psci";
190		};
191		cpu@105 {
192			device_type = "cpu";
193			compatible = "cavium,thunder", "arm,armv8";
194			reg = <0x0 0x105>;
195			enable-method = "psci";
196		};
197		cpu@106 {
198			device_type = "cpu";
199			compatible = "cavium,thunder", "arm,armv8";
200			reg = <0x0 0x106>;
201			enable-method = "psci";
202		};
203		cpu@107 {
204			device_type = "cpu";
205			compatible = "cavium,thunder", "arm,armv8";
206			reg = <0x0 0x107>;
207			enable-method = "psci";
208		};
209		cpu@108 {
210			device_type = "cpu";
211			compatible = "cavium,thunder", "arm,armv8";
212			reg = <0x0 0x108>;
213			enable-method = "psci";
214		};
215		cpu@109 {
216			device_type = "cpu";
217			compatible = "cavium,thunder", "arm,armv8";
218			reg = <0x0 0x109>;
219			enable-method = "psci";
220		};
221		cpu@10a {
222			device_type = "cpu";
223			compatible = "cavium,thunder", "arm,armv8";
224			reg = <0x0 0x10a>;
225			enable-method = "psci";
226		};
227		cpu@10b {
228			device_type = "cpu";
229			compatible = "cavium,thunder", "arm,armv8";
230			reg = <0x0 0x10b>;
231			enable-method = "psci";
232		};
233		cpu@10c {
234			device_type = "cpu";
235			compatible = "cavium,thunder", "arm,armv8";
236			reg = <0x0 0x10c>;
237			enable-method = "psci";
238		};
239		cpu@10d {
240			device_type = "cpu";
241			compatible = "cavium,thunder", "arm,armv8";
242			reg = <0x0 0x10d>;
243			enable-method = "psci";
244		};
245		cpu@10e {
246			device_type = "cpu";
247			compatible = "cavium,thunder", "arm,armv8";
248			reg = <0x0 0x10e>;
249			enable-method = "psci";
250		};
251		cpu@10f {
252			device_type = "cpu";
253			compatible = "cavium,thunder", "arm,armv8";
254			reg = <0x0 0x10f>;
255			enable-method = "psci";
256		};
257		cpu@200 {
258			device_type = "cpu";
259			compatible = "cavium,thunder", "arm,armv8";
260			reg = <0x0 0x200>;
261			enable-method = "psci";
262		};
263		cpu@201 {
264			device_type = "cpu";
265			compatible = "cavium,thunder", "arm,armv8";
266			reg = <0x0 0x201>;
267			enable-method = "psci";
268		};
269		cpu@202 {
270			device_type = "cpu";
271			compatible = "cavium,thunder", "arm,armv8";
272			reg = <0x0 0x202>;
273			enable-method = "psci";
274		};
275		cpu@203 {
276			device_type = "cpu";
277			compatible = "cavium,thunder", "arm,armv8";
278			reg = <0x0 0x203>;
279			enable-method = "psci";
280		};
281		cpu@204 {
282			device_type = "cpu";
283			compatible = "cavium,thunder", "arm,armv8";
284			reg = <0x0 0x204>;
285			enable-method = "psci";
286		};
287		cpu@205 {
288			device_type = "cpu";
289			compatible = "cavium,thunder", "arm,armv8";
290			reg = <0x0 0x205>;
291			enable-method = "psci";
292		};
293		cpu@206 {
294			device_type = "cpu";
295			compatible = "cavium,thunder", "arm,armv8";
296			reg = <0x0 0x206>;
297			enable-method = "psci";
298		};
299		cpu@207 {
300			device_type = "cpu";
301			compatible = "cavium,thunder", "arm,armv8";
302			reg = <0x0 0x207>;
303			enable-method = "psci";
304		};
305		cpu@208 {
306			device_type = "cpu";
307			compatible = "cavium,thunder", "arm,armv8";
308			reg = <0x0 0x208>;
309			enable-method = "psci";
310		};
311		cpu@209 {
312			device_type = "cpu";
313			compatible = "cavium,thunder", "arm,armv8";
314			reg = <0x0 0x209>;
315			enable-method = "psci";
316		};
317		cpu@20a {
318			device_type = "cpu";
319			compatible = "cavium,thunder", "arm,armv8";
320			reg = <0x0 0x20a>;
321			enable-method = "psci";
322		};
323		cpu@20b {
324			device_type = "cpu";
325			compatible = "cavium,thunder", "arm,armv8";
326			reg = <0x0 0x20b>;
327			enable-method = "psci";
328		};
329		cpu@20c {
330			device_type = "cpu";
331			compatible = "cavium,thunder", "arm,armv8";
332			reg = <0x0 0x20c>;
333			enable-method = "psci";
334		};
335		cpu@20d {
336			device_type = "cpu";
337			compatible = "cavium,thunder", "arm,armv8";
338			reg = <0x0 0x20d>;
339			enable-method = "psci";
340		};
341		cpu@20e {
342			device_type = "cpu";
343			compatible = "cavium,thunder", "arm,armv8";
344			reg = <0x0 0x20e>;
345			enable-method = "psci";
346		};
347		cpu@20f {
348			device_type = "cpu";
349			compatible = "cavium,thunder", "arm,armv8";
350			reg = <0x0 0x20f>;
351			enable-method = "psci";
352		};
353	};
354
355	timer {
356		compatible = "arm,armv8-timer";
357		interrupts = <1 13 4>,
358		             <1 14 4>,
359		             <1 11 4>,
360		             <1 10 4>;
361	};
362
363	pmu {
364		compatible = "cavium,thunder-pmu", "arm,armv8-pmuv3";
365		interrupts = <1 7 4>;
366	};
367
368	soc {
369		compatible = "simple-bus";
370		#address-cells = <2>;
371		#size-cells = <2>;
372		ranges;
373
374		refclk50mhz: refclk50mhz {
375			compatible = "fixed-clock";
376			#clock-cells = <0>;
377			clock-frequency = <50000000>;
378			clock-output-names = "refclk50mhz";
379		};
380
381		gic0: interrupt-controller@8010,00000000 {
382			compatible = "arm,gic-v3";
383			#interrupt-cells = <3>;
384			#address-cells = <2>;
385			#size-cells = <2>;
386			ranges;
387			interrupt-controller;
388			reg = <0x8010 0x00000000 0x0 0x010000>, /* GICD */
389			      <0x8010 0x80000000 0x0 0x600000>; /* GICR */
390			interrupts = <1 9 0xf04>;
391
392			its: gic-its@8010,00020000 {
393				compatible = "arm,gic-v3-its";
394				msi-controller;
395				reg = <0x8010 0x20000 0x0 0x200000>;
396			};
397		};
398
399		uaa0: serial@87e0,24000000 {
400			compatible = "arm,pl011", "arm,primecell";
401			reg = <0x87e0 0x24000000 0x0 0x1000>;
402			interrupts = <1 21 4>;
403			clocks = <&refclk50mhz>;
404			clock-names = "apb_pclk";
405		};
406
407		uaa1: serial@87e0,25000000 {
408			compatible = "arm,pl011", "arm,primecell";
409			reg = <0x87e0 0x25000000 0x0 0x1000>;
410			interrupts = <1 22 4>;
411			clocks = <&refclk50mhz>;
412			clock-names = "apb_pclk";
413		};
414	};
415};
416