mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-21 12:51:03 +00:00
fix(core): TS5 - wait for frame to appear on display before raising backlight
[no changelog]
This commit is contained in:
parent
a8e5d471fe
commit
594445c1f9
@ -135,6 +135,8 @@ void display_fb_clear(void) {
|
||||
static void bg_copy_callback(void) {
|
||||
display_driver_t *drv = &g_display_driver;
|
||||
|
||||
drv->update_pending = 1;
|
||||
|
||||
fb_queue_put(&drv->empty_frames, fb_queue_take(&drv->ready_frames));
|
||||
}
|
||||
|
||||
@ -144,6 +146,10 @@ static void display_te_interrupt_handler(void) {
|
||||
|
||||
__HAL_GPIO_EXTI_CLEAR_FLAG(DISPLAY_TE_PIN);
|
||||
|
||||
if (drv->update_pending > 0) {
|
||||
drv->update_pending--;
|
||||
}
|
||||
|
||||
if (!fb_queue_peeked(&drv->ready_frames)) {
|
||||
int16_t fb_idx = fb_queue_peek(&drv->ready_frames);
|
||||
|
||||
@ -256,7 +262,9 @@ void display_ensure_refreshed(void) {
|
||||
// so we can be sure there's not scheduled or pending
|
||||
// background copying
|
||||
do {
|
||||
copy_pending = !fb_queue_empty(&drv->ready_frames);
|
||||
irq_key_t irq_key = irq_lock();
|
||||
copy_pending = !fb_queue_empty(&drv->ready_frames) || drv->update_pending;
|
||||
irq_unlock(irq_key);
|
||||
__WFI();
|
||||
} while (copy_pending);
|
||||
|
||||
|
@ -25,6 +25,7 @@ typedef struct {
|
||||
|
||||
// Current display orientation (0, 90, 180, 270)
|
||||
int orientation_angle;
|
||||
int update_pending;
|
||||
|
||||
} display_driver_t;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user