1// SPDX-License-Identifier: GPL-2.0+ 2/* 3 * Copyright (C) 2016 Freescale Semiconductor, Inc. 4 * Copyright 2017-2018 NXP 5 * Dong Aisheng <aisheng.dong@nxp.com> 6 */ 7 8#include <dt-bindings/clock/imx8-clock.h> 9#include <dt-bindings/firmware/imx/rsrc.h> 10#include <dt-bindings/gpio/gpio.h> 11#include <dt-bindings/interrupt-controller/arm-gic.h> 12#include <dt-bindings/pinctrl/pads-imx8qxp.h> 13 14/ { 15 interrupt-parent = <&gic>; 16 #address-cells = <2>; 17 #size-cells = <2>; 18 19 aliases { 20 mmc0 = &usdhc1; 21 mmc1 = &usdhc2; 22 mmc2 = &usdhc3; 23 serial0 = &adma_lpuart0; 24 }; 25 26 cpus { 27 #address-cells = <2>; 28 #size-cells = <0>; 29 30 /* We have 1 clusters with 4 Cortex-A35 cores */ 31 A35_0: cpu@0 { 32 device_type = "cpu"; 33 compatible = "arm,cortex-a35"; 34 reg = <0x0 0x0>; 35 enable-method = "psci"; 36 next-level-cache = <&A35_L2>; 37 clocks = <&clk IMX_A35_CLK>; 38 operating-points-v2 = <&a35_opp_table>; 39 #cooling-cells = <2>; 40 }; 41 42 A35_1: cpu@1 { 43 device_type = "cpu"; 44 compatible = "arm,cortex-a35"; 45 reg = <0x0 0x1>; 46 enable-method = "psci"; 47 next-level-cache = <&A35_L2>; 48 clocks = <&clk IMX_A35_CLK>; 49 operating-points-v2 = <&a35_opp_table>; 50 #cooling-cells = <2>; 51 }; 52 53 A35_2: cpu@2 { 54 device_type = "cpu"; 55 compatible = "arm,cortex-a35"; 56 reg = <0x0 0x2>; 57 enable-method = "psci"; 58 next-level-cache = <&A35_L2>; 59 clocks = <&clk IMX_A35_CLK>; 60 operating-points-v2 = <&a35_opp_table>; 61 #cooling-cells = <2>; 62 }; 63 64 A35_3: cpu@3 { 65 device_type = "cpu"; 66 compatible = "arm,cortex-a35"; 67 reg = <0x0 0x3>; 68 enable-method = "psci"; 69 next-level-cache = <&A35_L2>; 70 clocks = <&clk IMX_A35_CLK>; 71 operating-points-v2 = <&a35_opp_table>; 72 #cooling-cells = <2>; 73 }; 74 75 A35_L2: l2-cache0 { 76 compatible = "cache"; 77 }; 78 }; 79 80 a35_opp_table: opp-table { 81 compatible = "operating-points-v2"; 82 opp-shared; 83 84 opp-900000000 { 85 opp-hz = /bits/ 64 <900000000>; 86 opp-microvolt = <1000000>; 87 clock-latency-ns = <150000>; 88 }; 89 90 opp-1200000000 { 91 opp-hz = /bits/ 64 <1200000000>; 92 opp-microvolt = <1100000>; 93 clock-latency-ns = <150000>; 94 opp-suspend; 95 }; 96 }; 97 98 gic: interrupt-controller@51a00000 { 99 compatible = "arm,gic-v3"; 100 reg = <0x0 0x51a00000 0 0x10000>, /* GIC Dist */ 101 <0x0 0x51b00000 0 0xc0000>; /* GICR (RD_base + SGI_base) */ 102 #interrupt-cells = <3>; 103 interrupt-controller; 104 interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>; 105 }; 106 107 pmu { 108 compatible = "arm,armv8-pmuv3"; 109 interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>; 110 }; 111 112 psci { 113 compatible = "arm,psci-1.0"; 114 method = "smc"; 115 }; 116 117 scu { 118 compatible = "fsl,imx-scu"; 119 mbox-names = "tx0", "tx1", "tx2", "tx3", 120 "rx0", "rx1", "rx2", "rx3"; 121 mboxes = <&lsio_mu1 0 0 122 &lsio_mu1 0 1 123 &lsio_mu1 0 2 124 &lsio_mu1 0 3 125 &lsio_mu1 1 0 126 &lsio_mu1 1 1 127 &lsio_mu1 1 2 128 &lsio_mu1 1 3>; 129 130 clk: clock-controller { 131 compatible = "fsl,imx8qxp-clk"; 132 #clock-cells = <1>; 133 clocks = <&xtal32k &xtal24m>; 134 clock-names = "xtal_32KHz", "xtal_24Mhz"; 135 }; 136 137 iomuxc: pinctrl { 138 compatible = "fsl,imx8qxp-iomuxc"; 139 }; 140 141 pd: imx8qx-pd { 142 compatible = "fsl,imx8qxp-scu-pd"; 143 #power-domain-cells = <1>; 144 }; 145 146 rtc: rtc { 147 compatible = "fsl,imx8qxp-sc-rtc"; 148 }; 149 }; 150 151 timer { 152 compatible = "arm,armv8-timer"; 153 interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>, /* Physical Secure */ 154 <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>, /* Physical Non-Secure */ 155 <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>, /* Virtual */ 156 <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>; /* Hypervisor */ 157 }; 158 159 xtal32k: clock-xtal32k { 160 compatible = "fixed-clock"; 161 #clock-cells = <0>; 162 clock-frequency = <32768>; 163 clock-output-names = "xtal_32KHz"; 164 }; 165 166 xtal24m: clock-xtal24m { 167 compatible = "fixed-clock"; 168 #clock-cells = <0>; 169 clock-frequency = <24000000>; 170 clock-output-names = "xtal_24MHz"; 171 }; 172 173 adma_subsys: bus@59000000 { 174 compatible = "simple-bus"; 175 #address-cells = <1>; 176 #size-cells = <1>; 177 ranges = <0x59000000 0x0 0x59000000 0x2000000>; 178 179 adma_lpcg: clock-controller@59000000 { 180 compatible = "fsl,imx8qxp-lpcg-adma"; 181 reg = <0x59000000 0x2000000>; 182 #clock-cells = <1>; 183 }; 184 185 adma_lpuart0: serial@5a060000 { 186 compatible = "fsl,imx8qxp-lpuart", "fsl,imx7ulp-lpuart"; 187 reg = <0x5a060000 0x1000>; 188 interrupts = <GIC_SPI 225 IRQ_TYPE_LEVEL_HIGH>; 189 interrupt-parent = <&gic>; 190 clocks = <&adma_lpcg IMX_ADMA_LPCG_UART0_BAUD_CLK>; 191 clock-names = "ipg"; 192 power-domains = <&pd IMX_SC_R_UART_0>; 193 status = "disabled"; 194 }; 195 196 adma_i2c0: i2c@5a800000 { 197 compatible = "fsl,imx8qxp-lpi2c", "fsl,imx7ulp-lpi2c"; 198 reg = <0x5a800000 0x4000>; 199 interrupts = <GIC_SPI 220 IRQ_TYPE_LEVEL_HIGH>; 200 interrupt-parent = <&gic>; 201 clocks = <&adma_lpcg IMX_ADMA_LPCG_I2C0_CLK>; 202 clock-names = "per"; 203 assigned-clocks = <&clk IMX_ADMA_I2C0_CLK>; 204 assigned-clock-rates = <24000000>; 205 power-domains = <&pd IMX_SC_R_I2C_0>; 206 status = "disabled"; 207 }; 208 209 adma_i2c1: i2c@5a810000 { 210 compatible = "fsl,imx8qxp-lpi2c", "fsl,imx7ulp-lpi2c"; 211 reg = <0x5a810000 0x4000>; 212 interrupts = <GIC_SPI 221 IRQ_TYPE_LEVEL_HIGH>; 213 interrupt-parent = <&gic>; 214 clocks = <&adma_lpcg IMX_ADMA_LPCG_I2C1_CLK>; 215 clock-names = "per"; 216 assigned-clocks = <&clk IMX_ADMA_I2C1_CLK>; 217 assigned-clock-rates = <24000000>; 218 power-domains = <&pd IMX_SC_R_I2C_1>; 219 status = "disabled"; 220 }; 221 222 adma_i2c2: i2c@5a820000 { 223 compatible = "fsl,imx8qxp-lpi2c", "fsl,imx7ulp-lpi2c"; 224 reg = <0x5a820000 0x4000>; 225 interrupts = <GIC_SPI 222 IRQ_TYPE_LEVEL_HIGH>; 226 interrupt-parent = <&gic>; 227 clocks = <&adma_lpcg IMX_ADMA_LPCG_I2C2_CLK>; 228 clock-names = "per"; 229 assigned-clocks = <&clk IMX_ADMA_I2C2_CLK>; 230 assigned-clock-rates = <24000000>; 231 power-domains = <&pd IMX_SC_R_I2C_2>; 232 status = "disabled"; 233 }; 234 235 adma_i2c3: i2c@5a830000 { 236 compatible = "fsl,imx8qxp-lpi2c", "fsl,imx7ulp-lpi2c"; 237 reg = <0x5a830000 0x4000>; 238 interrupts = <GIC_SPI 223 IRQ_TYPE_LEVEL_HIGH>; 239 interrupt-parent = <&gic>; 240 clocks = <&adma_lpcg IMX_ADMA_LPCG_I2C3_CLK>; 241 clock-names = "per"; 242 assigned-clocks = <&clk IMX_ADMA_I2C3_CLK>; 243 assigned-clock-rates = <24000000>; 244 power-domains = <&pd IMX_SC_R_I2C_3>; 245 status = "disabled"; 246 }; 247 }; 248 249 conn_subsys: bus@5b000000 { 250 compatible = "simple-bus"; 251 #address-cells = <1>; 252 #size-cells = <1>; 253 ranges = <0x5b000000 0x0 0x5b000000 0x1000000>; 254 255 conn_lpcg: clock-controller@5b200000 { 256 compatible = "fsl,imx8qxp-lpcg-conn"; 257 reg = <0x5b200000 0xb0000>; 258 #clock-cells = <1>; 259 }; 260 261 usdhc1: mmc@5b010000 { 262 compatible = "fsl,imx8qxp-usdhc", "fsl,imx7d-usdhc"; 263 interrupt-parent = <&gic>; 264 interrupts = <GIC_SPI 232 IRQ_TYPE_LEVEL_HIGH>; 265 reg = <0x5b010000 0x10000>; 266 clocks = <&conn_lpcg IMX_CONN_LPCG_SDHC0_IPG_CLK>, 267 <&conn_lpcg IMX_CONN_LPCG_SDHC0_PER_CLK>, 268 <&conn_lpcg IMX_CONN_LPCG_SDHC0_HCLK>; 269 clock-names = "ipg", "per", "ahb"; 270 assigned-clocks = <&clk IMX_CONN_SDHC0_CLK>; 271 assigned-clock-rates = <200000000>; 272 power-domains = <&pd IMX_SC_R_SDHC_0>; 273 status = "disabled"; 274 }; 275 276 usdhc2: mmc@5b020000 { 277 compatible = "fsl,imx8qxp-usdhc", "fsl,imx7d-usdhc"; 278 interrupt-parent = <&gic>; 279 interrupts = <GIC_SPI 233 IRQ_TYPE_LEVEL_HIGH>; 280 reg = <0x5b020000 0x10000>; 281 clocks = <&conn_lpcg IMX_CONN_LPCG_SDHC1_IPG_CLK>, 282 <&conn_lpcg IMX_CONN_LPCG_SDHC1_PER_CLK>, 283 <&conn_lpcg IMX_CONN_LPCG_SDHC1_HCLK>; 284 clock-names = "ipg", "per", "ahb"; 285 assigned-clocks = <&clk IMX_CONN_SDHC1_CLK>; 286 assigned-clock-rates = <200000000>; 287 power-domains = <&pd IMX_SC_R_SDHC_1>; 288 fsl,tuning-start-tap = <20>; 289 fsl,tuning-step= <2>; 290 status = "disabled"; 291 }; 292 293 usdhc3: mmc@5b030000 { 294 compatible = "fsl,imx8qxp-usdhc", "fsl,imx7d-usdhc"; 295 interrupt-parent = <&gic>; 296 interrupts = <GIC_SPI 234 IRQ_TYPE_LEVEL_HIGH>; 297 reg = <0x5b030000 0x10000>; 298 clocks = <&conn_lpcg IMX_CONN_LPCG_SDHC2_IPG_CLK>, 299 <&conn_lpcg IMX_CONN_LPCG_SDHC2_PER_CLK>, 300 <&conn_lpcg IMX_CONN_LPCG_SDHC2_HCLK>; 301 clock-names = "ipg", "per", "ahb"; 302 assigned-clocks = <&clk IMX_CONN_SDHC2_CLK>; 303 assigned-clock-rates = <200000000>; 304 power-domains = <&pd IMX_SC_R_SDHC_2>; 305 status = "disabled"; 306 }; 307 308 fec1: ethernet@5b040000 { 309 compatible = "fsl,imx8qxp-fec", "fsl,imx6sx-fec"; 310 reg = <0x5b040000 0x10000>; 311 interrupts = <GIC_SPI 258 IRQ_TYPE_LEVEL_HIGH>, 312 <GIC_SPI 256 IRQ_TYPE_LEVEL_HIGH>, 313 <GIC_SPI 257 IRQ_TYPE_LEVEL_HIGH>, 314 <GIC_SPI 259 IRQ_TYPE_LEVEL_HIGH>; 315 clocks = <&conn_lpcg IMX_CONN_LPCG_ENET0_IPG_CLK>, 316 <&conn_lpcg IMX_CONN_LPCG_ENET0_AHB_CLK>, 317 <&conn_lpcg IMX_CONN_LPCG_ENET0_TX_CLK>, 318 <&conn_lpcg IMX_CONN_LPCG_ENET0_ROOT_CLK>; 319 clock-names = "ipg", "ahb", "enet_clk_ref", "ptp"; 320 fsl,num-tx-queues=<3>; 321 fsl,num-rx-queues=<3>; 322 power-domains = <&pd IMX_SC_R_ENET_0>; 323 status = "disabled"; 324 }; 325 326 fec2: ethernet@5b050000 { 327 compatible = "fsl,imx8qxp-fec", "fsl,imx6sx-fec"; 328 reg = <0x5b050000 0x10000>; 329 interrupts = <GIC_SPI 262 IRQ_TYPE_LEVEL_HIGH>, 330 <GIC_SPI 260 IRQ_TYPE_LEVEL_HIGH>, 331 <GIC_SPI 261 IRQ_TYPE_LEVEL_HIGH>, 332 <GIC_SPI 263 IRQ_TYPE_LEVEL_HIGH>; 333 clocks = <&conn_lpcg IMX_CONN_LPCG_ENET1_IPG_CLK>, 334 <&conn_lpcg IMX_CONN_LPCG_ENET1_AHB_CLK>, 335 <&conn_lpcg IMX_CONN_LPCG_ENET1_TX_CLK>, 336 <&conn_lpcg IMX_CONN_LPCG_ENET1_ROOT_CLK>; 337 clock-names = "ipg", "ahb", "enet_clk_ref", "ptp"; 338 fsl,num-tx-queues=<3>; 339 fsl,num-rx-queues=<3>; 340 power-domains = <&pd IMX_SC_R_ENET_1>; 341 status = "disabled"; 342 }; 343 }; 344 345 lsio_subsys: bus@5d000000 { 346 compatible = "simple-bus"; 347 #address-cells = <1>; 348 #size-cells = <1>; 349 ranges = <0x5d000000 0x0 0x5d000000 0x1000000>; 350 351 lsio_lpcg: clock-controller@5d400000 { 352 compatible = "fsl,imx8qxp-lpcg-lsio"; 353 reg = <0x5d400000 0x400000>; 354 #clock-cells = <1>; 355 }; 356 357 lsio_mu0: mailbox@5d1b0000 { 358 compatible = "fsl,imx8qxp-mu", "fsl,imx6sx-mu"; 359 reg = <0x5d1b0000 0x10000>; 360 interrupts = <GIC_SPI 176 IRQ_TYPE_LEVEL_HIGH>; 361 #mbox-cells = <2>; 362 status = "disabled"; 363 }; 364 365 lsio_mu1: mailbox@5d1c0000 { 366 compatible = "fsl,imx8qxp-mu", "fsl,imx6sx-mu"; 367 reg = <0x5d1c0000 0x10000>; 368 interrupts = <GIC_SPI 177 IRQ_TYPE_LEVEL_HIGH>; 369 #mbox-cells = <2>; 370 }; 371 372 lsio_mu3: mailbox@5d1e0000 { 373 compatible = "fsl,imx8qxp-mu", "fsl,imx6sx-mu"; 374 reg = <0x5d1e0000 0x10000>; 375 interrupts = <GIC_SPI 179 IRQ_TYPE_LEVEL_HIGH>; 376 #mbox-cells = <2>; 377 status = "disabled"; 378 }; 379 380 lsio_mu4: mailbox@5d1f0000 { 381 compatible = "fsl,imx8qxp-mu", "fsl,imx6sx-mu"; 382 reg = <0x5d1f0000 0x10000>; 383 interrupts = <GIC_SPI 180 IRQ_TYPE_LEVEL_HIGH>; 384 #mbox-cells = <2>; 385 status = "disabled"; 386 }; 387 388 lsio_gpio0: gpio@5d080000 { 389 compatible = "fsl,imx8qxp-gpio", "fsl,imx35-gpio"; 390 reg = <0x5d080000 0x10000>; 391 interrupts = <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>; 392 gpio-controller; 393 #gpio-cells = <2>; 394 interrupt-controller; 395 #interrupt-cells = <2>; 396 power-domains = <&pd IMX_SC_R_GPIO_0>; 397 }; 398 399 lsio_gpio1: gpio@5d090000 { 400 compatible = "fsl,imx8qxp-gpio", "fsl,imx35-gpio"; 401 reg = <0x5d090000 0x10000>; 402 interrupts = <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>; 403 gpio-controller; 404 #gpio-cells = <2>; 405 interrupt-controller; 406 #interrupt-cells = <2>; 407 power-domains = <&pd IMX_SC_R_GPIO_1>; 408 }; 409 410 lsio_gpio2: gpio@5d0a0000 { 411 compatible = "fsl,imx8qxp-gpio", "fsl,imx35-gpio"; 412 reg = <0x5d0a0000 0x10000>; 413 interrupts = <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>; 414 gpio-controller; 415 #gpio-cells = <2>; 416 interrupt-controller; 417 #interrupt-cells = <2>; 418 power-domains = <&pd IMX_SC_R_GPIO_2>; 419 }; 420 421 lsio_gpio3: gpio@5d0b0000 { 422 compatible = "fsl,imx8qxp-gpio", "fsl,imx35-gpio"; 423 reg = <0x5d0b0000 0x10000>; 424 interrupts = <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>; 425 gpio-controller; 426 #gpio-cells = <2>; 427 interrupt-controller; 428 #interrupt-cells = <2>; 429 power-domains = <&pd IMX_SC_R_GPIO_3>; 430 }; 431 432 lsio_gpio4: gpio@5d0c0000 { 433 compatible = "fsl,imx8qxp-gpio", "fsl,imx35-gpio"; 434 reg = <0x5d0c0000 0x10000>; 435 interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>; 436 gpio-controller; 437 #gpio-cells = <2>; 438 interrupt-controller; 439 #interrupt-cells = <2>; 440 power-domains = <&pd IMX_SC_R_GPIO_4>; 441 }; 442 443 lsio_gpio5: gpio@5d0d0000 { 444 compatible = "fsl,imx8qxp-gpio", "fsl,imx35-gpio"; 445 reg = <0x5d0d0000 0x10000>; 446 interrupts = <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>; 447 gpio-controller; 448 #gpio-cells = <2>; 449 interrupt-controller; 450 #interrupt-cells = <2>; 451 power-domains = <&pd IMX_SC_R_GPIO_5>; 452 }; 453 454 lsio_gpio6: gpio@5d0e0000 { 455 compatible = "fsl,imx8qxp-gpio", "fsl,imx35-gpio"; 456 reg = <0x5d0e0000 0x10000>; 457 interrupts = <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>; 458 gpio-controller; 459 #gpio-cells = <2>; 460 interrupt-controller; 461 #interrupt-cells = <2>; 462 power-domains = <&pd IMX_SC_R_GPIO_6>; 463 }; 464 465 lsio_gpio7: gpio@5d0f0000 { 466 compatible = "fsl,imx8qxp-gpio", "fsl,imx35-gpio"; 467 reg = <0x5d0f0000 0x10000>; 468 interrupts = <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>; 469 gpio-controller; 470 #gpio-cells = <2>; 471 interrupt-controller; 472 #interrupt-cells = <2>; 473 power-domains = <&pd IMX_SC_R_GPIO_7>; 474 }; 475 }; 476}; 477