// SPDX-License-Identifier: BSD-3-Clause /* * sc7280 IDP board device tree source (common between SKU1 and SKU2) * * Copyright (c) 2021, The Linux Foundation. All rights reserved. */ #include #include #include "sc7280.dtsi" #include "pm7325.dtsi" #include "pm8350c.dtsi" #include "pmk8350.dtsi" #include "sc7280-chrome-common.dtsi" #include "sc7280-herobrine-lte-sku.dtsi" / { aliases { bluetooth0 = &bluetooth; serial1 = &uart7; wifi0 = &wifi; }; max98360a: audio-codec-0 { compatible = "maxim,max98360a"; pinctrl-names = "default"; pinctrl-0 = <&_en>; sdmode-gpios = <&tlmm 63 GPIO_ACTIVE_HIGH>; #sound-dai-cells = <0>; }; wcd9385: audio-codec-1 { compatible = "qcom,wcd9385-codec"; pinctrl-names = "default", "sleep"; pinctrl-0 = <&wcd_reset_n>; pinctrl-1 = <&wcd_reset_n_sleep>; reset-gpios = <&tlmm 83 GPIO_ACTIVE_LOW>; qcom,rx-device = <&wcd_rx>; qcom,tx-device = <&wcd_tx>; vdd-rxtx-supply = <&vreg_l18b_1p8>; vdd-io-supply = <&vreg_l18b_1p8>; vdd-buck-supply = <&vreg_l17b_1p8>; vdd-mic-bias-supply = <&vreg_bob>; qcom,micbias1-microvolt = <1800000>; qcom,micbias2-microvolt = <1800000>; qcom,micbias3-microvolt = <1800000>; qcom,micbias4-microvolt = <1800000>; qcom,mbhc-buttons-vthreshold-microvolt = <75000 150000 237000 500000 500000 500000 500000 500000>; qcom,mbhc-headset-vthreshold-microvolt = <1700000>; qcom,mbhc-headphone-vthreshold-microvolt = <50000>; #sound-dai-cells = <1>; }; gpio-keys { compatible = "gpio-keys"; label = "gpio-keys"; pinctrl-names = "default"; pinctrl-0 = <&key_vol_up_default>; key-volume-up { label = "volume_up"; gpios = <&pm7325_gpios 6 GPIO_ACTIVE_LOW>; linux,input-type = <1>; linux,code = ; wakeup-source; debounce-interval = <15>; linux,can-disable; }; }; nvme_3v3_regulator: nvme-3v3-regulator { compatible = "regulator-fixed"; regulator-name = "VLDO_3V3"; regulator-min-microvolt = <3300000>; regulator-max-microvolt = <3300000>; enable-active-high; pinctrl-names = "default"; pinctrl-0 = <&nvme_pwren>; }; sound: sound { compatible = "google,sc7280-herobrine"; model = "sc7280-wcd938x-max98360a-1mic"; audio-routing = "IN1_HPHL", "HPHL_OUT", "IN2_HPHR", "HPHR_OUT", "AMIC1", "MIC BIAS1", "AMIC2", "MIC BIAS2", "VA DMIC0", "MIC BIAS3", "VA DMIC1", "MIC BIAS3", "VA DMIC2", "MIC BIAS1", "VA DMIC3", "MIC BIAS1", "TX SWR_ADC0", "ADC1_OUTPUT", "TX SWR_ADC1", "ADC2_OUTPUT", "TX SWR_ADC2", "ADC3_OUTPUT", "TX SWR_DMIC0", "DMIC1_OUTPUT", "TX SWR_DMIC1", "DMIC2_OUTPUT", "TX SWR_DMIC2", "DMIC3_OUTPUT", "TX SWR_DMIC3", "DMIC4_OUTPUT", "TX SWR_DMIC4", "DMIC5_OUTPUT", "TX SWR_DMIC5", "DMIC6_OUTPUT", "TX SWR_DMIC6", "DMIC7_OUTPUT", "TX SWR_DMIC7", "DMIC8_OUTPUT"; #address-cells = <1>; #size-cells = <0>; dai-link@0 { link-name = "MAX98360A"; reg = <0>; cpu { sound-dai = <&lpass_cpu MI2S_SECONDARY>; }; codec { sound-dai = <&max98360a>; }; }; dai-link@1 { link-name = "DisplayPort"; reg = <1>; cpu { sound-dai = <&lpass_cpu LPASS_DP_RX>; }; codec { sound-dai = <&mdss_dp>; }; }; dai-link@2 { link-name = "WCD9385 Playback"; reg = <2>; cpu { sound-dai = <&lpass_cpu LPASS_CDC_DMA_RX0>; }; codec { sound-dai = <&wcd9385 0>, <&swr0 0>, <&lpass_rx_macro 0>; }; }; dai-link@3 { link-name = "WCD9385 Capture"; reg = <3>; cpu { sound-dai = <&lpass_cpu LPASS_CDC_DMA_TX3>; }; codec { sound-dai = <&wcd9385 1>, <&swr1 0>, <&lpass_tx_macro 0>; }; }; dai-link@4 { link-name = "DMIC"; reg = <4>; cpu { sound-dai = <&lpass_cpu LPASS_CDC_DMA_VA_TX0>; }; codec { sound-dai = <&lpass_va_macro 0>; }; }; }; }; &apps_rsc { regulators-0 { compatible = "qcom,pm7325-rpmh-regulators"; qcom,pmic-id = "b"; vreg_s1b_1p8: smps1 { regulator-min-microvolt = <1856000>; regulator-max-microvolt = <2040000>; }; vreg_s7b_0p9: smps7 { regulator-min-microvolt = <535000>; regulator-max-microvolt = <1120000>; }; vreg_s8b_1p2: smps8 { regulator-min-microvolt = <1256000>; regulator-max-microvolt = <1500000>; }; vreg_l1b_0p8: ldo1 { regulator-min-microvolt = <825000>; regulator-max-microvolt = <925000>; }; vreg_l2b_3p0: ldo2 { regulator-min-microvolt = <2700000>; regulator-max-microvolt = <3544000>; }; vreg_l6b_1p2: ldo6 { regulator-min-microvolt = <1140000>; regulator-max-microvolt = <1260000>; }; vreg_l7b_2p9: ldo7 { regulator-min-microvolt = <2960000>; regulator-max-microvolt = <2960000>; }; vreg_l8b_0p9: ldo8 { regulator-min-microvolt = <870000>; regulator-max-microvolt = <970000>; }; vreg_l9b_1p2: ldo9 { regulator-min-microvolt = <1080000>; regulator-max-microvolt = <1304000>; }; vreg_l11b_1p7: ldo11 { regulator-min-microvolt = <1504000>; regulator-max-microvolt = <2000000>; }; vreg_l12b_0p8: ldo12 { regulator-min-microvolt = <751000>; regulator-max-microvolt = <824000>; }; vreg_l13b_0p8: ldo13 { regulator-min-microvolt = <530000>; regulator-max-microvolt = <824000>; }; vreg_l14b_1p2: ldo14 { regulator-min-microvolt = <1080000>; regulator-max-microvolt = <1304000>; }; vreg_l15b_0p8: ldo15 { regulator-min-microvolt = <765000>; regulator-max-microvolt = <1020000>; }; vreg_l16b_1p2: ldo16 { regulator-min-microvolt = <1100000>; regulator-max-microvolt = <1300000>; }; vreg_l17b_1p8: ldo17 { regulator-min-microvolt = <1700000>; regulator-max-microvolt = <1900000>; }; vreg_l18b_1p8: ldo18 { regulator-min-microvolt = <1800000>; regulator-max-microvolt = <2000000>; }; vreg_l19b_1p8: ldo19 { regulator-min-microvolt = <1800000>; regulator-max-microvolt = <1800000>; }; }; regulators-1 { compatible = "qcom,pm8350c-rpmh-regulators"; qcom,pmic-id = "c"; vreg_s1c_2p2: smps1 { regulator-min-microvolt = <2190000>; regulator-max-microvolt = <2210000>; }; vreg_s9c_1p0: smps9 { regulator-min-microvolt = <1010000>; regulator-max-microvolt = <1170000>; }; vreg_l1c_1p8: ldo1 { regulator-min-microvolt = <1800000>; regulator-max-microvolt = <1980000>; }; vreg_l2c_1p8: ldo2 { regulator-min-microvolt = <1620000>; regulator-max-microvolt = <1980000>; }; vreg_l3c_3p0: ldo3 { regulator-min-microvolt = <2800000>; regulator-max-microvolt = <3540000>; }; vreg_l4c_1p8: ldo4 { regulator-min-microvolt = <1620000>; regulator-max-microvolt = <3300000>; }; vreg_l5c_1p8: ldo5 { regulator-min-microvolt = <1620000>; regulator-max-microvolt = <3300000>; }; vreg_l6c_2p9: ldo6 { regulator-min-microvolt = <1800000>; regulator-max-microvolt = <2950000>; }; vreg_l7c_3p0: ldo7 { regulator-min-microvolt = <3000000>; regulator-max-microvolt = <3544000>; }; vreg_l8c_1p8: ldo8 { regulator-min-microvolt = <1620000>; regulator-max-microvolt = <2000000>; }; vreg_l9c_2p9: ldo9 { regulator-min-microvolt = <2960000>; regulator-max-microvolt = <2960000>; }; vreg_l10c_0p8: ldo10 { regulator-min-microvolt = <720000>; regulator-max-microvolt = <1050000>; }; vreg_l11c_2p8: ldo11 { regulator-min-microvolt = <2800000>; regulator-max-microvolt = <3544000>; }; vreg_l12c_1p8: ldo12 { regulator-min-microvolt = <1650000>; regulator-max-microvolt = <2000000>; }; vreg_l13c_3p0: ldo13 { regulator-min-microvolt = <2700000>; regulator-max-microvolt = <3544000>; }; vreg_bob: bob { regulator-min-microvolt = <3008000>; regulator-max-microvolt = <3960000>; }; }; }; &gpi_dma0 { status = "okay"; }; &gpi_dma1 { status = "okay"; }; &lpass_cpu { status = "okay"; pinctrl-names = "default"; pinctrl-0 = <&mi2s1_data0>, <&mi2s1_sclk>, <&mi2s1_ws>; dai-link@1 { reg = ; qcom,playback-sd-lines = <0>; }; dai-link@5 { reg = ; }; dai-link@6 { reg = ; }; dai-link@19 { reg = ; }; dai-link@25 { reg = ; }; }; &lpass_rx_macro { status = "okay"; }; &lpass_tx_macro { status = "okay"; }; &lpass_va_macro { status = "okay"; vdd-micb-supply = <&vreg_bob>; }; &pcie1 { status = "okay"; perst-gpios = <&tlmm 2 GPIO_ACTIVE_LOW>; vddpe-3v3-supply = <&nvme_3v3_regulator>; pinctrl-names = "default"; pinctrl-0 = <&pcie1_reset_n>, <&pcie1_wake_n>; }; &pcie1_phy { status = "okay"; vdda-phy-supply = <&vreg_l10c_0p8>; vdda-pll-supply = <&vreg_l6b_1p2>; }; &pmk8350_vadc { channel@3 { reg = ; label = "pmk8350_die_temp"; qcom,pre-scaling = <1 1>; }; }; &qfprom { vcc-supply = <&vreg_l1c_1p8>; }; &qupv3_id_0 { status = "okay"; }; &qupv3_id_1 { status = "okay"; }; &sdhc_1 { status = "okay"; non-removable; no-sd; no-sdio; vmmc-supply = <&vreg_l7b_2p9>; vqmmc-supply = <&vreg_l19b_1p8>; }; &sdhc_2 { status = "okay"; pinctrl-0 = <&sdc2_clk>, <&sdc2_cmd>, <&sdc2_data>, <&sd_cd>; pinctrl-1 = <&sdc2_clk_sleep>, <&sdc2_cmd_sleep>, <&sdc2_data_sleep>, <&sd_cd>; vmmc-supply = <&vreg_l9c_2p9>; vqmmc-supply = <&vreg_l6c_2p9>; cd-gpios = <&tlmm 91 GPIO_ACTIVE_LOW>; }; &swr0 { status = "okay"; wcd_rx: codec@0,4 { compatible = "sdw20217010d00"; reg = <0 4>; qcom,rx-port-mapping = <1 2 3 4 5>; }; }; &swr1 { status = "okay"; wcd_tx: codec@0,3 { compatible = "sdw20217010d00"; reg = <0 3>; qcom,tx-port-mapping = <1 2 3 4>; }; }; &uart5 { compatible = "qcom,geni-debug-uart"; status = "okay"; }; &ufs_mem_hc { reset-gpios = <&tlmm 175 GPIO_ACTIVE_LOW>; vcc-supply = <&vreg_l7b_2p9>; vcc-max-microamp = <800000>; vccq-supply = <&vreg_l9b_1p2>; vccq-max-microamp = <900000>; vccq2-supply = <&vreg_l9b_1p2>; vccq2-max-microamp = <900000>; status = "okay"; }; &ufs_mem_phy { vdda-phy-supply = <&vreg_l10c_0p8>; vdda-pll-supply = <&vreg_l6b_1p2>; status = "okay"; }; &usb_1 { status = "okay"; }; &usb_1_dwc3 { dr_mode = "host"; }; &usb_1_hsphy { status = "okay"; vdda-pll-supply = <&vreg_l10c_0p8>; vdda33-supply = <&vreg_l2b_3p0>; vdda18-supply = <&vreg_l1c_1p8>; qcom,hs-rise-fall-time-bp = <0>; qcom,squelch-detector-bp = <(-2090)>; qcom,hs-disconnect-bp = <1743>; qcom,hs-amplitude-bp = <1780>; qcom,hs-crossover-voltage-microvolt = <(-31000)>; qcom,hs-output-impedance-micro-ohms = <2600000>; }; &usb_1_qmpphy { status = "okay"; vdda-phy-supply = <&vreg_l6b_1p2>; vdda-pll-supply = <&vreg_l1b_0p8>; }; &uart7 { status = "okay"; /delete-property/interrupts; interrupts-extended = <&intc GIC_SPI 608 IRQ_TYPE_LEVEL_HIGH>, <&tlmm 31 IRQ_TYPE_EDGE_FALLING>; pinctrl-names = "default", "sleep"; pinctrl-1 = <&qup_uart7_sleep_cts>, <&qup_uart7_sleep_rts>, <&qup_uart7_sleep_tx>, <&qup_uart7_sleep_rx>; bluetooth: bluetooth { compatible = "qcom,wcn6750-bt"; pinctrl-names = "default"; pinctrl-0 = <&bt_en>, <&sw_ctrl>; enable-gpios = <&tlmm 85 GPIO_ACTIVE_HIGH>; swctrl-gpios = <&tlmm 86 GPIO_ACTIVE_HIGH>; vddaon-supply = <&vreg_s7b_0p9>; vddbtcxmx-supply = <&vreg_s7b_0p9>; vddrfacmn-supply = <&vreg_s7b_0p9>; vddrfa0p8-supply = <&vreg_s7b_0p9>; vddrfa1p7-supply = <&vreg_s1b_1p8>; vddrfa1p2-supply = <&vreg_s8b_1p2>; vddrfa2p2-supply = <&vreg_s1c_2p2>; vddasd-supply = <&vreg_l11c_2p8>; max-speed = <3200000>; }; }; /* PINCTRL - additions to nodes defined in sc7280.dtsi */ &dp_hot_plug_det { bias-disable; }; &lpass_dmic01_clk { drive-strength = <8>; bias-disable; }; &lpass_dmic01_data { bias-pull-down; }; &lpass_dmic23_clk { drive-strength = <8>; bias-disable; }; &lpass_dmic23_data { bias-pull-down; }; &lpass_rx_swr_clk { drive-strength = <2>; slew-rate = <1>; bias-disable; }; &lpass_rx_swr_data { drive-strength = <2>; slew-rate = <1>; bias-bus-hold; }; &lpass_tx_swr_clk { drive-strength = <2>; slew-rate = <1>; bias-disable; }; &lpass_tx_swr_data { drive-strength = <2>; slew-rate = <1>; bias-bus-hold; }; &mi2s1_data0 { drive-strength = <6>; bias-disable; }; &mi2s1_sclk { drive-strength = <6>; bias-disable; }; &mi2s1_ws { drive-strength = <6>; }; &pm7325_gpios { key_vol_up_default: key-vol-up-state { pins = "gpio6"; function = "normal"; input-enable; bias-pull-up; power-source = <0>; qcom,drive-strength = <3>; }; }; &pcie1_clkreq_n { bias-pull-up; drive-strength = <2>; }; &qspi_cs0 { bias-disable; /* External pullup */ }; &qspi_clk { bias-pull-down; /* No external pulls or external pulldown */ }; &qspi_data0 { bias-pull-down; /* No external pulls or external pulldown */ }; &qspi_data1 { bias-pull-down; /* No external pulls or external pulldown */ }; &qup_uart5_tx { drive-strength = <2>; bias-disable; }; &qup_uart5_rx { drive-strength = <2>; bias-pull-up; }; &qup_uart7_cts { /* * 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_rts { /* We'll drive RTS, so no pull */ drive-strength = <2>; bias-disable; }; &qup_uart7_tx { /* We'll drive TX, so no pull */ drive-strength = <2>; bias-disable; }; &qup_uart7_rx { /* * Configure a pull-up on RX. This is needed to avoid * garbage data when the TX pin of the Bluetooth module is * in tri-state (module powered off or not driving the * signal yet). */ bias-pull-up; }; &sdc1_clk { bias-disable; drive-strength = <16>; }; &sdc1_cmd { bias-pull-up; drive-strength = <10>; }; &sdc1_data { bias-pull-up; drive-strength = <10>; }; &sdc1_rclk { bias-pull-down; }; &sdc2_clk { bias-disable; drive-strength = <16>; }; &sdc2_cmd { bias-pull-up; drive-strength = <10>; }; &sdc2_data { bias-pull-up; drive-strength = <10>; }; &tlmm { amp_en: amp-en-state { pins = "gpio63"; function = "gpio"; bias-pull-down; drive-strength = <2>; }; bt_en: bt-en-state { pins = "gpio85"; function = "gpio"; output-low; bias-disable; }; nvme_pwren: nvme-pwren-state { function = "gpio"; }; pcie1_reset_n: pcie1-reset-n-state { pins = "gpio2"; function = "gpio"; drive-strength = <16>; output-low; bias-disable; }; pcie1_wake_n: pcie1-wake-n-state { pins = "gpio3"; function = "gpio"; drive-strength = <2>; bias-pull-up; }; 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; }; sd_cd: sd-cd-state { pins = "gpio91"; function = "gpio"; bias-pull-up; }; sw_ctrl: sw-ctrl-state { pins = "gpio86"; function = "gpio"; bias-pull-down; }; wcd_reset_n: wcd-reset-n-state { pins = "gpio83"; function = "gpio"; drive-strength = <8>; }; wcd_reset_n_sleep: wcd-reset-n-sleep-state { pins = "gpio83"; function = "gpio"; drive-strength = <8>; bias-disable; }; };