// SPDX-License-Identifier: BSD-3-Clause /* * Copyright (c) 2023, Luca Weiss * Copyright (c) 2024, Caleb Connolly */ /dts-v1/; #define PM7250B_SID 8 #define PM7250B_SID1 9 #include #include #include #include #include #include "sc7280.dtsi" #include "pm7250b.dtsi" #include "pm7325.dtsi" #include "pm8350c.dtsi" /* PM7350C */ #include "pmk8350.dtsi" /* PMK7325 */ /delete-node/ &rmtfs_mem; / { model = "SHIFT SHIFTphone 8"; compatible = "shift,otter", "qcom,qcm6490"; chassis-type = "handset"; aliases { serial0 = &uart5; serial1 = &uart7; }; chosen { #address-cells = <2>; #size-cells = <2>; ranges; stdout-path = "serial0:115200n8"; framebuffer0: framebuffer@a000000 { compatible = "simple-framebuffer"; reg = <0x0 0xe1000000 0x0 (2400 * 1080 * 4)>; width = <1080>; height = <2400>; stride = <(1080 * 4)>; format = "a8r8g8b8"; clocks = <&gcc GCC_DISP_HF_AXI_CLK>; }; }; gpio-keys { compatible = "gpio-keys"; pinctrl-0 = <&volume_down_default>; pinctrl-names = "default"; key-volume-up { label = "Volume up"; gpios = <&pm7325_gpios 6 GPIO_ACTIVE_LOW>; linux,code = ; debounce-interval = <15>; }; }; pmic-glink { compatible = "qcom,qcm6490-pmic-glink", "qcom,pmic-glink"; #address-cells = <1>; #size-cells = <0>; connector@0 { compatible = "usb-c-connector"; reg = <0>; power-role = "dual"; data-role = "dual"; ports { #address-cells = <1>; #size-cells = <0>; port@0 { reg = <0>; pmic_glink_hs_in: endpoint { remote-endpoint = <&usb_1_dwc3_hs>; }; }; port@1 { reg = <1>; pmic_glink_ss_in: endpoint { remote-endpoint = <&usb_dp_qmpphy_out>; }; }; port@2 { reg = <2>; pmic_glink_sbu: endpoint { remote-endpoint = <&fsa4480_sbu_mux>; }; }; }; }; }; reserved-memory { cont_splash_mem: cont-splash@e1000000 { reg = <0x0 0xe1000000 0x0 0x2300000>; no-map; }; cdsp_mem: cdsp@88f00000 { reg = <0x0 0x88f00000 0x0 0x1e00000>; no-map; }; rmtfs_mem: rmtfs@f8500000 { compatible = "qcom,rmtfs-mem"; reg = <0x0 0xf8500000 0x0 0x600000>; no-map; qcom,client-id = <1>; qcom,vmid = , ; }; }; thermal-zones { camera-thermal { polling-delay-passive = <0>; polling-delay = <0>; thermal-sensors = <&pmk8350_adc_tm 2>; trips { active-config0 { temperature = <125000>; hysteresis = <1000>; type = "passive"; }; }; }; chg-skin-thermal { polling-delay-passive = <0>; polling-delay = <0>; thermal-sensors = <&pm7250b_adc_tm 0>; trips { active-config0 { temperature = <125000>; hysteresis = <1000>; type = "passive"; }; }; }; conn-thermal { polling-delay-passive = <0>; polling-delay = <0>; thermal-sensors = <&pm7250b_adc_tm 1>; trips { active-config0 { temperature = <125000>; hysteresis = <1000>; type = "passive"; }; }; }; quiet-thermal { polling-delay-passive = <0>; polling-delay = <0>; thermal-sensors = <&pmk8350_adc_tm 1>; trips { active-config0 { temperature = <125000>; hysteresis = <1000>; type = "passive"; }; }; }; rear-cam-thermal { polling-delay-passive = <0>; polling-delay = <0>; thermal-sensors = <&pmk8350_adc_tm 4>; trips { active-config0 { temperature = <125000>; hysteresis = <1000>; type = "passive"; }; }; }; sdm-skin-thermal { polling-delay-passive = <0>; polling-delay = <0>; thermal-sensors = <&pmk8350_adc_tm 3>; trips { active-config0 { temperature = <125000>; hysteresis = <1000>; type = "passive"; }; }; }; xo-thermal { polling-delay-passive = <0>; polling-delay = <0>; thermal-sensors = <&pmk8350_adc_tm 0>; trips { active-config0 { temperature = <125000>; hysteresis = <1000>; type = "passive"; }; }; }; }; }; &apps_rsc { regulators-0 { compatible = "qcom,pm7325-rpmh-regulators"; qcom,pmic-id = "b"; vreg_s1b: smps1 { regulator-name = "vreg_s1b"; regulator-min-microvolt = <1840000>; regulator-max-microvolt = <2040000>; }; vreg_s7b: smps7 { regulator-name = "vreg_s7b"; regulator-min-microvolt = <535000>; regulator-max-microvolt = <1120000>; }; vreg_s8b: smps8 { regulator-name = "vreg_s8b"; regulator-min-microvolt = <1200000>; regulator-max-microvolt = <1500000>; regulator-initial-mode = ; }; vreg_l1b: ldo1 { regulator-name = "vreg_l1b"; regulator-min-microvolt = <825000>; regulator-max-microvolt = <925000>; regulator-initial-mode = ; }; vreg_l2b: ldo2 { regulator-name = "vreg_l2b"; regulator-min-microvolt = <2700000>; regulator-max-microvolt = <3544000>; regulator-initial-mode = ; }; vreg_l3b: ldo3 { regulator-name = "vreg_l3b"; regulator-min-microvolt = <312000>; regulator-max-microvolt = <910000>; regulator-initial-mode = ; }; vreg_l6b: ldo6 { regulator-name = "vreg_l6b"; regulator-min-microvolt = <1140000>; regulator-max-microvolt = <1260000>; regulator-initial-mode = ; }; vreg_l7b: ldo7 { regulator-name = "vreg_l7b"; /* Constrained for UFS VCC, at least until UFS driver scales voltage */ regulator-min-microvolt = <2952000>; regulator-max-microvolt = <2952000>; regulator-initial-mode = ; }; vreg_l8b: ldo8 { regulator-name = "vreg_l8b"; regulator-min-microvolt = <870000>; regulator-max-microvolt = <970000>; regulator-initial-mode = ; }; vreg_l9b: ldo9 { regulator-name = "vreg_l9b"; regulator-min-microvolt = <1200000>; regulator-max-microvolt = <1304000>; regulator-initial-mode = ; }; vreg_l11b: ldo11 { regulator-name = "vreg_l11b"; regulator-min-microvolt = <1504000>; regulator-max-microvolt = <2000000>; regulator-initial-mode = ; }; vreg_l12b: ldo12 { regulator-name = "vreg_l12b"; regulator-min-microvolt = <751000>; regulator-max-microvolt = <824000>; regulator-initial-mode = ; }; vreg_l13b: ldo13 { regulator-name = "vreg_l13b"; regulator-min-microvolt = <530000>; regulator-max-microvolt = <824000>; regulator-initial-mode = ; }; vreg_l14b: ldo14 { regulator-name = "vreg_l14b"; regulator-min-microvolt = <1080000>; regulator-max-microvolt = <1304000>; regulator-initial-mode = ; }; vreg_l15b: ldo15 { regulator-name = "vreg_l15b"; regulator-min-microvolt = <765000>; regulator-max-microvolt = <1020000>; regulator-initial-mode = ; }; vreg_l16b: ldo16 { regulator-name = "vreg_l16b"; regulator-min-microvolt = <1100000>; regulator-max-microvolt = <1300000>; regulator-initial-mode = ; }; vreg_l17b: ldo17 { regulator-name = "vreg_l17b"; regulator-min-microvolt = <1700000>; regulator-max-microvolt = <1900000>; regulator-initial-mode = ; }; vreg_l18b: ldo18 { regulator-name = "vreg_l18b"; regulator-min-microvolt = <1800000>; regulator-max-microvolt = <2000000>; regulator-initial-mode = ; }; vreg_l19b: ldo19 { regulator-name = "vreg_l19b"; regulator-min-microvolt = <1800000>; regulator-max-microvolt = <2000000>; regulator-initial-mode = ; }; }; regulators-1 { compatible = "qcom,pm8350c-rpmh-regulators"; qcom,pmic-id = "c"; vreg_s1c: smps1 { regulator-name = "vreg_s1c"; regulator-min-microvolt = <2190000>; regulator-max-microvolt = <2210000>; regulator-initial-mode = ; }; vreg_s9c: smps9 { regulator-name = "vreg_s9c"; regulator-min-microvolt = <1010000>; regulator-max-microvolt = <1170000>; regulator-initial-mode = ; }; vreg_l1c: ldo1 { regulator-name = "vreg_l1c"; regulator-min-microvolt = <1800000>; regulator-max-microvolt = <1980000>; regulator-initial-mode = ; }; vreg_l2c: ldo2 { regulator-name = "vreg_l2c"; regulator-min-microvolt = <1800000>; regulator-max-microvolt = <1950000>; regulator-initial-mode = ; }; vreg_l3c: ldo3 { regulator-name = "vreg_l3c"; regulator-min-microvolt = <3000000>; regulator-max-microvolt = <3400000>; regulator-initial-mode = ; }; vreg_l4c: ldo4 { regulator-name = "vreg_l4c"; regulator-min-microvolt = <1620000>; regulator-max-microvolt = <3300000>; regulator-initial-mode = ; }; vreg_l5c: ldo5 { regulator-name = "vreg_l5c"; regulator-min-microvolt = <1620000>; regulator-max-microvolt = <3300000>; regulator-initial-mode = ; }; vreg_l6c: ldo6 { regulator-name = "vreg_l6c"; regulator-min-microvolt = <1650000>; regulator-max-microvolt = <3544000>; regulator-initial-mode = ; }; vreg_l7c: ldo7 { regulator-name = "vreg_l7c"; regulator-min-microvolt = <3000000>; regulator-max-microvolt = <3544000>; regulator-initial-mode = ; }; vreg_l8c: ldo8 { regulator-name = "vreg_l8c"; regulator-min-microvolt = <1620000>; regulator-max-microvolt = <2000000>; regulator-initial-mode = ; }; vreg_l9c: ldo9 { regulator-name = "vreg_l9c"; regulator-min-microvolt = <2700000>; regulator-max-microvolt = <3544000>; regulator-initial-mode = ; }; vreg_l10c: ldo10 { regulator-name = "vreg_l10c"; regulator-min-microvolt = <720000>; regulator-max-microvolt = <1050000>; regulator-initial-mode = ; }; vreg_l11c: ldo11 { regulator-name = "vreg_l11c"; regulator-min-microvolt = <2800000>; regulator-max-microvolt = <3544000>; regulator-initial-mode = ; }; vreg_l12c: ldo12 { regulator-name = "vreg_l12c"; regulator-min-microvolt = <1650000>; regulator-max-microvolt = <2000000>; regulator-initial-mode = ; }; vreg_l13c: ldo13 { regulator-name = "vreg_l13c"; regulator-min-microvolt = <2700000>; regulator-max-microvolt = <3544000>; regulator-initial-mode = ; }; vreg_bob: bob { regulator-name = "vreg_bob"; regulator-min-microvolt = <3008000>; regulator-max-microvolt = <3960000>; regulator-initial-mode = ; }; }; }; &gcc { protected-clocks = , , , , , , , , , , , , , , ; }; &gpi_dma0 { status = "okay"; }; &gpi_dma1 { status = "okay"; }; &gpu { status = "okay"; }; &gpu_zap_shader { firmware-name = "qcom/qcm6490/SHIFT/otter/a660_zap.mbn"; }; &i2c1 { status = "okay"; /* PM8008 PMIC @ 8 and 9 */ /* rtc6226 FM receiver @ 64 */ typec-mux@42 { compatible = "fcs,fsa4480"; reg = <0x42>; vcc-supply = <&vreg_bob>; mode-switch; orientation-switch; port { fsa4480_sbu_mux: endpoint { remote-endpoint = <&pmic_glink_sbu>; }; }; }; }; &i2c4 { status = "okay"; /* tas2563 audio codec @ 4d */ }; &i2c9 { status = "okay"; /* TMS(?) NFC @ 28 */ /* Ti drv2624 haptics @ 5a */ }; &i2c13 { status = "okay"; /* focaltech FT3658U @ 38 */ }; &ipa { qcom,gsi-loader = "self"; memory-region = <&ipa_fw_mem>; firmware-name = "qcom/qcm6490/SHIFT/otter/ipa_fws.mbn"; status = "okay"; }; &pm7250b_adc { channel@4d { reg = ; qcom,ratiometric; qcom,hw-settle-time = <200>; qcom,pre-scaling = <1 1>; label = "charger_skin_therm"; }; channel@4f { reg = ; qcom,ratiometric; qcom,hw-settle-time = <200>; qcom,pre-scaling = <1 1>; label = "conn_therm"; }; }; &pm7250b_adc_tm { status = "okay"; charger-skin-therm@0 { reg = <0>; io-channels = <&pm7250b_adc ADC5_AMUX_THM1_100K_PU>; qcom,ratiometric; qcom,hw-settle-time-us = <200>; }; conn-therm@1 { reg = <1>; io-channels = <&pm7250b_adc ADC5_AMUX_THM3_100K_PU>; qcom,ratiometric; qcom,hw-settle-time-us = <200>; }; }; &pm7325_gpios { volume_down_default: volume-down-default-state { pins = "gpio6"; function = PMIC_GPIO_FUNC_NORMAL; power-source = <1>; bias-pull-up; input-enable; }; }; &pmk8350_adc_tm { status = "okay"; xo-therm@0 { reg = <0>; io-channels = <&pmk8350_vadc PMK8350_ADC7_AMUX_THM1_100K_PU>; qcom,ratiometric; qcom,hw-settle-time-us = <200>; }; quiet-therm@1 { reg = <1>; io-channels = <&pmk8350_vadc PM7325_ADC7_AMUX_THM1_100K_PU>; qcom,ratiometric; qcom,hw-settle-time-us = <200>; }; cam-flash-therm@2 { reg = <2>; io-channels = <&pmk8350_vadc PM7325_ADC7_AMUX_THM2_100K_PU>; qcom,ratiometric; qcom,hw-settle-time-us = <200>; }; sdm-skin-therm@3 { reg = <3>; io-channels = <&pmk8350_vadc PM7325_ADC7_AMUX_THM3_100K_PU>; qcom,ratiometric; qcom,hw-settle-time-us = <200>; }; wide-rfc-therm@4 { reg = <4>; io-channels = <&pmk8350_vadc PM7325_ADC7_AMUX_THM4_100K_PU>; qcom,ratiometric; qcom,hw-settle-time-us = <200>; }; }; &pmk8350_rtc { status = "okay"; }; &pmk8350_vadc { status = "okay"; channel@44 { reg = ; qcom,ratiometric; qcom,hw-settle-time = <200>; qcom,pre-scaling = <1 1>; label = "pmk8350_xo_therm"; }; channel@144 { reg = ; qcom,ratiometric; qcom,hw-settle-time = <200>; qcom,pre-scaling = <1 1>; label = "pm7325_quiet_therm"; }; channel@145 { reg = ; qcom,ratiometric; qcom,hw-settle-time = <200>; qcom,pre-scaling = <1 1>; label = "pm7325_cam_flash_therm"; }; channel@146 { reg = ; qcom,ratiometric; qcom,hw-settle-time = <200>; qcom,pre-scaling = <1 1>; label = "pm7325_sdm_skin_therm"; }; channel@147 { reg = ; qcom,ratiometric; qcom,hw-settle-time = <200>; qcom,pre-scaling = <1 1>; label = "pm7325_wide_rfc_therm"; }; }; &pon_pwrkey { status = "okay"; }; &pon_resin { linux,code = ; status = "okay"; }; &qup_spi13_cs { drive-strength = <6>; bias-disable; }; &qup_spi13_data_clk { drive-strength = <6>; bias-disable; }; &qup_uart5_rx { drive-strength = <2>; bias-disable; }; &qup_uart5_tx { drive-strength = <2>; bias-disable; }; &qupv3_id_0 { status = "okay"; }; &qupv3_id_1 { status = "okay"; }; &remoteproc_adsp { firmware-name = "qcom/qcm6490/SHIFT/otter/adsp.mbn"; status = "okay"; }; &remoteproc_cdsp { firmware-name = "qcom/qcm6490/SHIFT/otter/cdsp.mbn"; status = "okay"; }; &remoteproc_mpss { firmware-name = "qcom/qcm6490/SHIFT/otter/modem.mbn"; status = "okay"; }; &remoteproc_wpss { firmware-name = "qcom/qcm6490/SHIFT/otter/wpss.mbn"; status = "okay"; }; &sdc2_clk { drive-strength = <16>; bias-disable; }; &sdc2_cmd { drive-strength = <10>; bias-pull-up; }; &sdc2_data { drive-strength = <10>; bias-pull-up; }; &sdhc_2 { vmmc-supply = <&vreg_l9c>; vqmmc-supply = <&vreg_l6c>; pinctrl-0 = <&sdc2_clk>, <&sdc2_cmd>, <&sdc2_data>; pinctrl-1 = <&sdc2_clk_sleep>, <&sdc2_cmd_sleep>, <&sdc2_data_sleep>; status = "okay"; }; &tlmm { /* * 48-52: protected by XPU, not sure why. */ gpio-reserved-ranges = <48 4>; bluetooth_enable_default: bluetooth-enable-default-state { pins = "gpio85"; function = "gpio"; output-low; bias-disable; }; qup_uart7_sleep_cts: qup-uart7-sleep-cts-state { pins = "gpio28"; function = "gpio"; /* * Configure a bias-bus-hold on CTS to lower power * usage when Bluetooth is turned off. Bus hold will * maintain a low power state regardless of whether * the Bluetooth module drives the pin in either * direction or leaves the pin fully unpowered. */ bias-bus-hold; }; qup_uart7_sleep_rts: qup-uart7-sleep-rts-state { pins = "gpio29"; function = "gpio"; /* * Configure pull-down on RTS. As RTS is active low * signal, pull it low to indicate the BT SoC that it * can wakeup the system anytime from suspend state by * pulling RX low (by sending wakeup bytes). */ bias-pull-down; }; qup_uart7_sleep_tx: qup-uart7-sleep-tx-state { pins = "gpio30"; function = "gpio"; /* * Configure pull-up on TX when it isn't actively driven * to prevent BT SoC from receiving garbage during sleep. */ bias-pull-up; }; qup_uart7_sleep_rx: qup-uart7-sleep-rx-state { pins = "gpio31"; function = "gpio"; /* * Configure a pull-up on RX. This is needed to avoid * garbage data when the TX pin of the Bluetooth module * is floating which may cause spurious wakeups. */ bias-pull-up; }; sw_ctrl_default: sw-ctrl-default-state { pins = "gpio86"; function = "gpio"; bias-pull-down; }; }; &uart5 { compatible = "qcom,geni-debug-uart"; status = "okay"; }; &uart7 { /delete-property/interrupts; interrupts-extended = <&intc GIC_SPI 608 IRQ_TYPE_LEVEL_HIGH>, <&tlmm 31 IRQ_TYPE_EDGE_FALLING>; pinctrl-1 = <&qup_uart7_sleep_cts>, <&qup_uart7_sleep_rts>, <&qup_uart7_sleep_tx>, <&qup_uart7_sleep_rx>; pinctrl-names = "default", "sleep"; status = "okay"; bluetooth: bluetooth { compatible = "qcom,wcn6750-bt"; pinctrl-0 = <&bluetooth_enable_default>, <&sw_ctrl_default>; pinctrl-names = "default"; enable-gpios = <&tlmm 85 GPIO_ACTIVE_HIGH>; swctrl-gpios = <&tlmm 86 GPIO_ACTIVE_HIGH>; vddio-supply = <&vreg_l19b>; vddaon-supply = <&vreg_s7b>; vddbtcxmx-supply = <&vreg_s7b>; vddrfacmn-supply = <&vreg_s7b>; vddrfa0p8-supply = <&vreg_s7b>; vddrfa1p7-supply = <&vreg_s1b>; vddrfa1p2-supply = <&vreg_s8b>; vddrfa2p2-supply = <&vreg_s1c>; vddasd-supply = <&vreg_l11c>; max-speed = <3200000>; }; }; &ufs_mem_hc { reset-gpios = <&tlmm 175 GPIO_ACTIVE_LOW>; vcc-supply = <&vreg_l7b>; vcc-max-microamp = <800000>; /* * Technically l9b enables an eLDO (supplied by s1b) which then powers * VCCQ2 of the UFS. */ vccq-supply = <&vreg_l9b>; vccq-max-microamp = <900000>; status = "okay"; }; &ufs_mem_phy { vdda-phy-supply = <&vreg_l10c>; vdda-pll-supply = <&vreg_l6b>; status = "okay"; }; &usb_1 { status = "okay"; }; &usb_1_dwc3 { dr_mode = "otg"; usb-role-switch; }; &usb_1_dwc3_hs { remote-endpoint = <&pmic_glink_hs_in>; }; &usb_dp_qmpphy_out { remote-endpoint = <&pmic_glink_ss_in>; }; &usb_1_hsphy { vdda-pll-supply = <&vreg_l10c>; vdda18-supply = <&vreg_l1c>; vdda33-supply = <&vreg_l2b>; qcom,hs-crossover-voltage-microvolt = <28000>; qcom,hs-output-impedance-micro-ohms = <2600000>; qcom,hs-rise-fall-time-bp = <5430>; qcom,hs-disconnect-bp = <1743>; qcom,hs-amplitude-bp = <2430>; qcom,pre-emphasis-amplitude-bp = <20000>; qcom,pre-emphasis-duration-bp = <20000>; qcom,squelch-detector-bp = <(-2090)>; orientation-switch; status = "okay"; }; &usb_1_qmpphy { vdda-phy-supply = <&vreg_l6b>; vdda-pll-supply = <&vreg_l1b>; status = "okay"; }; &wifi { qcom,ath11k-calibration-variant = "SHIFTphone_8"; status = "okay"; };