Skip to content

Commit 6a3e46e

Browse files
Merge pull request #99 from lvgl/fix/backlight-off
Don't call backlight function when backlight is disabled
2 parents 82583ce + 5043946 commit 6a3e46e

File tree

3 files changed

+15
-21
lines changed

3 files changed

+15
-21
lines changed

lvgl_tft/Kconfig

Lines changed: 2 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -934,16 +934,9 @@ menu "LVGL TFT Display controller"
934934
endchoice
935935

936936
choice
937+
default LV_DISP_BACKLIGHT_SWITCH
937938
prompt "Backlight Control" if \
938939
(! ( LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 ) )
939-
default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_M5STACK
940-
default LV_DISP_BACKLIGHT_OFF if LV_PREDEFINED_DISPLAY_M5CORE2
941-
default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_WROVER4
942-
default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_ERTFT0356
943-
default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_TTGO
944-
default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS
945-
default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_WT32_SC01
946-
default LV_DISP_BACKLIGHT_OFF
947940

948941
config LV_DISP_BACKLIGHT_OFF
949942
bool
@@ -995,7 +988,7 @@ menu "LVGL TFT Display controller"
995988
default 4 if LV_PREDEFINED_DISPLAY_TTGO
996989
default 2 if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS
997990
default 23 if LV_PREDEFINED_DISPLAY_WT32_SC01
998-
default 27
991+
default -1
999992

1000993
help
1001994
Configure the display BCLK (LED) pin here.

lvgl_tft/disp_driver.c

Lines changed: 5 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -47,7 +47,7 @@ void *disp_driver_init(void)
4747

4848
// We still use menuconfig for these settings
4949
// It will be set up during runtime in the future
50-
#ifndef CONFIG_LV_DISP_BACKLIGHT_OFF
50+
#if (defined(CONFIG_LV_DISP_BACKLIGHT_SWITCH) || defined(CONFIG_LV_DISP_BACKLIGHT_PWM))
5151
const disp_backlight_config_t bckl_config = {
5252
.gpio_num = CONFIG_LV_DISP_PIN_BCKL,
5353
#if defined CONFIG_LV_DISP_BACKLIGHT_PWM
@@ -63,15 +63,12 @@ void *disp_driver_init(void)
6363
.timer_idx = 0,
6464
.channel_idx = 0 // @todo this prevents us from having two PWM controlled displays
6565
};
66-
const disp_backlight_config_t *bckl_config_p = &bckl_config;
67-
#else
68-
const disp_backlight_config_t *bckl_config_p = NULL;
69-
#endif
70-
71-
disp_backlight_h bckl_handle = disp_backlight_new(bckl_config_p);
66+
disp_backlight_h bckl_handle = disp_backlight_new(&bckl_config);
7267
disp_backlight_set(bckl_handle, 100);
73-
7468
return bckl_handle;
69+
#else
70+
return NULL;
71+
#endif
7572
}
7673

7774
void disp_driver_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map)

lvgl_tft/esp_lcd_backlight.c

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,6 @@
1010
#include "driver/ledc.h"
1111
#include "driver/gpio.h"
1212
#include "esp_log.h"
13-
#include "esp_rom_gpio.h" // for output signal inversion
1413
#include "soc/ledc_periph.h" // to invert LEDC output on IDF version < v4.3
1514

1615
typedef struct {
@@ -22,11 +21,16 @@ static const char *TAG = "disp_backlight";
2221

2322
disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config)
2423
{
24+
// Check input parameters
2525
if (config == NULL)
2626
return NULL;
27+
if (!GPIO_IS_VALID_OUTPUT_GPIO(config->gpio_num)) {
28+
ESP_LOGW(TAG, "Invalid GPIO number");
29+
return NULL;
30+
}
2731
disp_backlight_t *bckl_dev = calloc(1, sizeof(disp_backlight_t));
2832
if (bckl_dev == NULL){
29-
ESP_LOGW(TAG, "Could not create new LCD backlight instance");
33+
ESP_LOGW(TAG, "Not enough memory");
3034
return NULL;
3135
}
3236

@@ -52,15 +56,15 @@ disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config)
5256

5357
ESP_ERROR_CHECK(ledc_timer_config(&LCD_backlight_timer));
5458
ESP_ERROR_CHECK(ledc_channel_config(&LCD_backlight_channel));
55-
esp_rom_gpio_connect_out_signal(config->gpio_num, ledc_periph_signal[LEDC_LOW_SPEED_MODE].sig_out0_idx + config->channel_idx, config->output_invert, 0);
59+
gpio_matrix_out(config->gpio_num, ledc_periph_signal[LEDC_LOW_SPEED_MODE].sig_out0_idx + config->channel_idx, config->output_invert, 0);
5660
}
5761
else
5862
{
5963
// Configure GPIO for output
6064
bckl_dev->index = config->gpio_num;
6165
gpio_pad_select_gpio(config->gpio_num);
6266
ESP_ERROR_CHECK(gpio_set_direction(config->gpio_num, GPIO_MODE_OUTPUT));
63-
esp_rom_gpio_connect_out_signal(config->gpio_num, SIG_GPIO_OUT_IDX, config->output_invert, false);
67+
gpio_matrix_out(config->gpio_num, SIG_GPIO_OUT_IDX, config->output_invert, false);
6468
}
6569

6670
return (disp_backlight_h)bckl_dev;

0 commit comments

Comments
 (0)