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 cpus { 56 #address-cells = <1>; 57 #size-cells = <0>; 58 59 /* We have 2 clusters having 4 Cortex-A53 cores each */ 60 cpu0: cpu@0 { 61 device_type = "cpu"; 62 compatible = "arm,cortex-a53"; 63 reg = <0x0>; 64 clocks = <&clockgen 1 0>; 65 #cooling-cells = <2>; 66 }; 67 68 cpu1: cpu@1 { 69 device_type = "cpu"; 70 compatible = "arm,cortex-a53"; 71 reg = <0x1>; 72 clocks = <&clockgen 1 0>; 73 }; 74 75 cpu2: cpu@2 { 76 device_type = "cpu"; 77 compatible = "arm,cortex-a53"; 78 reg = <0x2>; 79 clocks = <&clockgen 1 0>; 80 }; 81 82 cpu3: cpu@3 { 83 device_type = "cpu"; 84 compatible = "arm,cortex-a53"; 85 reg = <0x3>; 86 clocks = <&clockgen 1 0>; 87 }; 88 89 cpu4: cpu@100 { 90 device_type = "cpu"; 91 compatible = "arm,cortex-a53"; 92 reg = <0x100>; 93 clocks = <&clockgen 1 1>; 94 #cooling-cells = <2>; 95 }; 96 97 cpu5: cpu@101 { 98 device_type = "cpu"; 99 compatible = "arm,cortex-a53"; 100 reg = <0x101>; 101 clocks = <&clockgen 1 1>; 102 }; 103 104 cpu6: cpu@102 { 105 device_type = "cpu"; 106 compatible = "arm,cortex-a53"; 107 reg = <0x102>; 108 clocks = <&clockgen 1 1>; 109 }; 110 111 cpu7: cpu@103 { 112 device_type = "cpu"; 113 compatible = "arm,cortex-a53"; 114 reg = <0x103>; 115 clocks = <&clockgen 1 1>; 116 }; 117 }; 118 119 gic: interrupt-controller@6000000 { 120 compatible = "arm,gic-v3"; 121 #interrupt-cells = <3>; 122 interrupt-controller; 123 reg = <0x0 0x06000000 0 0x10000>, /* GIC Dist */ 124 <0x0 0x06100000 0 0x100000>, /* GICR(RD_base+SGI_base)*/ 125 <0x0 0x0c0c0000 0 0x2000>, /* GICC */ 126 <0x0 0x0c0d0000 0 0x1000>, /* GICH */ 127 <0x0 0x0c0e0000 0 0x20000>; /* GICV */ 128 interrupts = <1 9 IRQ_TYPE_LEVEL_HIGH>; 129 }; 130 131 timer { 132 compatible = "arm,armv8-timer"; 133 interrupts = <1 13 IRQ_TYPE_LEVEL_LOW>,/* Physical Secure PPI */ 134 <1 14 IRQ_TYPE_LEVEL_LOW>,/* Physical Non-Secure PPI */ 135 <1 11 IRQ_TYPE_LEVEL_LOW>,/* Virtual PPI */ 136 <1 10 IRQ_TYPE_LEVEL_LOW>;/* Hypervisor PPI */ 137 }; 138 139 sysclk: sysclk { 140 compatible = "fixed-clock"; 141 #clock-cells = <0>; 142 clock-frequency = <100000000>; 143 clock-output-names = "sysclk"; 144 }; 145 146 soc { 147 compatible = "simple-bus"; 148 #address-cells = <2>; 149 #size-cells = <2>; 150 ranges; 151 152 clockgen: clocking@1300000 { 153 compatible = "fsl,ls1088a-clockgen"; 154 reg = <0 0x1300000 0 0xa0000>; 155 #clock-cells = <2>; 156 clocks = <&sysclk>; 157 }; 158 159 tmu: tmu@1f80000 { 160 compatible = "fsl,qoriq-tmu"; 161 reg = <0x0 0x1f80000 0x0 0x10000>; 162 interrupts = <0 23 0x4>; 163 fsl,tmu-range = <0xb0000 0x9002a 0x6004c 0x30062>; 164 fsl,tmu-calibration = 165 /* Calibration data group 1 */ 166 <0x00000000 0x00000026 167 0x00000001 0x0000002d 168 0x00000002 0x00000032 169 0x00000003 0x00000039 170 0x00000004 0x0000003f 171 0x00000005 0x00000046 172 0x00000006 0x0000004d 173 0x00000007 0x00000054 174 0x00000008 0x0000005a 175 0x00000009 0x00000061 176 0x0000000a 0x0000006a 177 0x0000000b 0x00000071 178 /* Calibration data group 2 */ 179 0x00010000 0x00000025 180 0x00010001 0x0000002c 181 0x00010002 0x00000035 182 0x00010003 0x0000003d 183 0x00010004 0x00000045 184 0x00010005 0x0000004e 185 0x00010006 0x00000057 186 0x00010007 0x00000061 187 0x00010008 0x0000006b 188 0x00010009 0x00000076 189 /* Calibration data group 3 */ 190 0x00020000 0x00000029 191 0x00020001 0x00000033 192 0x00020002 0x0000003d 193 0x00020003 0x00000049 194 0x00020004 0x00000056 195 0x00020005 0x00000061 196 0x00020006 0x0000006d 197 /* Calibration data group 4 */ 198 0x00030000 0x00000021 199 0x00030001 0x0000002a 200 0x00030002 0x0000003c 201 0x00030003 0x0000004e>; 202 little-endian; 203 #thermal-sensor-cells = <1>; 204 }; 205 206 thermal-zones { 207 cpu_thermal: cpu-thermal { 208 polling-delay-passive = <1000>; 209 polling-delay = <5000>; 210 thermal-sensors = <&tmu 0>; 211 212 trips { 213 cpu_alert: cpu-alert { 214 temperature = <85000>; 215 hysteresis = <2000>; 216 type = "passive"; 217 }; 218 219 cpu_crit: cpu-crit { 220 temperature = <95000>; 221 hysteresis = <2000>; 222 type = "critical"; 223 }; 224 }; 225 226 cooling-maps { 227 map0 { 228 trip = <&cpu_alert>; 229 cooling-device = 230 <&cpu0 THERMAL_NO_LIMIT 231 THERMAL_NO_LIMIT>; 232 }; 233 234 map1 { 235 trip = <&cpu_alert>; 236 cooling-device = 237 <&cpu4 THERMAL_NO_LIMIT 238 THERMAL_NO_LIMIT>; 239 }; 240 }; 241 }; 242 }; 243 244 duart0: serial@21c0500 { 245 compatible = "fsl,ns16550", "ns16550a"; 246 reg = <0x0 0x21c0500 0x0 0x100>; 247 clocks = <&clockgen 4 3>; 248 interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>; 249 status = "disabled"; 250 }; 251 252 duart1: serial@21c0600 { 253 compatible = "fsl,ns16550", "ns16550a"; 254 reg = <0x0 0x21c0600 0x0 0x100>; 255 clocks = <&clockgen 4 3>; 256 interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>; 257 status = "disabled"; 258 }; 259 260 gpio0: gpio@2300000 { 261 compatible = "fsl,qoriq-gpio"; 262 reg = <0x0 0x2300000 0x0 0x10000>; 263 interrupts = <0 36 IRQ_TYPE_LEVEL_HIGH>; 264 gpio-controller; 265 #gpio-cells = <2>; 266 interrupt-controller; 267 #interrupt-cells = <2>; 268 }; 269 270 gpio1: gpio@2310000 { 271 compatible = "fsl,qoriq-gpio"; 272 reg = <0x0 0x2310000 0x0 0x10000>; 273 interrupts = <0 36 IRQ_TYPE_LEVEL_HIGH>; 274 gpio-controller; 275 #gpio-cells = <2>; 276 interrupt-controller; 277 #interrupt-cells = <2>; 278 }; 279 280 gpio2: gpio@2320000 { 281 compatible = "fsl,qoriq-gpio"; 282 reg = <0x0 0x2320000 0x0 0x10000>; 283 interrupts = <0 37 IRQ_TYPE_LEVEL_HIGH>; 284 gpio-controller; 285 #gpio-cells = <2>; 286 interrupt-controller; 287 #interrupt-cells = <2>; 288 }; 289 290 gpio3: gpio@2330000 { 291 compatible = "fsl,qoriq-gpio"; 292 reg = <0x0 0x2330000 0x0 0x10000>; 293 interrupts = <0 37 IRQ_TYPE_LEVEL_HIGH>; 294 gpio-controller; 295 #gpio-cells = <2>; 296 interrupt-controller; 297 #interrupt-cells = <2>; 298 }; 299 300 ifc: ifc@2240000 { 301 compatible = "fsl,ifc", "simple-bus"; 302 reg = <0x0 0x2240000 0x0 0x20000>; 303 interrupts = <0 21 IRQ_TYPE_LEVEL_HIGH>; 304 little-endian; 305 #address-cells = <2>; 306 #size-cells = <1>; 307 status = "disabled"; 308 }; 309 310 i2c0: i2c@2000000 { 311 compatible = "fsl,vf610-i2c"; 312 #address-cells = <1>; 313 #size-cells = <0>; 314 reg = <0x0 0x2000000 0x0 0x10000>; 315 interrupts = <0 34 IRQ_TYPE_LEVEL_HIGH>; 316 clocks = <&clockgen 4 3>; 317 status = "disabled"; 318 }; 319 320 i2c1: i2c@2010000 { 321 compatible = "fsl,vf610-i2c"; 322 #address-cells = <1>; 323 #size-cells = <0>; 324 reg = <0x0 0x2010000 0x0 0x10000>; 325 interrupts = <0 34 IRQ_TYPE_LEVEL_HIGH>; 326 clocks = <&clockgen 4 3>; 327 status = "disabled"; 328 }; 329 330 i2c2: i2c@2020000 { 331 compatible = "fsl,vf610-i2c"; 332 #address-cells = <1>; 333 #size-cells = <0>; 334 reg = <0x0 0x2020000 0x0 0x10000>; 335 interrupts = <0 35 IRQ_TYPE_LEVEL_HIGH>; 336 clocks = <&clockgen 4 3>; 337 status = "disabled"; 338 }; 339 340 i2c3: i2c@2030000 { 341 compatible = "fsl,vf610-i2c"; 342 #address-cells = <1>; 343 #size-cells = <0>; 344 reg = <0x0 0x2030000 0x0 0x10000>; 345 interrupts = <0 35 IRQ_TYPE_LEVEL_HIGH>; 346 clocks = <&clockgen 4 3>; 347 status = "disabled"; 348 }; 349 350 esdhc: esdhc@2140000 { 351 compatible = "fsl,ls1088a-esdhc", "fsl,esdhc"; 352 reg = <0x0 0x2140000 0x0 0x10000>; 353 interrupts = <0 28 0x4>; /* Level high type */ 354 clock-frequency = <0>; 355 voltage-ranges = <1800 1800 3300 3300>; 356 sdhci,auto-cmd12; 357 little-endian; 358 bus-width = <4>; 359 status = "disabled"; 360 }; 361 362 sata: sata@3200000 { 363 compatible = "fsl,ls1088a-ahci"; 364 reg = <0x0 0x3200000 0x0 0x10000>, 365 <0x7 0x100520 0x0 0x4>; 366 reg-names = "ahci", "sata-ecc"; 367 interrupts = <0 133 IRQ_TYPE_LEVEL_HIGH>; 368 clocks = <&clockgen 4 3>; 369 dma-coherent; 370 status = "disabled"; 371 }; 372 }; 373 374}; 375