GNU Linux-libre 4.14.294-gnu1
[releases.git] / arch / arm64 / boot / dts / freescale / fsl-ls1088a.dtsi
1 /*
2  * Device Tree Include file for NXP Layerscape-1088A family SoC.
3  *
4  * Copyright 2017 NXP
5  *
6  * Harninder Rai <harninder.rai@nxp.com>
7  *
8  * This file is dual-licensed: you can use it either under the terms
9  * of the GPLv2 or the X11 license, at your option. Note that this dual
10  * licensing only applies to this file, and not this project as a
11  * whole.
12  *
13  *  a) This library is free software; you can redistribute it and/or
14  *     modify it under the terms of the GNU General Public License as
15  *     published by the Free Software Foundation; either version 2 of the
16  *     License, or (at your option) any later version.
17  *
18  *     This library is distributed in the hope that it will be useful,
19  *     but WITHOUT ANY WARRANTY; without even the implied warranty of
20  *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21  *     GNU General Public License for more details.
22  *
23  * Or, alternatively,
24  *
25  *  b) Permission is hereby granted, free of charge, to any person
26  *     obtaining a copy of this software and associated documentation
27  *     files (the "Software"), to deal in the Software without
28  *     restriction, including without limitation the rights to use,
29  *     copy, modify, merge, publish, distribute, sublicense, and/or
30  *     sell copies of the Software, and to permit persons to whom the
31  *     Software is furnished to do so, subject to the following
32  *     conditions:
33  *
34  *     The above copyright notice and this permission notice shall be
35  *     included in all copies or substantial portions of the Software.
36  *
37  *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
38  *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
39  *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
40  *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
41  *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
42  *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
43  *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
44  *     OTHER DEALINGS IN THE SOFTWARE.
45  */
46 #include <dt-bindings/interrupt-controller/arm-gic.h>
47 #include <dt-bindings/thermal/thermal.h>
48
49 / {
50         compatible = "fsl,ls1088a";
51         interrupt-parent = <&gic>;
52         #address-cells = <2>;
53         #size-cells = <2>;
54
55         aliases {
56                 crypto = &crypto;
57         };
58
59         cpus {
60                 #address-cells = <1>;
61                 #size-cells = <0>;
62
63                 /* We have 2 clusters having 4 Cortex-A53 cores each */
64                 cpu0: cpu@0 {
65                         device_type = "cpu";
66                         compatible = "arm,cortex-a53";
67                         reg = <0x0>;
68                         clocks = <&clockgen 1 0>;
69                         cpu-idle-states = <&CPU_PH20>;
70                         #cooling-cells = <2>;
71                 };
72
73                 cpu1: cpu@1 {
74                         device_type = "cpu";
75                         compatible = "arm,cortex-a53";
76                         reg = <0x1>;
77                         clocks = <&clockgen 1 0>;
78                         cpu-idle-states = <&CPU_PH20>;
79                 };
80
81                 cpu2: cpu@2 {
82                         device_type = "cpu";
83                         compatible = "arm,cortex-a53";
84                         reg = <0x2>;
85                         clocks = <&clockgen 1 0>;
86                         cpu-idle-states = <&CPU_PH20>;
87                 };
88
89                 cpu3: cpu@3 {
90                         device_type = "cpu";
91                         compatible = "arm,cortex-a53";
92                         reg = <0x3>;
93                         clocks = <&clockgen 1 0>;
94                         cpu-idle-states = <&CPU_PH20>;
95                 };
96
97                 cpu4: cpu@100 {
98                         device_type = "cpu";
99                         compatible = "arm,cortex-a53";
100                         reg = <0x100>;
101                         clocks = <&clockgen 1 1>;
102                         cpu-idle-states = <&CPU_PH20>;
103                         #cooling-cells = <2>;
104                 };
105
106                 cpu5: cpu@101 {
107                         device_type = "cpu";
108                         compatible = "arm,cortex-a53";
109                         reg = <0x101>;
110                         clocks = <&clockgen 1 1>;
111                         cpu-idle-states = <&CPU_PH20>;
112                 };
113
114                 cpu6: cpu@102 {
115                         device_type = "cpu";
116                         compatible = "arm,cortex-a53";
117                         reg = <0x102>;
118                         clocks = <&clockgen 1 1>;
119                         cpu-idle-states = <&CPU_PH20>;
120                 };
121
122                 cpu7: cpu@103 {
123                         device_type = "cpu";
124                         compatible = "arm,cortex-a53";
125                         reg = <0x103>;
126                         clocks = <&clockgen 1 1>;
127                         cpu-idle-states = <&CPU_PH20>;
128                 };
129
130                 CPU_PH20: cpu-ph20 {
131                         compatible = "arm,idle-state";
132                         idle-state-name = "PH20";
133                         arm,psci-suspend-param = <0x00010000>;
134                         entry-latency-us = <1000>;
135                         exit-latency-us = <1000>;
136                         min-residency-us = <3000>;
137                 };
138         };
139
140         gic: interrupt-controller@6000000 {
141                 compatible = "arm,gic-v3";
142                 #interrupt-cells = <3>;
143                 interrupt-controller;
144                 reg = <0x0 0x06000000 0 0x10000>, /* GIC Dist */
145                       <0x0 0x06100000 0 0x100000>, /* GICR(RD_base+SGI_base)*/
146                       <0x0 0x0c0c0000 0 0x2000>, /* GICC */
147                       <0x0 0x0c0d0000 0 0x1000>, /* GICH */
148                       <0x0 0x0c0e0000 0 0x20000>; /* GICV */
149                 interrupts = <1 9 IRQ_TYPE_LEVEL_HIGH>;
150         };
151
152         timer {
153                 compatible = "arm,armv8-timer";
154                 interrupts = <1 13 IRQ_TYPE_LEVEL_LOW>,/* Physical Secure PPI */
155                              <1 14 IRQ_TYPE_LEVEL_LOW>,/* Physical Non-Secure PPI */
156                              <1 11 IRQ_TYPE_LEVEL_LOW>,/* Virtual PPI */
157                              <1 10 IRQ_TYPE_LEVEL_LOW>;/* Hypervisor PPI */
158         };
159
160         psci {
161                 compatible = "arm,psci-0.2";
162                 method = "smc";
163         };
164
165         sysclk: sysclk {
166                 compatible = "fixed-clock";
167                 #clock-cells = <0>;
168                 clock-frequency = <100000000>;
169                 clock-output-names = "sysclk";
170         };
171
172         soc {
173                 compatible = "simple-bus";
174                 #address-cells = <2>;
175                 #size-cells = <2>;
176                 ranges;
177
178                 clockgen: clocking@1300000 {
179                         compatible = "fsl,ls1088a-clockgen";
180                         reg = <0 0x1300000 0 0xa0000>;
181                         #clock-cells = <2>;
182                         clocks = <&sysclk>;
183                 };
184
185                 tmu: tmu@1f80000 {
186                         compatible = "fsl,qoriq-tmu";
187                         reg = <0x0 0x1f80000 0x0 0x10000>;
188                         interrupts = <0 23 0x4>;
189                         fsl,tmu-range = <0xb0000 0x9002a 0x6004c 0x30062>;
190                         fsl,tmu-calibration =
191                                 /* Calibration data group 1 */
192                                 <0x00000000 0x00000026
193                                 0x00000001 0x0000002d
194                                 0x00000002 0x00000032
195                                 0x00000003 0x00000039
196                                 0x00000004 0x0000003f
197                                 0x00000005 0x00000046
198                                 0x00000006 0x0000004d
199                                 0x00000007 0x00000054
200                                 0x00000008 0x0000005a
201                                 0x00000009 0x00000061
202                                 0x0000000a 0x0000006a
203                                 0x0000000b 0x00000071
204                                 /* Calibration data group 2 */
205                                 0x00010000 0x00000025
206                                 0x00010001 0x0000002c
207                                 0x00010002 0x00000035
208                                 0x00010003 0x0000003d
209                                 0x00010004 0x00000045
210                                 0x00010005 0x0000004e
211                                 0x00010006 0x00000057
212                                 0x00010007 0x00000061
213                                 0x00010008 0x0000006b
214                                 0x00010009 0x00000076
215                                 /* Calibration data group 3 */
216                                 0x00020000 0x00000029
217                                 0x00020001 0x00000033
218                                 0x00020002 0x0000003d
219                                 0x00020003 0x00000049
220                                 0x00020004 0x00000056
221                                 0x00020005 0x00000061
222                                 0x00020006 0x0000006d
223                                 /* Calibration data group 4 */
224                                 0x00030000 0x00000021
225                                 0x00030001 0x0000002a
226                                 0x00030002 0x0000003c
227                                 0x00030003 0x0000004e>;
228                         little-endian;
229                         #thermal-sensor-cells = <1>;
230                 };
231
232                 thermal-zones {
233                         cpu_thermal: cpu-thermal {
234                                 polling-delay-passive = <1000>;
235                                 polling-delay = <5000>;
236                                 thermal-sensors = <&tmu 0>;
237
238                                 trips {
239                                         cpu_alert: cpu-alert {
240                                                 temperature = <85000>;
241                                                 hysteresis = <2000>;
242                                                 type = "passive";
243                                         };
244
245                                         cpu_crit: cpu-crit {
246                                                 temperature = <95000>;
247                                                 hysteresis = <2000>;
248                                                 type = "critical";
249                                         };
250                                 };
251
252                                 cooling-maps {
253                                         map0 {
254                                                 trip = <&cpu_alert>;
255                                                 cooling-device =
256                                                         <&cpu0 THERMAL_NO_LIMIT
257                                                         THERMAL_NO_LIMIT>;
258                                         };
259
260                                         map1 {
261                                                 trip = <&cpu_alert>;
262                                                 cooling-device =
263                                                         <&cpu4 THERMAL_NO_LIMIT
264                                                         THERMAL_NO_LIMIT>;
265                                         };
266                                 };
267                         };
268                 };
269
270                 duart0: serial@21c0500 {
271                         compatible = "fsl,ns16550", "ns16550a";
272                         reg = <0x0 0x21c0500 0x0 0x100>;
273                         clocks = <&clockgen 4 3>;
274                         interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>;
275                         status = "disabled";
276                 };
277
278                 duart1: serial@21c0600 {
279                         compatible = "fsl,ns16550", "ns16550a";
280                         reg = <0x0 0x21c0600 0x0 0x100>;
281                         clocks = <&clockgen 4 3>;
282                         interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>;
283                         status = "disabled";
284                 };
285
286                 gpio0: gpio@2300000 {
287                         compatible = "fsl,qoriq-gpio";
288                         reg = <0x0 0x2300000 0x0 0x10000>;
289                         interrupts = <0 36 IRQ_TYPE_LEVEL_HIGH>;
290                         gpio-controller;
291                         #gpio-cells = <2>;
292                         interrupt-controller;
293                         #interrupt-cells = <2>;
294                 };
295
296                 gpio1: gpio@2310000 {
297                         compatible = "fsl,qoriq-gpio";
298                         reg = <0x0 0x2310000 0x0 0x10000>;
299                         interrupts = <0 36 IRQ_TYPE_LEVEL_HIGH>;
300                         gpio-controller;
301                         #gpio-cells = <2>;
302                         interrupt-controller;
303                         #interrupt-cells = <2>;
304                 };
305
306                 gpio2: gpio@2320000 {
307                         compatible = "fsl,qoriq-gpio";
308                         reg = <0x0 0x2320000 0x0 0x10000>;
309                         interrupts = <0 37 IRQ_TYPE_LEVEL_HIGH>;
310                         gpio-controller;
311                         #gpio-cells = <2>;
312                         interrupt-controller;
313                         #interrupt-cells = <2>;
314                 };
315
316                 gpio3: gpio@2330000 {
317                         compatible = "fsl,qoriq-gpio";
318                         reg = <0x0 0x2330000 0x0 0x10000>;
319                         interrupts = <0 37 IRQ_TYPE_LEVEL_HIGH>;
320                         gpio-controller;
321                         #gpio-cells = <2>;
322                         interrupt-controller;
323                         #interrupt-cells = <2>;
324                 };
325
326                 ifc: ifc@2240000 {
327                         compatible = "fsl,ifc", "simple-bus";
328                         reg = <0x0 0x2240000 0x0 0x20000>;
329                         interrupts = <0 21 IRQ_TYPE_LEVEL_HIGH>;
330                         little-endian;
331                         #address-cells = <2>;
332                         #size-cells = <1>;
333                         status = "disabled";
334                 };
335
336                 i2c0: i2c@2000000 {
337                         compatible = "fsl,vf610-i2c";
338                         #address-cells = <1>;
339                         #size-cells = <0>;
340                         reg = <0x0 0x2000000 0x0 0x10000>;
341                         interrupts = <0 34 IRQ_TYPE_LEVEL_HIGH>;
342                         clocks = <&clockgen 4 3>;
343                         status = "disabled";
344                 };
345
346                 i2c1: i2c@2010000 {
347                         compatible = "fsl,vf610-i2c";
348                         #address-cells = <1>;
349                         #size-cells = <0>;
350                         reg = <0x0 0x2010000 0x0 0x10000>;
351                         interrupts = <0 34 IRQ_TYPE_LEVEL_HIGH>;
352                         clocks = <&clockgen 4 3>;
353                         status = "disabled";
354                 };
355
356                 i2c2: i2c@2020000 {
357                         compatible = "fsl,vf610-i2c";
358                         #address-cells = <1>;
359                         #size-cells = <0>;
360                         reg = <0x0 0x2020000 0x0 0x10000>;
361                         interrupts = <0 35 IRQ_TYPE_LEVEL_HIGH>;
362                         clocks = <&clockgen 4 3>;
363                         status = "disabled";
364                 };
365
366                 i2c3: i2c@2030000 {
367                         compatible = "fsl,vf610-i2c";
368                         #address-cells = <1>;
369                         #size-cells = <0>;
370                         reg = <0x0 0x2030000 0x0 0x10000>;
371                         interrupts = <0 35 IRQ_TYPE_LEVEL_HIGH>;
372                         clocks = <&clockgen 4 3>;
373                         status = "disabled";
374                 };
375
376                 esdhc: esdhc@2140000 {
377                         compatible = "fsl,ls1088a-esdhc", "fsl,esdhc";
378                         reg = <0x0 0x2140000 0x0 0x10000>;
379                         interrupts = <0 28 0x4>; /* Level high type */
380                         clock-frequency = <0>;
381                         voltage-ranges = <1800 1800 3300 3300>;
382                         sdhci,auto-cmd12;
383                         little-endian;
384                         bus-width = <4>;
385                         status = "disabled";
386                 };
387
388                 sata: sata@3200000 {
389                         compatible = "fsl,ls1088a-ahci";
390                         reg = <0x0 0x3200000 0x0 0x10000>,
391                                 <0x7 0x100520 0x0 0x4>;
392                         reg-names = "ahci", "sata-ecc";
393                         interrupts = <0 133 IRQ_TYPE_LEVEL_HIGH>;
394                         clocks = <&clockgen 4 3>;
395                         dma-coherent;
396                         status = "disabled";
397                 };
398
399                 crypto: crypto@8000000 {
400                         compatible = "fsl,sec-v5.0", "fsl,sec-v4.0";
401                         fsl,sec-era = <8>;
402                         #address-cells = <1>;
403                         #size-cells = <1>;
404                         ranges = <0x0 0x00 0x8000000 0x100000>;
405                         reg = <0x00 0x8000000 0x0 0x100000>;
406                         interrupts = <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>;
407                         dma-coherent;
408
409                         sec_jr0: jr@10000 {
410                                 compatible = "fsl,sec-v5.0-job-ring",
411                                              "fsl,sec-v4.0-job-ring";
412                                 reg        = <0x10000 0x10000>;
413                                 interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>;
414                         };
415
416                         sec_jr1: jr@20000 {
417                                 compatible = "fsl,sec-v5.0-job-ring",
418                                              "fsl,sec-v4.0-job-ring";
419                                 reg        = <0x20000 0x10000>;
420                                 interrupts = <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>;
421                         };
422
423                         sec_jr2: jr@30000 {
424                                 compatible = "fsl,sec-v5.0-job-ring",
425                                              "fsl,sec-v4.0-job-ring";
426                                 reg        = <0x30000 0x10000>;
427                                 interrupts = <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>;
428                         };
429
430                         sec_jr3: jr@40000 {
431                                 compatible = "fsl,sec-v5.0-job-ring",
432                                              "fsl,sec-v4.0-job-ring";
433                                 reg        = <0x40000 0x10000>;
434                                 interrupts = <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
435                         };
436                 };
437         };
438
439 };