Message ID | 20241031-msm8917-v2-0-8a075faa89b1@mainlining.org |
---|---|
Headers | show |
Series | Add MSM8917/PM8937/Redmi 5A | expand |
On Thu, Oct 31, 2024 at 02:19:43AM +0100, Barnabás Czémán wrote: > PM8937 has 8 GPIO-s with holes on GPIO3, GPIO4 and GPIO6. > > Signed-off-by: Barnabás Czémán <barnabas.czeman@mainlining.org> > --- > drivers/pinctrl/qcom/pinctrl-spmi-gpio.c | 2 ++ > 1 file changed, 2 insertions(+) > Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
On Thu, Oct 31, 2024 at 02:19:45AM +0100, Barnabás Czémán wrote: > The PM8937 provides 4 MPPs. > Add a compatible to support them. > > Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> > Signed-off-by: Barnabás Czémán <barnabas.czeman@mainlining.org> > --- > drivers/pinctrl/qcom/pinctrl-spmi-mpp.c | 1 + > 1 file changed, 1 insertion(+) > Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
On Thu, Oct 31, 2024 at 02:19:46AM +0100, Barnabás Czémán wrote: > From: Dang Huynh <danct12@riseup.net> > > The PM8937 features integrated peripherals like ADC, GPIO controller, > MPPs, PON keys and others. > > Add the device tree so that any boards with this PMIC can use it. > > Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> > Signed-off-by: Dang Huynh <danct12@riseup.net> > Signed-off-by: Barnabás Czémán <barnabas.czeman@mainlining.org> > --- > arch/arm64/boot/dts/qcom/pm8937.dtsi | 216 +++++++++++++++++++++++++++++++++++ > 1 file changed, 216 insertions(+) > > diff --git a/arch/arm64/boot/dts/qcom/pm8937.dtsi b/arch/arm64/boot/dts/qcom/pm8937.dtsi > new file mode 100644 > index 0000000000000000000000000000000000000000..34e2b4cd0d5f4f92c16bb20f53e4520544a644bc > --- /dev/null > +++ b/arch/arm64/boot/dts/qcom/pm8937.dtsi > @@ -0,0 +1,216 @@ > +// SPDX-License-Identifier: BSD-3-Clause > +/* > + * Copyright (c) 2023, Dang Huynh <danct12@riseup.net> > + */ > + > +#include <dt-bindings/iio/qcom,spmi-vadc.h> > +#include <dt-bindings/input/linux-event-codes.h> > +#include <dt-bindings/interrupt-controller/irq.h> > +#include <dt-bindings/pinctrl/qcom,pmic-mpp.h> > +#include <dt-bindings/spmi/spmi.h> > + > +/ { > + thermal-zones { > + pm8937-thermal { > + polling-delay-passive = <0>; > + polling-delay = <0>; > + thermal-sensors = <&pm8937_temp>; > + > + trips { > + trip0 { > + temperature = <105000>; > + hysteresis = <0>; > + type = "passive"; > + }; > + > + trip1 { > + temperature = <125000>; > + hysteresis = <0>; > + type = "hot"; > + }; > + > + trip2 { > + temperature = <145000>; > + hysteresis = <0>; > + type = "critical"; > + }; > + }; > + }; > + }; > +}; > + > +&spmi_bus { > + pmic@0 { > + compatible = "qcom,pm8937", "qcom,spmi-pmic"; > + reg = <0x0 SPMI_USID>; > + #address-cells = <1>; > + #size-cells = <0>; > + > + pon@800 { > + compatible = "qcom,pm8916-pon"; > + reg = <0x800>; > + mode-bootloader = <0x2>; > + mode-recovery = <0x1>; > + > + pm8937_pwrkey: pwrkey { > + compatible = "qcom,pm8941-pwrkey"; > + interrupts = <0 0x8 0 IRQ_TYPE_EDGE_BOTH>; > + debounce = <15625>; > + bias-pull-up; > + linux,code = <KEY_POWER>; > + }; > + > + pm8937_resin: resin { > + compatible = "qcom,pm8941-resin"; > + interrupts = <0 0x8 1 IRQ_TYPE_EDGE_BOTH>; > + debounce = <15625>; > + bias-pull-up; > + status = "disabled"; > + }; > + }; > + > + pm8937_gpios: gpio@c000 { > + compatible = "qcom,pm8937-gpio", "qcom,spmi-gpio"; > + reg = <0xc000>; > + gpio-controller; > + gpio-ranges = <&pm8937_gpios 0 0 8>; > + #gpio-cells = <2>; > + interrupt-controller; > + #interrupt-cells = <2>; > + }; > + > + pm8937_mpps: mpps@a000 { > + compatible = "qcom,pm8937-mpp", "qcom,spmi-mpp"; > + reg = <0xa000>; > + gpio-controller; > + gpio-ranges = <&pm8937_mpps 0 0 4>; > + #gpio-cells = <2>; > + interrupt-controller; > + #interrupt-cells = <2>; > + }; > + > + pm8937_temp: temp-alarm@2400 { > + compatible = "qcom,spmi-temp-alarm"; > + reg = <0x2400>; > + interrupts = <0 0x24 0 IRQ_TYPE_EDGE_RISING>; > + io-channels = <&pm8937_vadc VADC_DIE_TEMP>; > + io-channel-names = "thermal"; > + #thermal-sensor-cells = <0>; > + }; > + > + pm8937_vadc: adc@3100 { > + compatible = "qcom,spmi-vadc"; > + reg = <0x3100>; > + interrupts = <0 0x31 0 IRQ_TYPE_EDGE_RISING>; > + #address-cells = <1>; > + #size-cells = <0>; > + #io-channel-cells = <1>; > + > + channel@5 { > + reg = <VADC_VCOIN>; > + qcom,pre-scaling = <1 1>; > + label = "vcoin"; Are all the channels available and usable on all the boards? > + }; > + > + channel@7 { > + reg = <VADC_VSYS>; > + qcom,pre-scaling = <1 1>; > + label = "vph_pwr"; > + }; > + > + channel@8 { > + reg = <VADC_DIE_TEMP>; > + qcom,pre-scaling = <1 1>; > + label = "die_temp"; > + }; > + > + channel@9 { > + reg = <VADC_REF_625MV>; > + qcom,pre-scaling = <1 1>; > + label = "ref_625mv"; > + }; > + > + channel@a { > + reg = <VADC_REF_1250MV>; > + qcom,pre-scaling = <1 1>; > + label = "ref_1250mv"; > + }; > + > + channel@c { > + reg = <VADC_SPARE1>; > + qcom,pre-scaling = <1 1>; > + label = "ref_buf_625mv"; > + }; > + > + channel@e { > + reg = <VADC_GND_REF>; > + qcom,pre-scaling = <1 1>; > + label = "ref_gnd"; > + }; > + > + channel@f { > + reg = <VADC_VDD_VADC>; > + qcom,pre-scaling = <1 1>; > + label = "ref_vdd"; > + }; > + > + channel@11 { > + reg = <VADC_P_MUX2_1_1>; > + qcom,pre-scaling = <1 1>; > + qcom,ratiometric; > + qcom,hw-settle-time = <200>; > + label = "pa_therm1"; > + }; > + > + channel@13 { > + reg = <VADC_P_MUX4_1_1>; > + qcom,pre-scaling = <1 1>; > + qcom,ratiometric; > + qcom,hw-settle-time = <200>; > + label = "case_therm"; This one looks particularly board-specific. Please move device-specific channels to the board.dtsi. > + }; > + > + channel@32 { > + reg = <VADC_LR_MUX3_XO_THERM>; > + qcom,pre-scaling = <1 1>; > + qcom,ratiometric; > + qcom,hw-settle-time = <200>; > + label = "xo_therm"; > + }; > + > + channel@36 { > + reg = <VADC_LR_MUX7_HW_ID>; > + qcom,pre-scaling = <1 1>; > + qcom,ratiometric; > + qcom,hw-settle-time = <200>; > + label = "pa_therm0"; > + }; > + > + channel@3c { > + reg = <VADC_LR_MUX3_BUF_XO_THERM>; > + qcom,pre-scaling = <1 1>; > + qcom,ratiometric; > + qcom,hw-settle-time = <200>; > + label = "xo_therm_buf"; > + }; > + }; > + > + rtc@6000 { > + compatible = "qcom,pm8941-rtc"; > + reg = <0x6000>, <0x6100>; > + reg-names = "rtc", "alarm"; > + interrupts = <0x0 0x61 0x1 IRQ_TYPE_EDGE_RISING>; > + }; > + }; > + > + pmic@1 { > + compatible = "qcom,pm8937", "qcom,spmi-pmic"; > + reg = <0x1 SPMI_USID>; > + #address-cells = <1>; > + #size-cells = <0>; > + > + pm8937_spmi_regulators: regulators { > + compatible = "qcom,pm8937-regulators"; > + }; > + }; > +}; > > -- > 2.47.0 >
On Thu, Oct 31, 2024 at 02:19:51AM +0100, Barnabás Czémán wrote: > Add support for tsens v1.4 block what can be found in > MSM8937 and MSM8917. > > Signed-off-by: Barnabás Czémán <barnabas.czeman@mainlining.org> > --- > drivers/thermal/qcom/tsens-v1.c | 13 +++++++++++++ > drivers/thermal/qcom/tsens.c | 3 +++ > drivers/thermal/qcom/tsens.h | 2 +- > 3 files changed, 17 insertions(+), 1 deletion(-) > Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
On 31.10.2024 2:19 AM, Barnabás Czémán wrote: > Add initial support for Xiaomi Redmi 5A (riva). > > Signed-off-by: Barnabás Czémán <barnabas.czeman@mainlining.org> > --- [...] > + reserved-memory { > + /delete-node/ reserved@85b00000; Deleting nodes is preferred via a &label (like in sm8550-samsung-q5q.dts) > + qseecom_mem: reserved@84a00000 { > + reg = <0x0 0x84a00000 0x0 0x1900000>; > + no-map; > + }; > + > + framebuffer_mem: memory@90001000 { > + reg = <0x0 0x90001000 0x0 (720 * 1280 * 3)>; > + no-map; > + }; > + }; > +}; > + > +&blsp_i2c3 { > + status = "okay"; > + > + touchscreen@38 { > + compatible = "edt,edt-ft5306"; > + reg = <0x38>; > + interrupt-parent = <&tlmm>; > + interrupts = <65 0x2008>; interrupts-extended = <&tlmm 65 IRQ_TYPE_LEVEL_LOW>; [...] > +&sdhc_1 { > + vmmc-supply = <&pm8937_l8>; > + vqmmc-supply = <&pm8937_l5>; > + status = "okay"; A newline before 'status' would be welcome Looks nice otherwise! Konrad
On Thu, Oct 31, 2024 at 2:19 AM Barnabás Czémán <barnabas.czeman@mainlining.org> wrote: > PM8937 has 8 GPIO-s with holes on GPIO3, GPIO4 and GPIO6. > > Signed-off-by: Barnabás Czémán <barnabas.czeman@mainlining.org> Patch applied for v6.13. Yours, Linus Walleij
On Thu, Oct 31, 2024 at 2:19 AM Barnabás Czémán <barnabas.czeman@mainlining.org> wrote: > The PM8937 provides 4 MPPs. > Add a compatible to support them. > > Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> > Signed-off-by: Barnabás Czémán <barnabas.czeman@mainlining.org> Patch applied for v6.13. Yours, Linus Walleij
This patch series add support for MSM8917 soc with PM8937 and Xiaomi Redmi 5A (riva). Signed-off-by: Barnabás Czémán <barnabas.czeman@mainlining.org> --- Changes in v2: - Add msm8937 tsens support. - Fix issues addressed by reviews. - Link to v1: https://lore.kernel.org/r/20241019-msm8917-v1-0-f1f3ca1d88e5@mainlining.org --- Barnabás Czémán (12): dt-bindings: pinctrl: qcom,pmic-gpio: add PM8937 pinctrl: qcom-pmic-gpio: add support for PM8937 dt-bindings: pinctrl: qcom,pmic-mpp: Document PM8937 compatible pinctrl: qcom: spmi-mpp: Add PM8937 compatible dt-bindings: pinctrl: qcom: Add MSM8917 pinctrl bindings dt-bindings: mfd: qcom,tcsr: Add compatible for MSM8917 dt-bindings: thermal: tsens: Add MSM8937 compatible thermal/drivers/qcom/tsens-v1: Add support for MSM8937 tsens dt-bindings: iommu: qcom,iommu: Add MSM8917 IOMMU to SMMUv1 compatibles dt-bindings: nvmem: Add compatible for MS8917 dt-bindings: arm: qcom: Add Xiaomi Redmi 5A arm64: dts: qcom: Add Xiaomi Redmi 5A Dang Huynh (1): arm64: dts: qcom: Add PM8937 PMIC Otto Pflüger (2): pinctrl: qcom: Add MSM8917 tlmm pinctrl driver arm64: dts: qcom: Add initial support for MSM8917 Documentation/devicetree/bindings/arm/qcom.yaml | 7 + .../devicetree/bindings/iommu/qcom,iommu.yaml | 1 + .../devicetree/bindings/mfd/qcom,tcsr.yaml | 1 + .../devicetree/bindings/nvmem/qcom,qfprom.yaml | 1 + .../bindings/pinctrl/qcom,msm8917-pinctrl.yaml | 155 ++ .../bindings/pinctrl/qcom,pmic-gpio.yaml | 3 + .../devicetree/bindings/pinctrl/qcom,pmic-mpp.yaml | 2 + .../devicetree/bindings/thermal/qcom-tsens.yaml | 1 + arch/arm64/boot/dts/qcom/Makefile | 1 + arch/arm64/boot/dts/qcom/msm8917-xiaomi-riva.dts | 293 +++ arch/arm64/boot/dts/qcom/msm8917.dtsi | 1999 ++++++++++++++++++++ arch/arm64/boot/dts/qcom/pm8937.dtsi | 216 +++ drivers/pinctrl/qcom/Kconfig.msm | 6 + drivers/pinctrl/qcom/Makefile | 1 + drivers/pinctrl/qcom/pinctrl-msm8917.c | 1620 ++++++++++++++++ drivers/pinctrl/qcom/pinctrl-spmi-gpio.c | 2 + drivers/pinctrl/qcom/pinctrl-spmi-mpp.c | 1 + drivers/thermal/qcom/tsens-v1.c | 13 + drivers/thermal/qcom/tsens.c | 3 + drivers/thermal/qcom/tsens.h | 2 +- 20 files changed, 4327 insertions(+), 1 deletion(-) --- base-commit: f2493655d2d3d5c6958ed996b043c821c23ae8d3 change-id: 20241019-msm8917-17c3d0ff4a52 Best regards,