162306a36Sopenharmony_ci// SPDX-License-Identifier: BSD-3-Clause
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright (c) 2020, Konrad Dybcio
462306a36Sopenharmony_ci */
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci#include <dt-bindings/iio/qcom,spmi-vadc.h>
762306a36Sopenharmony_ci#include <dt-bindings/input/linux-event-codes.h>
862306a36Sopenharmony_ci#include <dt-bindings/interrupt-controller/irq.h>
962306a36Sopenharmony_ci#include <dt-bindings/spmi/spmi.h>
1062306a36Sopenharmony_ci#include <dt-bindings/thermal/thermal.h>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ci/ {
1362306a36Sopenharmony_ci	thermal-zones {
1462306a36Sopenharmony_ci		pm660-thermal {
1562306a36Sopenharmony_ci			polling-delay-passive = <250>;
1662306a36Sopenharmony_ci			polling-delay = <1000>;
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci			thermal-sensors = <&pm660_temp>;
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci			trips {
2162306a36Sopenharmony_ci				pm660_alert0: pm660-alert0 {
2262306a36Sopenharmony_ci					temperature = <95000>;
2362306a36Sopenharmony_ci					hysteresis = <2000>;
2462306a36Sopenharmony_ci					type = "passive";
2562306a36Sopenharmony_ci				};
2662306a36Sopenharmony_ci				pm660_crit: pm660-crit {
2762306a36Sopenharmony_ci					temperature = <125000>;
2862306a36Sopenharmony_ci					hysteresis = <2000>;
2962306a36Sopenharmony_ci					type = "critical";
3062306a36Sopenharmony_ci				};
3162306a36Sopenharmony_ci			};
3262306a36Sopenharmony_ci		};
3362306a36Sopenharmony_ci	};
3462306a36Sopenharmony_ci};
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci&spmi_bus {
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci	pmic@0 {
3962306a36Sopenharmony_ci		compatible = "qcom,pm660", "qcom,spmi-pmic";
4062306a36Sopenharmony_ci		reg = <0x0 SPMI_USID>;
4162306a36Sopenharmony_ci		#address-cells = <1>;
4262306a36Sopenharmony_ci		#size-cells = <0>;
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ci		rtc@6000 {
4562306a36Sopenharmony_ci			compatible = "qcom,pm8941-rtc";
4662306a36Sopenharmony_ci			reg = <0x6000>, <0x6100>;
4762306a36Sopenharmony_ci			reg-names = "rtc", "alarm";
4862306a36Sopenharmony_ci			interrupts = <0x0 0x61 0x1 IRQ_TYPE_EDGE_RISING>;
4962306a36Sopenharmony_ci		};
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci		pon: pon@800 {
5262306a36Sopenharmony_ci			compatible = "qcom,pm8998-pon";
5362306a36Sopenharmony_ci			reg = <0x800>;
5462306a36Sopenharmony_ci			mode-bootloader = <0x2>;
5562306a36Sopenharmony_ci			mode-recovery = <0x1>;
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci			pon_pwrkey: pwrkey {
5862306a36Sopenharmony_ci				compatible = "qcom,pm8941-pwrkey";
5962306a36Sopenharmony_ci				interrupts = <0x0 0x8 0 IRQ_TYPE_EDGE_BOTH>;
6062306a36Sopenharmony_ci				debounce = <15625>;
6162306a36Sopenharmony_ci				bias-pull-up;
6262306a36Sopenharmony_ci				linux,code = <KEY_POWER>;
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ci				status = "disabled";
6562306a36Sopenharmony_ci			};
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ci			pon_resin: resin {
6862306a36Sopenharmony_ci				compatible = "qcom,pm8941-resin";
6962306a36Sopenharmony_ci				interrupts = <0x0 0x8 1 IRQ_TYPE_EDGE_BOTH>;
7062306a36Sopenharmony_ci				debounce = <15625>;
7162306a36Sopenharmony_ci				bias-pull-up;
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci				status = "disabled";
7462306a36Sopenharmony_ci			};
7562306a36Sopenharmony_ci		};
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_ci		pm660_temp: temp-alarm@2400 {
7862306a36Sopenharmony_ci			compatible = "qcom,spmi-temp-alarm";
7962306a36Sopenharmony_ci			reg = <0x2400>;
8062306a36Sopenharmony_ci			interrupts = <0x0 0x24 0x0 IRQ_TYPE_EDGE_RISING>;
8162306a36Sopenharmony_ci			io-channels = <&pm660_adc ADC5_DIE_TEMP>;
8262306a36Sopenharmony_ci			io-channel-names = "thermal";
8362306a36Sopenharmony_ci			#thermal-sensor-cells = <0>;
8462306a36Sopenharmony_ci		};
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_ci		pm660_adc: adc@3100 {
8762306a36Sopenharmony_ci			compatible = "qcom,spmi-adc-rev2";
8862306a36Sopenharmony_ci			reg = <0x3100>;
8962306a36Sopenharmony_ci			interrupts = <0x0 0x31 0x0 IRQ_TYPE_EDGE_RISING>;
9062306a36Sopenharmony_ci			#address-cells = <1>;
9162306a36Sopenharmony_ci			#size-cells = <0>;
9262306a36Sopenharmony_ci			#io-channel-cells = <1>;
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_ci			channel@0 {
9562306a36Sopenharmony_ci				reg = <ADC5_REF_GND>;
9662306a36Sopenharmony_ci				qcom,decimation = <1024>;
9762306a36Sopenharmony_ci				qcom,pre-scaling = <1 1>;
9862306a36Sopenharmony_ci				label = "ref_gnd";
9962306a36Sopenharmony_ci			};
10062306a36Sopenharmony_ci
10162306a36Sopenharmony_ci			channel@1 {
10262306a36Sopenharmony_ci				reg = <ADC5_1P25VREF>;
10362306a36Sopenharmony_ci				qcom,decimation = <1024>;
10462306a36Sopenharmony_ci				qcom,pre-scaling = <1 1>;
10562306a36Sopenharmony_ci				label = "vref_1p25";
10662306a36Sopenharmony_ci			};
10762306a36Sopenharmony_ci
10862306a36Sopenharmony_ci			channel@6 {
10962306a36Sopenharmony_ci				reg = <ADC5_DIE_TEMP>;
11062306a36Sopenharmony_ci				qcom,decimation = <1024>;
11162306a36Sopenharmony_ci				qcom,pre-scaling = <1 1>;
11262306a36Sopenharmony_ci				label = "die_temp";
11362306a36Sopenharmony_ci			};
11462306a36Sopenharmony_ci
11562306a36Sopenharmony_ci			channel@4c {
11662306a36Sopenharmony_ci				reg = <ADC5_XO_THERM_100K_PU>;
11762306a36Sopenharmony_ci				qcom,pre-scaling = <1 1>;
11862306a36Sopenharmony_ci				qcom,decimation = <1024>;
11962306a36Sopenharmony_ci				qcom,hw-settle-time = <200>;
12062306a36Sopenharmony_ci				qcom,ratiometric;
12162306a36Sopenharmony_ci				label = "xo_therm";
12262306a36Sopenharmony_ci			};
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_ci			channel@4d {
12562306a36Sopenharmony_ci				reg = <ADC5_AMUX_THM1_100K_PU>;
12662306a36Sopenharmony_ci				qcom,pre-scaling = <1 1>;
12762306a36Sopenharmony_ci				qcom,decimation = <1024>;
12862306a36Sopenharmony_ci				qcom,hw-settle-time = <200>;
12962306a36Sopenharmony_ci				qcom,ratiometric;
13062306a36Sopenharmony_ci				label = "msm_therm";
13162306a36Sopenharmony_ci			};
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci			channel@4e {
13462306a36Sopenharmony_ci				reg = <ADC5_AMUX_THM2_100K_PU>;
13562306a36Sopenharmony_ci				qcom,pre-scaling = <1 1>;
13662306a36Sopenharmony_ci				qcom,decimation = <1024>;
13762306a36Sopenharmony_ci				qcom,hw-settle-time = <200>;
13862306a36Sopenharmony_ci				qcom,ratiometric;
13962306a36Sopenharmony_ci				label = "emmc_therm";
14062306a36Sopenharmony_ci			};
14162306a36Sopenharmony_ci
14262306a36Sopenharmony_ci			channel@4f {
14362306a36Sopenharmony_ci				reg = <ADC5_AMUX_THM3_100K_PU>;
14462306a36Sopenharmony_ci				qcom,pre-scaling = <1 1>;
14562306a36Sopenharmony_ci				qcom,decimation = <1024>;
14662306a36Sopenharmony_ci				qcom,hw-settle-time = <200>;
14762306a36Sopenharmony_ci				qcom,ratiometric;
14862306a36Sopenharmony_ci				label = "pa_therm0";
14962306a36Sopenharmony_ci			};
15062306a36Sopenharmony_ci
15162306a36Sopenharmony_ci			channel@50 {
15262306a36Sopenharmony_ci				reg = <ADC5_AMUX_THM4_100K_PU>;
15362306a36Sopenharmony_ci				qcom,pre-scaling = <1 1>;
15462306a36Sopenharmony_ci				qcom,decimation = <1024>;
15562306a36Sopenharmony_ci				qcom,hw-settle-time = <200>;
15662306a36Sopenharmony_ci				qcom,ratiometric;
15762306a36Sopenharmony_ci				label = "pa_therm1";
15862306a36Sopenharmony_ci			};
15962306a36Sopenharmony_ci
16062306a36Sopenharmony_ci			channel@51 {
16162306a36Sopenharmony_ci				reg = <ADC5_AMUX_THM5_100K_PU>;
16262306a36Sopenharmony_ci				qcom,pre-scaling = <1 1>;
16362306a36Sopenharmony_ci				qcom,decimation = <1024>;
16462306a36Sopenharmony_ci				qcom,hw-settle-time = <200>;
16562306a36Sopenharmony_ci				qcom,ratiometric;
16662306a36Sopenharmony_ci				label = "quiet_therm";
16762306a36Sopenharmony_ci			};
16862306a36Sopenharmony_ci
16962306a36Sopenharmony_ci			channel@83 {
17062306a36Sopenharmony_ci				reg = <ADC5_VPH_PWR>;
17162306a36Sopenharmony_ci				qcom,decimation = <1024>;
17262306a36Sopenharmony_ci				qcom,pre-scaling = <1 3>;
17362306a36Sopenharmony_ci				label = "vph_pwr";
17462306a36Sopenharmony_ci			};
17562306a36Sopenharmony_ci
17662306a36Sopenharmony_ci			channel@85 {
17762306a36Sopenharmony_ci				reg = <ADC5_VCOIN>;
17862306a36Sopenharmony_ci				qcom,decimation = <1024>;
17962306a36Sopenharmony_ci				qcom,pre-scaling = <1 3>;
18062306a36Sopenharmony_ci				label = "vcoin";
18162306a36Sopenharmony_ci			};
18262306a36Sopenharmony_ci		};
18362306a36Sopenharmony_ci
18462306a36Sopenharmony_ci		pm660_gpios: gpio@c000 {
18562306a36Sopenharmony_ci			compatible = "qcom,pm660-gpio", "qcom,spmi-gpio";
18662306a36Sopenharmony_ci			reg = <0xc000>;
18762306a36Sopenharmony_ci			gpio-controller;
18862306a36Sopenharmony_ci			gpio-ranges = <&pm660_gpios 0 0 13>;
18962306a36Sopenharmony_ci			#gpio-cells = <2>;
19062306a36Sopenharmony_ci			interrupt-controller;
19162306a36Sopenharmony_ci			#interrupt-cells = <2>;
19262306a36Sopenharmony_ci		};
19362306a36Sopenharmony_ci	};
19462306a36Sopenharmony_ci
19562306a36Sopenharmony_ci	pmic@1 {
19662306a36Sopenharmony_ci		compatible = "qcom,pm660", "qcom,spmi-pmic";
19762306a36Sopenharmony_ci		reg = <0x1 SPMI_USID>;
19862306a36Sopenharmony_ci		#address-cells = <1>;
19962306a36Sopenharmony_ci		#size-cells = <0>;
20062306a36Sopenharmony_ci
20162306a36Sopenharmony_ci		pm660_spmi_regulators: regulators {
20262306a36Sopenharmony_ci			compatible = "qcom,pm660-regulators";
20362306a36Sopenharmony_ci		};
20462306a36Sopenharmony_ci	};
20562306a36Sopenharmony_ci};
206