1// SPDX-License-Identifier: GPL-2.0+ 2/* 3 * Copyright 2018-2019 NXP 4 * Dong Aisheng <aisheng.dong@nxp.com> 5 */ 6 7#include <dt-bindings/clock/imx8-lpcg.h> 8#include <dt-bindings/firmware/imx/rsrc.h> 9#include <dt-bindings/gpio/gpio.h> 10#include <dt-bindings/interrupt-controller/arm-gic.h> 11#include <dt-bindings/pinctrl/pads-imx8qm.h> 12#include <dt-bindings/thermal/thermal.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 = &lpuart0; 24 serial1 = &lpuart1; 25 serial2 = &lpuart2; 26 serial3 = &lpuart3; 27 vpu-core0 = &vpu_core0; 28 vpu-core1 = &vpu_core1; 29 vpu-core2 = &vpu_core2; 30 }; 31 32 cpus { 33 #address-cells = <2>; 34 #size-cells = <0>; 35 36 cpu-map { 37 cluster0 { 38 core0 { 39 cpu = <&A53_0>; 40 }; 41 core1 { 42 cpu = <&A53_1>; 43 }; 44 core2 { 45 cpu = <&A53_2>; 46 }; 47 core3 { 48 cpu = <&A53_3>; 49 }; 50 }; 51 52 cluster1 { 53 core0 { 54 cpu = <&A72_0>; 55 }; 56 core1 { 57 cpu = <&A72_1>; 58 }; 59 }; 60 }; 61 62 A53_0: cpu@0 { 63 device_type = "cpu"; 64 compatible = "arm,cortex-a53"; 65 reg = <0x0 0x0>; 66 clocks = <&clk IMX_SC_R_A53 IMX_SC_PM_CLK_CPU>; 67 enable-method = "psci"; 68 i-cache-size = <0x8000>; 69 i-cache-line-size = <64>; 70 i-cache-sets = <256>; 71 d-cache-size = <0x8000>; 72 d-cache-line-size = <64>; 73 d-cache-sets = <128>; 74 next-level-cache = <&A53_L2>; 75 operating-points-v2 = <&a53_opp_table>; 76 #cooling-cells = <2>; 77 }; 78 79 A53_1: cpu@1 { 80 device_type = "cpu"; 81 compatible = "arm,cortex-a53"; 82 reg = <0x0 0x1>; 83 clocks = <&clk IMX_SC_R_A53 IMX_SC_PM_CLK_CPU>; 84 enable-method = "psci"; 85 i-cache-size = <0x8000>; 86 i-cache-line-size = <64>; 87 i-cache-sets = <256>; 88 d-cache-size = <0x8000>; 89 d-cache-line-size = <64>; 90 d-cache-sets = <128>; 91 next-level-cache = <&A53_L2>; 92 operating-points-v2 = <&a53_opp_table>; 93 #cooling-cells = <2>; 94 }; 95 96 A53_2: cpu@2 { 97 device_type = "cpu"; 98 compatible = "arm,cortex-a53"; 99 reg = <0x0 0x2>; 100 clocks = <&clk IMX_SC_R_A53 IMX_SC_PM_CLK_CPU>; 101 enable-method = "psci"; 102 i-cache-size = <0x8000>; 103 i-cache-line-size = <64>; 104 i-cache-sets = <256>; 105 d-cache-size = <0x8000>; 106 d-cache-line-size = <64>; 107 d-cache-sets = <128>; 108 next-level-cache = <&A53_L2>; 109 operating-points-v2 = <&a53_opp_table>; 110 #cooling-cells = <2>; 111 }; 112 113 A53_3: cpu@3 { 114 device_type = "cpu"; 115 compatible = "arm,cortex-a53"; 116 reg = <0x0 0x3>; 117 clocks = <&clk IMX_SC_R_A53 IMX_SC_PM_CLK_CPU>; 118 enable-method = "psci"; 119 i-cache-size = <0x8000>; 120 i-cache-line-size = <64>; 121 i-cache-sets = <256>; 122 d-cache-size = <0x8000>; 123 d-cache-line-size = <64>; 124 d-cache-sets = <128>; 125 next-level-cache = <&A53_L2>; 126 operating-points-v2 = <&a53_opp_table>; 127 #cooling-cells = <2>; 128 }; 129 130 A72_0: cpu@100 { 131 device_type = "cpu"; 132 compatible = "arm,cortex-a72"; 133 reg = <0x0 0x100>; 134 clocks = <&clk IMX_SC_R_A72 IMX_SC_PM_CLK_CPU>; 135 enable-method = "psci"; 136 i-cache-size = <0xC000>; 137 i-cache-line-size = <64>; 138 i-cache-sets = <256>; 139 d-cache-size = <0x8000>; 140 d-cache-line-size = <64>; 141 d-cache-sets = <256>; 142 next-level-cache = <&A72_L2>; 143 operating-points-v2 = <&a72_opp_table>; 144 #cooling-cells = <2>; 145 }; 146 147 A72_1: cpu@101 { 148 device_type = "cpu"; 149 compatible = "arm,cortex-a72"; 150 reg = <0x0 0x101>; 151 clocks = <&clk IMX_SC_R_A72 IMX_SC_PM_CLK_CPU>; 152 enable-method = "psci"; 153 next-level-cache = <&A72_L2>; 154 operating-points-v2 = <&a72_opp_table>; 155 #cooling-cells = <2>; 156 }; 157 158 A53_L2: l2-cache0 { 159 compatible = "cache"; 160 cache-level = <2>; 161 cache-unified; 162 cache-size = <0x100000>; 163 cache-line-size = <64>; 164 cache-sets = <1024>; 165 }; 166 167 A72_L2: l2-cache1 { 168 compatible = "cache"; 169 cache-level = <2>; 170 cache-unified; 171 cache-size = <0x100000>; 172 cache-line-size = <64>; 173 cache-sets = <1024>; 174 }; 175 }; 176 177 a53_opp_table: opp-table-0 { 178 compatible = "operating-points-v2"; 179 opp-shared; 180 181 opp-600000000 { 182 opp-hz = /bits/ 64 <600000000>; 183 opp-microvolt = <900000>; 184 clock-latency-ns = <150000>; 185 }; 186 187 opp-896000000 { 188 opp-hz = /bits/ 64 <896000000>; 189 opp-microvolt = <1000000>; 190 clock-latency-ns = <150000>; 191 }; 192 193 opp-1104000000 { 194 opp-hz = /bits/ 64 <1104000000>; 195 opp-microvolt = <1100000>; 196 clock-latency-ns = <150000>; 197 }; 198 199 opp-1200000000 { 200 opp-hz = /bits/ 64 <1200000000>; 201 opp-microvolt = <1100000>; 202 clock-latency-ns = <150000>; 203 opp-suspend; 204 }; 205 }; 206 207 a72_opp_table: opp-table-1 { 208 compatible = "operating-points-v2"; 209 opp-shared; 210 211 opp-600000000 { 212 opp-hz = /bits/ 64 <600000000>; 213 opp-microvolt = <1000000>; 214 clock-latency-ns = <150000>; 215 }; 216 217 opp-1056000000 { 218 opp-hz = /bits/ 64 <1056000000>; 219 opp-microvolt = <1000000>; 220 clock-latency-ns = <150000>; 221 }; 222 223 opp-1296000000 { 224 opp-hz = /bits/ 64 <1296000000>; 225 opp-microvolt = <1100000>; 226 clock-latency-ns = <150000>; 227 }; 228 229 opp-1596000000 { 230 opp-hz = /bits/ 64 <1596000000>; 231 opp-microvolt = <1100000>; 232 clock-latency-ns = <150000>; 233 opp-suspend; 234 }; 235 }; 236 237 gic: interrupt-controller@51a00000 { 238 compatible = "arm,gic-v3"; 239 reg = <0x0 0x51a00000 0 0x10000>, /* GIC Dist */ 240 <0x0 0x51b00000 0 0xC0000>, /* GICR */ 241 <0x0 0x52000000 0 0x2000>, /* GICC */ 242 <0x0 0x52010000 0 0x1000>, /* GICH */ 243 <0x0 0x52020000 0 0x20000>; /* GICV */ 244 #interrupt-cells = <3>; 245 interrupt-controller; 246 interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>; 247 interrupt-parent = <&gic>; 248 }; 249 250 pmu { 251 compatible = "arm,armv8-pmuv3"; 252 interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>; 253 }; 254 255 psci { 256 compatible = "arm,psci-1.0"; 257 method = "smc"; 258 }; 259 260 timer { 261 compatible = "arm,armv8-timer"; 262 interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>, /* Physical Secure */ 263 <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>, /* Physical Non-Secure */ 264 <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>, /* Virtual */ 265 <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>; /* Hypervisor */ 266 }; 267 268 smmu: iommu@51400000 { 269 compatible = "arm,mmu-500"; 270 interrupt-parent = <&gic>; 271 reg = <0 0x51400000 0 0x40000>; 272 #global-interrupts = <1>; 273 #iommu-cells = <2>; 274 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 275 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 276 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 277 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 278 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 279 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 280 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 281 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 282 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 283 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 284 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 285 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 286 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 287 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 288 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 289 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 290 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 291 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 292 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 293 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 294 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 295 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 296 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 297 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 298 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 299 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 300 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 301 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 302 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 303 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 304 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 305 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 306 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>; 307 }; 308 309 system-controller { 310 compatible = "fsl,imx-scu"; 311 mbox-names = "tx0", 312 "rx0", 313 "gip3"; 314 mboxes = <&lsio_mu1 0 0 315 &lsio_mu1 1 0 316 &lsio_mu1 3 3>; 317 318 pd: power-controller { 319 compatible = "fsl,imx8qm-scu-pd", "fsl,scu-pd"; 320 #power-domain-cells = <1>; 321 }; 322 323 clk: clock-controller { 324 compatible = "fsl,imx8qm-clk", "fsl,scu-clk"; 325 #clock-cells = <2>; 326 }; 327 328 iomuxc: pinctrl { 329 compatible = "fsl,imx8qm-iomuxc"; 330 }; 331 332 rtc: rtc { 333 compatible = "fsl,imx8qxp-sc-rtc"; 334 }; 335 336 ocotp: ocotp { 337 compatible = "fsl,imx8qm-scu-ocotp"; 338 #address-cells = <1>; 339 #size-cells = <1>; 340 read-only; 341 342 fec_mac0: mac@1c4 { 343 reg = <0x1c4 6>; 344 }; 345 346 fec_mac1: mac@1c6 { 347 reg = <0x1c6 6>; 348 }; 349 }; 350 351 tsens: thermal-sensor { 352 compatible = "fsl,imx8qxp-sc-thermal", "fsl,imx-sc-thermal"; 353 #thermal-sensor-cells = <1>; 354 }; 355 }; 356 357 thermal-zones { 358 cpu0-thermal { 359 polling-delay-passive = <250>; 360 polling-delay = <2000>; 361 thermal-sensors = <&tsens IMX_SC_R_A53>; 362 363 trips { 364 cpu_alert0: trip0 { 365 temperature = <107000>; 366 hysteresis = <2000>; 367 type = "passive"; 368 }; 369 370 cpu_crit0: trip1 { 371 temperature = <127000>; 372 hysteresis = <2000>; 373 type = "critical"; 374 }; 375 }; 376 377 cooling-maps { 378 map0 { 379 trip = <&cpu_alert0>; 380 cooling-device = 381 <&A53_0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 382 <&A53_1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 383 <&A53_2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 384 <&A53_3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>; 385 }; 386 }; 387 }; 388 389 cpu1-thermal { 390 polling-delay-passive = <250>; 391 polling-delay = <2000>; 392 thermal-sensors = <&tsens IMX_SC_R_A72>; 393 394 trips { 395 cpu_alert1: trip0 { 396 temperature = <107000>; 397 hysteresis = <2000>; 398 type = "passive"; 399 }; 400 401 cpu_crit1: trip1 { 402 temperature = <127000>; 403 hysteresis = <2000>; 404 type = "critical"; 405 }; 406 }; 407 408 cooling-maps { 409 map0 { 410 trip = <&cpu_alert1>; 411 cooling-device = 412 <&A72_0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 413 <&A72_1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>; 414 }; 415 }; 416 }; 417 418 gpu0-thermal { 419 polling-delay-passive = <250>; 420 polling-delay = <2000>; 421 thermal-sensors = <&tsens IMX_SC_R_GPU_0_PID0>; 422 423 trips { 424 gpu_alert0: trip0 { 425 temperature = <107000>; 426 hysteresis = <2000>; 427 type = "passive"; 428 }; 429 430 gpu_crit0: trip1 { 431 temperature = <127000>; 432 hysteresis = <2000>; 433 type = "critical"; 434 }; 435 }; 436 }; 437 438 gpu1-thermal { 439 polling-delay-passive = <250>; 440 polling-delay = <2000>; 441 thermal-sensors = <&tsens IMX_SC_R_GPU_1_PID0>; 442 443 trips { 444 gpu_alert1: trip0 { 445 temperature = <107000>; 446 hysteresis = <2000>; 447 type = "passive"; 448 }; 449 450 gpu_crit1: trip1 { 451 temperature = <127000>; 452 hysteresis = <2000>; 453 type = "critical"; 454 }; 455 }; 456 }; 457 458 drc0-thermal { 459 polling-delay-passive = <250>; 460 polling-delay = <2000>; 461 thermal-sensors = <&tsens IMX_SC_R_DRC_0>; 462 463 trips { 464 drc_alert0: trip0 { 465 temperature = <107000>; 466 hysteresis = <2000>; 467 type = "passive"; 468 }; 469 470 drc_crit0: trip1 { 471 temperature = <127000>; 472 hysteresis = <2000>; 473 type = "critical"; 474 }; 475 }; 476 }; 477 }; 478 479 clk_dummy: clock-dummy { 480 compatible = "fixed-clock"; 481 #clock-cells = <0>; 482 clock-frequency = <0>; 483 clock-output-names = "clk_dummy"; 484 }; 485 486 clk_esai1_rx_clk: clock-esai1-rx { 487 compatible = "fixed-clock"; 488 #clock-cells = <0>; 489 clock-frequency = <0>; 490 clock-output-names = "esai1_rx_clk"; 491 }; 492 493 clk_esai1_rx_hf_clk: clock-esai1-rx-hf { 494 compatible = "fixed-clock"; 495 #clock-cells = <0>; 496 clock-frequency = <0>; 497 clock-output-names = "esai1_rx_hf_clk"; 498 }; 499 500 clk_esai1_tx_clk: clock-esai1-tx { 501 compatible = "fixed-clock"; 502 #clock-cells = <0>; 503 clock-frequency = <0>; 504 clock-output-names = "esai1_tx_clk"; 505 }; 506 507 clk_esai1_tx_hf_clk: clock-esai1-tx-hf { 508 compatible = "fixed-clock"; 509 #clock-cells = <0>; 510 clock-frequency = <0>; 511 clock-output-names = "esai1_tx_hf_clk"; 512 }; 513 514 clk_hdmi_rx_mclk: clock-hdmi-rx-mclk { 515 compatible = "fixed-clock"; 516 #clock-cells = <0>; 517 clock-frequency = <0>; 518 clock-output-names = "hdmi-rx-mclk"; 519 }; 520 521 clk_mlb_clk: clock-mlb-clk { 522 compatible = "fixed-clock"; 523 #clock-cells = <0>; 524 clock-frequency = <0>; 525 clock-output-names = "mlb_clk"; 526 }; 527 528 clk_sai5_rx_bclk: clock-sai5-rx-bclk { 529 compatible = "fixed-clock"; 530 #clock-cells = <0>; 531 clock-frequency = <0>; 532 clock-output-names = "sai5_rx_bclk"; 533 }; 534 535 clk_sai5_tx_bclk: clock-sai5-tx-bclk { 536 compatible = "fixed-clock"; 537 #clock-cells = <0>; 538 clock-frequency = <0>; 539 clock-output-names = "sai5_tx_bclk"; 540 }; 541 542 clk_sai6_rx_bclk: clock-sai6-rx-bclk { 543 compatible = "fixed-clock"; 544 #clock-cells = <0>; 545 clock-frequency = <0>; 546 clock-output-names = "sai6_rx_bclk"; 547 }; 548 549 clk_sai6_tx_bclk: clock-sai6-tx-bclk { 550 compatible = "fixed-clock"; 551 #clock-cells = <0>; 552 clock-frequency = <0>; 553 clock-output-names = "sai6_tx_bclk"; 554 }; 555 556 clk_spdif1_rx: clock-spdif1-rx { 557 compatible = "fixed-clock"; 558 #clock-cells = <0>; 559 clock-frequency = <0>; 560 clock-output-names = "spdif1_rx"; 561 }; 562 563 /* sorted in register address */ 564 #include "imx8-ss-cm41.dtsi" 565 #include "imx8-ss-audio.dtsi" 566 #include "imx8-ss-vpu.dtsi" 567 #include "imx8-ss-gpu0.dtsi" 568 #include "imx8-ss-img.dtsi" 569 #include "imx8-ss-dma.dtsi" 570 #include "imx8-ss-conn.dtsi" 571 #include "imx8-ss-lsio.dtsi" 572}; 573 574#include "imx8qm-ss-img.dtsi" 575#include "imx8qm-ss-dma.dtsi" 576#include "imx8qm-ss-conn.dtsi" 577#include "imx8qm-ss-lsio.dtsi" 578#include "imx8qm-ss-audio.dtsi" 579