diff --git a/core/embed/prodtest/.changelog.d/4252.added b/core/embed/prodtest/.changelog.d/4252.added new file mode 100644 index 0000000000..2311fe4cd1 --- /dev/null +++ b/core/embed/prodtest/.changelog.d/4252.added @@ -0,0 +1 @@ +Added TOUCH_POWER command to allow testing touch power supply without connected touch screen diff --git a/core/embed/prodtest/README.md b/core/embed/prodtest/README.md index 64d6eb4ced..4efd2effc0 100644 --- a/core/embed/prodtest/README.md +++ b/core/embed/prodtest/README.md @@ -148,6 +148,20 @@ TOUCH_IDLE 10 OK ``` +### TOUCH_POWER +The `TOUCH_POWER` command tests the functionality of touch layer power supply + +The command requires one input parameter: +* The timeout in seconds + +The powers up the touch layer and waits for a specific time period so that measurement can be done by test equipment. + +Example - wait ten seconds for touch power measurement: +``` +TOUCH_POWER 10 +OK +``` + ### SENS The `SENS` command is used to evaluating the touch screen sensitivity. It draws a filled box around the touch coordinates. diff --git a/core/embed/prodtest/main.c b/core/embed/prodtest/main.c index 365bc65ff6..897b2d22f4 100644 --- a/core/embed/prodtest/main.c +++ b/core/embed/prodtest/main.c @@ -498,6 +498,38 @@ static void test_touch_idle(const char *args) { touch_deinit(); } +static void test_touch_power(const char *args) { + static const int expected_params = 1; + int num_params = 0; + + int params[expected_params]; + + extract_params(args, params, &num_params, expected_params); + + if (num_params != expected_params) { + vcp_println("ERROR PARAM"); + return; + } + + int timeout = params[0]; + + display_clear(); + display_text_center(DISPLAY_RESX / 2, DISPLAY_RESY / 2, "MEASURING", -1, + FONT_BOLD, COLOR_WHITE, COLOR_BLACK); + display_refresh(); + + touch_power_set(true); + + systick_delay_ms(timeout * 1000); + + vcp_println("OK"); + + touch_power_set(false); + + display_clear(); + display_refresh(); +} + static void test_sensitivity(const char *args) { int v = atoi(args); @@ -869,6 +901,9 @@ int main(void) { } else if (startswith(line, "TOUCH_IDLE ")) { test_touch_idle(line + 11); + } else if (startswith(line, "TOUCH_POWER ")) { + test_touch_power(line + 12); + } else if (startswith(line, "SENS ")) { test_sensitivity(line + 5); diff --git a/core/embed/trezorhal/stm32f4/touch/ft6x36.c b/core/embed/trezorhal/stm32f4/touch/ft6x36.c index e037c5bc8b..d6e419c37b 100644 --- a/core/embed/trezorhal/stm32f4/touch/ft6x36.c +++ b/core/embed/trezorhal/stm32f4/touch/ft6x36.c @@ -303,6 +303,15 @@ void touch_deinit(void) { } } +void touch_power_set(bool on) { + if (on) { + ft6x36_power_up(); + } else { + touch_deinit(); + ft6x36_power_down(); + } +} + secbool touch_ready(void) { touch_driver_t* driver = &g_touch_driver; diff --git a/core/embed/trezorhal/stm32f4/touch/stmpe811.c b/core/embed/trezorhal/stm32f4/touch/stmpe811.c index 3d3003999a..f3590f07b4 100644 --- a/core/embed/trezorhal/stm32f4/touch/stmpe811.c +++ b/core/embed/trezorhal/stm32f4/touch/stmpe811.c @@ -642,6 +642,10 @@ void touch_deinit(void) { } } +void touch_power_set(bool on) { + // Not implemented for the discovery kit +} + secbool touch_ready(void) { touch_driver_t *driver = &g_touch_driver; return driver->initialized; diff --git a/core/embed/trezorhal/stm32u5/touch/sitronix.c b/core/embed/trezorhal/stm32u5/touch/sitronix.c index eb4d127cfc..bc951bde82 100644 --- a/core/embed/trezorhal/stm32u5/touch/sitronix.c +++ b/core/embed/trezorhal/stm32u5/touch/sitronix.c @@ -1253,6 +1253,10 @@ void touch_deinit(void) { } } +void touch_power_set(bool on) { + // Not implemented for the discovery kit +} + secbool touch_ready(void) { touch_driver_t *driver = &g_touch_driver; return driver->initialized; diff --git a/core/embed/trezorhal/touch.h b/core/embed/trezorhal/touch.h index 05843d1e36..ff5738eecf 100644 --- a/core/embed/trezorhal/touch.h +++ b/core/embed/trezorhal/touch.h @@ -1,6 +1,7 @@ #ifndef TREZOR_HAL_TOUCH_H #define TREZOR_HAL_TOUCH_H +#include #include #include "secbool.h" @@ -19,6 +20,12 @@ secbool touch_init(void); // The function deinitializes touch controller and powers it off. void touch_deinit(); +// Powers on/off the touch controller +// +// The function is used to test touch power supply during production. +// After forcing power off, the touch controller needs to be re-initialized +void touch_power_set(bool on); + // Checks if the touch driver is ready to report touches // // Some drivers need time after power-up to stabilize. The app diff --git a/core/embed/trezorhal/unix/touch.c b/core/embed/trezorhal/unix/touch.c index 5b8e24c8d9..194ee6c45c 100644 --- a/core/embed/trezorhal/unix/touch.c +++ b/core/embed/trezorhal/unix/touch.c @@ -216,6 +216,10 @@ void touch_deinit(void) { } } +void touch_power_set(bool on) { + // Not implemented on the emulator +} + secbool touch_ready(void) { touch_driver_t* driver = &g_touch_driver; return driver->initialized;