[PATCH] arm64: dts: qcom: sc8280xp-x13s: enable alternate touchpad

From: Johan Hovold
Date: Fri Mar 24 2023 - 05:48:51 EST


Enable both touchpad nodes in the devictree and let the HID driver
determine which one is actually populated (by attempting to read from
each i2c address).

Ideally this would not be needed and the boot firmware should instead
enable only the node for the populated touchpad, but this is unlikely to
ever be realised for the X13s.

Note that the pin configuration must currently be moved to the parent
i2c-bus node even though only one of these nodes will ever be
successfully probed on a specific device (e.g. to allow them to be
probed in parallel).

Signed-off-by: Johan Hovold <johan+linaro@xxxxxxxxxx>
---
.../boot/dts/qcom/sc8280xp-lenovo-thinkpad-x13s.dts | 10 +---------
1 file changed, 1 insertion(+), 9 deletions(-)

diff --git a/arch/arm64/boot/dts/qcom/sc8280xp-lenovo-thinkpad-x13s.dts b/arch/arm64/boot/dts/qcom/sc8280xp-lenovo-thinkpad-x13s.dts
index 6addc91d7c74..d7de7cb22d75 100644
--- a/arch/arm64/boot/dts/qcom/sc8280xp-lenovo-thinkpad-x13s.dts
+++ b/arch/arm64/boot/dts/qcom/sc8280xp-lenovo-thinkpad-x13s.dts
@@ -641,7 +641,7 @@ &i2c21 {
clock-frequency = <400000>;

pinctrl-names = "default";
- pinctrl-0 = <&i2c21_default>;
+ pinctrl-0 = <&i2c21_default>, <&tpad_default>;

status = "okay";

@@ -654,12 +654,7 @@ touchpad@15 {
vdd-supply = <&vreg_misc_3p3>;
vddl-supply = <&vreg_s10b>;

- pinctrl-names = "default";
- pinctrl-0 = <&tpad_default>;
-
wakeup-source;
-
- status = "disabled";
};

touchpad@2c {
@@ -671,9 +666,6 @@ touchpad@2c {
vdd-supply = <&vreg_misc_3p3>;
vddl-supply = <&vreg_s10b>;

- pinctrl-names = "default";
- pinctrl-0 = <&tpad_default>;
-
wakeup-source;
};

--
2.39.2