2023-08-30 17:31:07 +02:00
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2021, Luca Weiss <luca@z3ntu.xyz>
|
|
|
|
*/
|
|
|
|
|
|
|
|
/dts-v1/;
|
|
|
|
|
|
|
|
/* PMK8350 (in reality a PMK8003) is configured to use SID6 instead of 0 */
|
|
|
|
#define PMK8350_SID 6
|
|
|
|
|
|
|
|
#include <dt-bindings/gpio/gpio.h>
|
|
|
|
#include <dt-bindings/iio/qcom,spmi-adc7-pmk8350.h>
|
|
|
|
#include <dt-bindings/input/input.h>
|
|
|
|
#include <dt-bindings/leds/common.h>
|
|
|
|
#include <dt-bindings/pinctrl/qcom,pmic-gpio.h>
|
|
|
|
#include <dt-bindings/regulator/qcom,rpmh-regulator.h>
|
|
|
|
#include "sm7225.dtsi"
|
|
|
|
#include "pm6150l.dtsi"
|
|
|
|
#include "pm6350.dtsi"
|
|
|
|
#include "pm7250b.dtsi"
|
|
|
|
#include "pmk8350.dtsi"
|
|
|
|
|
|
|
|
/ {
|
|
|
|
model = "Fairphone 4";
|
|
|
|
compatible = "fairphone,fp4", "qcom,sm7225";
|
|
|
|
chassis-type = "handset";
|
|
|
|
|
|
|
|
/* required for bootloader to select correct board */
|
|
|
|
qcom,msm-id = <434 0x10000>, <459 0x10000>;
|
|
|
|
qcom,board-id = <8 32>;
|
|
|
|
|
|
|
|
aliases {
|
|
|
|
serial0 = &uart9;
|
2023-10-24 12:59:35 +02:00
|
|
|
serial1 = &uart1;
|
2023-08-30 17:31:07 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
chosen {
|
|
|
|
#address-cells = <2>;
|
|
|
|
#size-cells = <2>;
|
|
|
|
ranges;
|
|
|
|
|
|
|
|
stdout-path = "serial0:115200n8";
|
|
|
|
|
|
|
|
framebuffer0: framebuffer@a000000 {
|
|
|
|
compatible = "simple-framebuffer";
|
|
|
|
reg = <0 0xa0000000 0 (2340 * 1080 * 4)>;
|
|
|
|
width = <1080>;
|
|
|
|
height = <2340>;
|
|
|
|
stride = <(1080 * 4)>;
|
|
|
|
format = "a8r8g8b8";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
gpio-keys {
|
|
|
|
compatible = "gpio-keys";
|
|
|
|
pinctrl-names = "default";
|
|
|
|
pinctrl-0 = <&gpio_keys_pin>;
|
|
|
|
|
|
|
|
key-volume-up {
|
|
|
|
label = "volume_up";
|
|
|
|
linux,code = <KEY_VOLUMEUP>;
|
|
|
|
gpios = <&pm6350_gpios 2 GPIO_ACTIVE_LOW>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
reserved-memory {
|
|
|
|
/*
|
|
|
|
* The rmtfs memory region in downstream is 'dynamically allocated'
|
|
|
|
* but given the same address every time. Hard code it as this address is
|
|
|
|
* where the modem firmware expects it to be.
|
|
|
|
*/
|
|
|
|
memory@efe01000 {
|
|
|
|
compatible = "qcom,rmtfs-mem";
|
|
|
|
reg = <0 0xefe01000 0 0x600000>;
|
|
|
|
no-map;
|
|
|
|
|
|
|
|
qcom,client-id = <1>;
|
|
|
|
qcom,vmid = <15>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
thermal-zones {
|
|
|
|
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";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&adsp {
|
|
|
|
firmware-name = "qcom/sm7225/fairphone4/adsp.mdt";
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&apps_rsc {
|
|
|
|
regulators-0 {
|
|
|
|
compatible = "qcom,pm6350-rpmh-regulators";
|
|
|
|
qcom,pmic-id = "a";
|
|
|
|
|
|
|
|
vreg_s1a: smps1 {
|
|
|
|
regulator-min-microvolt = <1000000>;
|
|
|
|
regulator-max-microvolt = <1200000>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_s2a: smps2 {
|
|
|
|
regulator-min-microvolt = <1503000>;
|
|
|
|
regulator-max-microvolt = <2048000>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l2a: ldo2 {
|
|
|
|
regulator-min-microvolt = <1503000>;
|
|
|
|
regulator-max-microvolt = <1980000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l3a: ldo3 {
|
|
|
|
regulator-min-microvolt = <2700000>;
|
|
|
|
regulator-max-microvolt = <3300000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l4a: ldo4 {
|
|
|
|
regulator-min-microvolt = <352000>;
|
|
|
|
regulator-max-microvolt = <801000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l5a: ldo5 {
|
|
|
|
regulator-min-microvolt = <1503000>;
|
|
|
|
regulator-max-microvolt = <1980000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l6a: ldo6 {
|
|
|
|
regulator-min-microvolt = <1710000>;
|
|
|
|
regulator-max-microvolt = <3544000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l7a: ldo7 {
|
|
|
|
regulator-min-microvolt = <1620000>;
|
|
|
|
regulator-max-microvolt = <1980000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l8a: ldo8 {
|
|
|
|
regulator-min-microvolt = <2800000>;
|
|
|
|
regulator-max-microvolt = <2800000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l9a: ldo9 {
|
|
|
|
regulator-min-microvolt = <1650000>;
|
|
|
|
regulator-max-microvolt = <3401000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l11a: ldo11 {
|
|
|
|
regulator-min-microvolt = <1800000>;
|
|
|
|
regulator-max-microvolt = <2000000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l12a: ldo12 {
|
|
|
|
regulator-min-microvolt = <1620000>;
|
|
|
|
regulator-max-microvolt = <1980000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l13a: ldo13 {
|
|
|
|
regulator-min-microvolt = <570000>;
|
|
|
|
regulator-max-microvolt = <650000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l14a: ldo14 {
|
|
|
|
regulator-min-microvolt = <1700000>;
|
|
|
|
regulator-max-microvolt = <1900000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l15a: ldo15 {
|
|
|
|
regulator-min-microvolt = <1100000>;
|
|
|
|
regulator-max-microvolt = <1305000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l16a: ldo16 {
|
|
|
|
regulator-min-microvolt = <830000>;
|
|
|
|
regulator-max-microvolt = <921000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l18a: ldo18 {
|
|
|
|
regulator-min-microvolt = <788000>;
|
|
|
|
regulator-max-microvolt = <1049000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l19a: ldo19 {
|
|
|
|
regulator-min-microvolt = <1080000>;
|
|
|
|
regulator-max-microvolt = <1305000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l20a: ldo20 {
|
|
|
|
regulator-min-microvolt = <530000>;
|
|
|
|
regulator-max-microvolt = <801000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l21a: ldo21 {
|
|
|
|
regulator-min-microvolt = <751000>;
|
|
|
|
regulator-max-microvolt = <825000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l22a: ldo22 {
|
|
|
|
regulator-min-microvolt = <1080000>;
|
|
|
|
regulator-max-microvolt = <1305000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
regulators-1 {
|
|
|
|
compatible = "qcom,pm6150l-rpmh-regulators";
|
|
|
|
qcom,pmic-id = "e";
|
|
|
|
|
|
|
|
vreg_s8e: smps8 {
|
|
|
|
regulator-min-microvolt = <313000>;
|
|
|
|
regulator-max-microvolt = <1395000>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l1e: ldo1 {
|
|
|
|
regulator-min-microvolt = <1620000>;
|
|
|
|
regulator-max-microvolt = <1980000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l2e: ldo2 {
|
|
|
|
regulator-min-microvolt = <1170000>;
|
|
|
|
regulator-max-microvolt = <1305000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l3e: ldo3 {
|
|
|
|
regulator-min-microvolt = <1100000>;
|
|
|
|
regulator-max-microvolt = <1299000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l4e: ldo4 {
|
|
|
|
regulator-min-microvolt = <1620000>;
|
|
|
|
regulator-max-microvolt = <3300000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l5e: ldo5 {
|
|
|
|
regulator-min-microvolt = <1620000>;
|
|
|
|
regulator-max-microvolt = <3300000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l6e: ldo6 {
|
|
|
|
regulator-min-microvolt = <1700000>;
|
|
|
|
regulator-max-microvolt = <2950000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
regulator-allow-set-load;
|
|
|
|
regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM
|
|
|
|
RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l7e: ldo7 {
|
|
|
|
regulator-min-microvolt = <2700000>;
|
|
|
|
regulator-max-microvolt = <3544000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l8e: ldo8 {
|
|
|
|
regulator-min-microvolt = <1620000>;
|
|
|
|
regulator-max-microvolt = <2000000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l9e: ldo9 {
|
|
|
|
regulator-min-microvolt = <2700000>;
|
|
|
|
regulator-max-microvolt = <2960000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
regulator-allow-set-load;
|
|
|
|
regulator-allowed-modes = <RPMH_REGULATOR_MODE_LPM
|
|
|
|
RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l10e: ldo10 {
|
|
|
|
regulator-min-microvolt = <3000000>;
|
|
|
|
regulator-max-microvolt = <3401000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_l11e: ldo11 {
|
|
|
|
regulator-min-microvolt = <3000000>;
|
|
|
|
regulator-max-microvolt = <3401000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_HPM>;
|
|
|
|
};
|
|
|
|
|
|
|
|
vreg_bob: bob {
|
|
|
|
regulator-min-microvolt = <1620000>;
|
|
|
|
regulator-max-microvolt = <5492000>;
|
|
|
|
regulator-initial-mode = <RPMH_REGULATOR_MODE_AUTO>;
|
|
|
|
regulator-allow-bypass;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&cci0 {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&cci0_i2c0 {
|
|
|
|
/* IMX582 @ 0x1a */
|
|
|
|
};
|
|
|
|
|
|
|
|
&cci0_i2c1 {
|
|
|
|
/* IMX582 @ 0x1a */
|
|
|
|
};
|
|
|
|
|
|
|
|
&cci1 {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&cci1_i2c0 {
|
|
|
|
/* IMX576 @ 0x10 */
|
|
|
|
};
|
|
|
|
|
|
|
|
&cdsp {
|
|
|
|
firmware-name = "qcom/sm7225/fairphone4/cdsp.mdt";
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&gpi_dma0 {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&gpi_dma1 {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&i2c0 {
|
|
|
|
clock-frequency = <400000>;
|
|
|
|
status = "okay";
|
|
|
|
|
|
|
|
/* ST21NFCD NFC @ 8 */
|
|
|
|
/* VL53L3 ToF @ 29 */
|
|
|
|
/* AW88264A amplifier @ 34 */
|
|
|
|
/* AW88264A amplifier @ 35 */
|
|
|
|
};
|
|
|
|
|
|
|
|
&i2c8 {
|
|
|
|
clock-frequency = <400000>;
|
|
|
|
status = "okay";
|
|
|
|
|
|
|
|
/* HX83112A touchscreen @ 48 */
|
|
|
|
};
|
|
|
|
|
|
|
|
&i2c10 {
|
|
|
|
clock-frequency = <400000>;
|
|
|
|
status = "okay";
|
|
|
|
|
|
|
|
/* PM8008 PMIC @ 8 and 9 */
|
|
|
|
/* PX8618 @ 26 */
|
|
|
|
/* SMB1395 PMIC @ 34 */
|
|
|
|
|
|
|
|
haptics@5a {
|
|
|
|
compatible = "awinic,aw8695";
|
|
|
|
reg = <0x5a>;
|
|
|
|
interrupts-extended = <&tlmm 85 IRQ_TYPE_EDGE_FALLING>;
|
|
|
|
reset-gpios = <&tlmm 90 GPIO_ACTIVE_HIGH>;
|
|
|
|
|
|
|
|
awinic,f0-preset = <2350>;
|
|
|
|
awinic,f0-coefficient = <260>;
|
|
|
|
awinic,f0-calibration-percent = <7>;
|
|
|
|
awinic,drive-level = <125>;
|
|
|
|
|
|
|
|
awinic,f0-detection-play-time = <5>;
|
|
|
|
awinic,f0-detection-wait-time = <3>;
|
|
|
|
awinic,f0-detection-repeat = <2>;
|
|
|
|
awinic,f0-detection-trace = <15>;
|
|
|
|
|
|
|
|
awinic,boost-debug = /bits/ 8 <0x30 0xeb 0xd4>;
|
|
|
|
awinic,tset = /bits/ 8 <0x12>;
|
|
|
|
awinic,r-spare = /bits/ 8 <0x68>;
|
|
|
|
|
|
|
|
awinic,bemf-upper-threshold = <4104>;
|
|
|
|
awinic,bemf-lower-threshold = <1016>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&ipa {
|
|
|
|
qcom,gsi-loader = "self";
|
|
|
|
memory-region = <&pil_ipa_fw_mem>;
|
|
|
|
firmware-name = "qcom/sm7225/fairphone4/ipa_fws.mdt";
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&mpss {
|
|
|
|
firmware-name = "qcom/sm7225/fairphone4/modem.mdt";
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&pm6150l_flash {
|
|
|
|
status = "okay";
|
|
|
|
|
|
|
|
led-0 {
|
|
|
|
function = LED_FUNCTION_FLASH;
|
|
|
|
color = <LED_COLOR_ID_YELLOW>;
|
|
|
|
led-sources = <1>;
|
|
|
|
led-max-microamp = <180000>;
|
|
|
|
flash-max-microamp = <1000000>;
|
|
|
|
flash-max-timeout-us = <1280000>;
|
|
|
|
};
|
|
|
|
|
|
|
|
led-1 {
|
|
|
|
function = LED_FUNCTION_FLASH;
|
|
|
|
color = <LED_COLOR_ID_WHITE>;
|
|
|
|
led-sources = <2>;
|
|
|
|
led-max-microamp = <180000>;
|
|
|
|
flash-max-microamp = <1000000>;
|
|
|
|
flash-max-timeout-us = <1280000>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&pm6150l_wled {
|
|
|
|
qcom,switching-freq = <800>;
|
|
|
|
qcom,current-limit-microamp = <20000>;
|
|
|
|
qcom,num-strings = <2>;
|
|
|
|
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&pm6350_gpios {
|
|
|
|
gpio_keys_pin: gpio-keys-state {
|
|
|
|
pins = "gpio2";
|
|
|
|
function = PMIC_GPIO_FUNC_NORMAL;
|
|
|
|
bias-pull-up;
|
|
|
|
input-enable;
|
|
|
|
power-source = <0>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&pm6350_resin {
|
|
|
|
linux,code = <KEY_VOLUMEDOWN>;
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&pm7250b_adc {
|
|
|
|
adc-chan@4d {
|
|
|
|
reg = <ADC5_AMUX_THM1_100K_PU>;
|
|
|
|
qcom,ratiometric;
|
|
|
|
qcom,hw-settle-time = <200>;
|
|
|
|
qcom,pre-scaling = <1 1>;
|
|
|
|
label = "charger_skin_therm";
|
|
|
|
};
|
|
|
|
|
|
|
|
adc-chan@4f {
|
|
|
|
reg = <ADC5_AMUX_THM3_100K_PU>;
|
|
|
|
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>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&pmk8350_rtc {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&pmk8350_vadc {
|
|
|
|
adc-chan@644 {
|
|
|
|
reg = <PMK8350_ADC7_AMUX_THM1_100K_PU>;
|
|
|
|
qcom,ratiometric;
|
|
|
|
qcom,hw-settle-time = <200>;
|
|
|
|
qcom,pre-scaling = <1 1>;
|
|
|
|
label = "xo_therm";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-10-24 12:59:35 +02:00
|
|
|
&qup_uart1_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_uart1_rts {
|
|
|
|
/* We'll drive RTS, so no pull */
|
|
|
|
drive-strength = <2>;
|
|
|
|
bias-disable;
|
|
|
|
};
|
|
|
|
|
|
|
|
&qup_uart1_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;
|
|
|
|
};
|
|
|
|
|
|
|
|
&qup_uart1_tx {
|
|
|
|
/* We'll drive TX, so no pull */
|
|
|
|
drive-strength = <2>;
|
|
|
|
bias-disable;
|
|
|
|
};
|
|
|
|
|
2023-08-30 17:31:07 +02:00
|
|
|
&qupv3_id_0 {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&qupv3_id_1 {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&sdc2_off_state {
|
|
|
|
sd-cd-pins {
|
|
|
|
pins = "gpio94";
|
|
|
|
function = "gpio";
|
|
|
|
drive-strength = <2>;
|
|
|
|
bias-disable;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&sdc2_on_state {
|
|
|
|
sd-cd-pins {
|
|
|
|
pins = "gpio94";
|
|
|
|
function = "gpio";
|
|
|
|
drive-strength = <2>;
|
|
|
|
bias-pull-up;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&sdhc_2 {
|
|
|
|
vmmc-supply = <&vreg_l9e>;
|
|
|
|
vqmmc-supply = <&vreg_l6e>;
|
|
|
|
|
|
|
|
cd-gpios = <&tlmm 94 GPIO_ACTIVE_LOW>;
|
|
|
|
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&tlmm {
|
|
|
|
gpio-reserved-ranges = <13 4>, <56 2>;
|
2023-10-24 12:59:35 +02:00
|
|
|
|
|
|
|
qup_uart1_sleep_cts: qup-uart1-sleep-cts-state {
|
|
|
|
pins = "gpio61";
|
|
|
|
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_uart1_sleep_rts: qup-uart1-sleep-rts-state {
|
|
|
|
pins = "gpio62";
|
|
|
|
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_uart1_sleep_rx: qup-uart1-sleep-rx-state {
|
|
|
|
pins = "gpio64";
|
|
|
|
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_uart1_sleep_tx: qup-uart1-sleep-tx-state {
|
|
|
|
pins = "gpio63";
|
|
|
|
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;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&uart1 {
|
|
|
|
/delete-property/ interrupts;
|
|
|
|
interrupts-extended = <&intc GIC_SPI 602 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<&tlmm 64 IRQ_TYPE_EDGE_FALLING>;
|
|
|
|
|
|
|
|
pinctrl-names = "default", "sleep";
|
|
|
|
pinctrl-1 = <&qup_uart1_sleep_cts>, <&qup_uart1_sleep_rts>, <&qup_uart1_sleep_tx>, <&qup_uart1_sleep_rx>;
|
|
|
|
|
|
|
|
status = "okay";
|
|
|
|
|
|
|
|
bluetooth {
|
|
|
|
compatible = "qcom,wcn3988-bt";
|
|
|
|
|
|
|
|
vddio-supply = <&vreg_l11a>;
|
|
|
|
vddxo-supply = <&vreg_l7a>;
|
|
|
|
vddrf-supply = <&vreg_l2e>;
|
|
|
|
vddch0-supply = <&vreg_l10e>;
|
|
|
|
swctrl-gpios = <&tlmm 69 GPIO_ACTIVE_HIGH>;
|
|
|
|
|
|
|
|
max-speed = <3200000>;
|
|
|
|
};
|
2023-08-30 17:31:07 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
&uart9 {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&ufs_mem_hc {
|
|
|
|
reset-gpios = <&tlmm 156 GPIO_ACTIVE_LOW>;
|
|
|
|
|
|
|
|
vcc-supply = <&vreg_l7e>;
|
|
|
|
vcc-max-microamp = <800000>;
|
|
|
|
vccq2-supply = <&vreg_l12a>;
|
|
|
|
vccq2-max-microamp = <800000>;
|
|
|
|
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&ufs_mem_phy {
|
|
|
|
vdda-phy-supply = <&vreg_l18a>;
|
|
|
|
vdda-pll-supply = <&vreg_l22a>;
|
|
|
|
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&usb_1 {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&usb_1_dwc3 {
|
|
|
|
maximum-speed = "super-speed";
|
|
|
|
dr_mode = "peripheral";
|
|
|
|
};
|
|
|
|
|
|
|
|
&usb_1_hsphy {
|
|
|
|
vdd-supply = <&vreg_l18a>;
|
|
|
|
vdda-pll-supply = <&vreg_l2a>;
|
|
|
|
vdda-phy-dpdm-supply = <&vreg_l3a>;
|
|
|
|
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&usb_1_qmpphy {
|
|
|
|
vdda-phy-supply = <&vreg_l22a>;
|
|
|
|
vdda-pll-supply = <&vreg_l16a>;
|
|
|
|
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&wifi {
|
|
|
|
vdd-0.8-cx-mx-supply = <&vreg_l4a>;
|
|
|
|
vdd-1.8-xo-supply = <&vreg_l7a>;
|
|
|
|
vdd-1.3-rfa-supply = <&vreg_l2e>;
|
|
|
|
vdd-3.3-ch0-supply = <&vreg_l10e>;
|
|
|
|
vdd-3.3-ch1-supply = <&vreg_l11e>;
|
|
|
|
|
|
|
|
status = "okay";
|
|
|
|
};
|