1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-05 04:50:57 +00:00

fix(core/bootloader): fix ignoring disconnected touch in production mode

[no changelog]
This commit is contained in:
tychovrahe 2024-09-19 08:58:39 +02:00 committed by TychoVrahe
parent 12c3dc5ff8
commit c67d185da5

View File

@ -377,17 +377,20 @@ int bootloader_main(void) {
unit_variant_init(); unit_variant_init();
#ifdef USE_TOUCH #ifdef USE_TOUCH
secbool touch_initialized = secfalse;
secbool allow_touchless_mode = secfalse;
#ifdef TREZOR_MODEL_T3T1 #ifdef TREZOR_MODEL_T3T1
// on T3T1, tester needs to run without touch, so making an exception // on T3T1, tester needs to run without touch, so making an exception
// until unit variant is written in OTP // until unit variant is written in OTP
if (unit_variant_present()) { const secbool manufacturing_mode =
ensure(touch_init(), "Touch screen panel was not loaded properly."); unit_variant_present() ? secfalse : sectrue;
} else { allow_touchless_mode = manufacturing_mode;
touch_init();
}
#else
ensure(touch_init(), "Touch screen panel was not loaded properly.");
#endif #endif
touch_initialized = touch_init();
if (allow_touchless_mode != sectrue) {
ensure(touch_initialized, "Touch screen panel was not loaded properly.");
}
#endif #endif
ui_screen_boot_stage_1(false); ui_screen_boot_stage_1(false);
@ -506,9 +509,11 @@ int bootloader_main(void) {
if (firmware_present == sectrue && stay_in_bootloader != sectrue) { if (firmware_present == sectrue && stay_in_bootloader != sectrue) {
// Wait until the touch controller is ready // Wait until the touch controller is ready
// (on hardware this may take a while) // (on hardware this may take a while)
if (touch_initialized != secfalse) {
while (touch_ready() != sectrue) { while (touch_ready() != sectrue) {
hal_delay(1); hal_delay(1);
} }
}
#ifdef TREZOR_EMULATOR #ifdef TREZOR_EMULATOR
hal_delay(500); hal_delay(500);
#endif #endif