1// SPDX-License-Identifier: GPL-2.0-only 2/* Copyright (c) 2013-2016, The Linux Foundation. All rights reserved. 3 */ 4 5#include <dt-bindings/interrupt-controller/arm-gic.h> 6#include <dt-bindings/clock/qcom,gcc-msm8994.h> 7#include <dt-bindings/power/qcom-rpmpd.h> 8 9/ { 10 interrupt-parent = <&intc>; 11 12 #address-cells = <2>; 13 #size-cells = <2>; 14 15 chosen { }; 16 17 clocks { 18 xo_board: xo-board { 19 compatible = "fixed-clock"; 20 #clock-cells = <0>; 21 clock-frequency = <19200000>; 22 clock-output-names = "xo_board"; 23 }; 24 25 sleep_clk: sleep-clk { 26 compatible = "fixed-clock"; 27 #clock-cells = <0>; 28 clock-frequency = <32768>; 29 clock-output-names = "sleep_clk"; 30 }; 31 }; 32 33 cpus { 34 #address-cells = <2>; 35 #size-cells = <0>; 36 37 CPU0: cpu@0 { 38 device_type = "cpu"; 39 compatible = "arm,cortex-a53"; 40 reg = <0x0 0x0>; 41 enable-method = "psci"; 42 next-level-cache = <&L2_0>; 43 L2_0: l2-cache { 44 compatible = "cache"; 45 cache-level = <2>; 46 }; 47 }; 48 49 CPU1: cpu@1 { 50 device_type = "cpu"; 51 compatible = "arm,cortex-a53"; 52 reg = <0x0 0x1>; 53 enable-method = "psci"; 54 next-level-cache = <&L2_0>; 55 }; 56 57 CPU2: cpu@2 { 58 device_type = "cpu"; 59 compatible = "arm,cortex-a53"; 60 reg = <0x0 0x2>; 61 enable-method = "psci"; 62 next-level-cache = <&L2_0>; 63 }; 64 65 CPU3: cpu@3 { 66 device_type = "cpu"; 67 compatible = "arm,cortex-a53"; 68 reg = <0x0 0x3>; 69 enable-method = "psci"; 70 next-level-cache = <&L2_0>; 71 }; 72 73 CPU4: cpu@100 { 74 device_type = "cpu"; 75 compatible = "arm,cortex-a57"; 76 reg = <0x0 0x100>; 77 enable-method = "psci"; 78 next-level-cache = <&L2_1>; 79 L2_1: l2-cache { 80 compatible = "cache"; 81 cache-level = <2>; 82 }; 83 }; 84 85 CPU5: cpu@101 { 86 device_type = "cpu"; 87 compatible = "arm,cortex-a57"; 88 reg = <0x0 0x101>; 89 enable-method = "psci"; 90 next-level-cache = <&L2_1>; 91 }; 92 93 CPU6: cpu@102 { 94 device_type = "cpu"; 95 compatible = "arm,cortex-a57"; 96 reg = <0x0 0x101>; 97 enable-method = "psci"; 98 next-level-cache = <&L2_1>; 99 }; 100 101 CPU7: cpu@103 { 102 device_type = "cpu"; 103 compatible = "arm,cortex-a57"; 104 reg = <0x0 0x101>; 105 enable-method = "psci"; 106 next-level-cache = <&L2_1>; 107 }; 108 109 cpu-map { 110 cluster0 { 111 core0 { 112 cpu = <&CPU0>; 113 }; 114 115 core1 { 116 cpu = <&CPU1>; 117 }; 118 119 core2 { 120 cpu = <&CPU2>; 121 }; 122 123 core3 { 124 cpu = <&CPU3>; 125 }; 126 }; 127 128 cluster1 { 129 core0 { 130 cpu = <&CPU4>; 131 }; 132 133 core1 { 134 cpu = <&CPU5>; 135 }; 136 137 cpu6_map: core2 { 138 cpu = <&CPU6>; 139 }; 140 141 cpu7_map: core3 { 142 cpu = <&CPU7>; 143 }; 144 }; 145 }; 146 }; 147 148 firmware { 149 scm { 150 compatible = "qcom,scm-msm8994", "qcom,scm"; 151 }; 152 }; 153 154 memory@80000000 { 155 device_type = "memory"; 156 /* We expect the bootloader to fill in the reg */ 157 reg = <0 0x80000000 0 0>; 158 }; 159 160 tcsr_mutex: hwlock { 161 compatible = "qcom,tcsr-mutex"; 162 syscon = <&tcsr_mutex_regs 0 0x80>; 163 #hwlock-cells = <1>; 164 }; 165 166 pmu { 167 compatible = "arm,cortex-a53-pmu"; 168 interrupts = <GIC_PPI 7 (GIC_CPU_MASK_SIMPLE(4)| IRQ_TYPE_LEVEL_HIGH)>; 169 }; 170 171 psci { 172 compatible = "arm,psci-0.2"; 173 method = "hvc"; 174 }; 175 176 reserved-memory { 177 #address-cells = <2>; 178 #size-cells = <2>; 179 ranges; 180 181 dfps_data_mem: dfps_data_mem@3400000 { 182 reg = <0 0x03400000 0 0x1000>; 183 no-map; 184 }; 185 186 cont_splash_mem: memory@3800000 { 187 reg = <0 0x03800000 0 0x2400000>; 188 no-map; 189 }; 190 191 smem_mem: smem_region@6a00000 { 192 reg = <0 0x06a00000 0 0x200000>; 193 no-map; 194 }; 195 196 mpss_mem: memory@7000000 { 197 reg = <0 0x07000000 0 0x5a00000>; 198 no-map; 199 }; 200 201 peripheral_region: memory@ca00000 { 202 reg = <0 0x0ca00000 0 0x1f00000>; 203 no-map; 204 }; 205 206 rmtfs_mem: memory@c6400000 { 207 compatible = "qcom,rmtfs-mem"; 208 reg = <0 0xc6400000 0 0x180000>; 209 no-map; 210 211 qcom,client-id = <1>; 212 }; 213 214 mba_mem: memory@c6700000 { 215 reg = <0 0xc6700000 0 0x100000>; 216 no-map; 217 }; 218 219 audio_mem: memory@c7000000 { 220 reg = <0 0xc7000000 0 0x800000>; 221 no-map; 222 }; 223 224 adsp_mem: memory@c9400000 { 225 reg = <0 0xc9400000 0 0x3f00000>; 226 no-map; 227 }; 228 }; 229 230 smd { 231 compatible = "qcom,smd"; 232 rpm { 233 interrupts = <GIC_SPI 168 IRQ_TYPE_EDGE_RISING>; 234 qcom,ipc = <&apcs 8 0>; 235 qcom,smd-edge = <15>; 236 qcom,local-pid = <0>; 237 qcom,remote-pid = <6>; 238 239 rpm_requests: rpm-requests { 240 compatible = "qcom,rpm-msm8994"; 241 qcom,smd-channels = "rpm_requests"; 242 243 rpmcc: rpmcc { 244 compatible = "qcom,rpmcc-msm8994"; 245 #clock-cells = <1>; 246 }; 247 248 rpmpd: power-controller { 249 compatible = "qcom,msm8994-rpmpd"; 250 #power-domain-cells = <1>; 251 operating-points-v2 = <&rpmpd_opp_table>; 252 253 rpmpd_opp_table: opp-table { 254 compatible = "operating-points-v2"; 255 256 rpmpd_opp_ret: opp1 { 257 opp-level = <1>; 258 }; 259 rpmpd_opp_svs_krait: opp2 { 260 opp-level = <2>; 261 }; 262 rpmpd_opp_svs_soc: opp3 { 263 opp-level = <3>; 264 }; 265 rpmpd_opp_nom: opp4 { 266 opp-level = <4>; 267 }; 268 rpmpd_opp_turbo: opp5 { 269 opp-level = <5>; 270 }; 271 rpmpd_opp_super_turbo: opp6 { 272 opp-level = <6>; 273 }; 274 }; 275 }; 276 }; 277 }; 278 }; 279 280 smem { 281 compatible = "qcom,smem"; 282 memory-region = <&smem_mem>; 283 qcom,rpm-msg-ram = <&rpm_msg_ram>; 284 hwlocks = <&tcsr_mutex 3>; 285 }; 286 287 smp2p-lpass { 288 compatible = "qcom,smp2p"; 289 qcom,smem = <443>, <429>; 290 291 interrupts = <GIC_SPI 158 IRQ_TYPE_EDGE_RISING>; 292 293 qcom,ipc = <&apcs 8 10>; 294 295 qcom,local-pid = <0>; 296 qcom,remote-pid = <2>; 297 298 adsp_smp2p_out: master-kernel { 299 qcom,entry-name = "master-kernel"; 300 #qcom,smem-state-cells = <1>; 301 }; 302 303 adsp_smp2p_in: slave-kernel { 304 qcom,entry-name = "slave-kernel"; 305 306 interrupt-controller; 307 #interrupt-cells = <2>; 308 }; 309 }; 310 311 smp2p-modem { 312 compatible = "qcom,smp2p"; 313 qcom,smem = <435>, <428>; 314 315 interrupt-parent = <&intc>; 316 interrupts = <GIC_SPI 27 IRQ_TYPE_EDGE_RISING>; 317 318 qcom,ipc = <&apcs 8 14>; 319 320 qcom,local-pid = <0>; 321 qcom,remote-pid = <1>; 322 323 modem_smp2p_out: master-kernel { 324 qcom,entry-name = "master-kernel"; 325 #qcom,smem-state-cells = <1>; 326 }; 327 328 modem_smp2p_in: slave-kernel { 329 qcom,entry-name = "slave-kernel"; 330 331 interrupt-controller; 332 #interrupt-cells = <2>; 333 }; 334 }; 335 336 soc: soc { 337 338 #address-cells = <1>; 339 #size-cells = <1>; 340 ranges = <0 0 0 0xffffffff>; 341 compatible = "simple-bus"; 342 343 intc: interrupt-controller@f9000000 { 344 compatible = "qcom,msm-qgic2"; 345 interrupt-controller; 346 #interrupt-cells = <3>; 347 reg = <0xf9000000 0x1000>, 348 <0xf9002000 0x1000>; 349 }; 350 351 apcs: mailbox@f900d000 { 352 compatible = "qcom,msm8994-apcs-kpss-global", "syscon"; 353 reg = <0xf900d000 0x2000>; 354 #mbox-cells = <1>; 355 }; 356 357 timer@f9020000 { 358 #address-cells = <1>; 359 #size-cells = <1>; 360 ranges; 361 compatible = "arm,armv7-timer-mem"; 362 reg = <0xf9020000 0x1000>; 363 364 frame@f9021000 { 365 frame-number = <0>; 366 interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>, 367 <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>; 368 reg = <0xf9021000 0x1000>, 369 <0xf9022000 0x1000>; 370 }; 371 372 frame@f9023000 { 373 frame-number = <1>; 374 interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>; 375 reg = <0xf9023000 0x1000>; 376 status = "disabled"; 377 }; 378 379 frame@f9024000 { 380 frame-number = <2>; 381 interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>; 382 reg = <0xf9024000 0x1000>; 383 status = "disabled"; 384 }; 385 386 frame@f9025000 { 387 frame-number = <3>; 388 interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>; 389 reg = <0xf9025000 0x1000>; 390 status = "disabled"; 391 }; 392 393 frame@f9026000 { 394 frame-number = <4>; 395 interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>; 396 reg = <0xf9026000 0x1000>; 397 status = "disabled"; 398 }; 399 400 frame@f9027000 { 401 frame-number = <5>; 402 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>; 403 reg = <0xf9027000 0x1000>; 404 status = "disabled"; 405 }; 406 407 frame@f9028000 { 408 frame-number = <6>; 409 interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>; 410 reg = <0xf9028000 0x1000>; 411 status = "disabled"; 412 }; 413 }; 414 415 usb3: usb@f92f8800 { 416 compatible = "qcom,msm8996-dwc3", "qcom,dwc3"; 417 reg = <0xf92f8800 0x400>; 418 #address-cells = <1>; 419 #size-cells = <1>; 420 ranges; 421 422 clocks = <&gcc GCC_USB30_MASTER_CLK>, 423 <&gcc GCC_SYS_NOC_USB3_AXI_CLK>, 424 <&gcc GCC_USB30_SLEEP_CLK>, 425 <&gcc GCC_USB30_MOCK_UTMI_CLK>; 426 clock-names = "core", "iface", "sleep", "mock_utmi", "ref", "xo"; 427 428 assigned-clocks = <&gcc GCC_USB30_MOCK_UTMI_CLK>, 429 <&gcc GCC_USB30_MASTER_CLK>; 430 assigned-clock-rates = <19200000>, <120000000>; 431 432 power-domains = <&gcc USB30_GDSC>; 433 qcom,select-utmi-as-pipe-clk; 434 435 usb@f9200000 { 436 compatible = "snps,dwc3"; 437 reg = <0xf9200000 0xcc00>; 438 interrupts = <0 131 IRQ_TYPE_LEVEL_HIGH>; 439 snps,dis_u2_susphy_quirk; 440 snps,dis_enblslpm_quirk; 441 maximum-speed = "high-speed"; 442 dr_mode = "peripheral"; 443 }; 444 }; 445 446 sdhc1: sdhci@f9824900 { 447 compatible = "qcom,sdhci-msm-v4"; 448 reg = <0xf9824900 0x1a0>, <0xf9824000 0x800>; 449 reg-names = "hc_mem", "core_mem"; 450 451 interrupts = <GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>, 452 <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>; 453 interrupt-names = "hc_irq", "pwr_irq"; 454 455 clocks = <&gcc GCC_SDCC1_APPS_CLK>, 456 <&gcc GCC_SDCC1_AHB_CLK>, 457 <&xo_board>; 458 clock-names = "core", "iface", "xo"; 459 460 pinctrl-names = "default", "sleep"; 461 pinctrl-0 = <&sdc1_clk_on &sdc1_cmd_on &sdc1_data_on &sdc1_rclk_on>; 462 pinctrl-1 = <&sdc1_clk_off &sdc1_cmd_off &sdc1_data_off &sdc1_rclk_off>; 463 464 bus-width = <8>; 465 non-removable; 466 status = "disabled"; 467 }; 468 469 sdhc2: sdhci@f98a4900 { 470 compatible = "qcom,sdhci-msm-v4"; 471 reg = <0xf98a4900 0x11c>, <0xf98a4000 0x800>; 472 reg-names = "hc_mem", "core_mem"; 473 474 interrupts = <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>, 475 <GIC_SPI 221 IRQ_TYPE_LEVEL_HIGH>; 476 interrupt-names = "hc_irq", "pwr_irq"; 477 478 clocks = <&gcc GCC_SDCC2_APPS_CLK>, 479 <&gcc GCC_SDCC2_AHB_CLK>, 480 <&xo_board>; 481 clock-names = "core", "iface", "xo"; 482 483 pinctrl-names = "default", "sleep"; 484 pinctrl-0 = <&sdc2_clk_on &sdc2_cmd_on &sdc2_data_on>; 485 pinctrl-1 = <&sdc2_clk_off &sdc2_cmd_off &sdc2_data_off>; 486 487 cd-gpios = <&tlmm 100 0>; 488 bus-width = <4>; 489 status = "disabled"; 490 }; 491 492 blsp1_dma: dma-controller@f9904000 { 493 compatible = "qcom,bam-v1.7.0"; 494 reg = <0xf9904000 0x19000>; 495 interrupts = <GIC_SPI 238 IRQ_TYPE_LEVEL_HIGH>; 496 clocks = <&gcc GCC_BLSP1_AHB_CLK>; 497 clock-names = "bam_clk"; 498 #dma-cells = <1>; 499 qcom,ee = <0>; 500 qcom,controlled-remotely; 501 num-channels = <18>; 502 qcom,num-ees = <4>; 503 }; 504 505 blsp1_uart2: serial@f991e000 { 506 compatible = "qcom,msm-uartdm-v1.4", "qcom,msm-uartdm"; 507 reg = <0xf991e000 0x1000>; 508 interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>; 509 clock-names = "core", "iface"; 510 clocks = <&gcc GCC_BLSP1_UART2_APPS_CLK>, 511 <&gcc GCC_BLSP1_AHB_CLK>; 512 pinctrl-names = "default", "sleep"; 513 pinctrl-0 = <&blsp1_uart2_default>; 514 pinctrl-1 = <&blsp1_uart2_sleep>; 515 status = "disabled"; 516 }; 517 518 blsp1_i2c1: i2c@f9923000 { 519 compatible = "qcom,i2c-qup-v2.2.1"; 520 reg = <0xf9923000 0x500>; 521 interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>; 522 clocks = <&gcc GCC_BLSP1_AHB_CLK>, 523 <&gcc GCC_BLSP1_QUP1_I2C_APPS_CLK>; 524 clock-names = "iface", "core"; 525 clock-frequency = <400000>; 526 dmas = <&blsp1_dma 12>, <&blsp1_dma 13>; 527 dma-names = "tx", "rx"; 528 pinctrl-names = "default", "sleep"; 529 pinctrl-0 = <&i2c1_default>; 530 pinctrl-1 = <&i2c1_sleep>; 531 #address-cells = <1>; 532 #size-cells = <0>; 533 status = "disabled"; 534 }; 535 536 blsp1_spi1: spi@f9923000 { 537 compatible = "qcom,spi-qup-v2.2.1"; 538 reg = <0xf9923000 0x500>; 539 interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>; 540 clocks = <&gcc GCC_BLSP1_QUP1_SPI_APPS_CLK>, 541 <&gcc GCC_BLSP1_AHB_CLK>; 542 clock-names = "core", "iface"; 543 spi-max-frequency = <19200000>; 544 dmas = <&blsp1_dma 12>, <&blsp1_dma 13>; 545 dma-names = "tx", "rx"; 546 pinctrl-names = "default", "sleep"; 547 pinctrl-0 = <&blsp1_spi1_default>; 548 pinctrl-1 = <&blsp1_spi1_sleep>; 549 #address-cells = <1>; 550 #size-cells = <0>; 551 status = "disabled"; 552 }; 553 554 blsp1_i2c2: i2c@f9924000 { 555 compatible = "qcom,i2c-qup-v2.2.1"; 556 reg = <0xf9924000 0x500>; 557 interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>; 558 clocks = <&gcc GCC_BLSP1_AHB_CLK>, 559 <&gcc GCC_BLSP1_QUP2_I2C_APPS_CLK>; 560 clock-names = "iface", "core"; 561 clock-frequency = <400000>; 562 dmas = <&blsp1_dma 14>, <&blsp1_dma 15>; 563 dma-names = "tx", "rx"; 564 pinctrl-names = "default", "sleep"; 565 pinctrl-0 = <&i2c2_default>; 566 pinctrl-1 = <&i2c2_sleep>; 567 #address-cells = <1>; 568 #size-cells = <0>; 569 status = "disabled"; 570 }; 571 572 /* I2C3 doesn't exist */ 573 574 blsp1_i2c4: i2c@f9926000 { 575 compatible = "qcom,i2c-qup-v2.2.1"; 576 reg = <0xf9926000 0x500>; 577 interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>; 578 clocks = <&gcc GCC_BLSP1_AHB_CLK>, 579 <&gcc GCC_BLSP1_QUP4_I2C_APPS_CLK>; 580 clock-names = "iface", "core"; 581 clock-frequency = <400000>; 582 dmas = <&blsp1_dma 18>, <&blsp1_dma 19>; 583 dma-names = "tx", "rx"; 584 pinctrl-names = "default", "sleep"; 585 pinctrl-0 = <&i2c4_default>; 586 pinctrl-1 = <&i2c4_sleep>; 587 #address-cells = <1>; 588 #size-cells = <0>; 589 status = "disabled"; 590 }; 591 592 blsp1_i2c5: i2c@f9927000 { 593 compatible = "qcom,i2c-qup-v2.2.1"; 594 reg = <0xf9927000 0x500>; 595 interrupts = <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; 596 clocks = <&gcc GCC_BLSP1_AHB_CLK>, 597 <&gcc GCC_BLSP1_QUP5_I2C_APPS_CLK>; 598 clock-names = "iface", "core"; 599 clock-frequency = <400000>; 600 dmas = <&blsp2_dma 20>, <&blsp2_dma 21>; 601 dma-names = "tx", "rx"; 602 pinctrl-names = "default", "sleep"; 603 pinctrl-0 = <&i2c5_default>; 604 pinctrl-1 = <&i2c5_sleep>; 605 #address-cells = <1>; 606 #size-cells = <0>; 607 status = "disabled"; 608 }; 609 610 blsp1_i2c6: i2c@f9928000 { 611 compatible = "qcom,i2c-qup-v2.2.1"; 612 reg = <0xf9928000 0x500>; 613 interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>; 614 clocks = <&gcc GCC_BLSP1_AHB_CLK>, 615 <&gcc GCC_BLSP1_QUP6_I2C_APPS_CLK>; 616 clock-names = "iface", "core"; 617 clock-frequency = <400000>; 618 dmas = <&blsp1_dma 22>, <&blsp1_dma 23>; 619 dma-names = "tx", "rx"; 620 pinctrl-names = "default", "sleep"; 621 pinctrl-0 = <&i2c6_default>; 622 pinctrl-1 = <&i2c6_sleep>; 623 #address-cells = <1>; 624 #size-cells = <0>; 625 status = "disabled"; 626 }; 627 628 blsp2_dma: dma-controller@f9944000 { 629 compatible = "qcom,bam-v1.7.0"; 630 reg = <0xf9944000 0x19000>; 631 interrupts = <GIC_SPI 239 IRQ_TYPE_LEVEL_HIGH>; 632 clocks = <&gcc GCC_BLSP2_AHB_CLK>; 633 clock-names = "bam_clk"; 634 #dma-cells = <1>; 635 qcom,ee = <0>; 636 qcom,controlled-remotely; 637 num-channels = <18>; 638 qcom,num-ees = <4>; 639 }; 640 641 blsp2_uart2: serial@f995e000 { 642 compatible = "qcom,msm-uartdm-v1.4", "qcom,msm-uartdm"; 643 reg = <0xf995e000 0x1000>; 644 interrupts = <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>; 645 clock-names = "core", "iface"; 646 clocks = <&gcc GCC_BLSP2_UART2_APPS_CLK>, 647 <&gcc GCC_BLSP2_AHB_CLK>; 648 dmas = <&blsp2_dma 2>, <&blsp2_dma 3>; 649 dma-names = "tx", "rx"; 650 pinctrl-names = "default", "sleep"; 651 pinctrl-0 = <&blsp2_uart2_default>; 652 pinctrl-1 = <&blsp2_uart2_sleep>; 653 status = "disabled"; 654 }; 655 656 blsp2_i2c1: i2c@f9963000 { 657 compatible = "qcom,i2c-qup-v2.2.1"; 658 reg = <0xf9963000 0x500>; 659 interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>; 660 clocks = <&gcc GCC_BLSP2_AHB_CLK>, 661 <&gcc GCC_BLSP2_QUP1_I2C_APPS_CLK>; 662 clock-names = "iface", "core"; 663 clock-frequency = <400000>; 664 dmas = <&blsp2_dma 12>, <&blsp2_dma 13>; 665 dma-names = "tx", "rx"; 666 pinctrl-names = "default", "sleep"; 667 pinctrl-0 = <&i2c7_default>; 668 pinctrl-1 = <&i2c7_sleep>; 669 #address-cells = <1>; 670 #size-cells = <0>; 671 status = "disabled"; 672 }; 673 674 blsp2_spi4: spi@f9966000 { 675 compatible = "qcom,spi-qup-v2.2.1"; 676 reg = <0xf9966000 0x500>; 677 interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>; 678 clocks = <&gcc GCC_BLSP2_QUP4_SPI_APPS_CLK>, 679 <&gcc GCC_BLSP2_AHB_CLK>; 680 clock-names = "core", "iface"; 681 spi-max-frequency = <19200000>; 682 dmas = <&blsp2_dma 18>, <&blsp2_dma 19>; 683 dma-names = "tx", "rx"; 684 pinctrl-names = "default", "sleep"; 685 pinctrl-0 = <&blsp2_spi10_default>; 686 pinctrl-1 = <&blsp2_spi10_sleep>; 687 #address-cells = <1>; 688 #size-cells = <0>; 689 status = "disabled"; 690 }; 691 692 blsp2_i2c5: i2c@f9967000 { 693 compatible = "qcom,i2c-qup-v2.2.1"; 694 reg = <0xf9967000 0x500>; 695 interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>; 696 clocks = <&gcc GCC_BLSP2_AHB_CLK>, 697 <&gcc GCC_BLSP2_QUP5_I2C_APPS_CLK>; 698 clock-names = "iface", "core"; 699 clock-frequency = <355000>; 700 dmas = <&blsp2_dma 20>, <&blsp2_dma 21>; 701 dma-names = "tx", "rx"; 702 pinctrl-names = "default", "sleep"; 703 pinctrl-0 = <&i2c11_default>; 704 pinctrl-1 = <&i2c11_sleep>; 705 #address-cells = <1>; 706 #size-cells = <0>; 707 status = "disabled"; 708 }; 709 710 gcc: clock-controller@fc400000 { 711 compatible = "qcom,gcc-msm8994"; 712 #clock-cells = <1>; 713 #reset-cells = <1>; 714 #power-domain-cells = <1>; 715 reg = <0xfc400000 0x2000>; 716 }; 717 718 rpm_msg_ram: sram@fc428000 { 719 compatible = "qcom,rpm-msg-ram"; 720 reg = <0xfc428000 0x4000>; 721 }; 722 723 restart@fc4ab000 { 724 compatible = "qcom,pshold"; 725 reg = <0xfc4ab000 0x4>; 726 }; 727 728 spmi_bus: spmi@fc4c0000 { 729 compatible = "qcom,spmi-pmic-arb"; 730 reg = <0xfc4cf000 0x1000>, 731 <0xfc4cb000 0x1000>, 732 <0xfc4ca000 0x1000>; 733 reg-names = "core", "intr", "cnfg"; 734 interrupt-names = "periph_irq"; 735 interrupts = <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>; 736 qcom,ee = <0>; 737 qcom,channel = <0>; 738 #address-cells = <2>; 739 #size-cells = <0>; 740 interrupt-controller; 741 #interrupt-cells = <4>; 742 }; 743 744 tcsr_mutex_regs: syscon@fd484000 { 745 compatible = "syscon"; 746 reg = <0xfd484000 0x2000>; 747 }; 748 749 tlmm: pinctrl@fd510000 { 750 compatible = "qcom,msm8994-pinctrl"; 751 reg = <0xfd510000 0x4000>; 752 interrupts = <GIC_SPI 208 IRQ_TYPE_LEVEL_HIGH>; 753 gpio-controller; 754 gpio-ranges = <&tlmm 0 0 146>; 755 #gpio-cells = <2>; 756 interrupt-controller; 757 #interrupt-cells = <2>; 758 759 blsp1_uart2_default: blsp1-uart2-default { 760 function = "blsp_uart2"; 761 pins = "gpio4", "gpio5"; 762 drive-strength = <16>; 763 bias-disable; 764 }; 765 766 blsp1_uart2_sleep: blsp1-uart2-sleep { 767 function = "gpio"; 768 pins = "gpio4", "gpio5"; 769 drive-strength = <2>; 770 bias-pull-down; 771 }; 772 773 blsp2_uart2_default: blsp2-uart2-default { 774 function = "blsp_uart8"; 775 pins = "gpio45", "gpio46", 776 "gpio47", "gpio48"; 777 drive-strength = <16>; 778 bias-disable; 779 }; 780 781 blsp2_uart2_sleep: blsp2-uart2-sleep { 782 function = "gpio"; 783 pins = "gpio45", "gpio46", 784 "gpio47", "gpio48"; 785 drive-strength = <2>; 786 bias-disable; 787 }; 788 789 i2c1_default: i2c1-default { 790 function = "blsp_i2c1"; 791 pins = "gpio2", "gpio3"; 792 drive-strength = <2>; 793 bias-disable; 794 }; 795 796 i2c1_sleep: i2c1-sleep { 797 function = "gpio"; 798 pins = "gpio2", "gpio3"; 799 drive-strength = <2>; 800 bias-disable; 801 }; 802 803 i2c2_default: i2c2-default { 804 function = "blsp_i2c2"; 805 pins = "gpio6", "gpio7"; 806 drive-strength = <2>; 807 bias-disable; 808 }; 809 810 i2c2_sleep: i2c2-sleep { 811 function = "gpio"; 812 pins = "gpio6", "gpio7"; 813 drive-strength = <2>; 814 bias-disable; 815 }; 816 817 i2c4_default: i2c4-default { 818 function = "blsp_i2c4"; 819 pins = "gpio19", "gpio20"; 820 drive-strength = <2>; 821 bias-disable; 822 }; 823 824 i2c4_sleep: i2c4-sleep { 825 function = "gpio"; 826 pins = "gpio19", "gpio20"; 827 drive-strength = <2>; 828 bias-pull-down; 829 input-enable; 830 }; 831 832 i2c5_default: i2c5-default { 833 function = "blsp_i2c5"; 834 pins = "gpio23", "gpio24"; 835 drive-strength = <2>; 836 bias-disable; 837 }; 838 839 i2c5_sleep: i2c5-sleep { 840 function = "gpio"; 841 pins = "gpio23", "gpio24"; 842 drive-strength = <2>; 843 bias-disable; 844 }; 845 846 i2c6_default: i2c6-default { 847 function = "blsp_i2c6"; 848 pins = "gpio28", "gpio27"; 849 drive-strength = <2>; 850 bias-disable; 851 }; 852 853 i2c6_sleep: i2c6-sleep { 854 function = "gpio"; 855 pins = "gpio28", "gpio27"; 856 drive-strength = <2>; 857 bias-disable; 858 }; 859 860 i2c7_default: i2c7-default { 861 function = "blsp_i2c7"; 862 pins = "gpio44", "gpio43"; 863 drive-strength = <2>; 864 bias-disable; 865 }; 866 867 i2c7_sleep: i2c7-sleep { 868 function = "gpio"; 869 pins = "gpio44", "gpio43"; 870 drive-strength = <2>; 871 bias-disable; 872 }; 873 874 blsp2_spi10_default: blsp2-spi10-default { 875 default { 876 function = "blsp_spi10"; 877 pins = "gpio53", "gpio54", "gpio55"; 878 drive-strength = <10>; 879 bias-pull-down; 880 }; 881 cs { 882 function = "gpio"; 883 pins = "gpio55"; 884 drive-strength = <2>; 885 bias-disable; 886 }; 887 }; 888 889 blsp2_spi10_sleep: blsp2-spi10-sleep { 890 pins = "gpio53", "gpio54", "gpio55"; 891 drive-strength = <2>; 892 bias-disable; 893 }; 894 895 i2c11_default: i2c11-default { 896 function = "blsp_i2c11"; 897 pins = "gpio83", "gpio84"; 898 drive-strength = <2>; 899 bias-disable; 900 }; 901 902 i2c11_sleep: i2c11-sleep { 903 function = "gpio"; 904 pins = "gpio83", "gpio84"; 905 drive-strength = <2>; 906 bias-disable; 907 }; 908 909 blsp1_spi1_default: blsp1-spi1-default { 910 default { 911 function = "blsp_spi1"; 912 pins = "gpio0", "gpio1", "gpio3"; 913 drive-strength = <10>; 914 bias-pull-down; 915 }; 916 cs { 917 function = "gpio"; 918 pins = "gpio8"; 919 drive-strength = <2>; 920 bias-disable; 921 }; 922 }; 923 924 blsp1_spi1_sleep: blsp1-spi1-sleep { 925 pins = "gpio0", "gpio1", "gpio3"; 926 drive-strength = <2>; 927 bias-disable; 928 }; 929 930 sdc1_clk_on: clk-on { 931 pins = "sdc1_clk"; 932 bias-disable; 933 drive-strength = <16>; 934 }; 935 936 sdc1_clk_off: clk-off { 937 pins = "sdc1_clk"; 938 bias-disable; 939 drive-strength = <2>; 940 }; 941 942 sdc1_cmd_on: cmd-on { 943 pins = "sdc1_cmd"; 944 bias-pull-up; 945 drive-strength = <8>; 946 }; 947 948 sdc1_cmd_off: cmd-off { 949 pins = "sdc1_cmd"; 950 bias-pull-up; 951 drive-strength = <2>; 952 }; 953 954 sdc1_data_on: data-on { 955 pins = "sdc1_data"; 956 bias-pull-up; 957 drive-strength = <8>; 958 }; 959 960 sdc1_data_off: data-off { 961 pins = "sdc1_data"; 962 bias-pull-up; 963 drive-strength = <2>; 964 }; 965 966 sdc1_rclk_on: rclk-on { 967 pins = "sdc1_rclk"; 968 bias-pull-down; 969 }; 970 971 sdc1_rclk_off: rclk-off { 972 pins = "sdc1_rclk"; 973 bias-pull-down; 974 }; 975 976 sdc2_clk_on: sdc2-clk-on { 977 pins = "sdc2_clk"; 978 bias-disable; 979 drive-strength = <10>; 980 }; 981 982 sdc2_clk_off: sdc2-clk-off { 983 pins = "sdc2_clk"; 984 bias-disable; 985 drive-strength = <2>; 986 }; 987 988 sdc2_cmd_on: sdc2-cmd-on { 989 pins = "sdc2_cmd"; 990 bias-pull-up; 991 drive-strength = <10>; 992 }; 993 994 sdc2_cmd_off: sdc2-cmd-off { 995 pins = "sdc2_cmd"; 996 bias-pull-up; 997 drive-strength = <2>; 998 }; 999 1000 sdc2_data_on: sdc2-data-on { 1001 pins = "sdc2_data"; 1002 bias-pull-up; 1003 drive-strength = <10>; 1004 }; 1005 1006 sdc2_data_off: sdc2-data-off { 1007 pins = "sdc2_data"; 1008 bias-pull-up; 1009 drive-strength = <2>; 1010 }; 1011 }; 1012 }; 1013 1014 timer: timer { 1015 compatible = "arm,armv8-timer"; 1016 interrupts = <GIC_PPI 2 0xff08>, 1017 <GIC_PPI 3 0xff08>, 1018 <GIC_PPI 4 0xff08>, 1019 <GIC_PPI 1 0xff08>; 1020 }; 1021 1022 vph_pwr: vph-pwr-regulator { 1023 compatible = "regulator-fixed"; 1024 regulator-name = "vph_pwr"; 1025 1026 regulator-min-microvolt = <3600000>; 1027 regulator-max-microvolt = <3600000>; 1028 1029 regulator-always-on; 1030 }; 1031}; 1032 1033