From fd45d75c7dd18df6ea70f6fcb3ca7eef90944eca Mon Sep 17 00:00:00 2001 From: Richard Li Date: Thu, 13 Jun 2024 16:43:15 +0800 Subject: [PATCH] Backlight should be off when init to prevent flashing. --- radio/src/targets/pl18/backlight_driver.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/radio/src/targets/pl18/backlight_driver.cpp b/radio/src/targets/pl18/backlight_driver.cpp index 3996e0926af..02b522cdff6 100644 --- a/radio/src/targets/pl18/backlight_driver.cpp +++ b/radio/src/targets/pl18/backlight_driver.cpp @@ -40,13 +40,12 @@ void backlightInit() // PIN init gpio_init_af(BACKLIGHT_GPIO, BACKLIGHT_GPIO_AF, GPIO_PIN_SPEED_LOW); - // TODO review this when the timer will be chosen stm32_timer_enable_clock(BACKLIGHT_TIMER); BACKLIGHT_TIMER->ARR = 100; BACKLIGHT_TIMER->PSC = BACKLIGHT_TIMER_FREQ / 1000000 - 1; // 10kHz (same as FrOS) BACKLIGHT_TIMER->CCMR1 = TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_2 | TIM_CCMR1_OC1PE; // PWM mode 1 BACKLIGHT_TIMER->CCER = TIM_CCER_CC1E | TIM_CCER_CC1NE; - BACKLIGHT_TIMER->CCR1 = 100; // 100% on init + BACKLIGHT_TIMER->CCR1 = 0; BACKLIGHT_TIMER->EGR = TIM_EGR_UG; BACKLIGHT_TIMER->CR1 |= TIM_CR1_CEN; // Counter enable BACKLIGHT_TIMER->BDTR |= TIM_BDTR_MOE; @@ -68,6 +67,11 @@ void backlightEnable(uint8_t dutyCycle) lastDutyCycle = dutyCycle; } +void backlightFullOn() +{ + backlightEnable(BACKLIGHT_LEVEL_MAX); +} + void lcdOff() { backlightEnable(0); }