/* * Copyright (c) 2019, The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ #include #include #include #include "trinket-thermal-overlay.dtsi" #include "trinket-sde-display.dtsi" #include "trinket-audio-overlay.dtsi" #include #include #include "trinket-camera-sensor-qrd.dtsi" &qupv3_se1_i2c { status = "ok"; #include "smb1355.dtsi" }; &soc { mtp_batterydata: qcom,battery-data { qcom,batt-id-range-pct = <15>; #include "qg-batterydata-ascent-3450mah.dtsi" #include "qg-batterydata-mlp356477-2800mah.dtsi" }; fingerprint: fpc1020 { compatible = "fpc,fpc1020"; interrupt-parent = <&tlmm>; interrupts = <92 0>; fpc,gpio_rst = <&tlmm 93 0>; fpc,gpio_irq = <&tlmm 92 0>; vcc_spi-supply = <&pm6125_l9>; vdd_io-supply = <&pm6125_l9>; vdd_ana-supply = <&pm6125_l9>; fpc,enable-on-boot; pinctrl-names = "fpc1020_reset_reset", "fpc1020_reset_active", "fpc1020_irq_active"; pinctrl-0 = <&fpc_reset_low>; pinctrl-1 = <&fpc_reset_high>; pinctrl-2 = <&fpc_int_low>; }; }; &pmi632_qg { qcom,battery-data = <&mtp_batterydata>; qcom,qg-iterm-ma = <100>; qcom,hold-soc-while-full; qcom,linearize-soc; qcom,qg-use-s7-ocv; }; &pmi632_charger { qcom,battery-data = <&mtp_batterydata>; qcom,suspend-input-on-debug-batt; qcom,sw-jeita-enable; /* SMB1355 only */ qcom,sec-charger-config = <2>; dpdm-supply = <&qusb_phy0>; qcom,charger-temp-max = <800>; qcom,smb-temp-max = <800>; qcom,auto-recharge-soc = <98>; qcom,flash-disable-soc = <10>; qcom,hw-die-temp-mitigation; qcom,hw-connector-mitigation; qcom,connector-internal-pull-kohm = <100>; qcom,float-option = <1>; qcom,thermal-mitigation = <4200000 3500000 3000000 2500000 2000000 1500000 1000000 500000>; }; &qupv3_se2_i2c { status = "okay"; synaptics_tcm@20 { compatible = "synaptics,tcm-i2c"; reg = <0x20>; interrupt-parent = <&tlmm>; interrupts = <88 0x2008>; pinctrl-names = "pmx_ts_active","pmx_ts_suspend", "pmx_ts_release"; pinctrl-0 = <&ts_int_active &ts_reset_active>; pinctrl-1 = <&ts_int_suspend &ts_reset_suspend>; pinctrl-2 = <&ts_release>; synaptics,irq-gpio = <&tlmm 88 0x2008>; synaptics,irq-on-state = <0>; synaptics,reset-gpio = <&tlmm 87 0x00>; synaptics,reset-on-state = <0>; synaptics,reset-active-ms = <20>; synaptics,reset-delay-ms = <200>; synaptics,power-delay-ms = <200>; synaptics,ubl-i2c-addr = <0x20>; synaptics,y-flip; }; }; &qupv3_se1_i2c { status = "ok"; nq@28 { compatible = "qcom,nq-nci"; reg = <0x28>; qcom,nq-irq = <&tlmm 85 0x00>; qcom,nq-ven = <&tlmm 83 0x00>; qcom,nq-firm = <&tlmm 84 0x00>; qcom,nq-clkreq = <&tlmm 95 0x00>; interrupt-parent = <&tlmm>; interrupts = <85 0>; interrupt-names = "nfc_irq"; pinctrl-names = "nfc_active", "nfc_suspend"; pinctrl-0 = <&nfc_int_active &nfc_enable_active &nfc_clk_req_active>; pinctrl-1 = <&nfc_int_suspend &nfc_enable_suspend &nfc_clk_req_suspend>; }; }; &sdhc_1 { vdd-supply = <&pm6125_l24>; qcom,vdd-voltage-level = <2950000 2950000>; qcom,vdd-current-level = <0 570000>; vdd-io-supply = <&pm6125_l11>; qcom,vdd-io-always-on; qcom,vdd-io-lpm-sup; qcom,vdd-io-voltage-level = <1800000 1800000>; qcom,vdd-io-current-level = <0 325000>; pinctrl-names = "active", "sleep"; pinctrl-0 = <&sdc1_clk_on &sdc1_cmd_on &sdc1_data_on &sdc1_rclk_on>; pinctrl-1 = <&sdc1_clk_off &sdc1_cmd_off &sdc1_data_off &sdc1_rclk_off>; status = "ok"; }; &sdhc_2 { vdd-supply = <&pm6125_l22>; qcom,vdd-voltage-level = <2950000 2950000>; qcom,vdd-current-level = <0 800000>; vdd-io-supply = <&pm6125_l5>; qcom,vdd-io-voltage-level = <1800000 2950000>; qcom,vdd-io-current-level = <0 22000>; pinctrl-names = "active", "sleep"; pinctrl-0 = <&sdc2_clk_on &sdc2_cmd_on &sdc2_data_on &sdc2_cd_on>; pinctrl-1 = <&sdc2_clk_off &sdc2_cmd_off &sdc2_data_off &sdc2_cd_off>; cd-gpios = <&tlmm 98 GPIO_ACTIVE_HIGH>; status = "ok"; }; &pmi632_gpios { smb_en { smb_en_default: smb_en_default { pins = "gpio2"; function = "func1"; output-enable; }; }; pmi632_sense { /* GPIO 7 and 8 are external-sense pins for PMI632 */ pmi632_sense_default: pmi632_sense_default { pins = "gpio7", "gpio8"; bias-high-impedance; /* disable the GPIO */ bias-disable; /* no-pull */ }; }; pmi632_ctm { /* Disable GPIO1 for h/w base mitigation */ pmi632_ctm_default: pmi632_ctm_default { pins = "gpio1"; bias-high-impedance; /* disable the GPIO */ bias-disable; /* no-pull */ }; }; }; &pm6125_gpios { key_vol_up { key_vol_up_default: key_vol_up_default { pins = "gpio5"; function = "normal"; input-enable; bias-pull-up; power-source = <0>; }; }; }; &soc { gpio_keys { compatible = "gpio-keys"; label = "gpio-keys"; pinctrl-names = "default"; pinctrl-0 = <&key_vol_up_default>; vol_up { label = "volume_up"; gpios = <&pm6125_gpios 5 GPIO_ACTIVE_LOW>; linux,input-type = <1>; linux,code = ; linux,can-disable; debounce-interval = <15>; gpio-key,wakeup; }; }; }; &tlmm { smb_int_default: smb_int_default { mux { pins = "gpio130"; function = "gpio"; }; config { pins = "gpio130"; bias-pull-up; input-enable; }; }; }; &smb1355 { pinctrl-names = "default"; pinctrl-0 = <&smb_int_default>; interrupt-parent = <&tlmm>; interrupts = <130 IRQ_TYPE_LEVEL_LOW>; status = "ok"; }; &smb1355_charger { pinctrl-names = "default"; pinctrl-0 = <&smb_en_default &pmi632_sense_default &pmi632_ctm_default>; qcom,parallel-mode = <1>; qcom,disable-ctm; qcom,hw-die-temp-mitigation; status = "ok"; }; &ufsphy_mem { compatible = "qcom,ufs-phy-qmp-v3-660"; vdda-phy-supply = <&pm6125_l4>; /* 0.9v */ vdda-pll-supply = <&pm6125_l10>; /* 1.8v */ vdda-phy-max-microamp = <51400>; vdda-pll-max-microamp = <14200>; status = "ok"; }; &ufshc_mem { vdd-hba-supply = <&ufs_phy_gdsc>; vdd-hba-fixed-regulator; vcc-supply = <&pm6125_l24>; vcc-voltage-level = <2950000 2960000>; vccq2-supply = <&pm6125_l11>; vcc-max-microamp = <600000>; vccq2-max-microamp = <600000>; qcom,vddp-ref-clk-supply = <&pm6125_l18>; qcom,vddp-ref-clk-max-microamp = <100>; qcom,vddp-ref-clk-min-uV = <1200000>; qcom,vddp-ref-clk-max-uV = <1232000>; status = "ok"; }; &pmi632_vadc { bat_therm { qcom,lut-index = <0>; }; bat_therm_30k { qcom,lut-index = <0>; }; bat_therm_400k { qcom,lut-index = <0>; }; }; &usb0 { extcon = <&pmi632_charger>, <&eud>; }; &dsi_td4330_truly_cmd { qcom,panel-supply-entries = <&dsi_panel_pwr_supply>; pwms = <&pm6125_pwm 0 0>; qcom,mdss-dsi-bl-pmic-control-type = "bl_ctrl_pwm"; qcom,bl-pmic-pwm-period-usecs = <100>; qcom,mdss-dsi-bl-min-level = <1>; qcom,mdss-dsi-bl-max-level = <4095>; qcom,mdss-dsi-bl-default-level = <102>; qcom,platform-te-gpio = <&tlmm 89 0>; qcom,platform-reset-gpio = <&tlmm 90 0>; }; &dsi_td4330_truly_video { qcom,panel-supply-entries = <&dsi_panel_pwr_supply>; pwms = <&pm6125_pwm 0 0>; qcom,mdss-dsi-bl-pmic-control-type = "bl_ctrl_pwm"; qcom,bl-pmic-pwm-period-usecs = <100>; qcom,mdss-dsi-bl-min-level = <1>; qcom,mdss-dsi-bl-max-level = <4095>; qcom,mdss-dsi-bl-default-level = <102>; qcom,platform-reset-gpio = <&tlmm 90 0>; }; &dsi_td4330_truly_vid_display { qcom,dsi-display-active; }; &pm6125_pwm { status = "ok"; }; &sm6150_snd { status = "okay"; qcom,model = "trinket-qrd-snd-card"; qcom,audio-routing = "AMIC1", "MIC BIAS1", "MIC BIAS1", "Analog Mic1", "AMIC2", "MIC BIAS2", "MIC BIAS2", "Analog Mic2", "AMIC3", "MIC BIAS3", "MIC BIAS3", "Analog Mic3", "TX_AIF1 CAP", "VA_MCLK", "TX_AIF2 CAP", "VA_MCLK", "RX AIF1 PB", "VA_MCLK", "RX AIF2 PB", "VA_MCLK", "RX AIF3 PB", "VA_MCLK", "RX AIF4 PB", "VA_MCLK", "HPHL_OUT", "VA_MCLK", "HPHR_OUT", "VA_MCLK", "AUX_OUT", "VA_MCLK", "IN1_HPHL", "HPHL_OUT", "IN2_HPHR", "HPHR_OUT", "IN3_AUX", "AUX_OUT", "TX SWR_ADC0", "ADC1_OUTPUT", "TX SWR_ADC2", "ADC2_OUTPUT", "WSA SRC0_INP", "SRC0", "WSA_TX DEC0_INP", "TX DEC0 MUX", "WSA_TX DEC1_INP", "TX DEC1 MUX", "RX_TX DEC0_INP", "TX DEC0 MUX", "RX_TX DEC1_INP", "TX DEC1 MUX", "RX_TX DEC2_INP", "TX DEC2 MUX", "RX_TX DEC3_INP", "TX DEC3 MUX", "SpkrLeft IN", "WSA_SPK1 OUT", "WSA_SPK1 OUT", "VA_MCLK"; qcom,wsa-max-devs = <1>; qcom,wsa-devs = <&wsa881x_0211>, <&wsa881x_0213>; qcom,wsa-aux-dev-prefix = "SpkrLeft", "SpkrLeft"; qcom,msm-mbhc-hphl-swh = <1>; qcom,msm-mbhc-gnd-swh = <1>; asoc-codec = <&stub_codec>, <&bolero>, <&ext_disp_audio_codec>; asoc-codec-names = "msm-stub-codec.1", "bolero_codec", "msm-ext-disp-audio-codec-rx"; qcom,codec-max-aux-devs = <1>; qcom,codec-aux-devs = <&wcd937x_codec>; qcom,msm_audio_ssr_devs = <&audio_apr>, <&q6core>, <&bolero>; }; &qusb_phy0 { qcom,qusb-phy-init-seq = <0xc8 0x80 0x93 0x84 0x83 0x88 0xc7 0x8c 0x30 0x08 0x79 0x0c 0x21 0x10 0x14 0x9c 0x80 0x04 0x9f 0x1c 0x00 0x18>; };