// 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; serial1 = &uart1; }; 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 { channel@4d { reg = <ADC5_AMUX_THM1_100K_PU>; qcom,ratiometric; qcom,hw-settle-time = <200>; qcom,pre-scaling = <1 1>; label = "charger_skin_therm"; }; channel@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 { channel@644 { reg = <PMK8350_ADC7_AMUX_THM1_100K_PU>; qcom,ratiometric; qcom,hw-settle-time = <200>; qcom,pre-scaling = <1 1>; label = "xo_therm"; }; }; &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; }; &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>; 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>; }; }; &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"; };