linux/linux-5.18.11/arch/arm64/boot/dts/qcom/sc7280-herobrine-herobrine-...

1353 lines
26 KiB
Plaintext

// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
/*
* Google Herobrine board device tree source
*
* Copyright 2021 Google LLC.
*/
/dts-v1/;
#include <dt-bindings/iio/qcom,spmi-adc7-pmk8350.h>
#include <dt-bindings/iio/qcom,spmi-adc7-pmr735a.h>
#include <dt-bindings/input/gpio-keys.h>
#include <dt-bindings/input/input.h>
#include <dt-bindings/pinctrl/qcom,pmic-gpio.h>
#include <dt-bindings/regulator/qcom,rpmh-regulator.h>
#include "sc7280.dtsi"
/* PMICs depend on spmi_bus label and so must come after SoC */
#include "pm7325.dtsi"
#include "pm8350c.dtsi"
#include "pmk8350.dtsi"
#include "sc7280-chrome-common.dtsi"
/ {
model = "Google Herobrine (rev0)";
compatible = "google,herobrine-rev0", "qcom,sc7280";
};
/ {
aliases {
serial0 = &uart5;
serial1 = &uart7;
};
chosen {
stdout-path = "serial0:115200n8";
};
/* FIXED REGULATORS - parents above children */
/* This is the top level supply and variable voltage */
ppvar_sys: ppvar-sys-regulator {
compatible = "regulator-fixed";
regulator-name = "ppvar_sys";
regulator-always-on;
regulator-boot-on;
};
/* This divides ppvar_sys by 2, so voltage is variable */
src_vph_pwr: src-vph-pwr-regulator {
compatible = "regulator-fixed";
regulator-name = "src_vph_pwr";
/* EC turns on with switchcap_on; always on for AP */
regulator-always-on;
regulator-boot-on;
vin-supply = <&ppvar_sys>;
};
pp5000_s3: pp5000-s3-regulator {
compatible = "regulator-fixed";
regulator-name = "pp5000_s3";
/* EC turns on with en_pp5000_s3; always on for AP */
regulator-always-on;
regulator-boot-on;
regulator-min-microvolt = <5000000>;
regulator-max-microvolt = <5000000>;
vin-supply = <&ppvar_sys>;
};
pp3300_z1: pp3300-z1-regulator {
compatible = "regulator-fixed";
regulator-name = "pp3300_z1";
/* EC turns on with en_pp3300_z1; always on for AP */
regulator-always-on;
regulator-boot-on;
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
vin-supply = <&ppvar_sys>;
};
pp3300_audio:
pp3300_codec: pp3300-codec-regulator {
compatible = "regulator-fixed";
regulator-name = "pp3300_codec";
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
gpio = <&tlmm 67 GPIO_ACTIVE_HIGH>;
enable-active-high;
pinctrl-names = "default";
pinctrl-0 = <&en_pp3300_codec>;
vin-supply = <&pp3300_z1>;
};
pp3300_cam:
pp3300_edp:
pp3300_ts: pp3300-edp-regulator {
compatible = "regulator-fixed";
regulator-name = "pp3300_edp";
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
gpio = <&tlmm 80 GPIO_ACTIVE_HIGH>;
enable-active-high;
pinctrl-names = "default";
pinctrl-0 = <&en_pp3300_dx_edp>;
vin-supply = <&pp3300_z1>;
};
pp3300_fp:
pp3300_fp_ls:
pp3300_mcu: pp3300-fp-regulator {
compatible = "regulator-fixed";
regulator-name = "pp3300_fp";
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
regulator-boot-on;
regulator-always-on;
/*
* WARNING: it is intentional that GPIO 42 isn't listed here.
* The userspace script for updating the fingerprint firmware
* needs to control the FP regulators during a FW update,
* hence the signal can't be owned by the kernel regulator.
*/
pinctrl-names = "default";
pinctrl-0 = <&en_fp_rails>;
vin-supply = <&pp3300_z1>;
};
pp3300_hub: pp3300-hub-regulator {
compatible = "regulator-fixed";
regulator-name = "pp3300_hub";
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
regulator-boot-on;
regulator-always-on;
gpio = <&tlmm 24 GPIO_ACTIVE_HIGH>;
enable-active-high;
pinctrl-names = "default";
pinctrl-0 = <&en_pp3300_hub>;
vin-supply = <&pp3300_z1>;
};
pp3300_tp: pp3300-tp-regulator {
compatible = "regulator-fixed";
regulator-name = "pp3300_tp";
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
/* AP turns on with PP1800_L18B_S0; always on for AP */
regulator-always-on;
regulator-boot-on;
vin-supply = <&pp3300_z1>;
};
pp2850_uf_cam: pp2850-uf-cam-regulator {
compatible = "regulator-fixed";
regulator-name = "pp2850_uf_cam";
regulator-min-microvolt = <2850000>;
regulator-max-microvolt = <2850000>;
gpio = <&tlmm 6 GPIO_ACTIVE_HIGH>;
enable-active-high;
pinctrl-names = "default";
pinctrl-0 = <&uf_cam_en>;
vin-supply = <&pp3300_cam>;
};
pp2850_vcm_wf_cam: pp2850-vcm-wf-cam-regulator {
compatible = "regulator-fixed";
regulator-name = "pp2850_vcm_wf_cam";
regulator-min-microvolt = <2850000>;
regulator-max-microvolt = <2850000>;
gpio = <&tlmm 7 GPIO_ACTIVE_HIGH>;
enable-active-high;
pinctrl-names = "default";
pinctrl-0 = <&wf_cam_en>;
vin-supply = <&pp3300_cam>;
};
pp2850_wf_cam: pp2850-wf-cam-regulator {
compatible = "regulator-fixed";
regulator-name = "pp2850_wf_cam";
regulator-min-microvolt = <2850000>;
regulator-max-microvolt = <2850000>;
gpio = <&tlmm 7 GPIO_ACTIVE_HIGH>;
enable-active-high;
/*
* The pinconf can only be referenced once so we put it on the
* first regulator and comment it out here.
*
* pinctrl-names = "default";
* pinctrl-0 = <&wf_cam_en>;
*/
vin-supply = <&pp3300_cam>;
};
pp1800_fp: pp1800-fp-regulator {
compatible = "regulator-fixed";
regulator-name = "pp1800_fp";
regulator-min-microvolt = <1800000>;
regulator-max-microvolt = <1800000>;
regulator-boot-on;
regulator-always-on;
/*
* WARNING: it is intentional that GPIO 42 isn't listed here.
* The userspace script for updating the fingerprint firmware
* needs to control the FP regulators during a FW update,
* hence the signal can't be owned by the kernel regulator.
*/
pinctrl-names = "default";
pinctrl-0 = <&en_fp_rails>;
vin-supply = <&pp1800_l18b_s0>;
status = "disabled";
};
pp1800_uf_cam: pp1800-uf-cam-regulator {
compatible = "regulator-fixed";
regulator-name = "pp1800_uf_cam";
regulator-min-microvolt = <1800000>;
regulator-max-microvolt = <1800000>;
gpio = <&tlmm 6 GPIO_ACTIVE_HIGH>;
enable-active-high;
/*
* The pinconf can only be referenced once so we put it on the
* first regulator and comment it out here.
*
* pinctrl-names = "default";
* pinctrl-0 = <&uf_cam_en>;
*/
vin-supply = <&pp1800_l19b>;
};
pp1800_wf_cam: pp1800-wf-cam-regulator {
compatible = "regulator-fixed";
regulator-name = "pp1800_wf_cam";
regulator-min-microvolt = <1800000>;
regulator-max-microvolt = <1800000>;
gpio = <&tlmm 7 GPIO_ACTIVE_HIGH>;
enable-active-high;
/*
* The pinconf can only be referenced once so we put it on the
* first regulator and comment it out here.
*
* pinctrl-names = "default";
* pinctrl-0 = <&wf_cam_en>;
*/
vin-supply = <&pp1800_l19b>;
};
pp1200_wf_cam: pp1200-wf-cam-regulator {
compatible = "regulator-fixed";
regulator-name = "pp1200_wf_cam";
regulator-min-microvolt = <1200000>;
regulator-max-microvolt = <1200000>;
gpio = <&tlmm 7 GPIO_ACTIVE_HIGH>;
enable-active-high;
/*
* The pinconf can only be referenced once so we put it on the
* first regulator and comment it out here.
*
* pinctrl-names = "default";
* pinctrl-0 = <&wf_cam_en>;
*/
vin-supply = <&pp1200_l6b>;
};
/* BOARD-SPECIFIC TOP LEVEL NODES */
gpio_keys: gpio-keys {
compatible = "gpio-keys";
status = "disabled";
pinctrl-names = "default";
pinctrl-0 = <&pen_pdct_l>;
pen_insert: pen-insert {
label = "Pen Insert";
/* Insert = low, eject = high */
gpios = <&tlmm 39 GPIO_ACTIVE_LOW>;
linux,code = <SW_PEN_INSERTED>;
linux,input-type = <EV_SW>;
wakeup-event-action = <EV_ACT_DEASSERTED>;
wakeup-source;
};
};
pwmleds {
compatible = "pwm-leds";
status = "disabled";
keyboard_backlight: keyboard-backlight {
status = "disabled";
label = "cros_ec::kbd_backlight";
pwms = <&cros_ec_pwm 0>;
max-brightness = <1023>;
};
};
};
&apps_rsc {
pm7325-regulators {
compatible = "qcom,pm7325-rpmh-regulators";
qcom,pmic-id = "b";
vdd19_pmu_pcie_i:
vdd19_pmu_rfa_i:
vreg_s1b_wlan:
vreg_s1b: smps1 {
regulator-min-microvolt = <1856000>;
regulator-max-microvolt = <2040000>;
};
vdd_pmu_aon_i:
vreg_s7b_wlan:
vreg_s7b: smps7 {
regulator-min-microvolt = <535000>;
regulator-max-microvolt = <1120000>;
};
vdd13_pmu_pcie_i:
vdd13_pmu_rfa_i:
vreg_s8b_wlan:
vreg_s8b: smps8 {
regulator-min-microvolt = <1256000>;
regulator-max-microvolt = <1500000>;
};
vdda_usb_ss_dp_core:
vreg_l1b: ldo1 {
regulator-min-microvolt = <825000>;
regulator-max-microvolt = <925000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
vdda_usb_hs0_3p1:
vreg_l2b: ldo2 {
regulator-min-microvolt = <2700000>;
regulator-max-microvolt = <3544000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp1200_l6b:
vdd_ufs_1p2:
vdd_vref:
vdda_csi01_1p2:
vdda_csi23_1p2:
vdda_csi4_1p2:
vdda_dsi0_1p2:
vdda_pcie0_1p2:
vdda_pcie1_1p2:
vdda_usb_ss_dp_1p2:
vdda_qlink0_1p2_ck:
vdda_qlink1_1p2_ck:
vreg_l6b_1p2:
vreg_l6b: ldo6 {
regulator-min-microvolt = <1120000>;
regulator-max-microvolt = <1408000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp2950_l7b:
vreg_l7b: ldo7 {
regulator-min-microvolt = <2960000>;
regulator-max-microvolt = <2960000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
codec_vcc:
pp1800_l18b_s0:
pp1800_ts:
vdd1:
vddpx_0:
vddpx_3:
vddpx_7:
vreg_l18b: ldo18 {
regulator-min-microvolt = <1800000>;
regulator-max-microvolt = <2000000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp1800_l19b:
vddpx_ts:
vddpx_wl4otp:
vreg_l19b: ldo19 {
regulator-min-microvolt = <1800000>;
regulator-max-microvolt = <1800000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
};
pm8350c-regulators {
compatible = "qcom,pm8350c-rpmh-regulators";
qcom,pmic-id = "c";
vreg_s1c: smps1 {
regulator-min-microvolt = <2190000>;
regulator-max-microvolt = <2210000>;
};
vddpx_1:
vreg_s9c: smps9 {
regulator-min-microvolt = <1010000>;
regulator-max-microvolt = <1170000>;
};
pp1800_l1c:
pp1800_pen:
vdd_a_gfx_cs_1p1:
vdd_a_cxo_1p8:
vdd_qfprom:
vdda_apc_cs_1p8:
vdda_qrefs_1p8:
vdda_turing_q6_cs_1p8:
vdda_usb_hs0_1p8:
vreg_l1c: ldo1 {
regulator-min-microvolt = <1800000>;
regulator-max-microvolt = <1980000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
dmic_vdd:
pp1800_alc5682:
pp1800_l2c:
pp1800_vreg_alc5682:
vreg_l2c: ldo2 {
regulator-min-microvolt = <1620000>;
regulator-max-microvolt = <1980000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp3300_sar:
pp3300_sensor:
vreg_l3c: ldo3 {
regulator-min-microvolt = <2800000>;
regulator-max-microvolt = <3540000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
ppvar_uim1:
vddpx_5:
vreg_l4c: ldo4 {
regulator-min-microvolt = <1620000>;
regulator-max-microvolt = <3300000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp2950_l5c:
uim_vcc:
vddpx_6:
vreg_l5c: ldo5 {
regulator-min-microvolt = <1620000>;
regulator-max-microvolt = <3300000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
ppvar_l6c:
vddpx_2:
vreg_l6c: ldo6 {
regulator-min-microvolt = <1800000>;
regulator-max-microvolt = <2950000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
vreg_l7c: ldo7 {
regulator-min-microvolt = <3000000>;
regulator-max-microvolt = <3544000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp1800_prox:
pp1800_sar:
vreg_l8c: ldo8 {
regulator-min-microvolt = <1620000>;
regulator-max-microvolt = <2000000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp2950_l9c:
vreg_l9c: ldo9 {
regulator-min-microvolt = <2960000>;
regulator-max-microvolt = <2960000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
vdd_a_gnss_0p9:
vdd_ufs_core:
vdd_usb_hs0_core:
vdd_vref_0p9:
vdda_csi01_0p9:
vdda_csi23_0p9:
vdda_csi4_0p9:
vdda_dsi0_pll_0p9:
vdda_dsi0_0p9:
vdda_pcie0_core:
vdda_pcie1_core:
vdda_qlink0_0p9:
vdda_qlink1_0p9:
vdda_qlink0_0p9_ck:
vdda_qlink1_0p9_ck:
vdda_qrefs_0p875:
vreg_l10c_0p8:
vreg_l10c: ldo10 {
regulator-min-microvolt = <720000>;
regulator-max-microvolt = <1050000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp2800_l11c:
vreg_l11c: ldo11 {
regulator-min-microvolt = <2800000>;
regulator-max-microvolt = <3544000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp1800_l12c:
vreg_l12c: ldo12 {
regulator-min-microvolt = <1650000>;
regulator-max-microvolt = <2000000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
pp3300_l13c:
vreg_l13c: ldo13 {
regulator-min-microvolt = <2700000>;
regulator-max-microvolt = <3544000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
};
vreg_bob: bob {
regulator-min-microvolt = <3008000>;
regulator-max-microvolt = <3960000>;
regulator-initial-mode = <RPMH_REGULATOR_MODE_AUTO>;
};
};
};
ap_tp_i2c: &i2c1 {
status = "okay";
clock-frequency = <400000>;
trackpad: trackpad@15 {
compatible = "elan,ekth3000";
reg = <0x15>;
pinctrl-names = "default";
pinctrl-0 = <&tp_int_odl>;
interrupt-parent = <&tlmm>;
interrupts = <102 IRQ_TYPE_EDGE_FALLING>;
vcc-supply = <&pp3300_z1>;
wakeup-source;
};
};
ap_h1_i2c: &i2c12 {
status = "okay";
clock-frequency = <400000>;
tpm@50 {
compatible = "google,cr50";
reg = <0x50>;
pinctrl-names = "default";
pinctrl-0 = <&h1_ap_int_odl>;
interrupt-parent = <&tlmm>;
interrupts = <54 IRQ_TYPE_EDGE_RISING>;
};
};
ap_ts_pen: &i2c13 {
status = "okay";
clock-frequency = <400000>;
ap_ts: touchscreen@10 {
compatible = "hid-over-i2c";
reg = <0x10>;
pinctrl-names = "default";
pinctrl-0 = <&ts_int_l>, <&ts_reset_l>;
interrupt-parent = <&tlmm>;
interrupts = <81 IRQ_TYPE_LEVEL_LOW>;
post-power-on-delay-ms = <20>;
hid-descr-addr = <0x0001>;
vdd-supply = <&pp3300_ts>;
};
};
&pm7325_gpios {
status = "disabled"; /* No GPIOs are connected */
};
&pmk8350_gpios {
status = "disabled"; /* No GPIOs are connected */
};
&pmk8350_rtc {
status = "disabled";
};
&pmk8350_vadc {
pmk8350_die_temp {
reg = <PMK8350_ADC7_DIE_TEMP>;
label = "pmk8350_die_temp";
qcom,pre-scaling = <1 1>;
};
pmr735a_die_temp {
reg = <PMR735A_ADC7_DIE_TEMP>;
label = "pmr735a_die_temp";
qcom,pre-scaling = <1 1>;
};
};
&qfprom {
vcc-supply = <&vdd_qfprom>;
};
&qupv3_id_0 {
status = "okay";
};
&qupv3_id_1 {
status = "okay";
};
&sdhc_1 {
status = "okay";
vmmc-supply = <&pp2950_l7b>;
vqmmc-supply = <&pp1800_l19b>;
};
&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 = <&pp2950_l9c>;
vqmmc-supply = <&ppvar_l6c>;
cd-gpios = <&tlmm 91 GPIO_ACTIVE_LOW>;
};
ap_ec_spi: &spi8 {
status = "okay";
pinctrl-0 = <&qup_spi8_data_clk>, <&qup_spi8_cs_gpio_init_high>, <&qup_spi8_cs_gpio>;
cs-gpios = <&tlmm 35 GPIO_ACTIVE_LOW>;
cros_ec: ec@0 {
compatible = "google,cros-ec-spi";
reg = <0>;
interrupt-parent = <&tlmm>;
interrupts = <142 IRQ_TYPE_LEVEL_LOW>;
pinctrl-names = "default";
pinctrl-0 = <&ap_ec_int_l>;
spi-max-frequency = <3000000>;
cros_ec_pwm: pwm {
compatible = "google,cros-ec-pwm";
#pwm-cells = <1>;
};
i2c_tunnel: i2c-tunnel {
compatible = "google,cros-ec-i2c-tunnel";
google,remote-bus = <0>;
#address-cells = <1>;
#size-cells = <0>;
};
typec {
compatible = "google,cros-ec-typec";
#address-cells = <1>;
#size-cells = <0>;
usb_c0: connector@0 {
compatible = "usb-c-connector";
reg = <0>;
label = "left";
power-role = "dual";
data-role = "host";
try-power-role = "source";
};
usb_c1: connector@1 {
compatible = "usb-c-connector";
reg = <1>;
label = "right";
power-role = "dual";
data-role = "host";
try-power-role = "source";
};
};
};
};
#include <arm/cros-ec-keyboard.dtsi>
#include <arm/cros-ec-sbs.dtsi>
&keyboard_controller {
function-row-physmap = <
MATRIX_KEY(0x00, 0x02, 0) /* T1 */
MATRIX_KEY(0x03, 0x02, 0) /* T2 */
MATRIX_KEY(0x02, 0x02, 0) /* T3 */
MATRIX_KEY(0x01, 0x02, 0) /* T4 */
MATRIX_KEY(0x03, 0x04, 0) /* T5 */
MATRIX_KEY(0x02, 0x04, 0) /* T6 */
MATRIX_KEY(0x01, 0x04, 0) /* T7 */
MATRIX_KEY(0x02, 0x09, 0) /* T8 */
MATRIX_KEY(0x01, 0x09, 0) /* T9 */
MATRIX_KEY(0x00, 0x04, 0) /* T10 */
>;
linux,keymap = <
MATRIX_KEY(0x00, 0x02, KEY_BACK)
MATRIX_KEY(0x03, 0x02, KEY_REFRESH)
MATRIX_KEY(0x02, 0x02, KEY_ZOOM)
MATRIX_KEY(0x01, 0x02, KEY_SCALE)
MATRIX_KEY(0x03, 0x04, KEY_SYSRQ)
MATRIX_KEY(0x02, 0x04, KEY_BRIGHTNESSDOWN)
MATRIX_KEY(0x01, 0x04, KEY_BRIGHTNESSUP)
MATRIX_KEY(0x02, 0x09, KEY_MUTE)
MATRIX_KEY(0x01, 0x09, KEY_VOLUMEDOWN)
MATRIX_KEY(0x00, 0x04, KEY_VOLUMEUP)
CROS_STD_MAIN_KEYMAP
>;
};
&uart5 {
compatible = "qcom,geni-debug-uart";
status = "okay";
};
&uart7 {
status = "okay";
};
&usb_1 {
status = "okay";
};
&usb_1_dwc3 {
dr_mode = "host";
};
&usb_1_hsphy {
status = "okay";
vdda-pll-supply = <&vdd_usb_hs0_core>;
vdda33-supply = <&vdda_usb_hs0_3p1>;
vdda18-supply = <&vdda_usb_hs0_1p8>;
};
&usb_1_qmpphy {
status = "okay";
vdda-phy-supply = <&vdda_usb_ss_dp_1p2>;
vdda-pll-supply = <&vdda_usb_ss_dp_core>;
};
&usb_2 {
status = "okay";
};
&usb_2_dwc3 {
dr_mode = "host";
};
&usb_2_hsphy {
status = "okay";
vdda-pll-supply = <&vdd_usb_hs0_core>;
vdda33-supply = <&vdda_usb_hs0_3p1>;
vdda18-supply = <&vdda_usb_hs0_1p8>;
};
/* PINCTRL - additions to nodes defined in sc7280.dtsi */
&dp_hot_plug_det {
bias-disable;
};
&pcie1_clkreq_n {
bias-pull-up;
drive-strength = <2>;
};
&qspi_cs0 {
bias-disable;
};
&qspi_clk {
bias-disable;
};
&qspi_data01 {
/* High-Z when no transfers; nice to park the lines */
bias-pull-up;
};
&qup_uart5_rx {
drive-strength = <2>;
bias-pull-up;
};
&qup_uart5_tx {
drive-strength = <2>;
bias-disable;
};
&qup_uart7_cts {
/*
* Configure a pull-down on CTS to match the pull of
* the Bluetooth module.
*/
bias-pull-down;
};
&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>;
};
/* PINCTRL - board-specific pinctrl */
&pm8350c_gpios {
gpio-line-names = "AP_SUSPEND",
"",
"",
"AP_BL_EN",
"",
"SD_CD_ODL",
"",
"",
"AP_BL_PWM";
ap_bl_en: ap-bl-en {
pins = "gpio4";
function = "normal";
qcom,drive-strength = <PMIC_GPIO_STRENGTH_LOW>;
bias-disable;
/* Force backlight to be disabled to match state at boot. */
output-low;
};
};
&tlmm {
gpio-line-names = "HP_I2C_SDA", /* 0 */
"HP_I2C_SCL",
"SSD_RST_L",
"PE_WAKE_ODL",
"AP_TP_I2C_SDA",
"AP_TP_I2C_SCL",
"UF_CAM_EN",
"WF_CAM_EN",
"AP_SAR_SENSOR_SDA",
"AP_SAR_SENSOR_SCL",
"", /* 10 */
"",
"AP_SPI_MOSI",
"AP_SPI_MISO",
"AP_SPI_CLK",
"AP_SPI_CS0_L",
"",
"",
"EDP_HPD",
"",
"UF_CAM_RST_L", /* 20 */
"WF_CAM_RST_L",
"UART_AP_TX_DBG_RX",
"UART_DBG_TX_AP_RX",
"EN_PP3300_HUB",
"",
"HOST2WLAN_SOL",
"WLAN2HOST_SOL",
"BT_UART_CTS",
"BT_UART_RTS",
"BT_UART_TXD", /* 30 */
"BT_UART_RXD",
"AP_EC_SPI_MISO",
"AP_EC_SPI_MOSI",
"AP_EC_SPI_CLK",
"AP_EC_SPI_CS_L",
"",
"",
"",
"PEN_PDCT_L",
"IO_BRD_ID0", /* 40 */
"IO_BRD_ID1",
"EN_FP_RAILS",
"PEN_IRQ_L",
"AP_SPI_FP_MISO",
"AP_SPI_FP_MOSI",
"AP_SPI_FP_CLK",
"AP_SPI_FP_CS_L",
"AP_H1_SPI_MISO",
"AP_H1_SPI_MOSI",
"AP_H1_SPI_CLK", /* 50 */
"AP_H1_SPI_CS_L",
"AP_TS_PEN_I2C_SDA",
"AP_TS_PEN_I2C_SCL",
"H1_AP_INT_ODL",
"",
"LCM_RST_1V8_L",
"AMP_EN",
"",
"DP_HOT_PLUG_DET",
"HUB_RST_L", /* 60 */
"FP_TO_AP_IRQ_L",
"",
"",
"UF_CAM_MCLK",
"WF_CAM_MCLK",
"IO_BRD_ID2",
"EN_PP3300_CODEC",
"EC_IN_RW_ODL",
"UF_CAM_SDA",
"UF_CAM_SCL", /* 70 */
"WF_CAM_SDA",
"WF_CAM_SCL",
"AP_BRD_ID0",
"AP_BRD_ID1",
"AP_BRD_ID2",
"",
"FPMCU_BOOT0",
"FP_RST_L",
"PE_CLKREQ_ODL",
"EN_EDP_PP3300", /* 80 */
"TS_INT_L",
"FORCE_USB_BOOT",
"WCD_RST_L",
"WLAN_EN",
"BT_EN",
"WLAN_SW_CTRL",
"PCIE0_RESET_L",
"PCIE0_CLK_REQ_L",
"PCIE0_WAKE_L",
"AS_EN", /* 90 */
"SD_CD_ODL",
"",
/*
* AP_FLASH_WP_L is crossystem ABI. Schematics
* call it BIOS_FLASH_WP_L.
*/
"AP_FLASH_WP_L",
"BT_WLAN_SB_CLK",
"BT_WLAN_SB_DATA",
"HP_MCLK",
"HP_BCLK",
"HP_DOUT",
"HP_DIN",
"HP_LRCLK", /* 100 */
"HP_IRQ",
"TP_INT_ODL",
"",
"IO_SKU_ID2",
"TS_RESET_L",
"AMP_BCLK",
"AMP_DIN",
"AMP_LRCLK",
"UIM2_DATA",
"UIM2_CLK", /* 110 */
"UIM2_RST",
"UIM2_PRESENT",
"UIM1_DATA",
"UIM1_CLK",
"UIM1_RST",
"",
"RFFE0_CLK",
"RFFE0_DATA/BOOT_CONFIG_0",
"RFFE1_CLK",
"RFFE1_DATA/BOOT_CONFIG_1", /* 120 */
"RFFE2_CLK",
"RFFE2_DATA/BOOT_CONFIG_2",
"RFFE3_CLK",
"RFFE3_DATA/BOOT_CONFIG_3",
"RFFE4_CLK",
"RFFE4_DATA",
"WCI2_LTE_COEX_RXD",
"WCI2_LTE_COEX_TXD",
"IO_SKU_ID0",
"IO_SKU_ID1", /* 130 */
"",
"",
"QLINK0_REQ",
"QLINK0_EN",
"QLINK0_WMSS_RESET_L",
"QLINK1_REQ",
"QLINK1_EN",
"QLINK1_WMSS_RESET_L",
"FORCED_USB_BOOT_POL",
"", /* 140 */
"P_SENSOR_INT_L",
"AP_EC_INT_L",
"",
"WCD_SWR_TX_CLK",
"WCD_SWR_TX_DATA_0",
"WCD_SWR_TX_DATA_1",
"WCD_SWR_RX_CLK",
"WCD_SWR_RX_DATA_0",
"WCD_SWR_RX_DATA_1",
"", /* 150 */
"",
"",
"",
"",
"",
"",
"",
"WCD_SWR_TX_DATA_2",
"",
"", /* 160 */
"",
"",
"",
"",
"",
"",
"",
"",
"",
"", /* 170 */
"SENS_UART_TXD",
"SENS_UART_RXD",
"",
"",
"";
/*
* pinctrl settings for pins that have no real owners.
*/
pinctrl-names = "default";
pinctrl-0 = <&bios_flash_wp_l>;
amp_en: amp-en {
pins = "gpio57";
function = "gpio";
bias-pull-down;
};
ap_ec_int_l: ap-ec-int-l {
pins = "gpio142";
input-enable;
bias-pull-up;
};
bios_flash_wp_l: bios-flash-wp-l {
pins = "gpio93";
function = "gpio";
input-enable;
bias-disable;
};
bt_en: bt-en {
pins = "gpio85";
function = "gpio";
drive-strength = <2>;
output-low;
bias-pull-down;
};
en_fp_rails: en-fp-rails {
pins = "gpio42";
drive-strength = <2>;
output-high;
bias-disable;
};
en_pp3300_codec: en-pp3300-codec {
pins = "gpio67";
drive-strength = <2>;
bias-disable;
};
en_pp3300_dx_edp: en-pp3300-dx-edp {
pins = "gpio80";
function = "gpio";
drive-strength = <2>;
/* Has external pulldown */
bias-disable;
};
en_pp3300_hub: en-pp3300-hub {
pins = "gpio24";
function = "gpio";
drive-strength = <2>;
/* Has external pulldown */
bias-disable;
};
fp_to_ap_irq_l: fp-to-ap-irq-l {
pins = "gpio61";
function = "gpio";
input-enable;
/* Has external pullup */
bias-disable;
};
h1_ap_int_odl: h1-ap-int-odl {
pins = "gpio54";
function = "gpio";
input-enable;
bias-pull-up;
};
hp_irq: hp-irq {
pins = "gpio101";
function = "gpio";
bias-pull-up;
};
p_sensor_int_l: p-sensor-int-l {
pins = "gpio141";
function = "gpio";
input-enable;
bias-pull-up;
};
pen_irq_l: pen-irq-l {
pins = "gpio43";
function = "gpio";
/* Has external pullup */
bias-disable;
};
pen_pdct_l: pen-pdct-l {
pins = "gpio39";
function = "gpio";
/* Has external pullup */
bias-disable;
};
qup_spi8_cs_gpio_init_high: qup-spi8-cs-gpio-init-high {
pins = "gpio35";
output-high;
};
qup_spi11_cs_gpio_init_high: qup-spi11-cs-gpio-init-high {
pins = "gpio47";
output-high;
};
qup_spi12_cs_gpio_init_high: qup-spi12-cs-gpio-init-high {
pins = "gpio51";
output-high;
};
qup_uart7_sleep_cts: qup-uart7-sleep-cts {
pins = "gpio28";
function = "gpio";
/*
* Configure a pull-down on CTS to match the pull of
* the Bluetooth module.
*/
bias-pull-down;
};
qup_uart7_sleep_rts: qup-uart7-sleep-rts {
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_rx: qup-uart7-sleep-rx {
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;
};
qup_uart7_sleep_tx: qup-uart7-sleep-tx {
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;
};
sd_cd: sd-cd {
pins = "gpio91";
function = "gpio";
bias-pull-up;
};
tp_int_odl: tp-int-odl {
pins = "gpio102";
function = "gpio";
/* Has external pullup */
bias-disable;
};
ts_int_l: ts-int-l {
pins = "gpio81";
function = "gpio";
/* Has external pullup */
bias-pull-up;
};
ts_reset_l: ts-reset-l {
pins = "gpio105";
function = "gpio";
/* Has external pullup */
bias-disable;
drive-strength = <2>;
};
uf_cam_en: uf-cam-en {
pins = "gpio6";
function = "gpio";
drive-strength = <2>;
/* Has external pulldown */
bias-disable;
};
wf_cam_en: wf-cam-en {
pins = "gpio7";
function = "gpio";
drive-strength = <2>;
/* Has external pulldown */
bias-disable;
};
};