1// SPDX-License-Identifier: BSD-3-Clause 2/* 3 * Copyright (c) 2023, Linaro Limited 4 */ 5 6/dts-v1/; 7 8#include <dt-bindings/gpio/gpio.h> 9#include <dt-bindings/regulator/qcom,rpmh-regulator.h> 10 11#include "sa8775p.dtsi" 12#include "sa8775p-pmics.dtsi" 13 14/ { 15 model = "Qualcomm SA8775P Ride"; 16 compatible = "qcom,sa8775p-ride", "qcom,sa8775p"; 17 18 aliases { 19 serial0 = &uart10; 20 serial1 = &uart12; 21 serial2 = &uart17; 22 i2c11 = &i2c11; 23 i2c18 = &i2c18; 24 spi16 = &spi16; 25 ufshc1 = &ufs_mem_hc; 26 }; 27 28 chosen { 29 stdout-path = "serial0:115200n8"; 30 }; 31}; 32 33&apps_rsc { 34 regulators-0 { 35 compatible = "qcom,pmm8654au-rpmh-regulators"; 36 qcom,pmic-id = "a"; 37 38 vreg_s4a: smps4 { 39 regulator-name = "vreg_s4a"; 40 regulator-min-microvolt = <1800000>; 41 regulator-max-microvolt = <1816000>; 42 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 43 }; 44 45 vreg_s5a: smps5 { 46 regulator-name = "vreg_s5a"; 47 regulator-min-microvolt = <1850000>; 48 regulator-max-microvolt = <1996000>; 49 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 50 }; 51 52 vreg_s9a: smps9 { 53 regulator-name = "vreg_s9a"; 54 regulator-min-microvolt = <535000>; 55 regulator-max-microvolt = <1120000>; 56 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 57 }; 58 59 vreg_l4a: ldo4 { 60 regulator-name = "vreg_l4a"; 61 regulator-min-microvolt = <788000>; 62 regulator-max-microvolt = <1050000>; 63 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 64 regulator-allow-set-load; 65 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 66 RPMH_REGULATOR_MODE_HPM>; 67 }; 68 69 vreg_l5a: ldo5 { 70 regulator-name = "vreg_l5a"; 71 regulator-min-microvolt = <870000>; 72 regulator-max-microvolt = <950000>; 73 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 74 regulator-allow-set-load; 75 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 76 RPMH_REGULATOR_MODE_HPM>; 77 }; 78 79 vreg_l6a: ldo6 { 80 regulator-name = "vreg_l6a"; 81 regulator-min-microvolt = <870000>; 82 regulator-max-microvolt = <970000>; 83 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 84 regulator-allow-set-load; 85 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 86 RPMH_REGULATOR_MODE_HPM>; 87 }; 88 89 vreg_l7a: ldo7 { 90 regulator-name = "vreg_l7a"; 91 regulator-min-microvolt = <720000>; 92 regulator-max-microvolt = <950000>; 93 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 94 regulator-allow-set-load; 95 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 96 RPMH_REGULATOR_MODE_HPM>; 97 }; 98 99 vreg_l8a: ldo8 { 100 regulator-name = "vreg_l8a"; 101 regulator-min-microvolt = <2504000>; 102 regulator-max-microvolt = <3300000>; 103 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 104 regulator-allow-set-load; 105 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 106 RPMH_REGULATOR_MODE_HPM>; 107 }; 108 109 vreg_l9a: ldo9 { 110 regulator-name = "vreg_l9a"; 111 regulator-min-microvolt = <2970000>; 112 regulator-max-microvolt = <3544000>; 113 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 114 regulator-allow-set-load; 115 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 116 RPMH_REGULATOR_MODE_HPM>; 117 }; 118 }; 119 120 regulators-1 { 121 compatible = "qcom,pmm8654au-rpmh-regulators"; 122 qcom,pmic-id = "c"; 123 124 vreg_l1c: ldo1 { 125 regulator-name = "vreg_l1c"; 126 regulator-min-microvolt = <1140000>; 127 regulator-max-microvolt = <1260000>; 128 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 129 regulator-allow-set-load; 130 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 131 RPMH_REGULATOR_MODE_HPM>; 132 }; 133 134 vreg_l2c: ldo2 { 135 regulator-name = "vreg_l2c"; 136 regulator-min-microvolt = <900000>; 137 regulator-max-microvolt = <1100000>; 138 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 139 regulator-allow-set-load; 140 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 141 RPMH_REGULATOR_MODE_HPM>; 142 }; 143 144 vreg_l3c: ldo3 { 145 regulator-name = "vreg_l3c"; 146 regulator-min-microvolt = <1100000>; 147 regulator-max-microvolt = <1300000>; 148 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 149 regulator-allow-set-load; 150 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 151 RPMH_REGULATOR_MODE_HPM>; 152 }; 153 154 vreg_l4c: ldo4 { 155 regulator-name = "vreg_l4c"; 156 regulator-min-microvolt = <1100000>; 157 regulator-max-microvolt = <1300000>; 158 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 159 /* 160 * FIXME: This should have regulator-allow-set-load but 161 * we're getting an over-current fault from the PMIC 162 * when switching to LPM. 163 */ 164 }; 165 166 vreg_l5c: ldo5 { 167 regulator-name = "vreg_l5c"; 168 regulator-min-microvolt = <1100000>; 169 regulator-max-microvolt = <1300000>; 170 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 171 regulator-allow-set-load; 172 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 173 RPMH_REGULATOR_MODE_HPM>; 174 }; 175 176 vreg_l6c: ldo6 { 177 regulator-name = "vreg_l6c"; 178 regulator-min-microvolt = <1620000>; 179 regulator-max-microvolt = <1980000>; 180 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 181 regulator-allow-set-load; 182 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 183 RPMH_REGULATOR_MODE_HPM>; 184 }; 185 186 vreg_l7c: ldo7 { 187 regulator-name = "vreg_l7c"; 188 regulator-min-microvolt = <1620000>; 189 regulator-max-microvolt = <2000000>; 190 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 191 regulator-allow-set-load; 192 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 193 RPMH_REGULATOR_MODE_HPM>; 194 }; 195 196 vreg_l8c: ldo8 { 197 regulator-name = "vreg_l8c"; 198 regulator-min-microvolt = <2400000>; 199 regulator-max-microvolt = <3300000>; 200 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 201 regulator-allow-set-load; 202 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 203 RPMH_REGULATOR_MODE_HPM>; 204 }; 205 206 vreg_l9c: ldo9 { 207 regulator-name = "vreg_l9c"; 208 regulator-min-microvolt = <1650000>; 209 regulator-max-microvolt = <2700000>; 210 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 211 regulator-allow-set-load; 212 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 213 RPMH_REGULATOR_MODE_HPM>; 214 }; 215 }; 216 217 regulators-2 { 218 compatible = "qcom,pmm8654au-rpmh-regulators"; 219 qcom,pmic-id = "e"; 220 221 vreg_s4e: smps4 { 222 regulator-name = "vreg_s4e"; 223 regulator-min-microvolt = <970000>; 224 regulator-max-microvolt = <1520000>; 225 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 226 }; 227 228 vreg_s7e: smps7 { 229 regulator-name = "vreg_s7e"; 230 regulator-min-microvolt = <1010000>; 231 regulator-max-microvolt = <1170000>; 232 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 233 }; 234 235 vreg_s9e: smps9 { 236 regulator-name = "vreg_s9e"; 237 regulator-min-microvolt = <300000>; 238 regulator-max-microvolt = <570000>; 239 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 240 }; 241 242 vreg_l6e: ldo6 { 243 regulator-name = "vreg_l6e"; 244 regulator-min-microvolt = <1280000>; 245 regulator-max-microvolt = <1450000>; 246 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 247 regulator-allow-set-load; 248 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 249 RPMH_REGULATOR_MODE_HPM>; 250 }; 251 252 vreg_l8e: ldo8 { 253 regulator-name = "vreg_l8e"; 254 regulator-min-microvolt = <1800000>; 255 regulator-max-microvolt = <1950000>; 256 regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>; 257 regulator-allow-set-load; 258 regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM 259 RPMH_REGULATOR_MODE_HPM>; 260 }; 261 }; 262}; 263 264&i2c11 { 265 clock-frequency = <400000>; 266 pinctrl-0 = <&qup_i2c11_default>; 267 pinctrl-names = "default"; 268 status = "okay"; 269}; 270 271&i2c18 { 272 clock-frequency = <400000>; 273 pinctrl-0 = <&qup_i2c18_default>; 274 pinctrl-names = "default"; 275 status = "okay"; 276}; 277 278&pmm8654au_0_gpios { 279 gpio-line-names = "DS_EN", 280 "POFF_COMPLETE", 281 "UFS0_VER_ID", 282 "FAST_POFF", 283 "DBU1_PON_DONE", 284 "AOSS_SLEEP", 285 "CAM_DES0_EN", 286 "CAM_DES1_EN", 287 "CAM_DES2_EN", 288 "CAM_DES3_EN", 289 "UEFI", 290 "ANALOG_PON_OPT"; 291}; 292 293&pmm8654au_1_gpios { 294 gpio-line-names = "PMIC_C_ID0", 295 "PMIC_C_ID1", 296 "UFS1_VER_ID", 297 "IPA_PWR", 298 "", 299 "WLAN_DBU4_EN", 300 "WLAN_EN", 301 "BT_EN", 302 "USB2_PWR_EN", 303 "USB2_FAULT"; 304 305 usb2_en_state: usb2-en-state { 306 pins = "gpio9"; 307 function = "normal"; 308 output-high; 309 power-source = <0>; 310 }; 311}; 312 313&pmm8654au_2_gpios { 314 gpio-line-names = "PMIC_E_ID0", 315 "PMIC_E_ID1", 316 "USB0_PWR_EN", 317 "USB0_FAULT", 318 "SENSOR_IRQ_1", 319 "SENSOR_IRQ_2", 320 "SENSOR_RST", 321 "SGMIIO0_RST", 322 "SGMIIO1_RST", 323 "USB1_PWR_ENABLE", 324 "USB1_FAULT", 325 "VMON_SPX8"; 326 327 usb0_en_state: usb0-en-state { 328 pins = "gpio3"; 329 function = "normal"; 330 output-high; 331 power-source = <0>; 332 }; 333 334 usb1_en_state: usb1-en-state { 335 pins = "gpio10"; 336 function = "normal"; 337 output-high; 338 power-source = <0>; 339 }; 340}; 341 342&pmm8654au_3_gpios { 343 gpio-line-names = "PMIC_G_ID0", 344 "PMIC_G_ID1", 345 "GNSS_RST", 346 "GNSS_EN", 347 "GNSS_BOOT_MODE"; 348}; 349 350&qupv3_id_1 { 351 status = "okay"; 352}; 353 354&qupv3_id_2 { 355 status = "okay"; 356}; 357 358&sleep_clk { 359 clock-frequency = <32764>; 360}; 361 362&spi16 { 363 pinctrl-0 = <&qup_spi16_default>; 364 pinctrl-names = "default"; 365 status = "okay"; 366}; 367 368&tlmm { 369 qup_uart10_default: qup-uart10-state { 370 pins = "gpio46", "gpio47"; 371 function = "qup1_se3"; 372 }; 373 374 qup_spi16_default: qup-spi16-state { 375 pins = "gpio86", "gpio87", "gpio88", "gpio89"; 376 function = "qup2_se2"; 377 drive-strength = <6>; 378 bias-disable; 379 }; 380 381 qup_i2c11_default: qup-i2c11-state { 382 pins = "gpio48", "gpio49"; 383 function = "qup1_se4"; 384 drive-strength = <2>; 385 bias-pull-up; 386 }; 387 388 qup_i2c18_default: qup-i2c18-state { 389 pins = "gpio95", "gpio96"; 390 function = "qup2_se4"; 391 drive-strength = <2>; 392 bias-pull-up; 393 }; 394 395 qup_uart12_default: qup-uart12-state { 396 qup_uart12_cts: qup-uart12-cts-pins { 397 pins = "gpio52"; 398 function = "qup1_se5"; 399 bias-disable; 400 }; 401 402 qup_uart12_rts: qup-uart12-rts-pins { 403 pins = "gpio53"; 404 function = "qup1_se5"; 405 bias-pull-down; 406 }; 407 408 qup_uart12_tx: qup-uart12-tx-pins { 409 pins = "gpio54"; 410 function = "qup1_se5"; 411 bias-pull-up; 412 }; 413 414 qup_uart12_rx: qup-uart12-rx-pins { 415 pins = "gpio55"; 416 function = "qup1_se5"; 417 bias-pull-down; 418 }; 419 }; 420 421 qup_uart17_default: qup-uart17-state { 422 qup_uart17_cts: qup-uart17-cts-pins { 423 pins = "gpio91"; 424 function = "qup2_se3"; 425 bias-disable; 426 }; 427 428 qup_uart17_rts: qup0-uart17-rts-pins { 429 pins = "gpio92"; 430 function = "qup2_se3"; 431 bias-pull-down; 432 }; 433 434 qup_uart17_tx: qup0-uart17-tx-pins { 435 pins = "gpio93"; 436 function = "qup2_se3"; 437 bias-pull-up; 438 }; 439 440 qup_uart17_rx: qup0-uart17-rx-pins { 441 pins = "gpio94"; 442 function = "qup2_se3"; 443 bias-pull-down; 444 }; 445 }; 446}; 447 448&uart10 { 449 compatible = "qcom,geni-debug-uart"; 450 pinctrl-0 = <&qup_uart10_default>; 451 pinctrl-names = "default"; 452 status = "okay"; 453}; 454 455&uart12 { 456 pinctrl-0 = <&qup_uart12_default>; 457 pinctrl-names = "default"; 458 status = "okay"; 459}; 460 461&uart17 { 462 pinctrl-0 = <&qup_uart17_default>; 463 pinctrl-names = "default"; 464 status = "okay"; 465}; 466 467&ufs_mem_hc { 468 reset-gpios = <&tlmm 149 GPIO_ACTIVE_LOW>; 469 vcc-supply = <&vreg_l8a>; 470 vcc-max-microamp = <1100000>; 471 vccq-supply = <&vreg_l4c>; 472 vccq-max-microamp = <1200000>; 473 474 status = "okay"; 475}; 476 477&ufs_mem_phy { 478 vdda-phy-supply = <&vreg_l4a>; 479 vdda-pll-supply = <&vreg_l1c>; 480 481 status = "okay"; 482}; 483 484&usb_0 { 485 pinctrl-names = "default"; 486 pinctrl-0 = <&usb0_en_state>; 487 488 status = "okay"; 489}; 490 491&usb_0_dwc3 { 492 dr_mode = "peripheral"; 493}; 494 495&usb_0_hsphy { 496 vdda-pll-supply = <&vreg_l7a>; 497 vdda18-supply = <&vreg_l6c>; 498 vdda33-supply = <&vreg_l9a>; 499 500 status = "okay"; 501}; 502 503&usb_0_qmpphy { 504 vdda-phy-supply = <&vreg_l1c>; 505 vdda-pll-supply = <&vreg_l7a>; 506 507 status = "okay"; 508}; 509 510&usb_1 { 511 pinctrl-names = "default"; 512 pinctrl-0 = <&usb1_en_state>; 513 514 status = "okay"; 515}; 516 517&usb_1_dwc3 { 518 dr_mode = "host"; 519}; 520 521&usb_1_hsphy { 522 vdda-pll-supply = <&vreg_l7a>; 523 vdda18-supply = <&vreg_l6c>; 524 vdda33-supply = <&vreg_l9a>; 525 526 status = "okay"; 527}; 528 529&usb_1_qmpphy { 530 vdda-phy-supply = <&vreg_l1c>; 531 vdda-pll-supply = <&vreg_l7a>; 532 533 status = "okay"; 534}; 535 536&usb_2 { 537 pinctrl-names = "default"; 538 pinctrl-0 = <&usb2_en_state>; 539 540 status = "okay"; 541}; 542 543&usb_2_dwc3 { 544 dr_mode = "host"; 545}; 546 547&usb_2_hsphy { 548 vdda-pll-supply = <&vreg_l7a>; 549 vdda18-supply = <&vreg_l6c>; 550 vdda33-supply = <&vreg_l9a>; 551 552 status = "okay"; 553}; 554 555&xo_board_clk { 556 clock-frequency = <38400000>; 557}; 558