linux-input.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] input: goodix: Remove setting of RST pin to input
@ 2025-10-07 10:23 Martyn Welch
  2025-10-07 14:06 ` Hans de Goede
  0 siblings, 1 reply; 2+ messages in thread
From: Martyn Welch @ 2025-10-07 10:23 UTC (permalink / raw)
  To: Hans de Goede, Dmitry Torokhov
  Cc: kernel, Martyn Welch, linux-input, linux-kernel

The reset line is being set to input on non-ACPI devices apparently to
save power. This isn't being done on ACPI devices as it's been found
that some ACPI devices don't have a pull-up resistor fitted. This can
also be the case for non-ACPI devices, resulting in:

[  941.672207] Goodix-TS 1-0014: Error reading 10 bytes from 0x814e: -110
[  942.696168] Goodix-TS 1-0014: Error reading 10 bytes from 0x814e: -110
[  945.832208] Goodix-TS 1-0014: Error reading 10 bytes from 0x814e: -110

This behaviour appears to have been initially introduced in ec6e1b4082d9.
This doesn't seem to be based on information in either the GT911 or GT9271
datasheets cited as sources of information for this change. Thus it seems
likely that it is based on functionality in the Android driver which it
also lists. This behaviour may be viable in very specific instances where
the hardware is known to have a pull-up fitted, but seems unwise in the
upstream kernel where such hardware requirements can't be guaranteed.

Remove this over optimisation to improve reliability on non-ACPI
devices.

Signed-off-by: Martyn Welch <martyn.welch@collabora.com>

---
 drivers/input/touchscreen/goodix.c | 11 -----------
 1 file changed, 11 deletions(-)

diff --git a/drivers/input/touchscreen/goodix.c b/drivers/input/touchscreen/goodix.c
index 252dcae039f8..e7ef744011ad 100644
--- a/drivers/input/touchscreen/goodix.c
+++ b/drivers/input/touchscreen/goodix.c
@@ -796,17 +796,6 @@ int goodix_reset_no_int_sync(struct goodix_ts_data *ts)
 
 	usleep_range(6000, 10000);		/* T4: > 5ms */
 
-	/*
-	 * Put the reset pin back in to input / high-impedance mode to save
-	 * power. Only do this in the non ACPI case since some ACPI boards
-	 * don't have a pull-up, so there the reset pin must stay active-high.
-	 */
-	if (ts->irq_pin_access_method == IRQ_PIN_ACCESS_GPIO) {
-		error = gpiod_direction_input(ts->gpiod_rst);
-		if (error)
-			goto error;
-	}
-
 	return 0;
 
 error:
-- 
2.39.5


^ permalink raw reply related	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2025-10-07 14:06 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-10-07 10:23 [PATCH] input: goodix: Remove setting of RST pin to input Martyn Welch
2025-10-07 14:06 ` Hans de Goede

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).