Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/C/Linux/arch/arm64/boot/dts/qcom/   (Open Source Betriebssystem Version 6.17.9©)  Datei vom 24.10.2025 mit Größe 15 kB image not shown  

Quelle  sc7280-idp.dtsi   Sprache: unbekannt

 
// 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 <dt-bindings/iio/qcom,spmi-adc7-pmk8350.h>
#include <dt-bindings/input/linux-event-codes.h>
#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 = <KEY_VOLUMEUP>;
   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 = <MI2S_SECONDARY>;
  qcom,playback-sd-lines = <0>;
 };

 dai-link@5 {
  reg = <LPASS_DP_RX>;
 };

 dai-link@6 {
  reg = <LPASS_CDC_DMA_RX0>;
 };

 dai-link@19 {
  reg = <LPASS_CDC_DMA_TX3>;
 };

 dai-link@25 {
  reg = <LPASS_CDC_DMA_VA_TX0>;
 };
};

&lpass_rx_macro {
 status = "okay";
};

&lpass_tx_macro {
 status = "okay";
};

&lpass_va_macro {
 status = "okay";
 vdd-micb-supply = <&vreg_bob>;
 pinctrl-0 = <&lpass_dmic01_clk>, <&lpass_dmic01_data>;
 pinctrl-names = "default";
};

&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 = <PMK8350_ADC7_DIE_TEMP>;
  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 {
 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;
 };
};

[ Dauer der Verarbeitung: 0.15 Sekunden  (vorverarbeitet)  ]