1// SPDX-License-Identifier: BSD-3-Clause 2/* 3 * Copyright (c) 2021, Konrad Dybcio <konrad.dybcio@somainline.org> 4 * Copyright (c) 2022, Luca Weiss <luca.weiss@fairphone.com> 5 */ 6 7#include <dt-bindings/clock/qcom,dispcc-sm6350.h> 8#include <dt-bindings/clock/qcom,gcc-sm6350.h> 9#include <dt-bindings/clock/qcom,gpucc-sm6350.h> 10#include <dt-bindings/clock/qcom,rpmh.h> 11#include <dt-bindings/clock/qcom,sm6350-camcc.h> 12#include <dt-bindings/dma/qcom-gpi.h> 13#include <dt-bindings/gpio/gpio.h> 14#include <dt-bindings/interconnect/qcom,icc.h> 15#include <dt-bindings/interconnect/qcom,osm-l3.h> 16#include <dt-bindings/interconnect/qcom,sm6350.h> 17#include <dt-bindings/interrupt-controller/arm-gic.h> 18#include <dt-bindings/mailbox/qcom-ipcc.h> 19#include <dt-bindings/phy/phy-qcom-qmp.h> 20#include <dt-bindings/power/qcom-rpmpd.h> 21#include <dt-bindings/soc/qcom,rpmh-rsc.h> 22 23/ { 24 interrupt-parent = <&intc>; 25 #address-cells = <2>; 26 #size-cells = <2>; 27 28 clocks { 29 xo_board: xo-board { 30 compatible = "fixed-clock"; 31 #clock-cells = <0>; 32 clock-frequency = <76800000>; 33 clock-output-names = "xo_board"; 34 }; 35 36 sleep_clk: sleep-clk { 37 compatible = "fixed-clock"; 38 clock-frequency = <32764>; 39 #clock-cells = <0>; 40 }; 41 }; 42 43 cpus { 44 #address-cells = <2>; 45 #size-cells = <0>; 46 47 CPU0: cpu@0 { 48 device_type = "cpu"; 49 compatible = "qcom,kryo560"; 50 reg = <0x0 0x0>; 51 clocks = <&cpufreq_hw 0>; 52 enable-method = "psci"; 53 capacity-dmips-mhz = <1024>; 54 dynamic-power-coefficient = <100>; 55 next-level-cache = <&L2_0>; 56 qcom,freq-domain = <&cpufreq_hw 0>; 57 operating-points-v2 = <&cpu0_opp_table>; 58 interconnects = <&gem_noc MASTER_AMPSS_M0 QCOM_ICC_TAG_ACTIVE_ONLY 59 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>, 60 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 61 power-domains = <&CPU_PD0>; 62 power-domain-names = "psci"; 63 #cooling-cells = <2>; 64 L2_0: l2-cache { 65 compatible = "cache"; 66 cache-level = <2>; 67 cache-unified; 68 next-level-cache = <&L3_0>; 69 L3_0: l3-cache { 70 compatible = "cache"; 71 cache-level = <3>; 72 cache-unified; 73 }; 74 }; 75 }; 76 77 CPU1: cpu@100 { 78 device_type = "cpu"; 79 compatible = "qcom,kryo560"; 80 reg = <0x0 0x100>; 81 clocks = <&cpufreq_hw 0>; 82 enable-method = "psci"; 83 capacity-dmips-mhz = <1024>; 84 dynamic-power-coefficient = <100>; 85 next-level-cache = <&L2_100>; 86 qcom,freq-domain = <&cpufreq_hw 0>; 87 operating-points-v2 = <&cpu0_opp_table>; 88 interconnects = <&gem_noc MASTER_AMPSS_M0 QCOM_ICC_TAG_ACTIVE_ONLY 89 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>, 90 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 91 power-domains = <&CPU_PD1>; 92 power-domain-names = "psci"; 93 #cooling-cells = <2>; 94 L2_100: l2-cache { 95 compatible = "cache"; 96 cache-level = <2>; 97 cache-unified; 98 next-level-cache = <&L3_0>; 99 }; 100 }; 101 102 CPU2: cpu@200 { 103 device_type = "cpu"; 104 compatible = "qcom,kryo560"; 105 reg = <0x0 0x200>; 106 clocks = <&cpufreq_hw 0>; 107 enable-method = "psci"; 108 capacity-dmips-mhz = <1024>; 109 dynamic-power-coefficient = <100>; 110 next-level-cache = <&L2_200>; 111 qcom,freq-domain = <&cpufreq_hw 0>; 112 operating-points-v2 = <&cpu0_opp_table>; 113 interconnects = <&gem_noc MASTER_AMPSS_M0 QCOM_ICC_TAG_ACTIVE_ONLY 114 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>, 115 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 116 power-domains = <&CPU_PD2>; 117 power-domain-names = "psci"; 118 #cooling-cells = <2>; 119 L2_200: l2-cache { 120 compatible = "cache"; 121 cache-level = <2>; 122 cache-unified; 123 next-level-cache = <&L3_0>; 124 }; 125 }; 126 127 CPU3: cpu@300 { 128 device_type = "cpu"; 129 compatible = "qcom,kryo560"; 130 reg = <0x0 0x300>; 131 clocks = <&cpufreq_hw 0>; 132 enable-method = "psci"; 133 capacity-dmips-mhz = <1024>; 134 dynamic-power-coefficient = <100>; 135 next-level-cache = <&L2_300>; 136 qcom,freq-domain = <&cpufreq_hw 0>; 137 operating-points-v2 = <&cpu0_opp_table>; 138 interconnects = <&gem_noc MASTER_AMPSS_M0 QCOM_ICC_TAG_ACTIVE_ONLY 139 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>, 140 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 141 power-domains = <&CPU_PD3>; 142 power-domain-names = "psci"; 143 #cooling-cells = <2>; 144 L2_300: l2-cache { 145 compatible = "cache"; 146 cache-level = <2>; 147 cache-unified; 148 next-level-cache = <&L3_0>; 149 }; 150 }; 151 152 CPU4: cpu@400 { 153 device_type = "cpu"; 154 compatible = "qcom,kryo560"; 155 reg = <0x0 0x400>; 156 clocks = <&cpufreq_hw 0>; 157 enable-method = "psci"; 158 capacity-dmips-mhz = <1024>; 159 dynamic-power-coefficient = <100>; 160 next-level-cache = <&L2_400>; 161 qcom,freq-domain = <&cpufreq_hw 0>; 162 operating-points-v2 = <&cpu0_opp_table>; 163 interconnects = <&gem_noc MASTER_AMPSS_M0 QCOM_ICC_TAG_ACTIVE_ONLY 164 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>, 165 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 166 power-domains = <&CPU_PD4>; 167 power-domain-names = "psci"; 168 #cooling-cells = <2>; 169 L2_400: l2-cache { 170 compatible = "cache"; 171 cache-level = <2>; 172 cache-unified; 173 next-level-cache = <&L3_0>; 174 }; 175 }; 176 177 CPU5: cpu@500 { 178 device_type = "cpu"; 179 compatible = "qcom,kryo560"; 180 reg = <0x0 0x500>; 181 clocks = <&cpufreq_hw 0>; 182 enable-method = "psci"; 183 capacity-dmips-mhz = <1024>; 184 dynamic-power-coefficient = <100>; 185 next-level-cache = <&L2_500>; 186 qcom,freq-domain = <&cpufreq_hw 0>; 187 operating-points-v2 = <&cpu0_opp_table>; 188 interconnects = <&gem_noc MASTER_AMPSS_M0 QCOM_ICC_TAG_ACTIVE_ONLY 189 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>, 190 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 191 power-domains = <&CPU_PD5>; 192 power-domain-names = "psci"; 193 #cooling-cells = <2>; 194 L2_500: l2-cache { 195 compatible = "cache"; 196 cache-level = <2>; 197 cache-unified; 198 next-level-cache = <&L3_0>; 199 }; 200 }; 201 202 CPU6: cpu@600 { 203 device_type = "cpu"; 204 compatible = "qcom,kryo560"; 205 reg = <0x0 0x600>; 206 clocks = <&cpufreq_hw 1>; 207 enable-method = "psci"; 208 capacity-dmips-mhz = <1894>; 209 dynamic-power-coefficient = <703>; 210 next-level-cache = <&L2_600>; 211 qcom,freq-domain = <&cpufreq_hw 1>; 212 operating-points-v2 = <&cpu6_opp_table>; 213 interconnects = <&gem_noc MASTER_AMPSS_M0 QCOM_ICC_TAG_ACTIVE_ONLY 214 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>, 215 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 216 power-domains = <&CPU_PD6>; 217 power-domain-names = "psci"; 218 #cooling-cells = <2>; 219 L2_600: l2-cache { 220 compatible = "cache"; 221 cache-level = <2>; 222 cache-unified; 223 next-level-cache = <&L3_0>; 224 }; 225 }; 226 227 CPU7: cpu@700 { 228 device_type = "cpu"; 229 compatible = "qcom,kryo560"; 230 reg = <0x0 0x700>; 231 clocks = <&cpufreq_hw 1>; 232 enable-method = "psci"; 233 capacity-dmips-mhz = <1894>; 234 dynamic-power-coefficient = <703>; 235 next-level-cache = <&L2_700>; 236 qcom,freq-domain = <&cpufreq_hw 1>; 237 operating-points-v2 = <&cpu6_opp_table>; 238 interconnects = <&gem_noc MASTER_AMPSS_M0 QCOM_ICC_TAG_ACTIVE_ONLY 239 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>, 240 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 241 power-domains = <&CPU_PD7>; 242 power-domain-names = "psci"; 243 #cooling-cells = <2>; 244 L2_700: l2-cache { 245 compatible = "cache"; 246 cache-level = <2>; 247 cache-unified; 248 next-level-cache = <&L3_0>; 249 }; 250 }; 251 252 cpu-map { 253 cluster0 { 254 core0 { 255 cpu = <&CPU0>; 256 }; 257 258 core1 { 259 cpu = <&CPU1>; 260 }; 261 262 core2 { 263 cpu = <&CPU2>; 264 }; 265 266 core3 { 267 cpu = <&CPU3>; 268 }; 269 270 core4 { 271 cpu = <&CPU4>; 272 }; 273 274 core5 { 275 cpu = <&CPU5>; 276 }; 277 278 core6 { 279 cpu = <&CPU6>; 280 }; 281 282 core7 { 283 cpu = <&CPU7>; 284 }; 285 }; 286 }; 287 288 domain-idle-states { 289 CLUSTER_SLEEP_PC: cluster-sleep-0 { 290 compatible = "domain-idle-state"; 291 arm,psci-suspend-param = <0x41000044>; 292 entry-latency-us = <2752>; 293 exit-latency-us = <3048>; 294 min-residency-us = <6118>; 295 }; 296 297 CLUSTER_SLEEP_CX_RET: cluster-sleep-1 { 298 compatible = "domain-idle-state"; 299 arm,psci-suspend-param = <0x41001244>; 300 entry-latency-us = <3638>; 301 exit-latency-us = <4562>; 302 min-residency-us = <8467>; 303 }; 304 305 CLUSTER_AOSS_SLEEP: cluster-sleep-2 { 306 compatible = "domain-idle-state"; 307 arm,psci-suspend-param = <0x4100b244>; 308 entry-latency-us = <3263>; 309 exit-latency-us = <6562>; 310 min-residency-us = <9987>; 311 }; 312 }; 313 314 cpu_idle_states: idle-states { 315 entry-method = "psci"; 316 317 LITTLE_CPU_SLEEP_0: cpu-sleep-0-0 { 318 compatible = "arm,idle-state"; 319 idle-state-name = "little-power-collapse"; 320 arm,psci-suspend-param = <0x40000003>; 321 entry-latency-us = <549>; 322 exit-latency-us = <901>; 323 min-residency-us = <1774>; 324 local-timer-stop; 325 }; 326 327 LITTLE_CPU_SLEEP_1: cpu-sleep-0-1 { 328 compatible = "arm,idle-state"; 329 idle-state-name = "little-rail-power-collapse"; 330 arm,psci-suspend-param = <0x40000004>; 331 entry-latency-us = <702>; 332 exit-latency-us = <915>; 333 min-residency-us = <4001>; 334 local-timer-stop; 335 }; 336 337 BIG_CPU_SLEEP_0: cpu-sleep-1-0 { 338 compatible = "arm,idle-state"; 339 idle-state-name = "big-power-collapse"; 340 arm,psci-suspend-param = <0x40000003>; 341 entry-latency-us = <523>; 342 exit-latency-us = <1244>; 343 min-residency-us = <2207>; 344 local-timer-stop; 345 }; 346 347 BIG_CPU_SLEEP_1: cpu-sleep-1-1 { 348 compatible = "arm,idle-state"; 349 idle-state-name = "big-rail-power-collapse"; 350 arm,psci-suspend-param = <0x40000004>; 351 entry-latency-us = <526>; 352 exit-latency-us = <1854>; 353 min-residency-us = <5555>; 354 local-timer-stop; 355 }; 356 }; 357 }; 358 359 firmware { 360 scm: scm { 361 compatible = "qcom,scm-sm6350", "qcom,scm"; 362 #reset-cells = <1>; 363 }; 364 }; 365 366 memory@80000000 { 367 device_type = "memory"; 368 /* We expect the bootloader to fill in the size */ 369 reg = <0x0 0x80000000 0x0 0x0>; 370 }; 371 372 cpu0_opp_table: opp-table-cpu0 { 373 compatible = "operating-points-v2"; 374 opp-shared; 375 376 opp-300000000 { 377 opp-hz = /bits/ 64 <300000000>; 378 /* DDR: 4-wide, 2 channels, double data rate, L3: 16-wide, 2 channels */ 379 opp-peak-kBps = <(200000 * 4 * 2 * 2) (300000 * 16 * 2)>; 380 }; 381 382 opp-576000000 { 383 opp-hz = /bits/ 64 <576000000>; 384 opp-peak-kBps = <(547000 * 4 * 2 * 2) (556800 * 16 * 2)>; 385 }; 386 387 opp-768000000 { 388 opp-hz = /bits/ 64 <768000000>; 389 opp-peak-kBps = <(768000 * 4 * 2 * 2) (652800 * 16 * 2)>; 390 }; 391 392 opp-1017600000 { 393 opp-hz = /bits/ 64 <1017600000>; 394 opp-peak-kBps = <(1017000 * 4 * 2 * 2) (940800 * 16 * 2)>; 395 }; 396 397 opp-1248000000 { 398 opp-hz = /bits/ 64 <1248000000>; 399 opp-peak-kBps = <(1017000 * 4 * 2 * 2) (1209600 * 16 * 2)>; 400 }; 401 402 opp-1324800000 { 403 opp-hz = /bits/ 64 <1324800000>; 404 opp-peak-kBps = <(1017000 * 4 * 2 * 2) (1286400 * 16 * 2)>; 405 }; 406 407 opp-1516800000 { 408 opp-hz = /bits/ 64 <1516800000>; 409 opp-peak-kBps = <(1353000 * 4 * 2 * 2) (1459200 * 16 * 2)>; 410 }; 411 412 opp-1612800000 { 413 opp-hz = /bits/ 64 <1612800000>; 414 opp-peak-kBps = <(1555000 * 4 * 2 * 2) (1459200 * 16 * 2)>; 415 }; 416 417 opp-1708800000 { 418 opp-hz = /bits/ 64 <1708800000>; 419 opp-peak-kBps = <(1555000 * 4 * 2 * 2) (1459200 * 16 * 2)>; 420 }; 421 }; 422 423 cpu6_opp_table: opp-table-cpu6 { 424 compatible = "operating-points-v2"; 425 opp-shared; 426 427 opp-300000000 { 428 opp-hz = /bits/ 64 <300000000>; 429 opp-peak-kBps = <(200000 * 4 * 2 * 2) (300000 * 16 * 2)>; 430 }; 431 432 opp-787200000 { 433 opp-hz = /bits/ 64 <787200000>; 434 opp-peak-kBps = <(768000 * 4 * 2 * 2) (652800 * 16 * 2)>; 435 }; 436 437 opp-979200000 { 438 opp-hz = /bits/ 64 <979200000>; 439 opp-peak-kBps = <(768000 * 4 * 2 * 2) (940800 * 16 * 2)>; 440 }; 441 442 opp-1036800000 { 443 opp-hz = /bits/ 64 <1036800000>; 444 opp-peak-kBps = <(1017000 * 4 * 2 * 2) (940800 * 16 * 2)>; 445 }; 446 447 opp-1248000000 { 448 opp-hz = /bits/ 64 <1248000000>; 449 opp-peak-kBps = <(1017000 * 4 * 2 * 2) (1209600 * 16 * 2)>; 450 }; 451 452 opp-1401600000 { 453 opp-hz = /bits/ 64 <1401600000>; 454 opp-peak-kBps = <(1353000 * 4 * 2 * 2) (1401600 * 16 * 2)>; 455 }; 456 457 opp-1555200000 { 458 opp-hz = /bits/ 64 <1555200000>; 459 opp-peak-kBps = <(1555000 * 4 * 2 * 2) (1459200 * 16 * 2)>; 460 }; 461 462 opp-1766400000 { 463 opp-hz = /bits/ 64 <1766400000>; 464 opp-peak-kBps = <(1555000 * 4 * 2 * 2) (1459200 * 16 * 2)>; 465 }; 466 467 opp-1900800000 { 468 opp-hz = /bits/ 64 <1900800000>; 469 opp-peak-kBps = <(1804000 * 4 * 2 * 2) (1459200 * 16 * 2)>; 470 }; 471 472 opp-2073600000 { 473 opp-hz = /bits/ 64 <2073600000>; 474 opp-peak-kBps = <(2092000 * 4 * 2 * 2) (1459200 * 16 * 2)>; 475 }; 476 }; 477 478 qup_opp_table: opp-table-qup { 479 compatible = "operating-points-v2"; 480 481 opp-75000000 { 482 opp-hz = /bits/ 64 <75000000>; 483 required-opps = <&rpmhpd_opp_low_svs>; 484 }; 485 486 opp-100000000 { 487 opp-hz = /bits/ 64 <100000000>; 488 required-opps = <&rpmhpd_opp_svs>; 489 }; 490 491 opp-128000000 { 492 opp-hz = /bits/ 64 <128000000>; 493 required-opps = <&rpmhpd_opp_nom>; 494 }; 495 }; 496 497 pmu { 498 compatible = "arm,armv8-pmuv3"; 499 interrupts = <GIC_PPI 5 IRQ_TYPE_LEVEL_LOW>; 500 }; 501 502 psci { 503 compatible = "arm,psci-1.0"; 504 method = "smc"; 505 506 CPU_PD0: power-domain-cpu0 { 507 #power-domain-cells = <0>; 508 power-domains = <&CLUSTER_PD>; 509 domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>; 510 }; 511 512 CPU_PD1: power-domain-cpu1 { 513 #power-domain-cells = <0>; 514 power-domains = <&CLUSTER_PD>; 515 domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>; 516 }; 517 518 CPU_PD2: power-domain-cpu2 { 519 #power-domain-cells = <0>; 520 power-domains = <&CLUSTER_PD>; 521 domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>; 522 }; 523 524 CPU_PD3: power-domain-cpu3 { 525 #power-domain-cells = <0>; 526 power-domains = <&CLUSTER_PD>; 527 domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>; 528 }; 529 530 CPU_PD4: power-domain-cpu4 { 531 #power-domain-cells = <0>; 532 power-domains = <&CLUSTER_PD>; 533 domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>; 534 }; 535 536 CPU_PD5: power-domain-cpu5 { 537 #power-domain-cells = <0>; 538 power-domains = <&CLUSTER_PD>; 539 domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>; 540 }; 541 542 CPU_PD6: power-domain-cpu6 { 543 #power-domain-cells = <0>; 544 power-domains = <&CLUSTER_PD>; 545 domain-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>; 546 }; 547 548 CPU_PD7: power-domain-cpu7 { 549 #power-domain-cells = <0>; 550 power-domains = <&CLUSTER_PD>; 551 domain-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>; 552 }; 553 554 CLUSTER_PD: power-domain-cpu-cluster0 { 555 #power-domain-cells = <0>; 556 domain-idle-states = <&CLUSTER_SLEEP_PC 557 &CLUSTER_SLEEP_CX_RET 558 &CLUSTER_AOSS_SLEEP>; 559 }; 560 }; 561 562 reserved_memory: reserved-memory { 563 #address-cells = <2>; 564 #size-cells = <2>; 565 ranges; 566 567 hyp_mem: memory@80000000 { 568 reg = <0 0x80000000 0 0x600000>; 569 no-map; 570 }; 571 572 xbl_aop_mem: memory@80700000 { 573 reg = <0 0x80700000 0 0x160000>; 574 no-map; 575 }; 576 577 cmd_db: memory@80860000 { 578 compatible = "qcom,cmd-db"; 579 reg = <0 0x80860000 0 0x20000>; 580 no-map; 581 }; 582 583 sec_apps_mem: memory@808ff000 { 584 reg = <0 0x808ff000 0 0x1000>; 585 no-map; 586 }; 587 588 smem_mem: memory@80900000 { 589 reg = <0 0x80900000 0 0x200000>; 590 no-map; 591 }; 592 593 cdsp_sec_mem: memory@80b00000 { 594 reg = <0 0x80b00000 0 0x1e00000>; 595 no-map; 596 }; 597 598 pil_camera_mem: memory@86000000 { 599 reg = <0 0x86000000 0 0x500000>; 600 no-map; 601 }; 602 603 pil_npu_mem: memory@86500000 { 604 reg = <0 0x86500000 0 0x500000>; 605 no-map; 606 }; 607 608 pil_video_mem: memory@86a00000 { 609 reg = <0 0x86a00000 0 0x500000>; 610 no-map; 611 }; 612 613 pil_cdsp_mem: memory@86f00000 { 614 reg = <0 0x86f00000 0 0x1e00000>; 615 no-map; 616 }; 617 618 pil_adsp_mem: memory@88d00000 { 619 reg = <0 0x88d00000 0 0x2800000>; 620 no-map; 621 }; 622 623 wlan_fw_mem: memory@8b500000 { 624 reg = <0 0x8b500000 0 0x200000>; 625 no-map; 626 }; 627 628 pil_ipa_fw_mem: memory@8b700000 { 629 reg = <0 0x8b700000 0 0x10000>; 630 no-map; 631 }; 632 633 pil_ipa_gsi_mem: memory@8b710000 { 634 reg = <0 0x8b710000 0 0x5400>; 635 no-map; 636 }; 637 638 pil_modem_mem: memory@8b800000 { 639 reg = <0 0x8b800000 0 0xf800000>; 640 no-map; 641 }; 642 643 cont_splash_memory: memory@a0000000 { 644 reg = <0 0xa0000000 0 0x2300000>; 645 no-map; 646 }; 647 648 dfps_data_memory: memory@a2300000 { 649 reg = <0 0xa2300000 0 0x100000>; 650 no-map; 651 }; 652 653 removed_region: memory@c0000000 { 654 reg = <0 0xc0000000 0 0x3900000>; 655 no-map; 656 }; 657 658 pil_gpu_mem: memory@f0d00000 { 659 reg = <0 0xf0d00000 0 0x1000>; 660 no-map; 661 }; 662 663 debug_region: memory@ffb00000 { 664 reg = <0 0xffb00000 0 0xc0000>; 665 no-map; 666 }; 667 668 last_log_region: memory@ffbc0000 { 669 reg = <0 0xffbc0000 0 0x40000>; 670 no-map; 671 }; 672 673 ramoops: ramoops@ffc00000 { 674 compatible = "ramoops"; 675 reg = <0 0xffc00000 0 0x100000>; 676 record-size = <0x1000>; 677 console-size = <0x40000>; 678 pmsg-size = <0x20000>; 679 ecc-size = <16>; 680 no-map; 681 }; 682 683 cmdline_region: memory@ffd00000 { 684 reg = <0 0xffd00000 0 0x1000>; 685 no-map; 686 }; 687 }; 688 689 smem { 690 compatible = "qcom,smem"; 691 memory-region = <&smem_mem>; 692 hwlocks = <&tcsr_mutex 3>; 693 }; 694 695 smp2p-adsp { 696 compatible = "qcom,smp2p"; 697 qcom,smem = <443>, <429>; 698 interrupts-extended = <&ipcc IPCC_CLIENT_LPASS 699 IPCC_MPROC_SIGNAL_SMP2P 700 IRQ_TYPE_EDGE_RISING>; 701 mboxes = <&ipcc IPCC_CLIENT_LPASS 702 IPCC_MPROC_SIGNAL_SMP2P>; 703 704 qcom,local-pid = <0>; 705 qcom,remote-pid = <2>; 706 707 smp2p_adsp_out: master-kernel { 708 qcom,entry-name = "master-kernel"; 709 #qcom,smem-state-cells = <1>; 710 }; 711 712 smp2p_adsp_in: slave-kernel { 713 qcom,entry-name = "slave-kernel"; 714 interrupt-controller; 715 #interrupt-cells = <2>; 716 }; 717 }; 718 719 smp2p-cdsp { 720 compatible = "qcom,smp2p"; 721 qcom,smem = <94>, <432>; 722 interrupts-extended = <&ipcc IPCC_CLIENT_CDSP 723 IPCC_MPROC_SIGNAL_SMP2P 724 IRQ_TYPE_EDGE_RISING>; 725 mboxes = <&ipcc IPCC_CLIENT_CDSP 726 IPCC_MPROC_SIGNAL_SMP2P>; 727 728 qcom,local-pid = <0>; 729 qcom,remote-pid = <5>; 730 731 smp2p_cdsp_out: master-kernel { 732 qcom,entry-name = "master-kernel"; 733 #qcom,smem-state-cells = <1>; 734 }; 735 736 smp2p_cdsp_in: slave-kernel { 737 qcom,entry-name = "slave-kernel"; 738 interrupt-controller; 739 #interrupt-cells = <2>; 740 }; 741 }; 742 743 smp2p-mpss { 744 compatible = "qcom,smp2p"; 745 qcom,smem = <435>, <428>; 746 747 interrupts-extended = <&ipcc IPCC_CLIENT_MPSS 748 IPCC_MPROC_SIGNAL_SMP2P 749 IRQ_TYPE_EDGE_RISING>; 750 mboxes = <&ipcc IPCC_CLIENT_MPSS 751 IPCC_MPROC_SIGNAL_SMP2P>; 752 753 qcom,local-pid = <0>; 754 qcom,remote-pid = <1>; 755 756 modem_smp2p_out: master-kernel { 757 qcom,entry-name = "master-kernel"; 758 #qcom,smem-state-cells = <1>; 759 }; 760 761 modem_smp2p_in: slave-kernel { 762 qcom,entry-name = "slave-kernel"; 763 interrupt-controller; 764 #interrupt-cells = <2>; 765 }; 766 767 ipa_smp2p_out: ipa-ap-to-modem { 768 qcom,entry-name = "ipa"; 769 #qcom,smem-state-cells = <1>; 770 }; 771 772 ipa_smp2p_in: ipa-modem-to-ap { 773 qcom,entry-name = "ipa"; 774 interrupt-controller; 775 #interrupt-cells = <2>; 776 }; 777 }; 778 779 soc: soc@0 { 780 #address-cells = <2>; 781 #size-cells = <2>; 782 ranges = <0 0 0 0 0x10 0>; 783 dma-ranges = <0 0 0 0 0x10 0>; 784 compatible = "simple-bus"; 785 786 gcc: clock-controller@100000 { 787 compatible = "qcom,gcc-sm6350"; 788 reg = <0 0x00100000 0 0x1f0000>; 789 #clock-cells = <1>; 790 #reset-cells = <1>; 791 #power-domain-cells = <1>; 792 clock-names = "bi_tcxo", 793 "bi_tcxo_ao", 794 "sleep_clk"; 795 clocks = <&rpmhcc RPMH_CXO_CLK>, 796 <&rpmhcc RPMH_CXO_CLK_A>, 797 <&sleep_clk>; 798 }; 799 800 ipcc: mailbox@408000 { 801 compatible = "qcom,sm6350-ipcc", "qcom,ipcc"; 802 reg = <0 0x00408000 0 0x1000>; 803 interrupts = <GIC_SPI 228 IRQ_TYPE_LEVEL_HIGH>; 804 interrupt-controller; 805 #interrupt-cells = <3>; 806 #mbox-cells = <2>; 807 }; 808 809 qfprom: qfprom@784000 { 810 compatible = "qcom,sm6350-qfprom", "qcom,qfprom"; 811 reg = <0 0x00784000 0 0x3000>; 812 #address-cells = <1>; 813 #size-cells = <1>; 814 815 gpu_speed_bin: gpu-speed-bin@2015 { 816 reg = <0x2015 0x1>; 817 bits = <0 8>; 818 }; 819 }; 820 821 rng: rng@793000 { 822 compatible = "qcom,prng-ee"; 823 reg = <0 0x00793000 0 0x1000>; 824 clocks = <&gcc GCC_PRNG_AHB_CLK>; 825 clock-names = "core"; 826 }; 827 828 sdhc_1: mmc@7c4000 { 829 compatible = "qcom,sm6350-sdhci", "qcom,sdhci-msm-v5"; 830 reg = <0 0x007c4000 0 0x1000>, 831 <0 0x007c5000 0 0x1000>, 832 <0 0x007c8000 0 0x8000>; 833 reg-names = "hc", "cqhci", "ice"; 834 835 interrupts = <GIC_SPI 641 IRQ_TYPE_LEVEL_HIGH>, 836 <GIC_SPI 644 IRQ_TYPE_LEVEL_HIGH>; 837 interrupt-names = "hc_irq", "pwr_irq"; 838 iommus = <&apps_smmu 0x60 0x0>; 839 840 clocks = <&gcc GCC_SDCC1_AHB_CLK>, 841 <&gcc GCC_SDCC1_APPS_CLK>, 842 <&rpmhcc RPMH_CXO_CLK>; 843 clock-names = "iface", "core", "xo"; 844 resets = <&gcc GCC_SDCC1_BCR>; 845 qcom,dll-config = <0x000f642c>; 846 qcom,ddr-config = <0x80040868>; 847 power-domains = <&rpmhpd SM6350_CX>; 848 operating-points-v2 = <&sdhc1_opp_table>; 849 bus-width = <8>; 850 non-removable; 851 supports-cqe; 852 853 status = "disabled"; 854 855 sdhc1_opp_table: opp-table { 856 compatible = "operating-points-v2"; 857 858 opp-19200000 { 859 opp-hz = /bits/ 64 <19200000>; 860 required-opps = <&rpmhpd_opp_min_svs>; 861 }; 862 863 opp-100000000 { 864 opp-hz = /bits/ 64 <100000000>; 865 required-opps = <&rpmhpd_opp_low_svs>; 866 }; 867 868 opp-384000000 { 869 opp-hz = /bits/ 64 <384000000>; 870 required-opps = <&rpmhpd_opp_svs_l1>; 871 }; 872 }; 873 }; 874 875 gpi_dma0: dma-controller@800000 { 876 compatible = "qcom,sm6350-gpi-dma"; 877 reg = <0 0x00800000 0 0x60000>; 878 interrupts = <GIC_SPI 244 IRQ_TYPE_LEVEL_HIGH>, 879 <GIC_SPI 245 IRQ_TYPE_LEVEL_HIGH>, 880 <GIC_SPI 246 IRQ_TYPE_LEVEL_HIGH>, 881 <GIC_SPI 247 IRQ_TYPE_LEVEL_HIGH>, 882 <GIC_SPI 248 IRQ_TYPE_LEVEL_HIGH>, 883 <GIC_SPI 249 IRQ_TYPE_LEVEL_HIGH>, 884 <GIC_SPI 250 IRQ_TYPE_LEVEL_HIGH>, 885 <GIC_SPI 251 IRQ_TYPE_LEVEL_HIGH>, 886 <GIC_SPI 252 IRQ_TYPE_LEVEL_HIGH>, 887 <GIC_SPI 253 IRQ_TYPE_LEVEL_HIGH>; 888 dma-channels = <10>; 889 dma-channel-mask = <0x1f>; 890 iommus = <&apps_smmu 0x56 0x0>; 891 #dma-cells = <3>; 892 status = "disabled"; 893 }; 894 895 qupv3_id_0: geniqup@8c0000 { 896 compatible = "qcom,geni-se-qup"; 897 reg = <0x0 0x008c0000 0x0 0x2000>; 898 clock-names = "m-ahb", "s-ahb"; 899 clocks = <&gcc GCC_QUPV3_WRAP_0_M_AHB_CLK>, 900 <&gcc GCC_QUPV3_WRAP_0_S_AHB_CLK>; 901 #address-cells = <2>; 902 #size-cells = <2>; 903 iommus = <&apps_smmu 0x43 0x0>; 904 ranges; 905 status = "disabled"; 906 907 i2c0: i2c@880000 { 908 compatible = "qcom,geni-i2c"; 909 reg = <0 0x00880000 0 0x4000>; 910 clock-names = "se"; 911 clocks = <&gcc GCC_QUPV3_WRAP0_S0_CLK>; 912 pinctrl-names = "default"; 913 pinctrl-0 = <&qup_i2c0_default>; 914 interrupts = <GIC_SPI 601 IRQ_TYPE_LEVEL_HIGH>; 915 dmas = <&gpi_dma0 0 0 QCOM_GPI_I2C>, 916 <&gpi_dma0 1 0 QCOM_GPI_I2C>; 917 dma-names = "tx", "rx"; 918 #address-cells = <1>; 919 #size-cells = <0>; 920 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>, 921 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_QUP_0 0>, 922 <&aggre1_noc MASTER_QUP_0 0 &clk_virt SLAVE_EBI_CH0 0>; 923 interconnect-names = "qup-core", "qup-config", "qup-memory"; 924 status = "disabled"; 925 }; 926 927 uart1: serial@884000 { 928 compatible = "qcom,geni-uart"; 929 reg = <0 0x00884000 0 0x4000>; 930 clock-names = "se"; 931 clocks = <&gcc GCC_QUPV3_WRAP0_S1_CLK>; 932 pinctrl-names = "default"; 933 pinctrl-0 = <&qup_uart1_cts>, <&qup_uart1_rts>, <&qup_uart1_tx>, <&qup_uart1_rx>; 934 interrupts = <GIC_SPI 602 IRQ_TYPE_LEVEL_HIGH>; 935 power-domains = <&rpmhpd SM6350_CX>; 936 operating-points-v2 = <&qup_opp_table>; 937 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>, 938 <&aggre1_noc MASTER_QUP_0 0 &clk_virt SLAVE_EBI_CH0 0>; 939 interconnect-names = "qup-core", "qup-config"; 940 status = "disabled"; 941 }; 942 943 i2c2: i2c@888000 { 944 compatible = "qcom,geni-i2c"; 945 reg = <0 0x00888000 0 0x4000>; 946 clock-names = "se"; 947 clocks = <&gcc GCC_QUPV3_WRAP0_S2_CLK>; 948 pinctrl-names = "default"; 949 pinctrl-0 = <&qup_i2c2_default>; 950 interrupts = <GIC_SPI 603 IRQ_TYPE_LEVEL_HIGH>; 951 dmas = <&gpi_dma0 0 2 QCOM_GPI_I2C>, 952 <&gpi_dma0 1 2 QCOM_GPI_I2C>; 953 dma-names = "tx", "rx"; 954 #address-cells = <1>; 955 #size-cells = <0>; 956 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>, 957 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_QUP_0 0>, 958 <&aggre1_noc MASTER_QUP_0 0 &clk_virt SLAVE_EBI_CH0 0>; 959 interconnect-names = "qup-core", "qup-config", "qup-memory"; 960 status = "disabled"; 961 }; 962 }; 963 964 gpi_dma1: dma-controller@900000 { 965 compatible = "qcom,sm6350-gpi-dma"; 966 reg = <0 0x00900000 0 0x60000>; 967 interrupts = <GIC_SPI 645 IRQ_TYPE_LEVEL_HIGH>, 968 <GIC_SPI 646 IRQ_TYPE_LEVEL_HIGH>, 969 <GIC_SPI 647 IRQ_TYPE_LEVEL_HIGH>, 970 <GIC_SPI 648 IRQ_TYPE_LEVEL_HIGH>, 971 <GIC_SPI 649 IRQ_TYPE_LEVEL_HIGH>, 972 <GIC_SPI 650 IRQ_TYPE_LEVEL_HIGH>, 973 <GIC_SPI 651 IRQ_TYPE_LEVEL_HIGH>, 974 <GIC_SPI 652 IRQ_TYPE_LEVEL_HIGH>, 975 <GIC_SPI 653 IRQ_TYPE_LEVEL_HIGH>, 976 <GIC_SPI 654 IRQ_TYPE_LEVEL_HIGH>; 977 dma-channels = <10>; 978 dma-channel-mask = <0x3f>; 979 iommus = <&apps_smmu 0x4d6 0x0>; 980 #dma-cells = <3>; 981 status = "disabled"; 982 }; 983 984 qupv3_id_1: geniqup@9c0000 { 985 compatible = "qcom,geni-se-qup"; 986 reg = <0x0 0x009c0000 0x0 0x2000>; 987 clock-names = "m-ahb", "s-ahb"; 988 clocks = <&gcc GCC_QUPV3_WRAP_1_M_AHB_CLK>, 989 <&gcc GCC_QUPV3_WRAP_1_S_AHB_CLK>; 990 #address-cells = <2>; 991 #size-cells = <2>; 992 iommus = <&apps_smmu 0x4c3 0x0>; 993 ranges; 994 status = "disabled"; 995 996 i2c6: i2c@980000 { 997 compatible = "qcom,geni-i2c"; 998 reg = <0 0x00980000 0 0x4000>; 999 clock-names = "se"; 1000 clocks = <&gcc GCC_QUPV3_WRAP1_S0_CLK>; 1001 pinctrl-names = "default"; 1002 pinctrl-0 = <&qup_i2c6_default>; 1003 interrupts = <GIC_SPI 353 IRQ_TYPE_LEVEL_HIGH>; 1004 dmas = <&gpi_dma1 0 0 QCOM_GPI_I2C>, 1005 <&gpi_dma1 1 0 QCOM_GPI_I2C>; 1006 dma-names = "tx", "rx"; 1007 #address-cells = <1>; 1008 #size-cells = <0>; 1009 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>, 1010 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_QUP_1 0>, 1011 <&aggre2_noc MASTER_QUP_1 0 &clk_virt SLAVE_EBI_CH0 0>; 1012 interconnect-names = "qup-core", "qup-config", "qup-memory"; 1013 status = "disabled"; 1014 }; 1015 1016 i2c7: i2c@984000 { 1017 compatible = "qcom,geni-i2c"; 1018 reg = <0 0x00984000 0 0x4000>; 1019 clock-names = "se"; 1020 clocks = <&gcc GCC_QUPV3_WRAP1_S1_CLK>; 1021 pinctrl-names = "default"; 1022 pinctrl-0 = <&qup_i2c7_default>; 1023 interrupts = <GIC_SPI 354 IRQ_TYPE_LEVEL_HIGH>; 1024 dmas = <&gpi_dma1 0 1 QCOM_GPI_I2C>, 1025 <&gpi_dma1 1 1 QCOM_GPI_I2C>; 1026 dma-names = "tx", "rx"; 1027 #address-cells = <1>; 1028 #size-cells = <0>; 1029 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>, 1030 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_QUP_1 0>, 1031 <&aggre2_noc MASTER_QUP_1 0 &clk_virt SLAVE_EBI_CH0 0>; 1032 interconnect-names = "qup-core", "qup-config", "qup-memory"; 1033 status = "disabled"; 1034 }; 1035 1036 i2c8: i2c@988000 { 1037 compatible = "qcom,geni-i2c"; 1038 reg = <0 0x00988000 0 0x4000>; 1039 clock-names = "se"; 1040 clocks = <&gcc GCC_QUPV3_WRAP1_S2_CLK>; 1041 pinctrl-names = "default"; 1042 pinctrl-0 = <&qup_i2c8_default>; 1043 interrupts = <GIC_SPI 355 IRQ_TYPE_LEVEL_HIGH>; 1044 dmas = <&gpi_dma1 0 2 QCOM_GPI_I2C>, 1045 <&gpi_dma1 1 2 QCOM_GPI_I2C>; 1046 dma-names = "tx", "rx"; 1047 #address-cells = <1>; 1048 #size-cells = <0>; 1049 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>, 1050 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_QUP_1 0>, 1051 <&aggre2_noc MASTER_QUP_1 0 &clk_virt SLAVE_EBI_CH0 0>; 1052 interconnect-names = "qup-core", "qup-config", "qup-memory"; 1053 status = "disabled"; 1054 }; 1055 1056 uart9: serial@98c000 { 1057 compatible = "qcom,geni-debug-uart"; 1058 reg = <0 0x0098c000 0 0x4000>; 1059 clock-names = "se"; 1060 clocks = <&gcc GCC_QUPV3_WRAP1_S3_CLK>; 1061 pinctrl-names = "default"; 1062 pinctrl-0 = <&qup_uart9_default>; 1063 interrupts = <GIC_SPI 356 IRQ_TYPE_LEVEL_HIGH>; 1064 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>, 1065 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_QUP_1 0>; 1066 interconnect-names = "qup-core", "qup-config"; 1067 status = "disabled"; 1068 }; 1069 1070 i2c10: i2c@990000 { 1071 compatible = "qcom,geni-i2c"; 1072 reg = <0 0x00990000 0 0x4000>; 1073 clock-names = "se"; 1074 clocks = <&gcc GCC_QUPV3_WRAP1_S4_CLK>; 1075 pinctrl-names = "default"; 1076 pinctrl-0 = <&qup_i2c10_default>; 1077 interrupts = <GIC_SPI 357 IRQ_TYPE_LEVEL_HIGH>; 1078 dmas = <&gpi_dma1 0 4 QCOM_GPI_I2C>, 1079 <&gpi_dma1 1 4 QCOM_GPI_I2C>; 1080 dma-names = "tx", "rx"; 1081 #address-cells = <1>; 1082 #size-cells = <0>; 1083 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>, 1084 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_QUP_1 0>, 1085 <&aggre2_noc MASTER_QUP_1 0 &clk_virt SLAVE_EBI_CH0 0>; 1086 interconnect-names = "qup-core", "qup-config", "qup-memory"; 1087 status = "disabled"; 1088 }; 1089 }; 1090 1091 config_noc: interconnect@1500000 { 1092 compatible = "qcom,sm6350-config-noc"; 1093 reg = <0 0x01500000 0 0x28000>; 1094 #interconnect-cells = <2>; 1095 qcom,bcm-voters = <&apps_bcm_voter>; 1096 }; 1097 1098 system_noc: interconnect@1620000 { 1099 compatible = "qcom,sm6350-system-noc"; 1100 reg = <0 0x01620000 0 0x17080>; 1101 #interconnect-cells = <2>; 1102 qcom,bcm-voters = <&apps_bcm_voter>; 1103 1104 clk_virt: interconnect-clk-virt { 1105 compatible = "qcom,sm6350-clk-virt"; 1106 #interconnect-cells = <2>; 1107 qcom,bcm-voters = <&apps_bcm_voter>; 1108 }; 1109 }; 1110 1111 aggre1_noc: interconnect@16e0000 { 1112 compatible = "qcom,sm6350-aggre1-noc"; 1113 reg = <0 0x016e0000 0 0x15080>; 1114 #interconnect-cells = <2>; 1115 qcom,bcm-voters = <&apps_bcm_voter>; 1116 }; 1117 1118 aggre2_noc: interconnect@1700000 { 1119 compatible = "qcom,sm6350-aggre2-noc"; 1120 reg = <0 0x01700000 0 0x1f880>; 1121 #interconnect-cells = <2>; 1122 qcom,bcm-voters = <&apps_bcm_voter>; 1123 1124 compute_noc: interconnect-compute-noc { 1125 compatible = "qcom,sm6350-compute-noc"; 1126 #interconnect-cells = <2>; 1127 qcom,bcm-voters = <&apps_bcm_voter>; 1128 }; 1129 }; 1130 1131 mmss_noc: interconnect@1740000 { 1132 compatible = "qcom,sm6350-mmss-noc"; 1133 reg = <0 0x01740000 0 0x1c100>; 1134 #interconnect-cells = <2>; 1135 qcom,bcm-voters = <&apps_bcm_voter>; 1136 }; 1137 1138 ufs_mem_hc: ufs@1d84000 { 1139 compatible = "qcom,sm6350-ufshc", "qcom,ufshc", 1140 "jedec,ufs-2.0"; 1141 reg = <0 0x01d84000 0 0x3000>, 1142 <0 0x01d90000 0 0x8000>; 1143 reg-names = "std", "ice"; 1144 interrupts = <GIC_SPI 265 IRQ_TYPE_LEVEL_HIGH>; 1145 phys = <&ufs_mem_phy_lanes>; 1146 phy-names = "ufsphy"; 1147 lanes-per-direction = <2>; 1148 #reset-cells = <1>; 1149 resets = <&gcc GCC_UFS_PHY_BCR>; 1150 reset-names = "rst"; 1151 1152 power-domains = <&gcc UFS_PHY_GDSC>; 1153 1154 iommus = <&apps_smmu 0x80 0x0>; 1155 1156 clock-names = "core_clk", 1157 "bus_aggr_clk", 1158 "iface_clk", 1159 "core_clk_unipro", 1160 "ref_clk", 1161 "tx_lane0_sync_clk", 1162 "rx_lane0_sync_clk", 1163 "rx_lane1_sync_clk", 1164 "ice_core_clk"; 1165 clocks = <&gcc GCC_UFS_PHY_AXI_CLK>, 1166 <&gcc GCC_AGGRE_UFS_PHY_AXI_CLK>, 1167 <&gcc GCC_UFS_PHY_AHB_CLK>, 1168 <&gcc GCC_UFS_PHY_UNIPRO_CORE_CLK>, 1169 <&rpmhcc RPMH_QLINK_CLK>, 1170 <&gcc GCC_UFS_PHY_TX_SYMBOL_0_CLK>, 1171 <&gcc GCC_UFS_PHY_RX_SYMBOL_0_CLK>, 1172 <&gcc GCC_UFS_PHY_RX_SYMBOL_1_CLK>, 1173 <&gcc GCC_UFS_PHY_ICE_CORE_CLK>; 1174 freq-table-hz = 1175 <50000000 200000000>, 1176 <0 0>, 1177 <0 0>, 1178 <37500000 150000000>, 1179 <75000000 300000000>, 1180 <0 0>, 1181 <0 0>, 1182 <0 0>, 1183 <0 0>; 1184 1185 status = "disabled"; 1186 }; 1187 1188 ufs_mem_phy: phy@1d87000 { 1189 compatible = "qcom,sm6350-qmp-ufs-phy"; 1190 reg = <0 0x01d87000 0 0x18c>; 1191 #address-cells = <2>; 1192 #size-cells = <2>; 1193 ranges; 1194 1195 clock-names = "ref", 1196 "ref_aux"; 1197 clocks = <&gcc GCC_UFS_MEM_CLKREF_CLK>, 1198 <&gcc GCC_UFS_PHY_PHY_AUX_CLK>; 1199 1200 resets = <&ufs_mem_hc 0>; 1201 reset-names = "ufsphy"; 1202 1203 status = "disabled"; 1204 1205 ufs_mem_phy_lanes: phy@1d87400 { 1206 reg = <0 0x01d87400 0 0x128>, 1207 <0 0x01d87600 0 0x1fc>, 1208 <0 0x01d87c00 0 0x1dc>, 1209 <0 0x01d87800 0 0x128>, 1210 <0 0x01d87a00 0 0x1fc>; 1211 #phy-cells = <0>; 1212 }; 1213 }; 1214 1215 ipa: ipa@1e40000 { 1216 compatible = "qcom,sm6350-ipa"; 1217 1218 iommus = <&apps_smmu 0x440 0x0>, 1219 <&apps_smmu 0x442 0x0>; 1220 reg = <0 0x01e40000 0 0x8000>, 1221 <0 0x01e50000 0 0x3000>, 1222 <0 0x01e04000 0 0x23000>; 1223 reg-names = "ipa-reg", 1224 "ipa-shared", 1225 "gsi"; 1226 1227 interrupts-extended = <&intc GIC_SPI 311 IRQ_TYPE_EDGE_RISING>, 1228 <&intc GIC_SPI 432 IRQ_TYPE_LEVEL_HIGH>, 1229 <&ipa_smp2p_in 0 IRQ_TYPE_EDGE_RISING>, 1230 <&ipa_smp2p_in 1 IRQ_TYPE_EDGE_RISING>; 1231 interrupt-names = "ipa", 1232 "gsi", 1233 "ipa-clock-query", 1234 "ipa-setup-ready"; 1235 1236 clocks = <&rpmhcc RPMH_IPA_CLK>; 1237 clock-names = "core"; 1238 1239 interconnects = <&aggre2_noc MASTER_IPA 0 &clk_virt SLAVE_EBI_CH0 0>, 1240 <&aggre2_noc MASTER_IPA 0 &system_noc SLAVE_OCIMEM 0>, 1241 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_IPA_CFG 0>; 1242 interconnect-names = "memory", "imem", "config"; 1243 1244 qcom,smem-states = <&ipa_smp2p_out 0>, 1245 <&ipa_smp2p_out 1>; 1246 qcom,smem-state-names = "ipa-clock-enabled-valid", 1247 "ipa-clock-enabled"; 1248 1249 status = "disabled"; 1250 }; 1251 1252 tcsr_mutex: hwlock@1f40000 { 1253 compatible = "qcom,tcsr-mutex"; 1254 reg = <0x0 0x01f40000 0x0 0x40000>; 1255 #hwlock-cells = <1>; 1256 }; 1257 1258 adsp: remoteproc@3000000 { 1259 compatible = "qcom,sm6350-adsp-pas"; 1260 reg = <0 0x03000000 0 0x100>; 1261 1262 interrupts-extended = <&pdc 6 IRQ_TYPE_LEVEL_HIGH>, 1263 <&smp2p_adsp_in 0 IRQ_TYPE_EDGE_RISING>, 1264 <&smp2p_adsp_in 1 IRQ_TYPE_EDGE_RISING>, 1265 <&smp2p_adsp_in 2 IRQ_TYPE_EDGE_RISING>, 1266 <&smp2p_adsp_in 3 IRQ_TYPE_EDGE_RISING>; 1267 interrupt-names = "wdog", "fatal", "ready", 1268 "handover", "stop-ack"; 1269 1270 clocks = <&rpmhcc RPMH_CXO_CLK>; 1271 clock-names = "xo"; 1272 1273 power-domains = <&rpmhpd SM6350_LCX>, 1274 <&rpmhpd SM6350_LMX>; 1275 power-domain-names = "lcx", "lmx"; 1276 1277 memory-region = <&pil_adsp_mem>; 1278 1279 qcom,qmp = <&aoss_qmp>; 1280 1281 qcom,smem-states = <&smp2p_adsp_out 0>; 1282 qcom,smem-state-names = "stop"; 1283 1284 status = "disabled"; 1285 1286 glink-edge { 1287 interrupts-extended = <&ipcc IPCC_CLIENT_LPASS 1288 IPCC_MPROC_SIGNAL_GLINK_QMP 1289 IRQ_TYPE_EDGE_RISING>; 1290 mboxes = <&ipcc IPCC_CLIENT_LPASS 1291 IPCC_MPROC_SIGNAL_GLINK_QMP>; 1292 1293 label = "lpass"; 1294 qcom,remote-pid = <2>; 1295 1296 fastrpc { 1297 compatible = "qcom,fastrpc"; 1298 qcom,glink-channels = "fastrpcglink-apps-dsp"; 1299 label = "adsp"; 1300 #address-cells = <1>; 1301 #size-cells = <0>; 1302 1303 compute-cb@3 { 1304 compatible = "qcom,fastrpc-compute-cb"; 1305 reg = <3>; 1306 iommus = <&apps_smmu 0x1003 0x0>; 1307 }; 1308 1309 compute-cb@4 { 1310 compatible = "qcom,fastrpc-compute-cb"; 1311 reg = <4>; 1312 iommus = <&apps_smmu 0x1004 0x0>; 1313 }; 1314 1315 compute-cb@5 { 1316 compatible = "qcom,fastrpc-compute-cb"; 1317 reg = <5>; 1318 iommus = <&apps_smmu 0x1005 0x0>; 1319 qcom,nsessions = <5>; 1320 }; 1321 }; 1322 }; 1323 }; 1324 1325 gpu: gpu@3d00000 { 1326 compatible = "qcom,adreno-619.0", "qcom,adreno"; 1327 reg = <0 0x03d00000 0 0x40000>, 1328 <0 0x03d9e000 0 0x1000>; 1329 reg-names = "kgsl_3d0_reg_memory", 1330 "cx_mem"; 1331 interrupts = <GIC_SPI 300 IRQ_TYPE_LEVEL_HIGH>; 1332 1333 iommus = <&adreno_smmu 0>; 1334 operating-points-v2 = <&gpu_opp_table>; 1335 qcom,gmu = <&gmu>; 1336 nvmem-cells = <&gpu_speed_bin>; 1337 nvmem-cell-names = "speed_bin"; 1338 1339 status = "disabled"; 1340 1341 zap-shader { 1342 memory-region = <&pil_gpu_mem>; 1343 }; 1344 1345 gpu_opp_table: opp-table { 1346 compatible = "operating-points-v2"; 1347 1348 opp-850000000 { 1349 opp-hz = /bits/ 64 <850000000>; 1350 opp-level = <RPMH_REGULATOR_LEVEL_TURBO_L1>; 1351 opp-supported-hw = <0x02>; 1352 }; 1353 1354 opp-800000000 { 1355 opp-hz = /bits/ 64 <800000000>; 1356 opp-level = <RPMH_REGULATOR_LEVEL_TURBO>; 1357 opp-supported-hw = <0x04>; 1358 }; 1359 1360 opp-650000000 { 1361 opp-hz = /bits/ 64 <650000000>; 1362 opp-level = <RPMH_REGULATOR_LEVEL_NOM_L1>; 1363 opp-supported-hw = <0x08>; 1364 }; 1365 1366 opp-565000000 { 1367 opp-hz = /bits/ 64 <565000000>; 1368 opp-level = <RPMH_REGULATOR_LEVEL_NOM>; 1369 opp-supported-hw = <0x10>; 1370 }; 1371 1372 opp-430000000 { 1373 opp-hz = /bits/ 64 <430000000>; 1374 opp-level = <RPMH_REGULATOR_LEVEL_SVS_L1>; 1375 opp-supported-hw = <0xff>; 1376 }; 1377 1378 opp-355000000 { 1379 opp-hz = /bits/ 64 <355000000>; 1380 opp-level = <RPMH_REGULATOR_LEVEL_SVS>; 1381 opp-supported-hw = <0xff>; 1382 }; 1383 1384 opp-253000000 { 1385 opp-hz = /bits/ 64 <253000000>; 1386 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS>; 1387 opp-supported-hw = <0xff>; 1388 }; 1389 }; 1390 }; 1391 1392 adreno_smmu: iommu@3d40000 { 1393 compatible = "qcom,sm6350-smmu-v2", "qcom,adreno-smmu", "qcom,smmu-v2"; 1394 reg = <0 0x03d40000 0 0x10000>; 1395 #iommu-cells = <1>; 1396 #global-interrupts = <2>; 1397 interrupts = <GIC_SPI 229 IRQ_TYPE_LEVEL_HIGH>, 1398 <GIC_SPI 231 IRQ_TYPE_LEVEL_HIGH>, 1399 <GIC_SPI 364 IRQ_TYPE_LEVEL_HIGH>, 1400 <GIC_SPI 365 IRQ_TYPE_LEVEL_HIGH>, 1401 <GIC_SPI 366 IRQ_TYPE_LEVEL_HIGH>, 1402 <GIC_SPI 367 IRQ_TYPE_LEVEL_HIGH>, 1403 <GIC_SPI 368 IRQ_TYPE_LEVEL_HIGH>, 1404 <GIC_SPI 369 IRQ_TYPE_LEVEL_HIGH>, 1405 <GIC_SPI 370 IRQ_TYPE_LEVEL_HIGH>, 1406 <GIC_SPI 371 IRQ_TYPE_LEVEL_HIGH>; 1407 1408 clocks = <&gpucc GPU_CC_AHB_CLK>, 1409 <&gcc GCC_GPU_MEMNOC_GFX_CLK>, 1410 <&gcc GCC_GPU_SNOC_DVM_GFX_CLK>; 1411 clock-names = "ahb", 1412 "bus", 1413 "iface"; 1414 1415 power-domains = <&gpucc GPU_CX_GDSC>; 1416 }; 1417 1418 gmu: gmu@3d6a000 { 1419 compatible = "qcom,adreno-gmu-619.0", "qcom,adreno-gmu"; 1420 reg = <0 0x03d6a000 0 0x31000>, 1421 <0 0x0b290000 0 0x10000>, 1422 <0 0x0b490000 0 0x10000>; 1423 reg-names = "gmu", 1424 "gmu_pdc", 1425 "gmu_pdc_seq"; 1426 1427 interrupts = <GIC_SPI 304 IRQ_TYPE_LEVEL_HIGH>, 1428 <GIC_SPI 305 IRQ_TYPE_LEVEL_HIGH>; 1429 interrupt-names = "hfi", 1430 "gmu"; 1431 1432 clocks = <&gpucc GPU_CC_AHB_CLK>, 1433 <&gpucc GPU_CC_CX_GMU_CLK>, 1434 <&gpucc GPU_CC_CXO_CLK>, 1435 <&gcc GCC_DDRSS_GPU_AXI_CLK>, 1436 <&gcc GCC_GPU_MEMNOC_GFX_CLK>; 1437 clock-names = "ahb", 1438 "gmu", 1439 "cxo", 1440 "axi", 1441 "memnoc"; 1442 1443 power-domains = <&gpucc GPU_CX_GDSC>, 1444 <&gpucc GPU_GX_GDSC>; 1445 power-domain-names = "cx", 1446 "gx"; 1447 1448 iommus = <&adreno_smmu 5>; 1449 1450 operating-points-v2 = <&gmu_opp_table>; 1451 1452 status = "disabled"; 1453 1454 gmu_opp_table: opp-table { 1455 compatible = "operating-points-v2"; 1456 1457 opp-200000000 { 1458 opp-hz = /bits/ 64 <200000000>; 1459 opp-level = <RPMH_REGULATOR_LEVEL_MIN_SVS>; 1460 }; 1461 }; 1462 }; 1463 1464 gpucc: clock-controller@3d90000 { 1465 compatible = "qcom,sm6350-gpucc"; 1466 reg = <0 0x03d90000 0 0x9000>; 1467 clocks = <&rpmhcc RPMH_CXO_CLK>, 1468 <&gcc GCC_GPU_GPLL0_CLK>, 1469 <&gcc GCC_GPU_GPLL0_DIV_CLK>; 1470 clock-names = "bi_tcxo", 1471 "gcc_gpu_gpll0_clk_src", 1472 "gcc_gpu_gpll0_div_clk_src"; 1473 #clock-cells = <1>; 1474 #reset-cells = <1>; 1475 #power-domain-cells = <1>; 1476 }; 1477 1478 mpss: remoteproc@4080000 { 1479 compatible = "qcom,sm6350-mpss-pas"; 1480 reg = <0x0 0x04080000 0x0 0x4040>; 1481 1482 interrupts-extended = <&intc GIC_SPI 136 IRQ_TYPE_EDGE_RISING>, 1483 <&modem_smp2p_in 0 IRQ_TYPE_EDGE_RISING>, 1484 <&modem_smp2p_in 1 IRQ_TYPE_EDGE_RISING>, 1485 <&modem_smp2p_in 2 IRQ_TYPE_EDGE_RISING>, 1486 <&modem_smp2p_in 3 IRQ_TYPE_EDGE_RISING>, 1487 <&modem_smp2p_in 7 IRQ_TYPE_EDGE_RISING>; 1488 interrupt-names = "wdog", "fatal", "ready", "handover", 1489 "stop-ack", "shutdown-ack"; 1490 1491 clocks = <&rpmhcc RPMH_CXO_CLK>; 1492 clock-names = "xo"; 1493 1494 power-domains = <&rpmhpd SM6350_CX>, 1495 <&rpmhpd SM6350_MSS>; 1496 power-domain-names = "cx", "mss"; 1497 1498 memory-region = <&pil_modem_mem>; 1499 1500 qcom,qmp = <&aoss_qmp>; 1501 1502 qcom,smem-states = <&modem_smp2p_out 0>; 1503 qcom,smem-state-names = "stop"; 1504 1505 status = "disabled"; 1506 1507 glink-edge { 1508 interrupts-extended = <&ipcc IPCC_CLIENT_MPSS 1509 IPCC_MPROC_SIGNAL_GLINK_QMP 1510 IRQ_TYPE_EDGE_RISING>; 1511 mboxes = <&ipcc IPCC_CLIENT_MPSS 1512 IPCC_MPROC_SIGNAL_GLINK_QMP>; 1513 label = "modem"; 1514 qcom,remote-pid = <1>; 1515 }; 1516 }; 1517 1518 cdsp: remoteproc@8300000 { 1519 compatible = "qcom,sm6350-cdsp-pas"; 1520 reg = <0 0x08300000 0 0x10000>; 1521 1522 interrupts-extended = <&intc GIC_SPI 578 IRQ_TYPE_LEVEL_HIGH>, 1523 <&smp2p_cdsp_in 0 IRQ_TYPE_EDGE_RISING>, 1524 <&smp2p_cdsp_in 1 IRQ_TYPE_EDGE_RISING>, 1525 <&smp2p_cdsp_in 2 IRQ_TYPE_EDGE_RISING>, 1526 <&smp2p_cdsp_in 3 IRQ_TYPE_EDGE_RISING>; 1527 interrupt-names = "wdog", "fatal", "ready", 1528 "handover", "stop-ack"; 1529 1530 clocks = <&rpmhcc RPMH_CXO_CLK>; 1531 clock-names = "xo"; 1532 1533 power-domains = <&rpmhpd SM6350_CX>, 1534 <&rpmhpd SM6350_MX>; 1535 power-domain-names = "cx", "mx"; 1536 1537 memory-region = <&pil_cdsp_mem>; 1538 1539 qcom,qmp = <&aoss_qmp>; 1540 1541 qcom,smem-states = <&smp2p_cdsp_out 0>; 1542 qcom,smem-state-names = "stop"; 1543 1544 status = "disabled"; 1545 1546 glink-edge { 1547 interrupts-extended = <&ipcc IPCC_CLIENT_CDSP 1548 IPCC_MPROC_SIGNAL_GLINK_QMP 1549 IRQ_TYPE_EDGE_RISING>; 1550 mboxes = <&ipcc IPCC_CLIENT_CDSP 1551 IPCC_MPROC_SIGNAL_GLINK_QMP>; 1552 1553 label = "cdsp"; 1554 qcom,remote-pid = <5>; 1555 1556 fastrpc { 1557 compatible = "qcom,fastrpc"; 1558 qcom,glink-channels = "fastrpcglink-apps-dsp"; 1559 label = "cdsp"; 1560 #address-cells = <1>; 1561 #size-cells = <0>; 1562 1563 compute-cb@1 { 1564 compatible = "qcom,fastrpc-compute-cb"; 1565 reg = <1>; 1566 iommus = <&apps_smmu 0x1401 0x20>; 1567 }; 1568 1569 compute-cb@2 { 1570 compatible = "qcom,fastrpc-compute-cb"; 1571 reg = <2>; 1572 iommus = <&apps_smmu 0x1402 0x20>; 1573 }; 1574 1575 compute-cb@3 { 1576 compatible = "qcom,fastrpc-compute-cb"; 1577 reg = <3>; 1578 iommus = <&apps_smmu 0x1403 0x20>; 1579 }; 1580 1581 compute-cb@4 { 1582 compatible = "qcom,fastrpc-compute-cb"; 1583 reg = <4>; 1584 iommus = <&apps_smmu 0x1404 0x20>; 1585 }; 1586 1587 compute-cb@5 { 1588 compatible = "qcom,fastrpc-compute-cb"; 1589 reg = <5>; 1590 iommus = <&apps_smmu 0x1405 0x20>; 1591 }; 1592 1593 compute-cb@6 { 1594 compatible = "qcom,fastrpc-compute-cb"; 1595 reg = <6>; 1596 iommus = <&apps_smmu 0x1406 0x20>; 1597 }; 1598 1599 compute-cb@7 { 1600 compatible = "qcom,fastrpc-compute-cb"; 1601 reg = <7>; 1602 iommus = <&apps_smmu 0x1407 0x20>; 1603 }; 1604 1605 compute-cb@8 { 1606 compatible = "qcom,fastrpc-compute-cb"; 1607 reg = <8>; 1608 iommus = <&apps_smmu 0x1408 0x20>; 1609 }; 1610 1611 /* note: secure cb9 in downstream */ 1612 }; 1613 }; 1614 }; 1615 1616 sdhc_2: mmc@8804000 { 1617 compatible = "qcom,sm6350-sdhci", "qcom,sdhci-msm-v5"; 1618 reg = <0 0x08804000 0 0x1000>; 1619 1620 interrupts = <GIC_SPI 204 IRQ_TYPE_LEVEL_HIGH>, 1621 <GIC_SPI 222 IRQ_TYPE_LEVEL_HIGH>; 1622 interrupt-names = "hc_irq", "pwr_irq"; 1623 iommus = <&apps_smmu 0x560 0x0>; 1624 1625 clocks = <&gcc GCC_SDCC2_AHB_CLK>, 1626 <&gcc GCC_SDCC2_APPS_CLK>, 1627 <&rpmhcc RPMH_CXO_CLK>; 1628 clock-names = "iface", "core", "xo"; 1629 resets = <&gcc GCC_SDCC2_BCR>; 1630 interconnects = <&aggre2_noc MASTER_SDCC_2 0 &clk_virt SLAVE_EBI_CH0 0>, 1631 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_SDCC_2 0>; 1632 interconnect-names = "sdhc-ddr", "cpu-sdhc"; 1633 1634 pinctrl-0 = <&sdc2_on_state>; 1635 pinctrl-1 = <&sdc2_off_state>; 1636 pinctrl-names = "default", "sleep"; 1637 1638 qcom,dll-config = <0x0007642c>; 1639 qcom,ddr-config = <0x80040868>; 1640 power-domains = <&rpmhpd SM6350_CX>; 1641 operating-points-v2 = <&sdhc2_opp_table>; 1642 bus-width = <4>; 1643 1644 status = "disabled"; 1645 1646 sdhc2_opp_table: opp-table { 1647 compatible = "operating-points-v2"; 1648 1649 opp-100000000 { 1650 opp-hz = /bits/ 64 <100000000>; 1651 required-opps = <&rpmhpd_opp_svs_l1>; 1652 opp-peak-kBps = <790000 131000>; 1653 opp-avg-kBps = <50000 50000>; 1654 }; 1655 1656 opp-202000000 { 1657 opp-hz = /bits/ 64 <202000000>; 1658 required-opps = <&rpmhpd_opp_nom>; 1659 opp-peak-kBps = <3190000 294000>; 1660 opp-avg-kBps = <261438 300000>; 1661 }; 1662 }; 1663 }; 1664 1665 usb_1_hsphy: phy@88e3000 { 1666 compatible = "qcom,sm6350-qusb2-phy", "qcom,qusb2-v2-phy"; 1667 reg = <0 0x088e3000 0 0x400>; 1668 status = "disabled"; 1669 #phy-cells = <0>; 1670 1671 clocks = <&xo_board>, <&rpmhcc RPMH_CXO_CLK>; 1672 clock-names = "cfg_ahb", "ref"; 1673 1674 resets = <&gcc GCC_QUSB2PHY_PRIM_BCR>; 1675 }; 1676 1677 usb_1_qmpphy: phy@88e8000 { 1678 compatible = "qcom,sm6350-qmp-usb3-dp-phy"; 1679 reg = <0 0x088e8000 0 0x3000>; 1680 1681 clocks = <&gcc GCC_USB3_PRIM_PHY_AUX_CLK>, 1682 <&gcc GCC_USB3_PRIM_CLKREF_CLK>, 1683 <&gcc GCC_USB3_PRIM_PHY_COM_AUX_CLK>, 1684 <&gcc GCC_USB3_PRIM_PHY_PIPE_CLK>; 1685 clock-names = "aux", "ref", "com_aux", "usb3_pipe"; 1686 1687 power-domains = <&gcc USB30_PRIM_GDSC>; 1688 1689 resets = <&gcc GCC_USB3_PHY_PRIM_BCR>, 1690 <&gcc GCC_USB3_DP_PHY_PRIM_BCR>; 1691 reset-names = "phy", "common"; 1692 1693 #clock-cells = <1>; 1694 #phy-cells = <1>; 1695 1696 status = "disabled"; 1697 }; 1698 1699 dc_noc: interconnect@9160000 { 1700 compatible = "qcom,sm6350-dc-noc"; 1701 reg = <0 0x09160000 0 0x3200>; 1702 #interconnect-cells = <2>; 1703 qcom,bcm-voters = <&apps_bcm_voter>; 1704 }; 1705 1706 system-cache-controller@9200000 { 1707 compatible = "qcom,sm6350-llcc"; 1708 reg = <0 0x09200000 0 0x50000>, <0 0x09600000 0 0x50000>; 1709 reg-names = "llcc0_base", "llcc_broadcast_base"; 1710 }; 1711 1712 gem_noc: interconnect@9680000 { 1713 compatible = "qcom,sm6350-gem-noc"; 1714 reg = <0 0x09680000 0 0x3e200>; 1715 #interconnect-cells = <2>; 1716 qcom,bcm-voters = <&apps_bcm_voter>; 1717 }; 1718 1719 npu_noc: interconnect@9990000 { 1720 compatible = "qcom,sm6350-npu-noc"; 1721 reg = <0 0x09990000 0 0x1600>; 1722 #interconnect-cells = <2>; 1723 qcom,bcm-voters = <&apps_bcm_voter>; 1724 }; 1725 1726 pmu@90b6300 { 1727 compatible = "qcom,sm6350-llcc-bwmon", "qcom,sdm845-bwmon"; 1728 reg = <0x0 0x090b6300 0x0 0x600>; 1729 interrupts = <GIC_SPI 581 IRQ_TYPE_LEVEL_HIGH>; 1730 1731 operating-points-v2 = <&llcc_bwmon_opp_table>; 1732 interconnects = <&clk_virt MASTER_LLCC QCOM_ICC_TAG_ACTIVE_ONLY 1733 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>; 1734 1735 llcc_bwmon_opp_table: opp-table { 1736 compatible = "operating-points-v2"; 1737 1738 opp-0 { 1739 opp-peak-kBps = <2288000>; 1740 }; 1741 1742 opp-1 { 1743 opp-peak-kBps = <4577000>; 1744 }; 1745 1746 opp-2 { 1747 opp-peak-kBps = <7110000>; 1748 }; 1749 1750 opp-3 { 1751 opp-peak-kBps = <9155000>; 1752 }; 1753 1754 opp-4 { 1755 opp-peak-kBps = <12298000>; 1756 }; 1757 1758 opp-5 { 1759 opp-peak-kBps = <14236000>; 1760 }; 1761 1762 }; 1763 }; 1764 1765 pmu@90cd000 { 1766 compatible = "qcom,sm6350-cpu-bwmon", "qcom,sc7280-llcc-bwmon"; 1767 reg = <0x0 0x090cd000 0x0 0x1000>; 1768 interrupts = <GIC_SPI 241 IRQ_TYPE_LEVEL_HIGH>; 1769 1770 operating-points-v2 = <&cpu_bwmon_opp_table>; 1771 interconnects = <&gem_noc MASTER_AMPSS_M0 QCOM_ICC_TAG_ACTIVE_ONLY 1772 &clk_virt SLAVE_EBI_CH0 QCOM_ICC_TAG_ACTIVE_ONLY>; 1773 1774 cpu_bwmon_opp_table: opp-table { 1775 compatible = "operating-points-v2"; 1776 1777 opp-0 { 1778 opp-peak-kBps = <762000>; 1779 }; 1780 1781 opp-1 { 1782 opp-peak-kBps = <1144000>; 1783 }; 1784 1785 opp-2 { 1786 opp-peak-kBps = <1720000>; 1787 }; 1788 1789 opp-3 { 1790 opp-peak-kBps = <2086000>; 1791 }; 1792 1793 opp-4 { 1794 opp-peak-kBps = <2597000>; 1795 }; 1796 1797 opp-5 { 1798 opp-peak-kBps = <2929000>; 1799 }; 1800 1801 opp-6 { 1802 opp-peak-kBps = <3879000>; 1803 }; 1804 1805 opp-7 { 1806 opp-peak-kBps = <5161000>; 1807 }; 1808 1809 opp-8 { 1810 opp-peak-kBps = <5931000>; 1811 }; 1812 1813 opp-9 { 1814 opp-peak-kBps = <6881000>; 1815 }; 1816 1817 opp-10 { 1818 opp-peak-kBps = <7980000>; 1819 }; 1820 }; 1821 }; 1822 1823 usb_1: usb@a6f8800 { 1824 compatible = "qcom,sm6350-dwc3", "qcom,dwc3"; 1825 reg = <0 0x0a6f8800 0 0x400>; 1826 status = "disabled"; 1827 #address-cells = <2>; 1828 #size-cells = <2>; 1829 ranges; 1830 1831 clocks = <&gcc GCC_CFG_NOC_USB3_PRIM_AXI_CLK>, 1832 <&gcc GCC_USB30_PRIM_MASTER_CLK>, 1833 <&gcc GCC_AGGRE_USB3_PRIM_AXI_CLK>, 1834 <&gcc GCC_USB30_PRIM_SLEEP_CLK>, 1835 <&gcc GCC_USB30_PRIM_MOCK_UTMI_CLK>; 1836 clock-names = "cfg_noc", 1837 "core", 1838 "iface", 1839 "sleep", 1840 "mock_utmi"; 1841 1842 interrupts-extended = <&intc GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>, 1843 <&pdc 17 IRQ_TYPE_LEVEL_HIGH>, 1844 <&pdc 15 IRQ_TYPE_EDGE_BOTH>, 1845 <&pdc 14 IRQ_TYPE_EDGE_BOTH>; 1846 1847 interrupt-names = "hs_phy_irq", "ss_phy_irq", 1848 "dm_hs_phy_irq", "dp_hs_phy_irq"; 1849 1850 power-domains = <&gcc USB30_PRIM_GDSC>; 1851 1852 resets = <&gcc GCC_USB30_PRIM_BCR>; 1853 1854 interconnects = <&aggre2_noc MASTER_USB3 0 &clk_virt SLAVE_EBI_CH0 0>, 1855 <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_USB3 0>; 1856 interconnect-names = "usb-ddr", "apps-usb"; 1857 1858 usb_1_dwc3: usb@a600000 { 1859 compatible = "snps,dwc3"; 1860 reg = <0 0x0a600000 0 0xcd00>; 1861 interrupts = <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>; 1862 iommus = <&apps_smmu 0x540 0x0>; 1863 snps,dis_u2_susphy_quirk; 1864 snps,dis_enblslpm_quirk; 1865 snps,has-lpm-erratum; 1866 snps,hird-threshold = /bits/ 8 <0x10>; 1867 snps,parkmode-disable-ss-quirk; 1868 phys = <&usb_1_hsphy>, <&usb_1_qmpphy QMP_USB43DP_USB3_PHY>; 1869 phy-names = "usb2-phy", "usb3-phy"; 1870 }; 1871 }; 1872 1873 cci0: cci@ac4a000 { 1874 compatible = "qcom,sm6350-cci", "qcom,msm8996-cci"; 1875 reg = <0 0x0ac4a000 0 0x1000>; 1876 interrupts = <GIC_SPI 468 IRQ_TYPE_EDGE_RISING>; 1877 power-domains = <&camcc TITAN_TOP_GDSC>; 1878 1879 clocks = <&camcc CAMCC_CAMNOC_AXI_CLK>, 1880 <&camcc CAMCC_SOC_AHB_CLK>, 1881 <&camcc CAMCC_SLOW_AHB_CLK_SRC>, 1882 <&camcc CAMCC_CPAS_AHB_CLK>, 1883 <&camcc CAMCC_CCI_0_CLK>, 1884 <&camcc CAMCC_CCI_0_CLK_SRC>; 1885 clock-names = "camnoc_axi", 1886 "soc_ahb", 1887 "slow_ahb_src", 1888 "cpas_ahb", 1889 "cci", 1890 "cci_src"; 1891 1892 assigned-clocks = <&camcc CAMCC_CAMNOC_AXI_CLK>, 1893 <&camcc CAMCC_CCI_0_CLK>; 1894 assigned-clock-rates = <80000000>, <37500000>; 1895 1896 pinctrl-0 = <&cci0_default &cci1_default>; 1897 pinctrl-1 = <&cci0_sleep &cci1_sleep>; 1898 pinctrl-names = "default", "sleep"; 1899 1900 #address-cells = <1>; 1901 #size-cells = <0>; 1902 1903 status = "disabled"; 1904 1905 cci0_i2c0: i2c-bus@0 { 1906 reg = <0>; 1907 clock-frequency = <1000000>; 1908 #address-cells = <1>; 1909 #size-cells = <0>; 1910 }; 1911 1912 cci0_i2c1: i2c-bus@1 { 1913 reg = <1>; 1914 clock-frequency = <1000000>; 1915 #address-cells = <1>; 1916 #size-cells = <0>; 1917 }; 1918 }; 1919 1920 cci1: cci@ac4b000 { 1921 compatible = "qcom,sm6350-cci", "qcom,msm8996-cci"; 1922 reg = <0 0x0ac4b000 0 0x1000>; 1923 interrupts = <GIC_SPI 462 IRQ_TYPE_EDGE_RISING>; 1924 power-domains = <&camcc TITAN_TOP_GDSC>; 1925 1926 clocks = <&camcc CAMCC_CAMNOC_AXI_CLK>, 1927 <&camcc CAMCC_SOC_AHB_CLK>, 1928 <&camcc CAMCC_SLOW_AHB_CLK_SRC>, 1929 <&camcc CAMCC_CPAS_AHB_CLK>, 1930 <&camcc CAMCC_CCI_1_CLK>, 1931 <&camcc CAMCC_CCI_1_CLK_SRC>; 1932 clock-names = "camnoc_axi", 1933 "soc_ahb", 1934 "slow_ahb_src", 1935 "cpas_ahb", 1936 "cci", 1937 "cci_src"; 1938 1939 assigned-clocks = <&camcc CAMCC_CAMNOC_AXI_CLK>, 1940 <&camcc CAMCC_CCI_1_CLK>; 1941 assigned-clock-rates = <80000000>, <37500000>; 1942 1943 pinctrl-0 = <&cci2_default>; 1944 pinctrl-1 = <&cci2_sleep>; 1945 pinctrl-names = "default", "sleep"; 1946 1947 #address-cells = <1>; 1948 #size-cells = <0>; 1949 1950 status = "disabled"; 1951 1952 cci1_i2c0: i2c-bus@0 { 1953 reg = <0>; 1954 clock-frequency = <1000000>; 1955 #address-cells = <1>; 1956 #size-cells = <0>; 1957 }; 1958 1959 /* SM6350 seems to have cci1_i2c1 on gpio2 & gpio3 but unused downstream */ 1960 }; 1961 1962 camcc: clock-controller@ad00000 { 1963 compatible = "qcom,sm6350-camcc"; 1964 reg = <0 0x0ad00000 0 0x16000>; 1965 clocks = <&rpmhcc RPMH_CXO_CLK>; 1966 #clock-cells = <1>; 1967 #reset-cells = <1>; 1968 #power-domain-cells = <1>; 1969 }; 1970 1971 mdss: display-subsystem@ae00000 { 1972 compatible = "qcom,sm6350-mdss"; 1973 reg = <0 0x0ae00000 0 0x1000>; 1974 reg-names = "mdss"; 1975 1976 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>; 1977 interrupt-controller; 1978 #interrupt-cells = <1>; 1979 1980 clocks = <&gcc GCC_DISP_AHB_CLK>, 1981 <&gcc GCC_DISP_AXI_CLK>, 1982 <&dispcc DISP_CC_MDSS_MDP_CLK>; 1983 clock-names = "iface", 1984 "bus", 1985 "core"; 1986 1987 power-domains = <&dispcc MDSS_GDSC>; 1988 iommus = <&apps_smmu 0x800 0x2>; 1989 1990 #address-cells = <2>; 1991 #size-cells = <2>; 1992 ranges; 1993 1994 status = "disabled"; 1995 1996 mdss_mdp: display-controller@ae01000 { 1997 compatible = "qcom,sm6350-dpu"; 1998 reg = <0 0x0ae01000 0 0x8f000>, 1999 <0 0x0aeb0000 0 0x2008>; 2000 reg-names = "mdp", "vbif"; 2001 2002 interrupt-parent = <&mdss>; 2003 interrupts = <0>; 2004 2005 clocks = <&gcc GCC_DISP_AXI_CLK>, 2006 <&dispcc DISP_CC_MDSS_AHB_CLK>, 2007 <&dispcc DISP_CC_MDSS_ROT_CLK>, 2008 <&dispcc DISP_CC_MDSS_MDP_LUT_CLK>, 2009 <&dispcc DISP_CC_MDSS_MDP_CLK>, 2010 <&dispcc DISP_CC_MDSS_VSYNC_CLK>; 2011 clock-names = "bus", 2012 "iface", 2013 "rot", 2014 "lut", 2015 "core", 2016 "vsync"; 2017 2018 assigned-clocks = <&dispcc DISP_CC_MDSS_VSYNC_CLK>; 2019 assigned-clock-rates = <19200000>; 2020 2021 operating-points-v2 = <&mdp_opp_table>; 2022 power-domains = <&rpmhpd SM6350_CX>; 2023 2024 ports { 2025 #address-cells = <1>; 2026 #size-cells = <0>; 2027 2028 port@0 { 2029 reg = <0>; 2030 2031 dpu_intf1_out: endpoint { 2032 remote-endpoint = <&mdss_dsi0_in>; 2033 }; 2034 }; 2035 }; 2036 2037 mdp_opp_table: opp-table { 2038 compatible = "operating-points-v2"; 2039 2040 opp-19200000 { 2041 opp-hz = /bits/ 64 <19200000>; 2042 required-opps = <&rpmhpd_opp_min_svs>; 2043 }; 2044 2045 opp-200000000 { 2046 opp-hz = /bits/ 64 <200000000>; 2047 required-opps = <&rpmhpd_opp_low_svs>; 2048 }; 2049 2050 opp-300000000 { 2051 opp-hz = /bits/ 64 <300000000>; 2052 required-opps = <&rpmhpd_opp_svs>; 2053 }; 2054 2055 opp-373333333 { 2056 opp-hz = /bits/ 64 <373333333>; 2057 required-opps = <&rpmhpd_opp_svs_l1>; 2058 }; 2059 2060 opp-448000000 { 2061 opp-hz = /bits/ 64 <448000000>; 2062 required-opps = <&rpmhpd_opp_nom>; 2063 }; 2064 2065 opp-560000000 { 2066 opp-hz = /bits/ 64 <560000000>; 2067 required-opps = <&rpmhpd_opp_turbo>; 2068 }; 2069 }; 2070 }; 2071 2072 mdss_dsi0: dsi@ae94000 { 2073 compatible = "qcom,sm6350-dsi-ctrl", "qcom,mdss-dsi-ctrl"; 2074 reg = <0 0x0ae94000 0 0x400>; 2075 reg-names = "dsi_ctrl"; 2076 2077 interrupt-parent = <&mdss>; 2078 interrupts = <4>; 2079 2080 clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK>, 2081 <&dispcc DISP_CC_MDSS_BYTE0_INTF_CLK>, 2082 <&dispcc DISP_CC_MDSS_PCLK0_CLK>, 2083 <&dispcc DISP_CC_MDSS_ESC0_CLK>, 2084 <&dispcc DISP_CC_MDSS_AHB_CLK>, 2085 <&gcc GCC_DISP_AXI_CLK>; 2086 clock-names = "byte", 2087 "byte_intf", 2088 "pixel", 2089 "core", 2090 "iface", 2091 "bus"; 2092 2093 assigned-clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK_SRC>, 2094 <&dispcc DISP_CC_MDSS_PCLK0_CLK_SRC>; 2095 assigned-clock-parents = <&mdss_dsi0_phy 0>, <&mdss_dsi0_phy 1>; 2096 2097 operating-points-v2 = <&mdss_dsi_opp_table>; 2098 power-domains = <&rpmhpd SM6350_MX>; 2099 2100 phys = <&mdss_dsi0_phy>; 2101 phy-names = "dsi"; 2102 2103 #address-cells = <1>; 2104 #size-cells = <0>; 2105 2106 status = "disabled"; 2107 2108 ports { 2109 #address-cells = <1>; 2110 #size-cells = <0>; 2111 2112 port@0 { 2113 reg = <0>; 2114 2115 mdss_dsi0_in: endpoint { 2116 remote-endpoint = <&dpu_intf1_out>; 2117 }; 2118 }; 2119 2120 port@1 { 2121 reg = <1>; 2122 2123 mdss_dsi0_out: endpoint { 2124 }; 2125 }; 2126 }; 2127 2128 mdss_dsi_opp_table: opp-table { 2129 compatible = "operating-points-v2"; 2130 2131 opp-187500000 { 2132 opp-hz = /bits/ 64 <187500000>; 2133 required-opps = <&rpmhpd_opp_low_svs>; 2134 }; 2135 2136 opp-300000000 { 2137 opp-hz = /bits/ 64 <300000000>; 2138 required-opps = <&rpmhpd_opp_svs>; 2139 }; 2140 2141 opp-358000000 { 2142 opp-hz = /bits/ 64 <358000000>; 2143 required-opps = <&rpmhpd_opp_svs_l1>; 2144 }; 2145 }; 2146 }; 2147 2148 mdss_dsi0_phy: phy@ae94400 { 2149 compatible = "qcom,dsi-phy-10nm"; 2150 reg = <0 0x0ae94400 0 0x200>, 2151 <0 0x0ae94600 0 0x280>, 2152 <0 0x0ae94a00 0 0x1e0>; 2153 reg-names = "dsi_phy", 2154 "dsi_phy_lane", 2155 "dsi_pll"; 2156 2157 #clock-cells = <1>; 2158 #phy-cells = <0>; 2159 2160 clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>, 2161 <&rpmhcc RPMH_CXO_CLK>; 2162 clock-names = "iface", "ref"; 2163 2164 status = "disabled"; 2165 }; 2166 }; 2167 2168 dispcc: clock-controller@af00000 { 2169 compatible = "qcom,sm6350-dispcc"; 2170 reg = <0 0x0af00000 0 0x20000>; 2171 clocks = <&rpmhcc RPMH_CXO_CLK>, 2172 <&gcc GCC_DISP_GPLL0_CLK>, 2173 <&mdss_dsi0_phy 0>, 2174 <&mdss_dsi0_phy 1>, 2175 <&usb_1_qmpphy QMP_USB43DP_DP_LINK_CLK>, 2176 <&usb_1_qmpphy QMP_USB43DP_DP_VCO_DIV_CLK>; 2177 clock-names = "bi_tcxo", 2178 "gcc_disp_gpll0_clk", 2179 "dsi0_phy_pll_out_byteclk", 2180 "dsi0_phy_pll_out_dsiclk", 2181 "dp_phy_pll_link_clk", 2182 "dp_phy_pll_vco_div_clk"; 2183 #clock-cells = <1>; 2184 #reset-cells = <1>; 2185 #power-domain-cells = <1>; 2186 }; 2187 2188 pdc: interrupt-controller@b220000 { 2189 compatible = "qcom,sm6350-pdc", "qcom,pdc"; 2190 reg = <0 0x0b220000 0 0x30000>, <0 0x17c000f0 0 0x64>; 2191 qcom,pdc-ranges = <0 480 94>, <94 609 31>, 2192 <125 63 1>, <126 655 12>, <138 139 15>; 2193 #interrupt-cells = <2>; 2194 interrupt-parent = <&intc>; 2195 interrupt-controller; 2196 }; 2197 2198 tsens0: thermal-sensor@c263000 { 2199 compatible = "qcom,sm6350-tsens", "qcom,tsens-v2"; 2200 reg = <0 0x0c263000 0 0x1ff>, /* TM */ 2201 <0 0x0c222000 0 0x8>; /* SROT */ 2202 #qcom,sensors = <16>; 2203 interrupts-extended = <&pdc 26 IRQ_TYPE_LEVEL_HIGH>, 2204 <&pdc 28 IRQ_TYPE_LEVEL_HIGH>; 2205 interrupt-names = "uplow", "critical"; 2206 #thermal-sensor-cells = <1>; 2207 }; 2208 2209 tsens1: thermal-sensor@c265000 { 2210 compatible = "qcom,sm6350-tsens", "qcom,tsens-v2"; 2211 reg = <0 0x0c265000 0 0x1ff>, /* TM */ 2212 <0 0x0c223000 0 0x8>; /* SROT */ 2213 #qcom,sensors = <16>; 2214 interrupts-extended = <&pdc 27 IRQ_TYPE_LEVEL_HIGH>, 2215 <&pdc 29 IRQ_TYPE_LEVEL_HIGH>; 2216 interrupt-names = "uplow", "critical"; 2217 #thermal-sensor-cells = <1>; 2218 }; 2219 2220 aoss_qmp: power-management@c300000 { 2221 compatible = "qcom,sm6350-aoss-qmp", "qcom,aoss-qmp"; 2222 reg = <0 0x0c300000 0 0x1000>; 2223 interrupts-extended = <&ipcc IPCC_CLIENT_AOP IPCC_MPROC_SIGNAL_GLINK_QMP 2224 IRQ_TYPE_EDGE_RISING>; 2225 mboxes = <&ipcc IPCC_CLIENT_AOP IPCC_MPROC_SIGNAL_GLINK_QMP>; 2226 2227 #clock-cells = <0>; 2228 }; 2229 2230 spmi_bus: spmi@c440000 { 2231 compatible = "qcom,spmi-pmic-arb"; 2232 reg = <0 0x0c440000 0 0x1100>, 2233 <0 0x0c600000 0 0x2000000>, 2234 <0 0x0e600000 0 0x100000>, 2235 <0 0x0e700000 0 0xa0000>, 2236 <0 0x0c40a000 0 0x26000>; 2237 reg-names = "core", "chnls", "obsrvr", "intr", "cnfg"; 2238 interrupt-names = "periph_irq"; 2239 interrupts-extended = <&pdc 1 IRQ_TYPE_LEVEL_HIGH>; 2240 qcom,ee = <0>; 2241 qcom,channel = <0>; 2242 #address-cells = <2>; 2243 #size-cells = <0>; 2244 interrupt-controller; 2245 #interrupt-cells = <4>; 2246 }; 2247 2248 tlmm: pinctrl@f100000 { 2249 compatible = "qcom,sm6350-tlmm"; 2250 reg = <0 0x0f100000 0 0x300000>; 2251 interrupts = <GIC_SPI 208 IRQ_TYPE_LEVEL_HIGH>, 2252 <GIC_SPI 209 IRQ_TYPE_LEVEL_HIGH>, 2253 <GIC_SPI 210 IRQ_TYPE_LEVEL_HIGH>, 2254 <GIC_SPI 211 IRQ_TYPE_LEVEL_HIGH>, 2255 <GIC_SPI 212 IRQ_TYPE_LEVEL_HIGH>, 2256 <GIC_SPI 213 IRQ_TYPE_LEVEL_HIGH>, 2257 <GIC_SPI 214 IRQ_TYPE_LEVEL_HIGH>, 2258 <GIC_SPI 215 IRQ_TYPE_LEVEL_HIGH>, 2259 <GIC_SPI 216 IRQ_TYPE_LEVEL_HIGH>; 2260 gpio-controller; 2261 #gpio-cells = <2>; 2262 interrupt-controller; 2263 #interrupt-cells = <2>; 2264 gpio-ranges = <&tlmm 0 0 157>; 2265 wakeup-parent = <&pdc>; 2266 2267 cci0_default: cci0-default-state { 2268 pins = "gpio39", "gpio40"; 2269 function = "cci_i2c"; 2270 drive-strength = <2>; 2271 bias-pull-up; 2272 }; 2273 2274 cci0_sleep: cci0-sleep-state { 2275 pins = "gpio39", "gpio40"; 2276 function = "cci_i2c"; 2277 drive-strength = <2>; 2278 bias-pull-down; 2279 }; 2280 2281 cci1_default: cci1-default-state { 2282 pins = "gpio41", "gpio42"; 2283 function = "cci_i2c"; 2284 drive-strength = <2>; 2285 bias-pull-up; 2286 }; 2287 2288 cci1_sleep: cci1-sleep-state { 2289 pins = "gpio41", "gpio42"; 2290 function = "cci_i2c"; 2291 drive-strength = <2>; 2292 bias-pull-down; 2293 }; 2294 2295 cci2_default: cci2-default-state { 2296 pins = "gpio43", "gpio44"; 2297 function = "cci_i2c"; 2298 drive-strength = <2>; 2299 bias-pull-up; 2300 }; 2301 2302 cci2_sleep: cci2-sleep-state { 2303 pins = "gpio43", "gpio44"; 2304 function = "cci_i2c"; 2305 drive-strength = <2>; 2306 bias-pull-down; 2307 }; 2308 2309 sdc2_off_state: sdc2-off-state { 2310 clk-pins { 2311 pins = "sdc2_clk"; 2312 drive-strength = <2>; 2313 bias-disable; 2314 }; 2315 2316 cmd-pins { 2317 pins = "sdc2_cmd"; 2318 drive-strength = <2>; 2319 bias-pull-up; 2320 }; 2321 2322 data-pins { 2323 pins = "sdc2_data"; 2324 drive-strength = <2>; 2325 bias-pull-up; 2326 }; 2327 }; 2328 2329 sdc2_on_state: sdc2-on-state { 2330 clk-pins { 2331 pins = "sdc2_clk"; 2332 drive-strength = <16>; 2333 bias-disable; 2334 }; 2335 2336 cmd-pins { 2337 pins = "sdc2_cmd"; 2338 drive-strength = <10>; 2339 bias-pull-up; 2340 }; 2341 2342 data-pins { 2343 pins = "sdc2_data"; 2344 drive-strength = <10>; 2345 bias-pull-up; 2346 }; 2347 }; 2348 2349 qup_uart9_default: qup-uart9-default-state { 2350 pins = "gpio25", "gpio26"; 2351 function = "qup13_f2"; 2352 drive-strength = <2>; 2353 bias-disable; 2354 }; 2355 2356 qup_i2c0_default: qup-i2c0-default-state { 2357 pins = "gpio0", "gpio1"; 2358 function = "qup00"; 2359 drive-strength = <2>; 2360 bias-pull-up; 2361 }; 2362 2363 qup_i2c2_default: qup-i2c2-default-state { 2364 pins = "gpio45", "gpio46"; 2365 function = "qup02"; 2366 drive-strength = <2>; 2367 bias-pull-up; 2368 }; 2369 2370 qup_i2c6_default: qup-i2c6-default-state { 2371 pins = "gpio13", "gpio14"; 2372 function = "qup10"; 2373 drive-strength = <2>; 2374 bias-pull-up; 2375 }; 2376 2377 qup_i2c7_default: qup-i2c7-default-state { 2378 pins = "gpio27", "gpio28"; 2379 function = "qup11"; 2380 drive-strength = <2>; 2381 bias-pull-up; 2382 }; 2383 2384 qup_i2c8_default: qup-i2c8-default-state { 2385 pins = "gpio19", "gpio20"; 2386 function = "qup12"; 2387 drive-strength = <2>; 2388 bias-pull-up; 2389 }; 2390 2391 qup_i2c10_default: qup-i2c10-default-state { 2392 pins = "gpio4", "gpio5"; 2393 function = "qup14"; 2394 drive-strength = <2>; 2395 bias-pull-up; 2396 }; 2397 2398 qup_uart1_cts: qup-uart1-cts-default-state { 2399 pins = "gpio61"; 2400 function = "qup01"; 2401 drive-strength = <2>; 2402 bias-disable; 2403 }; 2404 2405 qup_uart1_rts: qup-uart1-rts-default-state { 2406 pins = "gpio62"; 2407 function = "qup01"; 2408 drive-strength = <2>; 2409 bias-pull-down; 2410 }; 2411 2412 qup_uart1_rx: qup-uart1-rx-default-state { 2413 pins = "gpio64"; 2414 function = "qup01"; 2415 drive-strength = <2>; 2416 bias-disable; 2417 }; 2418 2419 qup_uart1_tx: qup-uart1-tx-default-state { 2420 pins = "gpio63"; 2421 function = "qup01"; 2422 drive-strength = <2>; 2423 bias-pull-up; 2424 }; 2425 }; 2426 2427 apps_smmu: iommu@15000000 { 2428 compatible = "qcom,sm6350-smmu-500", "arm,mmu-500"; 2429 reg = <0 0x15000000 0 0x100000>; 2430 #iommu-cells = <2>; 2431 #global-interrupts = <1>; 2432 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, 2433 <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>, 2434 <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>, 2435 <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>, 2436 <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>, 2437 <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>, 2438 <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>, 2439 <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>, 2440 <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>, 2441 <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>, 2442 <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>, 2443 <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>, 2444 <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>, 2445 <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>, 2446 <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>, 2447 <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>, 2448 <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>, 2449 <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>, 2450 <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>, 2451 <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>, 2452 <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>, 2453 <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>, 2454 <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>, 2455 <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>, 2456 <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>, 2457 <GIC_SPI 181 IRQ_TYPE_LEVEL_HIGH>, 2458 <GIC_SPI 182 IRQ_TYPE_LEVEL_HIGH>, 2459 <GIC_SPI 183 IRQ_TYPE_LEVEL_HIGH>, 2460 <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>, 2461 <GIC_SPI 185 IRQ_TYPE_LEVEL_HIGH>, 2462 <GIC_SPI 186 IRQ_TYPE_LEVEL_HIGH>, 2463 <GIC_SPI 187 IRQ_TYPE_LEVEL_HIGH>, 2464 <GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>, 2465 <GIC_SPI 189 IRQ_TYPE_LEVEL_HIGH>, 2466 <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>, 2467 <GIC_SPI 191 IRQ_TYPE_LEVEL_HIGH>, 2468 <GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>, 2469 <GIC_SPI 315 IRQ_TYPE_LEVEL_HIGH>, 2470 <GIC_SPI 316 IRQ_TYPE_LEVEL_HIGH>, 2471 <GIC_SPI 317 IRQ_TYPE_LEVEL_HIGH>, 2472 <GIC_SPI 318 IRQ_TYPE_LEVEL_HIGH>, 2473 <GIC_SPI 319 IRQ_TYPE_LEVEL_HIGH>, 2474 <GIC_SPI 320 IRQ_TYPE_LEVEL_HIGH>, 2475 <GIC_SPI 321 IRQ_TYPE_LEVEL_HIGH>, 2476 <GIC_SPI 322 IRQ_TYPE_LEVEL_HIGH>, 2477 <GIC_SPI 323 IRQ_TYPE_LEVEL_HIGH>, 2478 <GIC_SPI 324 IRQ_TYPE_LEVEL_HIGH>, 2479 <GIC_SPI 325 IRQ_TYPE_LEVEL_HIGH>, 2480 <GIC_SPI 326 IRQ_TYPE_LEVEL_HIGH>, 2481 <GIC_SPI 327 IRQ_TYPE_LEVEL_HIGH>, 2482 <GIC_SPI 328 IRQ_TYPE_LEVEL_HIGH>, 2483 <GIC_SPI 329 IRQ_TYPE_LEVEL_HIGH>, 2484 <GIC_SPI 330 IRQ_TYPE_LEVEL_HIGH>, 2485 <GIC_SPI 331 IRQ_TYPE_LEVEL_HIGH>, 2486 <GIC_SPI 332 IRQ_TYPE_LEVEL_HIGH>, 2487 <GIC_SPI 333 IRQ_TYPE_LEVEL_HIGH>, 2488 <GIC_SPI 334 IRQ_TYPE_LEVEL_HIGH>, 2489 <GIC_SPI 335 IRQ_TYPE_LEVEL_HIGH>, 2490 <GIC_SPI 336 IRQ_TYPE_LEVEL_HIGH>, 2491 <GIC_SPI 337 IRQ_TYPE_LEVEL_HIGH>, 2492 <GIC_SPI 338 IRQ_TYPE_LEVEL_HIGH>, 2493 <GIC_SPI 339 IRQ_TYPE_LEVEL_HIGH>, 2494 <GIC_SPI 340 IRQ_TYPE_LEVEL_HIGH>, 2495 <GIC_SPI 341 IRQ_TYPE_LEVEL_HIGH>, 2496 <GIC_SPI 342 IRQ_TYPE_LEVEL_HIGH>, 2497 <GIC_SPI 343 IRQ_TYPE_LEVEL_HIGH>, 2498 <GIC_SPI 344 IRQ_TYPE_LEVEL_HIGH>, 2499 <GIC_SPI 345 IRQ_TYPE_LEVEL_HIGH>, 2500 <GIC_SPI 401 IRQ_TYPE_LEVEL_HIGH>, 2501 <GIC_SPI 402 IRQ_TYPE_LEVEL_HIGH>, 2502 <GIC_SPI 403 IRQ_TYPE_LEVEL_HIGH>, 2503 <GIC_SPI 404 IRQ_TYPE_LEVEL_HIGH>, 2504 <GIC_SPI 405 IRQ_TYPE_LEVEL_HIGH>, 2505 <GIC_SPI 406 IRQ_TYPE_LEVEL_HIGH>, 2506 <GIC_SPI 407 IRQ_TYPE_LEVEL_HIGH>, 2507 <GIC_SPI 408 IRQ_TYPE_LEVEL_HIGH>, 2508 <GIC_SPI 409 IRQ_TYPE_LEVEL_HIGH>, 2509 <GIC_SPI 410 IRQ_TYPE_LEVEL_HIGH>, 2510 <GIC_SPI 411 IRQ_TYPE_LEVEL_HIGH>, 2511 <GIC_SPI 412 IRQ_TYPE_LEVEL_HIGH>, 2512 <GIC_SPI 413 IRQ_TYPE_LEVEL_HIGH>; 2513 }; 2514 2515 intc: interrupt-controller@17a00000 { 2516 compatible = "arm,gic-v3"; 2517 #interrupt-cells = <3>; 2518 interrupt-controller; 2519 reg = <0x0 0x17a00000 0x0 0x10000>, /* GICD */ 2520 <0x0 0x17a60000 0x0 0x100000>; /* GICR * 8 */ 2521 interrupts = <GIC_PPI 8 IRQ_TYPE_LEVEL_HIGH>; 2522 }; 2523 2524 watchdog@17c10000 { 2525 compatible = "qcom,apss-wdt-sm6350", "qcom,kpss-wdt"; 2526 reg = <0 0x17c10000 0 0x1000>; 2527 clocks = <&sleep_clk>; 2528 interrupts = <GIC_SPI 0 IRQ_TYPE_EDGE_RISING>; 2529 }; 2530 2531 timer@17c20000 { 2532 compatible = "arm,armv7-timer-mem"; 2533 reg = <0x0 0x17c20000 0x0 0x1000>; 2534 clock-frequency = <19200000>; 2535 #address-cells = <1>; 2536 #size-cells = <1>; 2537 ranges = <0 0 0 0x20000000>; 2538 2539 frame@17c21000 { 2540 frame-number = <0>; 2541 interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>, 2542 <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>; 2543 reg = <0x17c21000 0x1000>, 2544 <0x17c22000 0x1000>; 2545 }; 2546 2547 frame@17c23000 { 2548 frame-number = <1>; 2549 interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>; 2550 reg = <0x17c23000 0x1000>; 2551 status = "disabled"; 2552 }; 2553 2554 frame@17c25000 { 2555 frame-number = <2>; 2556 interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>; 2557 reg = <0x17c25000 0x1000>; 2558 status = "disabled"; 2559 }; 2560 2561 frame@17c27000 { 2562 frame-number = <3>; 2563 interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>; 2564 reg = <0x17c27000 0x1000>; 2565 status = "disabled"; 2566 }; 2567 2568 frame@17c29000 { 2569 frame-number = <4>; 2570 interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>; 2571 reg = <0x17c29000 0x1000>; 2572 status = "disabled"; 2573 }; 2574 2575 frame@17c2b000 { 2576 frame-number = <5>; 2577 interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>; 2578 reg = <0x17c2b000 0x1000>; 2579 status = "disabled"; 2580 }; 2581 2582 frame@17c2d000 { 2583 frame-number = <6>; 2584 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>; 2585 reg = <0x17c2d000 0x1000>; 2586 status = "disabled"; 2587 }; 2588 }; 2589 2590 apps_rsc: rsc@18200000 { 2591 compatible = "qcom,rpmh-rsc"; 2592 label = "apps_rsc"; 2593 reg = <0x0 0x18200000 0x0 0x10000>, 2594 <0x0 0x18210000 0x0 0x10000>, 2595 <0x0 0x18220000 0x0 0x10000>; 2596 reg-names = "drv-0", "drv-1", "drv-2"; 2597 interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>, 2598 <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>, 2599 <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>; 2600 qcom,tcs-offset = <0xd00>; 2601 qcom,drv-id = <2>; 2602 qcom,tcs-config = <ACTIVE_TCS 2>, <SLEEP_TCS 3>, 2603 <WAKE_TCS 3>, <CONTROL_TCS 1>; 2604 power-domains = <&CLUSTER_PD>; 2605 2606 rpmhcc: clock-controller { 2607 compatible = "qcom,sm6350-rpmh-clk"; 2608 #clock-cells = <1>; 2609 clock-names = "xo"; 2610 clocks = <&xo_board>; 2611 }; 2612 2613 rpmhpd: power-controller { 2614 compatible = "qcom,sm6350-rpmhpd"; 2615 #power-domain-cells = <1>; 2616 operating-points-v2 = <&rpmhpd_opp_table>; 2617 2618 rpmhpd_opp_table: opp-table { 2619 compatible = "operating-points-v2"; 2620 2621 rpmhpd_opp_ret: opp1 { 2622 opp-level = <RPMH_REGULATOR_LEVEL_RETENTION>; 2623 }; 2624 2625 rpmhpd_opp_min_svs: opp2 { 2626 opp-level = <RPMH_REGULATOR_LEVEL_MIN_SVS>; 2627 }; 2628 2629 rpmhpd_opp_low_svs: opp3 { 2630 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS>; 2631 }; 2632 2633 rpmhpd_opp_svs: opp4 { 2634 opp-level = <RPMH_REGULATOR_LEVEL_SVS>; 2635 }; 2636 2637 rpmhpd_opp_svs_l1: opp5 { 2638 opp-level = <RPMH_REGULATOR_LEVEL_SVS_L1>; 2639 }; 2640 2641 rpmhpd_opp_nom: opp6 { 2642 opp-level = <RPMH_REGULATOR_LEVEL_NOM>; 2643 }; 2644 2645 rpmhpd_opp_nom_l1: opp7 { 2646 opp-level = <RPMH_REGULATOR_LEVEL_NOM_L1>; 2647 }; 2648 2649 rpmhpd_opp_nom_l2: opp8 { 2650 opp-level = <RPMH_REGULATOR_LEVEL_NOM_L2>; 2651 }; 2652 2653 rpmhpd_opp_turbo: opp9 { 2654 opp-level = <RPMH_REGULATOR_LEVEL_TURBO>; 2655 }; 2656 2657 rpmhpd_opp_turbo_l1: opp10 { 2658 opp-level = <RPMH_REGULATOR_LEVEL_TURBO_L1>; 2659 }; 2660 }; 2661 }; 2662 2663 apps_bcm_voter: bcm-voter { 2664 compatible = "qcom,bcm-voter"; 2665 }; 2666 }; 2667 2668 osm_l3: interconnect@18321000 { 2669 compatible = "qcom,sm6350-osm-l3", "qcom,osm-l3"; 2670 reg = <0x0 0x18321000 0x0 0x1000>; 2671 2672 clocks = <&rpmhcc RPMH_CXO_CLK>, <&gcc GPLL0>; 2673 clock-names = "xo", "alternate"; 2674 2675 #interconnect-cells = <1>; 2676 }; 2677 2678 cpufreq_hw: cpufreq@18323000 { 2679 compatible = "qcom,sm6350-cpufreq-hw", "qcom,cpufreq-hw"; 2680 reg = <0 0x18323000 0 0x1000>, <0 0x18325800 0 0x1000>; 2681 reg-names = "freq-domain0", "freq-domain1"; 2682 clocks = <&rpmhcc RPMH_CXO_CLK>, <&gcc GPLL0>; 2683 clock-names = "xo", "alternate"; 2684 2685 #freq-domain-cells = <1>; 2686 #clock-cells = <1>; 2687 }; 2688 2689 wifi: wifi@18800000 { 2690 compatible = "qcom,wcn3990-wifi"; 2691 reg = <0 0x18800000 0 0x800000>; 2692 reg-names = "membase"; 2693 memory-region = <&wlan_fw_mem>; 2694 interrupts = <GIC_SPI 414 IRQ_TYPE_LEVEL_HIGH>, 2695 <GIC_SPI 415 IRQ_TYPE_LEVEL_HIGH>, 2696 <GIC_SPI 416 IRQ_TYPE_LEVEL_HIGH>, 2697 <GIC_SPI 417 IRQ_TYPE_LEVEL_HIGH>, 2698 <GIC_SPI 418 IRQ_TYPE_LEVEL_HIGH>, 2699 <GIC_SPI 419 IRQ_TYPE_LEVEL_HIGH>, 2700 <GIC_SPI 420 IRQ_TYPE_LEVEL_HIGH>, 2701 <GIC_SPI 421 IRQ_TYPE_LEVEL_HIGH>, 2702 <GIC_SPI 422 IRQ_TYPE_LEVEL_HIGH>, 2703 <GIC_SPI 423 IRQ_TYPE_LEVEL_HIGH>, 2704 <GIC_SPI 424 IRQ_TYPE_LEVEL_HIGH>, 2705 <GIC_SPI 425 IRQ_TYPE_LEVEL_HIGH>; 2706 iommus = <&apps_smmu 0x20 0x1>; 2707 qcom,msa-fixed-perm; 2708 status = "disabled"; 2709 }; 2710 }; 2711 2712 timer { 2713 compatible = "arm,armv8-timer"; 2714 clock-frequency = <19200000>; 2715 interrupts = <GIC_PPI 1 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>, 2716 <GIC_PPI 2 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>, 2717 <GIC_PPI 3 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>, 2718 <GIC_PPI 0 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>; 2719 }; 2720}; 2721