From 82b738e533a8cdf33f0f86ca8b03577f284ef292 Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Tue, 2 Mar 2021 12:51:29 +0100 Subject: [PATCH 01/70] ili9341: display inversion --- lvgl_tft/ili9341.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lvgl_tft/ili9341.c b/lvgl_tft/ili9341.c index ab9480f0..faf5546f 100644 --- a/lvgl_tft/ili9341.c +++ b/lvgl_tft/ili9341.c @@ -229,7 +229,7 @@ static void ili9341_set_orientation(uint8_t orientation) #if defined CONFIG_LV_PREDEFINED_DISPLAY_M5STACK uint8_t data[] = {0x68, 0x68, 0x08, 0x08}; #elif defined (CONFIG_LV_PREDEFINED_DISPLAY_WROVER4) - uint8_t data[] = {0x4C, 0x88, 0x28, 0xE8}; + uint8_t data[] = {0x6C, 0xEC, 0xCC, 0x4C}; #elif defined (CONFIG_LV_PREDEFINED_DISPLAY_NONE) uint8_t data[] = {0x48, 0x88, 0x28, 0xE8}; #endif From 0442ebe7360aa55a5927028ea31d6209f2467cbf Mon Sep 17 00:00:00 2001 From: C47D Date: Sun, 14 Mar 2021 16:27:57 -0600 Subject: [PATCH 02/70] SSD1306: Fix orientation symbol names Kconfig sets CONFIG_DISPLAY_ORIENTATION_LANDSCAPE and CONFIG_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED. This commit replaces the old references to CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE and CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED. Fixes: #48 --- lvgl_tft/ssd1306.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lvgl_tft/ssd1306.c b/lvgl_tft/ssd1306.c index 58fb88ec..be35be6b 100644 --- a/lvgl_tft/ssd1306.c +++ b/lvgl_tft/ssd1306.c @@ -101,10 +101,10 @@ void ssd1306_init(void) uint8_t orientation_1 = 0; uint8_t orientation_2 = 0; -#if defined (CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE) +#if defined (CONFIG_DISPLAY_ORIENTATION_LANDSCAPE) orientation_1 = OLED_CMD_SET_SEGMENT_REMAP; orientation_2 = OLED_CMD_SET_COM_SCAN_MODE_REMAP; -#elif defined (CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) +#elif defined (CONFIG_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) orientation_1 = 0xA0; orientation_2 = OLED_CMD_SET_COM_SCAN_MODE_NORMAL; #else From 63cfe0fdd8439187f6867f8a3f6deaa4348c4c58 Mon Sep 17 00:00:00 2001 From: Alnef <81906646+Alnef@users.noreply.github.com> Date: Sat, 10 Apr 2021 14:59:11 +0200 Subject: [PATCH 03/70] Fix contrast and display mode initialisation The double byte command OLED_CMD_SET_CONTRAST (SSD1306 datasheet rev 1.1 p.28) was followed by display_mode. So the contrast was set to 0xA6 or 0xA7 depending on the display mode configured and the display mode itself wasn't configurable. --- lvgl_tft/ssd1306.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lvgl_tft/ssd1306.c b/lvgl_tft/ssd1306.c index be35be6b..43e5966c 100644 --- a/lvgl_tft/ssd1306.c +++ b/lvgl_tft/ssd1306.c @@ -126,8 +126,8 @@ void ssd1306_init(void) orientation_1, orientation_2, OLED_CMD_SET_CONTRAST, - display_mode, 0xFF, + display_mode, OLED_CMD_DISPLAY_ON }; From 7b571a7fc707d2471424b36fca89d0405b1bed46 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Wed, 28 Apr 2021 11:04:53 +0200 Subject: [PATCH 04/70] LV_DISP_USE_RST Allows to not allocate a GPIO for display reset: some may have that pin tied or attached to a Power management IC. Supersedes PR from @usedbytes doing same but only for IL9341, this is for all supported displays. --- lvgl_tft/EVE_commands.c | 6 ++++-- lvgl_tft/EVE_commands.h | 4 ++++ lvgl_tft/EVE_config.h | 11 ++++++----- lvgl_tft/FT81x.c | 6 ++++++ lvgl_tft/GC9A01.c | 6 ++++++ lvgl_tft/GC9A01.h | 7 ++++--- lvgl_tft/Kconfig | 13 +++++++++++++ lvgl_tft/hx8357.c | 5 +++++ lvgl_tft/hx8357.h | 7 ++++--- lvgl_tft/il3820.c | 6 ++++++ lvgl_tft/il3820.h | 1 + lvgl_tft/ili9341.c | 5 +++++ lvgl_tft/ili9341.h | 7 ++++--- lvgl_tft/ili9481.c | 5 +++++ lvgl_tft/ili9481.h | 7 ++++--- lvgl_tft/ili9486.c | 5 +++++ lvgl_tft/ili9486.h | 7 ++++--- lvgl_tft/ili9488.c | 5 +++++ lvgl_tft/ili9488.h | 7 ++++--- lvgl_tft/ra8875.c | 6 ++++++ lvgl_tft/ra8875.h | 3 ++- lvgl_tft/sh1107.c | 3 +++ lvgl_tft/sh1107.h | 5 +++-- lvgl_tft/st7735s.c | 3 +++ lvgl_tft/st7735s.h | 5 +++-- lvgl_tft/st7789.c | 4 ++-- lvgl_tft/st7789.h | 9 +++++++++ lvgl_tft/st7796s.c | 6 ++++++ lvgl_tft/st7796s.h | 7 ++++--- 29 files changed, 136 insertions(+), 35 deletions(-) diff --git a/lvgl_tft/EVE_commands.c b/lvgl_tft/EVE_commands.c index 9e458f48..2a93efab 100644 --- a/lvgl_tft/EVE_commands.c +++ b/lvgl_tft/EVE_commands.c @@ -144,7 +144,7 @@ void DELAY_MS(uint16_t ms) vTaskDelay(ms / portTICK_PERIOD_MS); } - +#if EVE_USE_PDN void EVE_pdn_set(void) { gpio_set_level(EVE_PDN, 0); /* Power-Down low */ @@ -155,7 +155,7 @@ void EVE_pdn_clear(void) { gpio_set_level(EVE_PDN, 1); /* Power-Down high */ } - +#endif void spi_acquire() { @@ -841,11 +841,13 @@ uint8_t EVE_init(void) uint8_t chipid = 0; uint16_t timeout = 0; +#if EVE_USE_PDN EVE_pdn_set(); DELAY_MS(6); /* minimum time for power-down is 5ms */ EVE_pdn_clear(); DELAY_MS(21); /* minimum time to allow from rising PD_N to first access is 20ms */ +#endif /* EVE_cmdWrite(EVE_CORERST,0); */ /* reset, only required for warm-start if PowerDown line is not used */ diff --git a/lvgl_tft/EVE_commands.h b/lvgl_tft/EVE_commands.h index 3c5c1047..7377a7f5 100644 --- a/lvgl_tft/EVE_commands.h +++ b/lvgl_tft/EVE_commands.h @@ -39,8 +39,12 @@ TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR TH #define BLOCK_TRANSFER_SIZE 3840 // block transfer size when write data to CMD buffer void DELAY_MS(uint16_t ms); + +#if EVE_USE_PDN void EVE_pdn_set(void); void EVE_pdn_clear(void); +#endif + void spi_acquire(); void spi_release(); diff --git a/lvgl_tft/EVE_config.h b/lvgl_tft/EVE_config.h index 53225a23..386edb9b 100644 --- a/lvgl_tft/EVE_config.h +++ b/lvgl_tft/EVE_config.h @@ -44,11 +44,12 @@ TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR TH #include "FT81x.h" -#define EVE_CLK DISP_SPI_CLK // orange -#define EVE_MISO DISP_SPI_MISO // yellow -#define EVE_MOSI DISP_SPI_MOSI // green -#define EVE_CS DISP_SPI_CS // blue -#define EVE_PDN CONFIG_LV_DISP_PIN_RST // grey +#define EVE_CLK DISP_SPI_CLK // orange +#define EVE_MISO DISP_SPI_MISO // yellow +#define EVE_MOSI DISP_SPI_MOSI // green +#define EVE_CS DISP_SPI_CS // blue +#define EVE_PDN CONFIG_LV_DISP_PIN_RST // grey +#define EVE_USE_PDN CONFIG_LV_DISP_USE_RST #define SPI_TRANSER_SIZE (DISP_BUF_SIZE * (LV_COLOR_DEPTH / 8)) diff --git a/lvgl_tft/FT81x.c b/lvgl_tft/FT81x.c index b004eba2..4afc52b8 100644 --- a/lvgl_tft/FT81x.c +++ b/lvgl_tft/FT81x.c @@ -262,9 +262,15 @@ void TFT_bitmap_display(void) void FT81x_init(void) { +#if EVE_USE_PDN gpio_pad_select_gpio(EVE_PDN); +#endif + gpio_set_level(EVE_CS, 1); + +#if EVE_USE_PDN gpio_set_direction(EVE_PDN, GPIO_MODE_OUTPUT); +#endif spi_acquire(); diff --git a/lvgl_tft/GC9A01.c b/lvgl_tft/GC9A01.c index 63687e3c..525efc99 100644 --- a/lvgl_tft/GC9A01.c +++ b/lvgl_tft/GC9A01.c @@ -124,18 +124,24 @@ void GC9A01_init(void) //Initialize non-SPI GPIOs gpio_pad_select_gpio(GC9A01_DC); gpio_set_direction(GC9A01_DC, GPIO_MODE_OUTPUT); + +#if GC9A01_USE_RST gpio_pad_select_gpio(GC9A01_RST); gpio_set_direction(GC9A01_RST, GPIO_MODE_OUTPUT); +#endif #if GC9A01_ENABLE_BACKLIGHT_CONTROL gpio_pad_select_gpio(GC9A01_BCKL); gpio_set_direction(GC9A01_BCKL, GPIO_MODE_OUTPUT); #endif + +#if GC9A01_USE_RST //Reset the display gpio_set_level(GC9A01_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); gpio_set_level(GC9A01_RST, 1); vTaskDelay(100 / portTICK_RATE_MS); +#endif ESP_LOGI(TAG, "Initialization."); diff --git a/lvgl_tft/GC9A01.h b/lvgl_tft/GC9A01.h index d462c8d4..29958112 100644 --- a/lvgl_tft/GC9A01.h +++ b/lvgl_tft/GC9A01.h @@ -25,9 +25,10 @@ extern "C" { /********************* * DEFINES *********************/ -#define GC9A01_DC CONFIG_LV_DISP_PIN_DC -#define GC9A01_RST CONFIG_LV_DISP_PIN_RST -#define GC9A01_BCKL CONFIG_LV_DISP_PIN_BCKL +#define GC9A01_DC CONFIG_LV_DISP_PIN_DC +#define GC9A01_RST CONFIG_LV_DISP_PIN_RST +#define GC9A01_USE_RST CONFIG_LV_DISP_USE_RST +#define GC9A01_BCKL CONFIG_LV_DISP_PIN_BCKL #define GC9A01_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index ddd7f516..d2063930 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -900,8 +900,21 @@ menu "LVGL TFT Display controller" help Configure the display DC pin here. + config LV_DISP_USE_RST + bool "Use a GPIO for resetting the display" if LV_TFT_DISPLAY_PROTOCOL_SPI + default y + help + Enable display reset control. Set this if the reset pin of the + display is connected to the host. If this is not set, then it is + the user's responsibility to ensure that the display is reset + before initialisation. + You may want to disable this option because the reset pin is not + connected, or is connected to an external component such as the + power management IC. + config LV_DISP_PIN_RST int "GPIO for Reset" if LV_TFT_DISPLAY_PROTOCOL_SPI && !LV_DISP_ST7789_SOFT_RESET + depends on LV_DISP_USE_RST range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 diff --git a/lvgl_tft/hx8357.c b/lvgl_tft/hx8357.c index ad180fdf..6b6cd34f 100644 --- a/lvgl_tft/hx8357.c +++ b/lvgl_tft/hx8357.c @@ -162,19 +162,24 @@ void hx8357_init(void) //Initialize non-SPI GPIOs gpio_pad_select_gpio(HX8357_DC); gpio_set_direction(HX8357_DC, GPIO_MODE_OUTPUT); + +#if HX8357_USE_RST gpio_pad_select_gpio(HX8357_RST); gpio_set_direction(HX8357_RST, GPIO_MODE_OUTPUT); +#endif #if HX8357_ENABLE_BACKLIGHT_CONTROL gpio_pad_select_gpio(HX8357_BCKL); gpio_set_direction(HX8357_BCKL, GPIO_MODE_OUTPUT); #endif +#if HX8357_USE_RST //Reset the display gpio_set_level(HX8357_RST, 0); vTaskDelay(10 / portTICK_RATE_MS); gpio_set_level(HX8357_RST, 1); vTaskDelay(120 / portTICK_RATE_MS); +#endif ESP_LOGI(TAG, "Initialization."); diff --git a/lvgl_tft/hx8357.h b/lvgl_tft/hx8357.h index 6bad32d9..1e54627f 100644 --- a/lvgl_tft/hx8357.h +++ b/lvgl_tft/hx8357.h @@ -35,9 +35,10 @@ extern "C" { /********************* * DEFINES *********************/ -#define HX8357_DC CONFIG_LV_DISP_PIN_DC -#define HX8357_RST CONFIG_LV_DISP_PIN_RST -#define HX8357_BCKL CONFIG_LV_DISP_PIN_BCKL +#define HX8357_DC CONFIG_LV_DISP_PIN_DC +#define HX8357_RST CONFIG_LV_DISP_PIN_RST +#define HX8357_USE_RST CONFIG_LV_DISP_USE_RST +#define HX8357_BCKL CONFIG_LV_DISP_PIN_BCKL #define HX8357_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL #define HX8357_INVERT_COLORS CONFIG_LV_INVERT_COLORS diff --git a/lvgl_tft/il3820.c b/lvgl_tft/il3820.c index 45ae2762..80358b27 100644 --- a/lvgl_tft/il3820.c +++ b/lvgl_tft/il3820.c @@ -198,16 +198,22 @@ void il3820_init(void) /* Initialize non-SPI GPIOs */ gpio_pad_select_gpio(IL3820_DC_PIN); gpio_set_direction(IL3820_DC_PIN, GPIO_MODE_OUTPUT); + +#if IL3820_USE_RST gpio_pad_select_gpio(IL3820_RST_PIN); gpio_set_direction(IL3820_RST_PIN, GPIO_MODE_OUTPUT); +#endif + gpio_pad_select_gpio(IL3820_BUSY_PIN); gpio_set_direction(IL3820_BUSY_PIN, GPIO_MODE_INPUT); +#if IL3820_USE_RST /* Harware reset */ gpio_set_level( IL3820_RST_PIN, 0); vTaskDelay(IL3820_RESET_DELAY / portTICK_RATE_MS); gpio_set_level( IL3820_RST_PIN, 1); vTaskDelay(IL3820_RESET_DELAY / portTICK_RATE_MS); +#endif /* Software reset */ il3820_write_cmd(IL3820_CMD_SW_RESET, NULL, 0); diff --git a/lvgl_tft/il3820.h b/lvgl_tft/il3820.h index e0b73cd6..f77ffb4b 100644 --- a/lvgl_tft/il3820.h +++ b/lvgl_tft/il3820.h @@ -28,6 +28,7 @@ extern "C" #define IL3820_DC_PIN CONFIG_LV_DISP_PIN_DC #define IL3820_RST_PIN CONFIG_LV_DISP_PIN_RST +#define IL3820_USE_RST CONFIG_LV_DISP_USE_RST #define IL3820_BUSY_PIN CONFIG_LV_DISP_PIN_BUSY #define IL3820_BUSY_LEVEL 1 diff --git a/lvgl_tft/ili9341.c b/lvgl_tft/ili9341.c index faf5546f..41bd1995 100644 --- a/lvgl_tft/ili9341.c +++ b/lvgl_tft/ili9341.c @@ -93,18 +93,23 @@ void ili9341_init(void) //Initialize non-SPI GPIOs gpio_pad_select_gpio(ILI9341_DC); gpio_set_direction(ILI9341_DC, GPIO_MODE_OUTPUT); +#if ILI9341_USE_RST gpio_pad_select_gpio(ILI9341_RST); gpio_set_direction(ILI9341_RST, GPIO_MODE_OUTPUT); +#endif #if ILI9341_ENABLE_BACKLIGHT_CONTROL gpio_pad_select_gpio(ILI9341_BCKL); gpio_set_direction(ILI9341_BCKL, GPIO_MODE_OUTPUT); #endif + +#if ILI9341_USE_RST //Reset the display gpio_set_level(ILI9341_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); gpio_set_level(ILI9341_RST, 1); vTaskDelay(100 / portTICK_RATE_MS); +#endif ESP_LOGI(TAG, "Initialization."); diff --git a/lvgl_tft/ili9341.h b/lvgl_tft/ili9341.h index 4beb4f32..5768fbef 100644 --- a/lvgl_tft/ili9341.h +++ b/lvgl_tft/ili9341.h @@ -25,9 +25,10 @@ extern "C" { /********************* * DEFINES *********************/ -#define ILI9341_DC CONFIG_LV_DISP_PIN_DC -#define ILI9341_RST CONFIG_LV_DISP_PIN_RST -#define ILI9341_BCKL CONFIG_LV_DISP_PIN_BCKL +#define ILI9341_DC CONFIG_LV_DISP_PIN_DC +#define ILI9341_USE_RST CONFIG_LV_DISP_USE_RST +#define ILI9341_RST CONFIG_LV_DISP_PIN_RST +#define ILI9341_BCKL CONFIG_LV_DISP_PIN_BCKL #define ILI9341_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL diff --git a/lvgl_tft/ili9481.c b/lvgl_tft/ili9481.c index 6472a932..f80c8108 100644 --- a/lvgl_tft/ili9481.c +++ b/lvgl_tft/ili9481.c @@ -76,19 +76,24 @@ void ili9481_init(void) //Initialize non-SPI GPIOs gpio_pad_select_gpio(ILI9481_DC); gpio_set_direction(ILI9481_DC, GPIO_MODE_OUTPUT); + +#if ILI9481_USE_RST gpio_pad_select_gpio(ILI9481_RST); gpio_set_direction(ILI9481_RST, GPIO_MODE_OUTPUT); +#endif #if ILI9481_ENABLE_BACKLIGHT_CONTROL gpio_pad_select_gpio(ILI9481_BCKL); gpio_set_direction(ILI9481_BCKL, GPIO_MODE_OUTPUT); #endif +#if ILI9481_USE_RST //Reset the display gpio_set_level(ILI9481_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); gpio_set_level(ILI9481_RST, 1); vTaskDelay(100 / portTICK_RATE_MS); +#endif ESP_LOGI(TAG, "ILI9481 initialization."); diff --git a/lvgl_tft/ili9481.h b/lvgl_tft/ili9481.h index 79321908..c0d07fe8 100644 --- a/lvgl_tft/ili9481.h +++ b/lvgl_tft/ili9481.h @@ -25,9 +25,10 @@ extern "C" { /********************* * DEFINES *********************/ -#define ILI9481_DC CONFIG_LV_DISP_PIN_DC -#define ILI9481_RST CONFIG_LV_DISP_PIN_RST -#define ILI9481_BCKL CONFIG_LV_DISP_PIN_BCKL +#define ILI9481_DC CONFIG_LV_DISP_PIN_DC +#define ILI9481_RST CONFIG_LV_DISP_PIN_RST +#define ILI9481_USE_RST CONFIG_LV_DISP_USE_RST +#define ILI9481_BCKL CONFIG_LV_DISP_PIN_BCKL #define ILI9481_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL #define ILI9481_INVERT_COLORS CONFIG_LV_INVERT_COLORS diff --git a/lvgl_tft/ili9486.c b/lvgl_tft/ili9486.c index e9b2b083..dd82ac97 100644 --- a/lvgl_tft/ili9486.c +++ b/lvgl_tft/ili9486.c @@ -78,19 +78,24 @@ void ili9486_init(void) //Initialize non-SPI GPIOs gpio_pad_select_gpio(ILI9486_DC); gpio_set_direction(ILI9486_DC, GPIO_MODE_OUTPUT); + +#if ILI9486_USE_RST gpio_pad_select_gpio(ILI9486_RST); gpio_set_direction(ILI9486_RST, GPIO_MODE_OUTPUT); +#endif #if ILI9486_ENABLE_BACKLIGHT_CONTROL gpio_pad_select_gpio(ILI9486_BCKL); gpio_set_direction(ILI9486_BCKL, GPIO_MODE_OUTPUT); #endif +#if ILI9486_USE_RST //Reset the display gpio_set_level(ILI9486_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); gpio_set_level(ILI9486_RST, 1); vTaskDelay(100 / portTICK_RATE_MS); +#endif ESP_LOGI(TAG, "ILI9486 Initialization."); diff --git a/lvgl_tft/ili9486.h b/lvgl_tft/ili9486.h index f65dd801..08e002f4 100644 --- a/lvgl_tft/ili9486.h +++ b/lvgl_tft/ili9486.h @@ -25,9 +25,10 @@ extern "C" { /********************* * DEFINES *********************/ -#define ILI9486_DC CONFIG_LV_DISP_PIN_DC -#define ILI9486_RST CONFIG_LV_DISP_PIN_RST -#define ILI9486_BCKL CONFIG_LV_DISP_PIN_BCKL +#define ILI9486_DC CONFIG_LV_DISP_PIN_DC +#define ILI9486_RST CONFIG_LV_DISP_PIN_RST +#define ILI9486_USE_RST CONFIG_LV_DISP_USE_RST +#define ILI9486_BCKL CONFIG_LV_DISP_PIN_BCKL #define ILI9486_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL diff --git a/lvgl_tft/ili9488.c b/lvgl_tft/ili9488.c index 74f7139b..5379b776 100644 --- a/lvgl_tft/ili9488.c +++ b/lvgl_tft/ili9488.c @@ -78,19 +78,24 @@ void ili9488_init(void) //Initialize non-SPI GPIOs gpio_pad_select_gpio(ILI9488_DC); gpio_set_direction(ILI9488_DC, GPIO_MODE_OUTPUT); + +#if ILI9488_USE_RST gpio_pad_select_gpio(ILI9488_RST); gpio_set_direction(ILI9488_RST, GPIO_MODE_OUTPUT); +#endif #if ILI9488_ENABLE_BACKLIGHT_CONTROL gpio_pad_select_gpio(ILI9488_BCKL); gpio_set_direction(ILI9488_BCKL, GPIO_MODE_OUTPUT); #endif +#if ILI9488_USE_RST //Reset the display gpio_set_level(ILI9488_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); gpio_set_level(ILI9488_RST, 1); vTaskDelay(100 / portTICK_RATE_MS); +#endif ESP_LOGI(TAG, "ILI9488 initialization."); diff --git a/lvgl_tft/ili9488.h b/lvgl_tft/ili9488.h index 45a70454..2ecfd447 100644 --- a/lvgl_tft/ili9488.h +++ b/lvgl_tft/ili9488.h @@ -25,9 +25,10 @@ extern "C" { /********************* * DEFINES *********************/ -#define ILI9488_DC CONFIG_LV_DISP_PIN_DC -#define ILI9488_RST CONFIG_LV_DISP_PIN_RST -#define ILI9488_BCKL CONFIG_LV_DISP_PIN_BCKL +#define ILI9488_DC CONFIG_LV_DISP_PIN_DC +#define ILI9488_RST CONFIG_LV_DISP_PIN_RST +#define ILI9488_USE_RST CONFIG_LV_DISP_USE_RST +#define ILI9488_BCKL CONFIG_LV_DISP_PIN_BCKL #define ILI9488_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL diff --git a/lvgl_tft/ra8875.c b/lvgl_tft/ra8875.c index 98eea028..c08ff887 100644 --- a/lvgl_tft/ra8875.c +++ b/lvgl_tft/ra8875.c @@ -159,18 +159,24 @@ void ra8875_init(void) #endif // Initialize non-SPI GPIOs + +#if RA8875_USE_RST gpio_pad_select_gpio(RA8875_RST); gpio_set_direction(RA8875_RST, GPIO_MODE_OUTPUT); +#endif + #ifdef CONFIG_LV_DISP_PIN_BCKL gpio_pad_select_gpio(CONFIG_LV_DISP_PIN_BCKL); gpio_set_direction(CONFIG_LV_DISP_PIN_BCKL, GPIO_MODE_OUTPUT); #endif +#if RA8875_USE_RST // Reset the RA8875 gpio_set_level(RA8875_RST, 0); vTaskDelay(DIV_ROUND_UP(100, portTICK_RATE_MS)); gpio_set_level(RA8875_RST, 1); vTaskDelay(DIV_ROUND_UP(100, portTICK_RATE_MS)); +#endif // Initalize RA8875 clocks (SPI must be decelerated before initializing clocks) disp_spi_change_device_speed(SPI_CLOCK_SPEED_SLOW_HZ); diff --git a/lvgl_tft/ra8875.h b/lvgl_tft/ra8875.h index a6d1fe5d..6942c3e9 100644 --- a/lvgl_tft/ra8875.h +++ b/lvgl_tft/ra8875.h @@ -24,7 +24,8 @@ extern "C" { /********************* * DEFINES *********************/ -#define RA8875_RST CONFIG_LV_DISP_PIN_RST +#define RA8875_RST CONFIG_LV_DISP_PIN_RST +#define RA8875_USE_RST CONFIG_LV_DISP_USE_RST // System & Configuration Registers #define RA8875_REG_PWRR (0x01) // Power and Display Control Register (PWRR) diff --git a/lvgl_tft/sh1107.c b/lvgl_tft/sh1107.c index d8d8c848..d7f60676 100644 --- a/lvgl_tft/sh1107.c +++ b/lvgl_tft/sh1107.c @@ -94,6 +94,8 @@ void sh1107_init(void) //Initialize non-SPI GPIOs gpio_pad_select_gpio(SH1107_DC); gpio_set_direction(SH1107_DC, GPIO_MODE_OUTPUT); + +#if SH1107_USE_RST gpio_pad_select_gpio(SH1107_RST); gpio_set_direction(SH1107_RST, GPIO_MODE_OUTPUT); @@ -102,6 +104,7 @@ void sh1107_init(void) vTaskDelay(100 / portTICK_RATE_MS); gpio_set_level(SH1107_RST, 1); vTaskDelay(100 / portTICK_RATE_MS); +#endif //Send all the commands uint16_t cmd = 0; diff --git a/lvgl_tft/sh1107.h b/lvgl_tft/sh1107.h index 7a0db68b..ba77a618 100644 --- a/lvgl_tft/sh1107.h +++ b/lvgl_tft/sh1107.h @@ -25,8 +25,9 @@ extern "C" { /********************* * DEFINES *********************/ -#define SH1107_DC CONFIG_LV_DISP_PIN_DC -#define SH1107_RST CONFIG_LV_DISP_PIN_RST +#define SH1107_DC CONFIG_LV_DISP_PIN_DC +#define SH1107_RST CONFIG_LV_DISP_PIN_RST +#define SH1107_USE_RST CONFIG_LV_DISP_USE_RST /********************** * TYPEDEFS diff --git a/lvgl_tft/st7735s.c b/lvgl_tft/st7735s.c index 861904c0..2507118b 100644 --- a/lvgl_tft/st7735s.c +++ b/lvgl_tft/st7735s.c @@ -99,6 +99,8 @@ void st7735s_init(void) //Initialize non-SPI GPIOs gpio_pad_select_gpio(ST7735S_DC); gpio_set_direction(ST7735S_DC, GPIO_MODE_OUTPUT); + +#if ST7735S_USE_RST gpio_pad_select_gpio(ST7735S_RST); gpio_set_direction(ST7735S_RST, GPIO_MODE_OUTPUT); @@ -107,6 +109,7 @@ void st7735s_init(void) vTaskDelay(100 / portTICK_RATE_MS); gpio_set_level(ST7735S_RST, 1); vTaskDelay(100 / portTICK_RATE_MS); +#endif ESP_LOGI(TAG, "ST7735S initialization."); diff --git a/lvgl_tft/st7735s.h b/lvgl_tft/st7735s.h index de471409..71924bf3 100644 --- a/lvgl_tft/st7735s.h +++ b/lvgl_tft/st7735s.h @@ -25,8 +25,9 @@ extern "C" { *********************/ #define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40) -#define ST7735S_DC CONFIG_LV_DISP_PIN_DC -#define ST7735S_RST CONFIG_LV_DISP_PIN_RST +#define ST7735S_DC CONFIG_LV_DISP_PIN_DC +#define ST7735S_RST CONFIG_LV_DISP_PIN_RST +#define ST7735S_USE_RST CONFIG_LV_DISP_USE_RST #define AXP192_SDA CONFIG_LV_AXP192_PIN_SDA #define AXP192_SCL CONFIG_LV_AXP192_PIN_SCL diff --git a/lvgl_tft/st7789.c b/lvgl_tft/st7789.c index 2b5bd7ee..38bdb96d 100644 --- a/lvgl_tft/st7789.c +++ b/lvgl_tft/st7789.c @@ -91,7 +91,7 @@ void st7789_init(void) gpio_pad_select_gpio(ST7789_DC); gpio_set_direction(ST7789_DC, GPIO_MODE_OUTPUT); -#if !defined(CONFIG_LV_DISP_ST7789_SOFT_RESET) +#if !defined(ST7789_SOFT_RST) gpio_pad_select_gpio(ST7789_RST); gpio_set_direction(ST7789_RST, GPIO_MODE_OUTPUT); #endif @@ -102,7 +102,7 @@ void st7789_init(void) #endif //Reset the display -#if !defined(CONFIG_LV_DISP_ST7789_SOFT_RESET) +#if !defined(ST7789_SOFT_RST) gpio_set_level(ST7789_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); gpio_set_level(ST7789_RST, 1); diff --git a/lvgl_tft/st7789.h b/lvgl_tft/st7789.h index 31753299..cccbd78e 100644 --- a/lvgl_tft/st7789.h +++ b/lvgl_tft/st7789.h @@ -25,6 +25,15 @@ extern "C" #define ST7789_RST CONFIG_LV_DISP_PIN_RST #define ST7789_BCKL CONFIG_LV_DISP_PIN_BCKL +#if CONFIG_LV_DISP_USE_RST + #if CONFIG_LV_DISP_ST7789_SOFT_RESET + #define ST7789_SOFT_RST + #endif +#else + #define ST7789_SOFT_RST +#endif + + #define ST7789_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL #define ST7789_INVERT_COLORS CONFIG_LV_INVERT_COLORS diff --git a/lvgl_tft/st7796s.c b/lvgl_tft/st7796s.c index 457b7079..44959f8d 100644 --- a/lvgl_tft/st7796s.c +++ b/lvgl_tft/st7796s.c @@ -94,18 +94,24 @@ void st7796s_init(void) //Initialize non-SPI GPIOs gpio_pad_select_gpio(ST7796S_DC); gpio_set_direction(ST7796S_DC, GPIO_MODE_OUTPUT); + +#if ST7796S_USE_RST gpio_pad_select_gpio(ST7796S_RST); gpio_set_direction(ST7796S_RST, GPIO_MODE_OUTPUT); +#endif #if ST7796S_ENABLE_BACKLIGHT_CONTROL gpio_pad_select_gpio(ST7796S_BCKL); gpio_set_direction(ST7796S_BCKL, GPIO_MODE_OUTPUT); #endif + +#if ST7796S_USE_RST //Reset the display gpio_set_level(ST7796S_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); gpio_set_level(ST7796S_RST, 1); vTaskDelay(100 / portTICK_RATE_MS); +#endif ESP_LOGI(TAG, "Initialization."); diff --git a/lvgl_tft/st7796s.h b/lvgl_tft/st7796s.h index 418ec9b7..48e566d0 100644 --- a/lvgl_tft/st7796s.h +++ b/lvgl_tft/st7796s.h @@ -26,9 +26,10 @@ extern "C" /********************* * DEFINES *********************/ -#define ST7796S_DC CONFIG_LV_DISP_PIN_DC -#define ST7796S_RST CONFIG_LV_DISP_PIN_RST -#define ST7796S_BCKL CONFIG_LV_DISP_PIN_BCKL +#define ST7796S_DC CONFIG_LV_DISP_PIN_DC +#define ST7796S_RST CONFIG_LV_DISP_PIN_RST +#define ST7796S_USE_RST CONFIG_LV_DISP_USE_RST +#define ST7796S_BCKL CONFIG_LV_DISP_PIN_BCKL #define ST7796S_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL #define ST7796S_INVERT_COLORS CONFIG_LV_INVERT_COLORS From 00dd1504d94209900e00e35031b9401cc7d1a3df Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Wed, 28 Apr 2021 11:15:00 +0200 Subject: [PATCH 05/70] Removed white space at EOL, added some EOLs at EOF Many code editors are set to do this automatically now, so it ends up being annoying to scrape back out of commits to keep them easily reviewable. Also added '.DS_Store' and 'build' entries to .gitignore --- .gitignore | 6 +++++ lvgl_tft/EVE_commands.h | 2 +- lvgl_tft/FT81x.c | 8 +++---- lvgl_tft/GC9A01.c | 8 +++---- lvgl_tft/Kconfig | 4 ++-- lvgl_tft/il3820.c | 50 ++++++++++++++++++++--------------------- lvgl_tft/ili9486.c | 6 ++--- lvgl_tft/ili9488.c | 6 ++--- 8 files changed, 48 insertions(+), 42 deletions(-) diff --git a/.gitignore b/.gitignore index c6127b38..38eeab75 100644 --- a/.gitignore +++ b/.gitignore @@ -50,3 +50,9 @@ modules.order Module.symvers Mkfile.old dkms.conf + +# MacOS +.DS_Store + +# ESP-IDF build dir +build diff --git a/lvgl_tft/EVE_commands.h b/lvgl_tft/EVE_commands.h index 7377a7f5..aa9d0612 100644 --- a/lvgl_tft/EVE_commands.h +++ b/lvgl_tft/EVE_commands.h @@ -68,7 +68,7 @@ void EVE_get_cmdoffset(void); /* commands to operate on memory: */ void EVE_cmd_memzero(uint32_t ptr, uint32_t num); void EVE_cmd_memset(uint32_t ptr, uint8_t value, uint32_t num); -void EVE_cmd_memwrite(uint32_t dest, uint32_t num, const uint8_t *data); +void EVE_cmd_memwrite(uint32_t dest, uint32_t num, const uint8_t *data); void EVE_cmd_memcpy(uint32_t dest, uint32_t src, uint32_t num); #if FT81X_FULL diff --git a/lvgl_tft/FT81x.c b/lvgl_tft/FT81x.c index 4afc52b8..63e0dee7 100644 --- a/lvgl_tft/FT81x.c +++ b/lvgl_tft/FT81x.c @@ -250,7 +250,7 @@ void TFT_bitmap_display(void) EVE_cmd_dl(TAG(0)); EVE_cmd_dl(DL_DISPLAY); /* instruct the graphics processor to show the list */ - + EVE_cmd_dl(CMD_SWAP); /* make this list active */ EVE_end_cmd_burst(); /* stop writing to the cmd-fifo */ @@ -273,7 +273,7 @@ void FT81x_init(void) #endif spi_acquire(); - + if(EVE_init()) { tft_active = 1; @@ -284,7 +284,7 @@ void FT81x_init(void) EVE_cmd_memset(SCREEN_BITMAP_ADDR, BLACK, SCREEN_BUFFER_SIZE); // clear screen buffer EVE_cmd_execute(); - + TFT_bitmap_display(); // set DL for fullscreen bitmap display } @@ -326,4 +326,4 @@ void TFT_WriteBitmap(uint8_t* Bitmap, uint16_t X, uint16_t Y, uint16_t Width, ui void FT81x_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map) { TFT_WriteBitmap((uint8_t*)color_map, area->x1, area->y1, lv_area_get_width(area), lv_area_get_height(area)); -} \ No newline at end of file +} diff --git a/lvgl_tft/GC9A01.c b/lvgl_tft/GC9A01.c index 525efc99..6f320518 100644 --- a/lvgl_tft/GC9A01.c +++ b/lvgl_tft/GC9A01.c @@ -173,7 +173,7 @@ void GC9A01_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo uint8_t data[4]; /*Column addresses*/ - GC9A01_send_cmd(0x2A); //0x2A + GC9A01_send_cmd(0x2A); //0x2A data[0] = (area->x1 >> 8) & 0xFF; data[1] = area->x1 & 0xFF; data[2] = (area->x2 >> 8) & 0xFF; @@ -181,7 +181,7 @@ void GC9A01_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo GC9A01_send_data(data, 4); /*Page addresses*/ - GC9A01_send_cmd(0x2B); //0x2B + GC9A01_send_cmd(0x2B); //0x2B data[0] = (area->y1 >> 8) & 0xFF; data[1] = area->y1 & 0xFF; data[2] = (area->y2 >> 8) & 0xFF; @@ -189,7 +189,7 @@ void GC9A01_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo GC9A01_send_data(data, 4); /*Memory write*/ - GC9A01_send_cmd(0x2C); //0x2C + GC9A01_send_cmd(0x2C); //0x2C uint32_t size = lv_area_get_width(area) * lv_area_get_height(area); @@ -217,7 +217,7 @@ void GC9A01_sleep_in() { uint8_t data[] = {0x08}; GC9A01_send_cmd(0x10); //0x10 Enter Sleep Mode - GC9A01_send_data(&data, 1); + GC9A01_send_data(&data, 1); } void GC9A01_sleep_out() diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index d2063930..01bb4ba9 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -744,11 +744,11 @@ menu "LVGL TFT Display controller" config LV_DISP_ST7789_SOFT_RESET bool "Soft reset - use software reset instead of reset pin" - depends on LV_TFT_DISPLAY_CONTROLLER_ST7789 + depends on LV_TFT_DISPLAY_CONTROLLER_ST7789 default n help Use software reset and ignores configured reset pin (some hardware does not use a reset pin). - + endmenu # menu will be visible only when LV_PREDEFINED_DISPLAY_NONE is y diff --git a/lvgl_tft/il3820.c b/lvgl_tft/il3820.c index 80358b27..fee39e23 100644 --- a/lvgl_tft/il3820.c +++ b/lvgl_tft/il3820.c @@ -73,9 +73,9 @@ static uint8_t il3820_lut_initial[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; static uint8_t il3820_lut_default[] = { - 0x10, 0x18, 0x18, 0x08, 0x18, 0x18, - 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x10, 0x18, 0x18, 0x08, 0x18, 0x18, + 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x13, 0x14, 0x44, 0x12, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; @@ -113,7 +113,7 @@ void il3820_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_m uint8_t *buffer = (uint8_t*) color_map; uint16_t x_addr_counter = 0; uint16_t y_addr_counter = 0; - + /* Configure entry mode */ il3820_write_cmd(IL3820_CMD_ENTRY_MODE, &il3820_scan_mode, 1); @@ -131,7 +131,7 @@ void il3820_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_m il3820_set_cursor(x_addr_counter, y_addr_counter); il3820_send_cmd(IL3820_CMD_WRITE_RAM); - + /* Write the pixel data to graphic RAM, linelen bytes at the time. */ for(size_t row = 0; row <= (EPD_PANEL_HEIGHT - 1); row++){ il3820_send_data(buffer, linelen); @@ -139,7 +139,7 @@ void il3820_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_m } il3820_set_window(0, EPD_PANEL_WIDTH - 1, 0, EPD_PANEL_HEIGHT - 1); - + il3820_update_display(); /* IMPORTANT!!! @@ -152,7 +152,7 @@ void il3820_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_m * BIT_SET(byte_index, bit_index) clears the bit_index pixel at byte_index of * the display buffer. * BIT_CLEAR(byte_index, bit_index) sets the bit_index pixel at the byte_index - * of the display buffer. */ + * of the display buffer. */ void il3820_set_px_cb(lv_disp_drv_t * disp_drv, uint8_t* buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y, lv_color_t color, lv_opa_t opa) @@ -217,7 +217,7 @@ void il3820_init(void) /* Software reset */ il3820_write_cmd(IL3820_CMD_SW_RESET, NULL, 0); - + /* Busy wait for the BUSY signal to go low */ il3820_waitbusy(IL3820_WAIT); @@ -245,10 +245,10 @@ void il3820_init(void) // allow partial updates now il3820_partial = true; - + /* Update LUT */ il3820_write_cmd(IL3820_CMD_UPDATE_LUT, il3820_lut_default, sizeof(il3820_lut_default)); - + /* Clear control memory and update */ il3820_clear_cntlr_mem(IL3820_CMD_WRITE_RAM, true); } @@ -257,10 +257,10 @@ void il3820_init(void) void il3820_sleep_in(void) { uint8_t data[] = {0x01}; - + /* Wait for the BUSY signal to go low */ il3820_waitbusy(IL3820_WAIT); - + il3820_write_cmd(IL3820_CMD_SLEEP_MODE, data, 1); } @@ -270,15 +270,15 @@ static void il3820_waitbusy(int wait_ms) int i = 0; vTaskDelay(10 / portTICK_RATE_MS); // 10ms delay - + for(i = 0; i < (wait_ms * 10); i++) { if(gpio_get_level(IL3820_BUSY_PIN) != IL3820_BUSY_LEVEL) { return; } - + vTaskDelay(10 / portTICK_RATE_MS); } - + ESP_LOGE( TAG, "busy exceeded %dms", i*10 ); } @@ -294,10 +294,10 @@ static inline void il3820_data_mode(void) gpio_set_level(IL3820_DC_PIN, 1); } -static inline void il3820_write_cmd(uint8_t cmd, uint8_t *data, size_t len) +static inline void il3820_write_cmd(uint8_t cmd, uint8_t *data, size_t len) { disp_wait_for_pending_transactions(); - + il3820_command_mode(); disp_spi_send_data(&cmd, 1); @@ -308,10 +308,10 @@ static inline void il3820_write_cmd(uint8_t cmd, uint8_t *data, size_t len) } /* Send cmd to the display */ -static inline void il3820_send_cmd(uint8_t cmd) +static inline void il3820_send_cmd(uint8_t cmd) { disp_wait_for_pending_transactions(); - + il3820_command_mode(); disp_spi_send_data(&cmd, 1); } @@ -320,14 +320,14 @@ static inline void il3820_send_cmd(uint8_t cmd) static void il3820_send_data(uint8_t *data, uint16_t length) { disp_wait_for_pending_transactions(); - + il3820_data_mode(); disp_spi_send_colors(data, length); } /* Specify the start/end positions of the window address in the X and Y * directions by an address unit. - * + * * @param sx: X Start position. * @param ex: X End position. * @param ys: Y Start position. @@ -336,7 +336,7 @@ static void il3820_send_data(uint8_t *data, uint16_t length) static inline void il3820_set_window( uint16_t sx, uint16_t ex, uint16_t ys, uint16_t ye) { uint8_t tmp[4] = {0}; - + tmp[0] = sx / 8; tmp[1] = ex / 8; @@ -384,7 +384,7 @@ static void il3820_update_display(void) } else { tmp = (IL3820_CTRL2_ENABLE_CLK | IL3820_CTRL2_ENABLE_ANALOG | IL3820_CTRL2_TO_PATTERN); } - + il3820_write_cmd(IL3820_CMD_UPDATE_CTRL2, &tmp, 1); il3820_write_cmd(IL3820_CMD_MASTER_ACTIVATION, NULL, 0); @@ -400,10 +400,10 @@ static void il3820_clear_cntlr_mem(uint8_t ram_cmd, bool update) /* Arrays used by SPI must be word alligned */ WORD_ALIGNED_ATTR uint8_t clear_page[IL3820_COLUMNS]; memset(clear_page, 0xff, sizeof clear_page); - + /* Configure entry mode */ il3820_write_cmd(IL3820_CMD_ENTRY_MODE, &il3820_scan_mode, 1); - + /* Configure the window */ il3820_set_window(0, EPD_PANEL_WIDTH - 1, 0, EPD_PANEL_HEIGHT - 1); diff --git a/lvgl_tft/ili9486.c b/lvgl_tft/ili9486.c index dd82ac97..166bef87 100644 --- a/lvgl_tft/ili9486.c +++ b/lvgl_tft/ili9486.c @@ -60,8 +60,8 @@ void ili9486_init(void) {0xE0, {0x0F, 0x1F, 0x1C, 0x0C, 0x0F, 0x08, 0x48, 0x98, 0x37, 0x0A, 0x13, 0x04, 0x11, 0x0D, 0x00}, 15}, {0XE1, {0x0F, 0x32, 0x2E, 0x0B, 0x0D, 0x05, 0x47, 0x75, 0x37, 0x06, 0x10, 0x03, 0x24, 0x20, 0x00}, 15}, {0x20, {0}, 0}, /* display inversion OFF */ - {0x36, {0x48}, 1}, - {0x29, {0}, 0x80}, /* display on */ + {0x36, {0x48}, 1}, + {0x29, {0}, 0x80}, /* display on */ {0x00, {0}, 0xff}, }; @@ -140,7 +140,7 @@ void ili9486_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * col ili9486_send_cmd(0x2C); size = lv_area_get_width(area) * lv_area_get_height(area); - + ili9486_send_color((void*) color_map, size * 2); } diff --git a/lvgl_tft/ili9488.c b/lvgl_tft/ili9488.c index 5379b776..ce8bba08 100644 --- a/lvgl_tft/ili9488.c +++ b/lvgl_tft/ili9488.c @@ -50,7 +50,7 @@ static void ili9488_send_color(void * data, uint16_t length); /********************** * GLOBAL FUNCTIONS **********************/ -// From github.com/jeremyjh/ESP32_TFT_library +// From github.com/jeremyjh/ESP32_TFT_library // From github.com/mvturnho/ILI9488-lvgl-ESP32-WROVER-B void ili9488_init(void) { @@ -102,7 +102,7 @@ void ili9488_init(void) // Exit sleep ili9488_send_cmd(0x01); /* Software reset */ vTaskDelay(100 / portTICK_RATE_MS); - + //Send all the commands uint16_t cmd = 0; while (ili_init_cmds[cmd].databytes!=0xff) { @@ -151,7 +151,7 @@ void ili9488_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * col (uint8_t) (area->x2 >> 8) & 0xFF, (uint8_t) (area->x2) & 0xFF, }; - + /* Page addresses */ uint8_t yb[] = { (uint8_t) (area->y1 >> 8) & 0xFF, From 4ba7c7602833cb9c8337aa45702ece9de2c0ec8a Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Wed, 28 Apr 2021 11:43:40 +0200 Subject: [PATCH 06/70] Added support for M5Core2 screen (CONFIG_LV_PREDEFINED_DISPLAY_M5CORE2) Update README.md --- README.md | 1 + lvgl_tft/Kconfig | 12 ++++++++++++ lvgl_tft/ili9341.c | 2 ++ 3 files changed, 15 insertions(+) diff --git a/README.md b/README.md index 6aeec919..7ee9a6c7 100644 --- a/README.md +++ b/README.md @@ -51,6 +51,7 @@ and sets the gpio numbers for the interface. |---------------------------|-----------------------|-----------|-----------|-----------| | ESP Wrover Kit v4.1 | ILI9341 | SPI | 240 | 320 | | M5Stack | ILI9341 | SPI | 240 | 320 | +| M5Core2 | ILI9341 | SPI | 240 | 320 | | M5Stick | SH1107 | SPI | - | - | | M5StickC | ST7735S | SPI | 80 | 160 | | Adafruit 3.5 Featherwing | HX8357 | SPI | 480 | 320 | diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 01bb4ba9..47be8d16 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -21,6 +21,10 @@ menu "LVGL TFT Display controller" bool "M5Stack" select LV_TFT_DISPLAY_CONTROLLER_ILI9341 select LV_TFT_DISPLAY_PROTOCOL_SPI + config LV_PREDEFINED_DISPLAY_M5CORE2 + bool "M5Core2" + select LV_TFT_DISPLAY_CONTROLLER_ILI9341 + select LV_TFT_DISPLAY_PROTOCOL_SPI config LV_PREDEFINED_DISPLAY_M5STICK bool "M5Stick" select LV_TFT_DISPLAY_CONTROLLER_SH1107 @@ -763,6 +767,7 @@ menu "LVGL TFT Display controller" default 23 if LV_PREDEFINED_DISPLAY_WROVER4 default 23 if LV_PREDEFINED_DISPLAY_ATAG default 23 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK + default 23 if LV_PREDEFINED_DISPLAY_M5CORE2 default 15 if LV_PREDEFINED_DISPLAY_M5STICKC default 18 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING default 23 if LV_PREDEFINED_PINS_TKOALA @@ -777,6 +782,7 @@ menu "LVGL TFT Display controller" config LV_DISPLAY_USE_SPI_MISO bool "GPIO for MISO (Master In Slave Out)" if LV_TFT_DISPLAY_PROTOCOL_SPI default y if LV_PREDEFINED_PINS_TKOALA + default y if LV_PREDEFINED_DISPLAY_M5CORE2 help Enable the MISO signal to control the display. You can disable it when the display does not need MISO signal to be controlled. @@ -788,6 +794,7 @@ menu "LVGL TFT Display controller" range 0 43 if IDF_TARGET_ESP32S2 default 19 if LV_PREDEFINED_PINS_TKOALA + default 38 if LV_PREDEFINED_DISPLAY_M5CORE2 default 0 help @@ -830,6 +837,7 @@ menu "LVGL TFT Display controller" range 0 43 if IDF_TARGET_ESP32S2 default 18 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK + default 18 if LV_PREDEFINED_DISPLAY_M5CORE2 default 13 if LV_PREDEFINED_DISPLAY_M5STICKC default 18 if LV_PREDEFINED_DISPLAY_ATAG default 19 if LV_PREDEFINED_DISPLAY_WROVER4 @@ -858,6 +866,7 @@ menu "LVGL TFT Display controller" default 5 if LV_PREDEFINED_PINS_38V1 default 14 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK + default 5 if LV_PREDEFINED_DISPLAY_M5CORE2 default 5 if LV_PREDEFINED_DISPLAY_M5STICKC default 22 if LV_PREDEFINED_DISPLAY_WROVER4 default 15 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING @@ -887,6 +896,7 @@ menu "LVGL TFT Display controller" default 19 if LV_PREDEFINED_PINS_38V1 default 17 if LV_PREDEFINED_PINS_38V4 default 27 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK + default 15 if LV_PREDEFINED_DISPLAY_M5CORE2 default 23 if LV_PREDEFINED_DISPLAY_M5STICKC default 21 if LV_PREDEFINED_DISPLAY_WROVER4 default 21 if LV_PREDEFINED_DISPLAY_WT32_SC01 @@ -902,6 +912,7 @@ menu "LVGL TFT Display controller" config LV_DISP_USE_RST bool "Use a GPIO for resetting the display" if LV_TFT_DISPLAY_PROTOCOL_SPI + default n if LV_PREDEFINED_DISPLAY_M5CORE2 default y help Enable display reset control. Set this if the reset pin of the @@ -950,6 +961,7 @@ menu "LVGL TFT Display controller" ( LV_PREDEFINED_DISPLAY_NONE && ! ( LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 ) ) \ || LV_PREDEFINED_DISPLAY_RPI_MPI3501 default y if LV_PREDEFINED_DISPLAY_M5STACK + default n if LV_PREDEFINED_DISPLAY_M5CORE2 default y if LV_PREDEFINED_DISPLAY_WROVER4 default y if LV_PREDEFINED_DISPLAY_ERTFT0356 default y if LV_PREDEFINED_DISPLAY_TTGO diff --git a/lvgl_tft/ili9341.c b/lvgl_tft/ili9341.c index 41bd1995..23aba09c 100644 --- a/lvgl_tft/ili9341.c +++ b/lvgl_tft/ili9341.c @@ -233,6 +233,8 @@ static void ili9341_set_orientation(uint8_t orientation) #if defined CONFIG_LV_PREDEFINED_DISPLAY_M5STACK uint8_t data[] = {0x68, 0x68, 0x08, 0x08}; +#elif defined (CONFIG_LV_PREDEFINED_DISPLAY_M5CORE2) + uint8_t data[] = {0x08, 0x88, 0x28, 0xE8}; #elif defined (CONFIG_LV_PREDEFINED_DISPLAY_WROVER4) uint8_t data[] = {0x6C, 0xEC, 0xCC, 0x4C}; #elif defined (CONFIG_LV_PREDEFINED_DISPLAY_NONE) From 21f81d117b49c8e0097bc9ac435ed3124d39d96f Mon Sep 17 00:00:00 2001 From: Martin Lindberg Mogensen Date: Thu, 29 Apr 2021 09:55:22 +0200 Subject: [PATCH 07/70] Support ILI9163c (Sparkfun LCD-15143) --- CMakeLists.txt | 2 + README.md | 1 + lvgl_helpers.h | 2 + lvgl_spi_conf.h | 7 +- lvgl_tft/Kconfig | 15 ++- lvgl_tft/disp_driver.c | 8 +- lvgl_tft/disp_driver.h | 2 + lvgl_tft/ili9163c.c | 270 +++++++++++++++++++++++++++++++++++++++++ lvgl_tft/ili9163c.h | 65 ++++++++++ 9 files changed, 365 insertions(+), 7 deletions(-) create mode 100644 lvgl_tft/ili9163c.c create mode 100644 lvgl_tft/ili9163c.h diff --git a/CMakeLists.txt b/CMakeLists.txt index d86bd33f..58322335 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -41,6 +41,8 @@ elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_RA8875) list(APPEND SOURCES "lvgl_tft/ra8875.c") elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_GC9A01) list(APPEND SOURCES "lvgl_tft/GC9A01.c") +elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C) + list(APPEND SOURCES "lvgl_tft/ili9163c.c") else() message(WARNING "LVGL ESP32 drivers: Display controller not defined.") endif() diff --git a/README.md b/README.md index 6aeec919..70fa0473 100644 --- a/README.md +++ b/README.md @@ -17,6 +17,7 @@ swap of RGB565 color on the LVGL configuration menuconfig (it's not handled auto | Display Controller | Type | Interface | Color depth (LV_COLOR_DEPTH) | Swap RGB565 color (LV_COLOR_16_SWAP) | |---------------------------------------------|------------|------------------------|------------------------------|----------------------------------------| | ILI9341 | TFT | SPI | 16: RGB565 | Yes | +| ILI9163C | TFT | SPI | 16: RGB565 | Yes | | ILI9486 | TFT | SPI | 16: RGB565 | Yes | | ILI9488 | TFT | SPI | 16: RGB565 | No | | HX8357B/HX8357D | TFT | SPI | 16: RGB565 | Yes | diff --git a/lvgl_helpers.h b/lvgl_helpers.h index 70ef3534..081a8437 100644 --- a/lvgl_helpers.h +++ b/lvgl_helpers.h @@ -73,6 +73,8 @@ extern "C" { #define DISP_BUF_SIZE ((LV_VER_RES_MAX * LV_VER_RES_MAX) / 8) // 5KB #elif defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_UC8151D) #define DISP_BUF_SIZE ((LV_VER_RES_MAX * LV_VER_RES_MAX) / 8) // 2888 bytes +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C +#define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40) #else #error "No display controller selected" #endif diff --git a/lvgl_spi_conf.h b/lvgl_spi_conf.h index 16e63b4f..b5e79012 100644 --- a/lvgl_spi_conf.h +++ b/lvgl_spi_conf.h @@ -130,7 +130,8 @@ extern "C" { defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_SH1107) || \ defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_FT81X) || \ defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_IL3820) || \ - defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_JD79653A) + defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_JD79653A) || \ + defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C) #define SPI_BUS_MAX_TRANSFER_SZ (DISP_BUF_SIZE * 2) @@ -157,7 +158,9 @@ extern "C" { #define SPI_TFT_CLOCK_SPEED_HZ (40*1000*1000) #elif defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9341) #define SPI_TFT_CLOCK_SPEED_HZ (40*1000*1000) -#elif defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_FT81X) +#elif defined(CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C) +#define SPI_TFT_CLOCK_SPEED_HZ (40 * 1000 * 1000) +#elif defined(CONFIG_LV_TFT_DISPLAY_CONTROLLER_FT81X) #define SPI_TFT_CLOCK_SPEED_HZ (32*1000*1000) #else #define SPI_TFT_CLOCK_SPEED_HZ (40*1000*1000) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index ddd7f516..e822f600 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -165,6 +165,11 @@ menu "LVGL TFT Display controller" help ST7796S display controller. + config LV_TFT_DISPLAY_CONTROLLER_ILI9163C + bool + help + ILI9163C display controller. + # Display controller communication protocol # # This symbols define the communication protocol used by the @@ -327,6 +332,10 @@ menu "LVGL TFT Display controller" bool "RA8875" select LV_TFT_DISPLAY_CONTROLLER_RA8875 select LV_TFT_DISPLAY_PROTOCOL_SPI + config LV_TFT_DISPLAY_USER_CONTROLLER_ILI9163C + bool "ILI9163C" + select LV_TFT_DISPLAY_CONTROLLER_ILI9163C + select LV_TFT_DISPLAY_PROTOCOL_SPI endchoice config CUSTOM_DISPLAY_BUFFER_SIZE @@ -586,7 +595,7 @@ menu "LVGL TFT Display controller" If text is backwards on your display, try enabling this. config LV_INVERT_COLORS - bool "Invert colors in display" if LV_TFT_DISPLAY_CONTROLLER_ILI9341 || LV_TFT_DISPLAY_CONTROLLER_ST7735S || LV_TFT_DISPLAY_CONTROLLER_ILI9481 || LV_TFT_DISPLAY_CONTROLLER_ST7789 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 || LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_HX8357 + bool "Invert colors in display" if LV_TFT_DISPLAY_CONTROLLER_ILI9341 || LV_TFT_DISPLAY_CONTROLLER_ST7735S || LV_TFT_DISPLAY_CONTROLLER_ILI9481 || LV_TFT_DISPLAY_CONTROLLER_ST7789 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 || LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_HX8357 || LV_TFT_DISPLAY_CONTROLLER_ILI9163C default y if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICKC help If the colors look inverted on your display, try enabling this. @@ -744,11 +753,11 @@ menu "LVGL TFT Display controller" config LV_DISP_ST7789_SOFT_RESET bool "Soft reset - use software reset instead of reset pin" - depends on LV_TFT_DISPLAY_CONTROLLER_ST7789 + depends on LV_TFT_DISPLAY_CONTROLLER_ST7789 default n help Use software reset and ignores configured reset pin (some hardware does not use a reset pin). - + endmenu # menu will be visible only when LV_PREDEFINED_DISPLAY_NONE is y diff --git a/lvgl_tft/disp_driver.c b/lvgl_tft/disp_driver.c index 9f8e8579..adae2ad7 100644 --- a/lvgl_tft/disp_driver.c +++ b/lvgl_tft/disp_driver.c @@ -21,7 +21,7 @@ void disp_driver_init(void) st7735s_init(); #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_HX8357 hx8357_init(); -#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9486 +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9486 ili9486_init(); #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SH1107 sh1107_init(); @@ -39,6 +39,8 @@ void disp_driver_init(void) jd79653a_init(); #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_UC8151D uc8151d_init(); +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C + ili9163c_init(); #endif } @@ -76,6 +78,8 @@ void disp_driver_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * jd79653a_lv_fb_flush(drv, area, color_map); #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_UC8151D uc8151d_lv_fb_flush(drv, area, color_map); +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C + ili9163c_flush(drv, area, color_map); #endif } @@ -95,7 +99,7 @@ void disp_driver_rounder(lv_disp_drv_t * disp_drv, lv_area_t * area) } void disp_driver_set_px(lv_disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y, - lv_color_t color, lv_opa_t opa) + lv_color_t color, lv_opa_t opa) { #if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_SSD1306 ssd1306_set_px_cb(disp_drv, buf, buf_w, x, y, color, opa); diff --git a/lvgl_tft/disp_driver.h b/lvgl_tft/disp_driver.h index e48d05ec..2e369cc9 100644 --- a/lvgl_tft/disp_driver.h +++ b/lvgl_tft/disp_driver.h @@ -50,6 +50,8 @@ extern "C" { #include "jd79653a.h" #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_UC8151D #include "uc8151d.h" +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C +#include "ili9163c.h" #endif /********************* diff --git a/lvgl_tft/ili9163c.c b/lvgl_tft/ili9163c.c new file mode 100644 index 00000000..77346e40 --- /dev/null +++ b/lvgl_tft/ili9163c.c @@ -0,0 +1,270 @@ +/** + * @file ILI9163C.c + * + */ + +/********************* + * INCLUDES + *********************/ +#include "ili9163c.h" +#include "disp_spi.h" +#include "driver/gpio.h" +#include "esp_log.h" +#include "freertos/FreeRTOS.h" +#include "freertos/task.h" +#include "assert.h" + +/********************* + * DEFINES + *********************/ +#define TAG "ILI9163C" + +// ILI9163C specific commands used in init +#define ILI9163C_NOP 0x00 +#define ILI9163C_SWRESET 0x01 +#define ILI9163C_RDDID 0x04 +#define ILI9163C_RDDST 0x09 + +#define ILI9163C_SLPIN 0x10 +#define ILI9163C_SLPOUT 0x11 +#define ILI9163C_PTLON 0x12 +#define ILI9163C_NORON 0x13 + +#define ILI9163C_INVOFF 0x20 +#define ILI9163C_INVON 0x21 +#define ILI9163C_CMD_GAMST 0x26 +#define ILI9163C_DISPOFF 0x28 +#define ILI9163C_DISPON 0x29 +#define ILI9163C_CASET 0x2A +#define ILI9163C_RASET 0x2B +#define ILI9163C_RAMWR 0x2C +#define ILI9163C_COLORSET 0x2D +#define ILI9163C_RAMRD 0x2E + +#define ILI9163C_PTLAR 0x30 +#define ILI9163C_VSCRDEF 0x33 +#define ILI9163C_COLMOD 0x3A +#define ILI9163C_MADCTL 0x36 +#define ILI9163C_VSCRSADD 0x37 + +#define ILI9163C_FRMCTR1 0xB1 +#define ILI9163C_FRMCTR2 0xB2 +#define ILI9163C_FRMCTR3 0xB3 +#define ILI9163C_INVCTR 0xB4 +#define ILI9163C_DISSET5 0xB6 +#define ILI9163C_SDDC 0xB7 + +#define ILI9163C_PWCTR1 0xC0 +#define ILI9163C_PWCTR2 0xC1 +#define ILI9163C_PWCTR3 0xC2 +#define ILI9163C_PWCTR4 0xC3 +#define ILI9163C_PWCTR5 0xC4 +#define ILI9163C_VMCTR1 0xC5 +#define ILI9163C_VMCOFFS 0xC7 + +#define ILI9163C_GAMCTL 0xF2 + +#define ILI9163C_GMCTRP1 0xE0 +#define ILI9163C_GMCTRN1 0xE1 + +#define ST77XX_MADCTL_MY 0x80 +#define ST77XX_MADCTL_MX 0x40 +#define ST77XX_MADCTL_MV 0x20 #define +#define ST77XX_MADCTL_ML 0x10 +#define ST77XX_MADCTL_RGB 0x00 +#define ST77XX_MADCTL_BGR 0x08 + +/********************** + * TYPEDEFS + **********************/ + +/*The LCD needs a bunch of command/argument values to be initialized. They are stored in this struct. */ +typedef struct +{ + uint8_t cmd; + uint8_t data[16]; + uint8_t databytes; //No of data in data; bit 7 = delay after set; 0xFF = end of cmds. +} lcd_init_cmd_t; + +/********************** + * STATIC PROTOTYPES + **********************/ +static void ili9163c_set_orientation(uint8_t orientation); + +static void ili9163c_send_cmd(uint8_t cmd); +static void ili9163c_send_data(void *data, uint16_t length); +static void ili9163c_send_color(void *data, uint16_t length); + +/********************** + * STATIC VARIABLES + **********************/ + +/********************** + * MACROS + **********************/ + +/********************** + * GLOBAL FUNCTIONS + **********************/ + +void ili9163c_init(void) +{ + ESP_LOGD(TAG, "Init"); + + lcd_init_cmd_t ili_init_cmds[] = { + {ILI9163C_SWRESET, {0}, 0x80}, // Software reset, 0 args, w/delay 120ms + {ILI9163C_SLPOUT, {0}, 0x80}, // Out of sleep mode, 0 args, w/delay 5ms + {ILI9163C_CMD_GAMST, {0x04}, 1}, // Gamma Curve + {ILI9163C_FRMCTR1, {0x0C, 0x14}, 2}, // Frame rate ctrl - normal mode + {ILI9163C_INVCTR, {0x07}, 1}, // Display inversion ctrl, 1 arg, no delay:No inversion + {ILI9163C_PWCTR1, {0x0C, 0x05}, 2}, // Power control, 2 args, no delay + {ILI9163C_PWCTR2, {0x02}, 1}, // Power control, 1 arg + {ILI9163C_PWCTR3, {0x02}, 1}, // Power control, 1 arg + {ILI9163C_VMCTR1, {0x20, 0x55}, 2}, // Power control, 1 arg, no delay: + {ILI9163C_VMCOFFS, {0x40}, 1}, // VCOM Offset +#if ILI9163C_INVERT_COLORS == 1 + {ILI9163C_INVON, {0}, 0}, // set inverted mode +#else + {ILI9163C_INVOFF, {0}, 0}, // set non-inverted mode +#endif + {ILI9163C_COLMOD, {0x5}, 1}, // set color mode, 1 arg, no delay: 16-bit color + {ILI9163C_SDDC, {0}, 1}, // set source driver direction control + {ILI9163C_GAMCTL, {0x01}, 1}, // set source driver direction control + {ILI9163C_GMCTRP1, {0x36, 0x29, 0x12, 0x22, 0x1C, 0x15, 0x42, 0xB7, 0x2F, 0x13, 0x12, 0x0A, 0x11, 0x0B, 0x06}, 16}, // 16 args, no delay: + {ILI9163C_GMCTRN1, {0x09, 0x16, 0x2D, 0x0D, 0x13, 0x15, 0x40, 0x48, 0x53, 0x0C, 0x1D, 0x25, 0x2E, 0x34, 0x39}, 16}, // 16 args, no delay: + {ILI9163C_NORON, {0}, 0x80}, // Normal display on, no args, w/delay 10 ms delay + {ILI9163C_DISPON, {0}, 0x80}, // Main screen turn on, no args w/delay 100 ms delay + {0, {0}, 0xff} + }; + + //Initialize non-SPI GPIOs + gpio_pad_select_gpio(ILI9163C_DC); + gpio_set_direction(ILI9163C_DC, GPIO_MODE_OUTPUT); + gpio_pad_select_gpio(ILI9163C_RST); + gpio_set_direction(ILI9163C_RST, GPIO_MODE_OUTPUT); + +#if ILI9163C_ENABLE_BACKLIGHT_CONTROL + gpio_pad_select_gpio(ILI9163C_BCKL); + gpio_set_direction(ILI9163C_BCKL, GPIO_MODE_OUTPUT); +#endif + //Reset the display + gpio_set_level(ILI9163C_RST, 0); + vTaskDelay(100 / portTICK_RATE_MS); + gpio_set_level(ILI9163C_RST, 1); + vTaskDelay(150 / portTICK_RATE_MS); + + //Send all the commands + uint16_t cmd = 0; + while (ili_init_cmds[cmd].databytes != 0xff) + { + ili9163c_send_cmd(ili_init_cmds[cmd].cmd); + ili9163c_send_data(ili_init_cmds[cmd].data, ili_init_cmds[cmd].databytes & 0x1F); + if (ili_init_cmds[cmd].databytes & 0x80) + { + vTaskDelay(150 / portTICK_RATE_MS); + } + cmd++; + } + + ili9163c_enable_backlight(true); + + ili9163c_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); +} + +void ili9163c_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map) +{ + uint8_t data[4]; + + /*Column addresses*/ + ili9163c_send_cmd(ILI9163C_CASET); + data[0] = (area->x1 >> 8) & 0xFF; + data[1] = area->x1 & 0xFF; + data[2] = (area->x2 >> 8) & 0xFF; + data[3] = area->x2 & 0xFF; + ili9163c_send_data(data, 4); + + /*Page addresses*/ + ili9163c_send_cmd(ILI9163C_RASET); + data[0] = (area->y1 >> 8) & 0xFF; + data[1] = area->y1 & 0xFF; + data[2] = (area->y2 >> 8) & 0xFF; + data[3] = area->y2 & 0xFF; + ili9163c_send_data(data, 4); + + /*Memory write*/ + ili9163c_send_cmd(ILI9163C_RAMWR); + + uint32_t size = lv_area_get_width(area) * lv_area_get_height(area); + + ili9163c_send_color((void *)color_map, size * 2); +} + +void ili9163c_enable_backlight(bool backlight) +{ +#if ILI9163C_ENABLE_BACKLIGHT_CONTROL + ESP_LOGD(TAG, "%s backlight.", backlight ? "Enabling" : "Disabling"); + uint32_t tmp = 0; + +#if (ILI9163C_BCKL_ACTIVE_LVL == 1) + tmp = backlight ? 1 : 0; +#else + tmp = backlight ? 0 : 1; +#endif + + gpio_set_level(ILI9163C_BCKL, tmp); +#endif +} + +void ili9163c_sleep_in() +{ + uint8_t data[] = {0x08}; + ili9163c_send_cmd(ILI9163C_SLPIN); + ili9163c_send_data(&data, 1); +} + +void ili9163c_sleep_out() +{ + uint8_t data[] = {0x08}; + ili9163c_send_cmd(ILI9163C_SLPOUT); + ili9163c_send_data(&data, 1); +} + +/********************** + * STATIC FUNCTIONS + **********************/ + +static void ili9163c_send_cmd(uint8_t cmd) +{ + disp_wait_for_pending_transactions(); + gpio_set_level(ILI9163C_DC, 0); /*Command mode*/ + disp_spi_send_data(&cmd, 1); +} + +static void ili9163c_send_data(void *data, uint16_t length) +{ + disp_wait_for_pending_transactions(); + gpio_set_level(ILI9163C_DC, 1); /*Data mode*/ + disp_spi_send_data(data, length); +} + +static void ili9163c_send_color(void *data, uint16_t length) +{ + disp_wait_for_pending_transactions(); + gpio_set_level(ILI9163C_DC, 1); /*Data mode*/ + disp_spi_send_colors(data, length); +} + +static void ili9163c_set_orientation(uint8_t orientation) +{ + assert(orientation < 4); + + const char *orientation_str[] = { + "PORTRAIT", "PORTRAIT_INVERTED", "LANDSCAPE", "LANDSCAPE_INVERTED"}; + + ESP_LOGD(TAG, "Display orientation: %s", orientation_str[orientation]); + + uint8_t data[] = {0x48, 0x88, 0xA8, 0x68}; + + ili9163c_send_cmd(ILI9163C_MADCTL); + ili9163c_send_data((void *)&data[orientation], 1); +} diff --git a/lvgl_tft/ili9163c.h b/lvgl_tft/ili9163c.h new file mode 100644 index 00000000..f164ba80 --- /dev/null +++ b/lvgl_tft/ili9163c.h @@ -0,0 +1,65 @@ +/** + * @file lv_templ.h + * + */ + +#ifndef ILI9163C_H +#define ILI9163C_H + +#ifdef __cplusplus +extern "C" +{ +#endif + +/********************* + * INCLUDES + *********************/ +#include + +#ifdef LV_LVGL_H_INCLUDE_SIMPLE +#include "lvgl.h" +#else +#include "lvgl/lvgl.h" +#endif +#include "../lvgl_helpers.h" + +/********************* + * DEFINES + *********************/ +#define ILI9163C_DC CONFIG_LV_DISP_PIN_DC +#define ILI9163C_RST CONFIG_LV_DISP_PIN_RST +#define ILI9163C_BCKL CONFIG_LV_DISP_PIN_BCKL + +#define ILI9163C_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL + +#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL +#define ILI9163C_BCKL_ACTIVE_LVL 1 +#else +#define ILI9163C_BCKL_ACTIVE_LVL 0 +#endif + +#define ILI9163C_INVERT_COLORS CONFIG_LV_INVERT_COLORS + + /********************** + * TYPEDEFS + **********************/ + + /********************** + * GLOBAL PROTOTYPES + **********************/ + + void ili9163c_init(void); + void ili9163c_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map); + void ili9163c_enable_backlight(bool backlight); + void ili9163c_sleep_in(void); + void ili9163c_sleep_out(void); + + /********************** + * MACROS + **********************/ + +#ifdef __cplusplus +} /* extern "C" */ +#endif + +#endif /*ILI9163C_H*/ From 23907711caeb2e90690d16f051d676ac9af7c18c Mon Sep 17 00:00:00 2001 From: C47D Date: Sun, 9 May 2021 21:31:32 -0500 Subject: [PATCH 08/70] ST7789: Expose send_cmd and send_data to the user --- lvgl_tft/st7789.c | 6 ++---- lvgl_tft/st7789.h | 3 +++ 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/lvgl_tft/st7789.c b/lvgl_tft/st7789.c index 2b5bd7ee..b8b9fb3e 100644 --- a/lvgl_tft/st7789.c +++ b/lvgl_tft/st7789.c @@ -35,8 +35,6 @@ typedef struct { **********************/ static void st7789_set_orientation(uint8_t orientation); -static void st7789_send_cmd(uint8_t cmd); -static void st7789_send_data(void *data, uint16_t length); static void st7789_send_color(void *data, uint16_t length); /********************** @@ -201,14 +199,14 @@ void st7789_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo /********************** * STATIC FUNCTIONS **********************/ -static void st7789_send_cmd(uint8_t cmd) +void st7789_send_cmd(uint8_t cmd) { disp_wait_for_pending_transactions(); gpio_set_level(ST7789_DC, 0); disp_spi_send_data(&cmd, 1); } -static void st7789_send_data(void * data, uint16_t length) +void st7789_send_data(void * data, uint16_t length) { disp_wait_for_pending_transactions(); gpio_set_level(ST7789_DC, 1); diff --git a/lvgl_tft/st7789.h b/lvgl_tft/st7789.h index 31753299..7fc6a304 100644 --- a/lvgl_tft/st7789.h +++ b/lvgl_tft/st7789.h @@ -114,6 +114,9 @@ void st7789_init(void); void st7789_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map); void st7789_enable_backlight(bool backlight); +void st7789_send_cmd(uint8_t cmd); +void st7789_send_data(void *data, uint16_t length); + #ifdef __cplusplus } /* extern "C" */ #endif From c3e8f49ae41e0a4c592707bc7f3cdac2b78a4cde Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Abra=C3=A3o=20de=20Santana?= Date: Thu, 27 May 2021 22:36:39 -0300 Subject: [PATCH 09/70] Update Kconfig --- lvgl_tft/Kconfig | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index ddd7f516..11ae4d25 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -586,7 +586,7 @@ menu "LVGL TFT Display controller" If text is backwards on your display, try enabling this. config LV_INVERT_COLORS - bool "Invert colors in display" if LV_TFT_DISPLAY_CONTROLLER_ILI9341 || LV_TFT_DISPLAY_CONTROLLER_ST7735S || LV_TFT_DISPLAY_CONTROLLER_ILI9481 || LV_TFT_DISPLAY_CONTROLLER_ST7789 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 || LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_HX8357 + bool "Invert colors in display" if LV_TFT_DISPLAY_CONTROLLER_ILI9341 || LV_TFT_DISPLAY_CONTROLLER_ST7735S || LV_TFT_DISPLAY_CONTROLLER_ILI9481 || LV_TFT_DISPLAY_CONTROLLER_ST7789 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 || LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_HX8357 || LV_TFT_DISPLAY_CONTROLLER_GC9A01 default y if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICKC help If the colors look inverted on your display, try enabling this. From a387e799e14926bf2bff931f551afdec7a019165 Mon Sep 17 00:00:00 2001 From: C47D Date: Mon, 7 Jun 2021 21:57:00 -0500 Subject: [PATCH 10/70] Print LV_HOR_RES_MAX and LV_VER_RES_MAX only when using LVGL v7 or below --- lvgl_helpers.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/lvgl_helpers.c b/lvgl_helpers.c index 41253307..2a904b1f 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -53,7 +53,12 @@ /* Interface and driver initialization */ void lvgl_driver_init(void) { + /* Since LVGL v8 LV_HOR_RES_MAX and LV_VER_RES_MAX are not defined, so + * print it only if they are defined. */ +#if (LVGL_VERSION_MAJOR < 8) ESP_LOGI(TAG, "Display hor size: %d, ver size: %d", LV_HOR_RES_MAX, LV_VER_RES_MAX); +#endif + ESP_LOGI(TAG, "Display buffer size: %d", DISP_BUF_SIZE); #if defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_FT81X) From 8b65d3547cee38e765a0580d4957c9dd9aa5b7c6 Mon Sep 17 00:00:00 2001 From: C47D Date: Mon, 7 Jun 2021 22:00:17 -0500 Subject: [PATCH 11/70] Fix path when using LVGL v8 --- lvgl_helpers.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/lvgl_helpers.c b/lvgl_helpers.c index 2a904b1f..5cc82c0c 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -19,9 +19,17 @@ #include "driver/i2c.h" #ifdef LV_LVGL_H_INCLUDE_SIMPLE -#include "src/lv_core/lv_refr.h" +#if (LVGL_VERSION_MAJOR < 8) + #include "src/lv_core/lv_refr.h" +#else + #include "src/core/lv_refr.h" +#endif #else -#include "lvgl/src/lv_core/lv_refr.h" +#if (LVGL_VERSION_MAJOR < 8) + #include "lvgl/src/lv_core/lv_refr.h" +#else + #include "lvgl/src/core/lv_refr.h" +#endif #endif /********************* From 1af29975e95fb66b1bf7f32b0080f83a017e4657 Mon Sep 17 00:00:00 2001 From: C47D Date: Tue, 8 Jun 2021 10:26:03 -0500 Subject: [PATCH 12/70] Add support for ESP32C3 SPI hosts --- lvgl_helpers.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/lvgl_helpers.c b/lvgl_helpers.c index 5cc82c0c..41f02138 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -227,6 +227,13 @@ bool lvgl_spi_driver_init(int host, const char *spi_names[] = { "SPI_HOST", "", "" }; +#elif defined (CONFIG_IDF_TARGET_ESP32C3) + assert((SPI1_HOST <= host) && (SPI3_HOST >= host)); + const char *spi_names[] = { + "SPI1_HOST", "SPI2_HOST", "SPI3_HOST" + }; +#else +#error "Target chip not selected" #endif ESP_LOGI(TAG, "Configuring SPI host %s (%d)", spi_names[host], host); From 696b6ff46328e66783cbf4f120b2d9a53a43dcd6 Mon Sep 17 00:00:00 2001 From: C47D Date: Thu, 10 Jun 2021 22:22:44 -0500 Subject: [PATCH 13/70] lvgl_helpers: Set spi dma channel to SPI_DMA_CH_AUTO when using ESP32C3 --- lvgl_helpers.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/lvgl_helpers.c b/lvgl_helpers.c index 41f02138..56c9183e 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -217,21 +217,29 @@ bool lvgl_spi_driver_init(int host, int dma_channel, int quadwp_pin, int quadhd_pin) { + spi_dma_chan_t dma_chan = SPI_DMA_DISABLED; + #if defined (CONFIG_IDF_TARGET_ESP32) assert((SPI_HOST <= host) && (VSPI_HOST >= host)); const char *spi_names[] = { "SPI_HOST", "HSPI_HOST", "VSPI_HOST" }; + + dma_chan = dma_channel; #elif defined (CONFIG_IDF_TARGET_ESP32S2) assert((SPI_HOST <= host) && (HSPI_HOST >= host)); const char *spi_names[] = { "SPI_HOST", "", "" }; + + dma_chan = dma_channel; #elif defined (CONFIG_IDF_TARGET_ESP32C3) assert((SPI1_HOST <= host) && (SPI3_HOST >= host)); const char *spi_names[] = { "SPI1_HOST", "SPI2_HOST", "SPI3_HOST" }; + + dma_chan = SPI_DMA_CH_AUTO; #else #error "Target chip not selected" #endif @@ -252,7 +260,7 @@ bool lvgl_spi_driver_init(int host, }; ESP_LOGI(TAG, "Initializing SPI bus..."); - esp_err_t ret = spi_bus_initialize(host, &buscfg, dma_channel); + esp_err_t ret = spi_bus_initialize(host, &buscfg, dma_chan); assert(ret == ESP_OK); return ESP_OK != ret; From d09fd59869ef0c33c0fa4a960c45374035e88000 Mon Sep 17 00:00:00 2001 From: C47D Date: Thu, 10 Jun 2021 22:31:09 -0500 Subject: [PATCH 14/70] Add ESP32C3 support on Kconfig files --- lvgl_tft/Kconfig | 15 ++++++++++++++- lvgl_touch/Kconfig | 11 +++++++++++ 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index b6221466..7059a6c9 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -772,6 +772,7 @@ menu "LVGL TFT Display controller" int "GPIO for MOSI (Master Out Slave In)" if LV_TFT_DISPLAY_PROTOCOL_SPI range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 23 if LV_PREDEFINED_DISPLAY_WROVER4 default 23 if LV_PREDEFINED_DISPLAY_ATAG @@ -801,6 +802,7 @@ menu "LVGL TFT Display controller" depends on LV_DISPLAY_USE_SPI_MISO range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 19 if LV_PREDEFINED_PINS_TKOALA default 38 if LV_PREDEFINED_DISPLAY_M5CORE2 @@ -823,6 +825,7 @@ menu "LVGL TFT Display controller" depends on LV_TFT_DISPLAY_SPI_TRANS_MODE_QIO range -1 39 if IDF_TARGET_ESP32 range -1 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 22 if LV_PREDEFINED_PINS_TKOALA && LV_TFT_DISPLAY_SPI_TRANS_MODE_QIO default -1 @@ -834,6 +837,7 @@ menu "LVGL TFT Display controller" depends on LV_TFT_DISPLAY_SPI_TRANS_MODE_QIO range -1 39 if IDF_TARGET_ESP32 range -1 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 21 if LV_PREDEFINED_PINS_TKOALA && LV_TFT_DISPLAY_SPI_TRANS_MODE_QIO default -1 @@ -844,6 +848,7 @@ menu "LVGL TFT Display controller" int "GPIO for CLK (SCK / Serial Clock)" if LV_TFT_DISPLAY_PROTOCOL_SPI range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 18 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK default 18 if LV_PREDEFINED_DISPLAY_M5CORE2 @@ -872,6 +877,7 @@ menu "LVGL TFT Display controller" depends on LV_DISPLAY_USE_SPI_CS range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 5 if LV_PREDEFINED_PINS_38V1 default 14 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK @@ -900,6 +906,7 @@ menu "LVGL TFT Display controller" int "GPIO for DC (Data / Command)" if LV_TFT_DISPLAY_PROTOCOL_SPI range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 depends on LV_DISPLAY_USE_DC default 19 if LV_PREDEFINED_PINS_38V1 @@ -937,6 +944,7 @@ menu "LVGL TFT Display controller" depends on LV_DISP_USE_RST range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 18 if LV_PREDEFINED_PINS_38V1 default 25 if LV_PREDEFINED_PINS_38V4 @@ -958,9 +966,11 @@ menu "LVGL TFT Display controller" int "GPIO for Busy" if LV_TFT_DISPLAY_CONTROLLER_IL3820 || LV_TFT_DISPLAY_CONTROLLER_JD79653A || LV_TFT_DISPLAY_CONTROLLER_UC8151D range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 35 if LV_TFT_DISPLAY_CONTROLLER_IL3820 || LV_TFT_DISPLAY_CONTROLLER_JD79653A || LV_TFT_DISPLAY_CONTROLLER_UC8151D - default 35 + default 35 if IDF_TARGET_ESP32 || IDF_TARGET_ESP32S2 + default 21 if IDF_TARGET_ESP32C3 help Configure the display Busy pin here. @@ -997,6 +1007,7 @@ menu "LVGL TFT Display controller" depends on LV_ENABLE_BACKLIGHT_CONTROL range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 23 if LV_PREDEFINED_PINS_38V1 default 26 if LV_PREDEFINED_PINS_38V4 @@ -1017,6 +1028,7 @@ menu "LVGL TFT Display controller" int "GPIO for I2C SDA" if LV_TFT_DISPLAY_PROTOCOL_I2C range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 5 if LV_PREDEFINED_DISPLAY_WEMOS_LOLIN default 5 @@ -1028,6 +1040,7 @@ menu "LVGL TFT Display controller" int "GPIO for I2C SCL" if LV_TFT_DISPLAY_PROTOCOL_I2C range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 4 if LV_PREDEFINED_DISPLAY_WEMOS_LOLIN default 4 diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index edd1dab0..7f6e9954 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -98,6 +98,7 @@ menu "LVGL Touch controller" prompt "GPIO for MISO (Master In Slave Out)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 35 if LV_PREDEFINED_PINS_38V1 default 19 @@ -109,6 +110,7 @@ menu "LVGL Touch controller" prompt "GPIO for MOSI (Master Out Slave In)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 32 if LV_PREDEFINED_PINS_38V1 default 23 @@ -119,6 +121,7 @@ menu "LVGL Touch controller" int "GPIO for CLK (SCK / Serial Clock)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 26 if LV_PREDEFINED_PINS_38V1 default 18 @@ -139,6 +142,7 @@ menu "LVGL Touch controller" int "GPIO for IRQ (Interrupt Request)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 27 if LV_PREDEFINED_PINS_38V4 default 25 @@ -211,6 +215,7 @@ menu "LVGL Touch controller" prompt "GPIO for SDA (I2C)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 21 help @@ -220,6 +225,7 @@ menu "LVGL Touch controller" int "GPIO for clock signal SCL (I2C)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 22 help @@ -254,6 +260,7 @@ menu "LVGL Touch controller" prompt "GPIO for MISO (Master In Slave Out)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 35 if LV_PREDEFINED_PINS_38V1 default 19 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING @@ -263,10 +270,12 @@ menu "LVGL Touch controller" Configure the touchpanel MISO pin here. config LV_TOUCH_SPI_MOSI + # TODO Fix default for ESP32C3 int prompt "GPIO for MOSI (Master Out Slave In)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 32 if LV_PREDEFINED_PINS_38V1 default 18 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING @@ -279,6 +288,7 @@ menu "LVGL Touch controller" int "GPIO for CLK (SCK / Serial Clock)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 26 if LV_PREDEFINED_PINS_38V1 default 5 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING @@ -290,6 +300,7 @@ menu "LVGL Touch controller" int "GPIO for CS (Slave Select)" range 0 39 if IDF_TARGET_ESP32 range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 default 33 if LV_PREDEFINED_PINS_38V1 default 32 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING From d379a4e8514d041dbeb1c146f2ae0a9a8142c367 Mon Sep 17 00:00:00 2001 From: C47D Date: Thu, 10 Jun 2021 22:36:01 -0500 Subject: [PATCH 15/70] Handle ESP32C3 when using ESP32C3 --- lvgl_spi_conf.h | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/lvgl_spi_conf.h b/lvgl_spi_conf.h index b5e79012..240090d8 100644 --- a/lvgl_spi_conf.h +++ b/lvgl_spi_conf.h @@ -65,11 +65,15 @@ extern "C" { #define ENABLE_TOUCH_INPUT CONFIG_LV_ENABLE_TOUCH #if defined (CONFIG_LV_TFT_DISPLAY_SPI_HSPI) -#define TFT_SPI_HOST HSPI_HOST +#if defined (CONFIG_IDF_TARGET_ESP32C3) +#define TFT_SPI_HOST SPI2_HOST +#else +#define TFT_SPI_HOST HSPI_HOST +#endif #elif defined (CONFIG_LV_TFT_DISPLAY_SPI_VSPI) -#define TFT_SPI_HOST VSPI_HOST +#define TFT_SPI_HOST VSPI_HOST #elif defined (CONFIG_LV_TFT_DISPLAY_SPI_FSPI) -#define TFT_SPI_HOST FSPI_HOST +#define TFT_SPI_HOST FSPI_HOST #endif #if defined (CONFIG_LV_TFT_DISPLAY_SPI_HALF_DUPLEX) From f726311525474489a409f4cdb1a6a7ae315f2c05 Mon Sep 17 00:00:00 2001 From: C47D Date: Thu, 10 Jun 2021 22:49:56 -0500 Subject: [PATCH 16/70] Indev: Add support for GT911 touch driver by @dastarling --- CMakeLists.txt | 2 ++ lvgl_touch/Kconfig | 49 +++++++++++++++++++++++++++++++++++++++ lvgl_touch/touch_driver.c | 4 ++++ lvgl_touch/touch_driver.h | 2 ++ 4 files changed, 57 insertions(+) diff --git a/CMakeLists.txt b/CMakeLists.txt index 58322335..10262c19 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -70,6 +70,8 @@ if(CONFIG_LV_TOUCH_CONTROLLER) list(APPEND SOURCES "lvgl_touch/FT81x.c") elseif(CONFIG_LV_TOUCH_CONTROLLER_RA8875) list(APPEND SOURCES "lvgl_touch/ra8875_touch.c") + elseif(CONFIG_LV_TOUCH_CONTROLLER_GT911) + list(APPEND SOURCES "lvgl_touch/gt911.c") endif() if(CONFIG_LV_TOUCH_DRIVER_PROTOCOL_SPI) diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index 7f6e9954..9942e0ab 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -9,6 +9,7 @@ menu "LVGL Touch controller" default 4 if LV_TOUCH_CONTROLLER_ADCRAW default 5 if LV_TOUCH_CONTROLLER_FT81X default 6 if LV_TOUCH_CONTROLLER_RA8875 + default 7 if LV_TOUCH_CONTROLLER_GT911 choice prompt "Select a touch panel controller model." @@ -36,6 +37,9 @@ menu "LVGL Touch controller" config LV_TOUCH_CONTROLLER_RA8875 select LV_TOUCH_DRIVER_DISPLAY bool "RA8875" + config LV_TOUCH_CONTROLLER_GT911 + select LV_TOUCH_DRIVER_PROTOCOL_I2C + bool "GT911" endchoice config LV_TOUCH_DRIVER_PROTOCOL_SPI @@ -498,5 +502,50 @@ menu "LVGL Touch controller" default y endmenu + + menu "Touchpanel (GT911) Pin Assignments" + depends on LV_TOUCH_CONTROLLER_GT911 + + config LV_TOUCH_I2C_SDA + int + prompt "GPIO for SDA (I2C)" + range 0 39 if IDF_TARGET_ESP32 + range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 + + default 2 + help + Configure the I2C touchpanel SDA pin here. + + config LV_TOUCH_I2C_SCL + int "GPIO for clock signal SCL (I2C)" + range 0 39 if IDF_TARGET_ESP32 + range 0 43 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 + + default 3 + help + Configure the I2C touchpanel SCL pin here. + endmenu + + menu "Touchpanel Configuration (GT911)" + depends on LV_TOUCH_CONTROLLER_GT911 + + config LV_GT911_SWAPXY + bool + prompt "Swap X with Y coordinate." + default y + + config LV_GT911_INVERT_X + bool + prompt "Invert X coordinate value." + default n + + config LV_GT911_INVERT_Y + bool + prompt "Invert Y coordinate value." + default y + + endmenu endmenu diff --git a/lvgl_touch/touch_driver.c b/lvgl_touch/touch_driver.c index b0aed881..6a7afb38 100644 --- a/lvgl_touch/touch_driver.c +++ b/lvgl_touch/touch_driver.c @@ -21,6 +21,8 @@ void touch_driver_init(void) /* nothing to do */ #elif defined (CONFIG_LV_TOUCH_CONTROLLER_RA8875) ra8875_touch_init(); +#elif defined (CONFIG_LV_TOUCH_CONTROLLER_GT911) + gt911_init(GT911_I2C_SLAVE_ADDR); #endif } @@ -40,6 +42,8 @@ bool touch_driver_read(lv_indev_drv_t *drv, lv_indev_data_t *data) res = FT81x_read(drv, data); #elif defined (CONFIG_LV_TOUCH_CONTROLLER_RA8875) res = ra8875_touch_read(drv, data); +#elif defined (CONFIG_LV_TOUCH_CONTROLLER_GT911) + res = gt911_read(drv, data); #endif return res; diff --git a/lvgl_touch/touch_driver.h b/lvgl_touch/touch_driver.h index bc92f4fe..44378db7 100644 --- a/lvgl_touch/touch_driver.h +++ b/lvgl_touch/touch_driver.h @@ -32,6 +32,8 @@ extern "C" { #include "FT81x.h" #elif defined (CONFIG_LV_TOUCH_CONTROLLER_RA8875) #include "ra8875_touch.h" +#elif defined (CONFIG_LV_TOUCH_CONTROLLER_GT911) +#include "gt911.h" #endif /********************* From 0d32432f4c05a6294f03532e7d7d94c10c436f81 Mon Sep 17 00:00:00 2001 From: C47D Date: Sun, 13 Jun 2021 15:06:22 -0500 Subject: [PATCH 17/70] touch driver: Add LVGL v8 compatibility --- lvgl_touch/gt911.c | 168 ++++++++++++++++++++++++++++++++++++++ lvgl_touch/gt911.h | 94 +++++++++++++++++++++ lvgl_touch/touch_driver.c | 8 ++ lvgl_touch/touch_driver.h | 5 ++ 4 files changed, 275 insertions(+) create mode 100644 lvgl_touch/gt911.c create mode 100644 lvgl_touch/gt911.h diff --git a/lvgl_touch/gt911.c b/lvgl_touch/gt911.c new file mode 100644 index 00000000..e6cb9724 --- /dev/null +++ b/lvgl_touch/gt911.c @@ -0,0 +1,168 @@ +/* +* Copyright © 2021 Sturnus Inc. + +* Permission is hereby granted, free of charge, to any person obtaining a copy of this +* software and associated documentation files (the “Software”), to deal in the Software +* without restriction, including without limitation the rights to use, copy, modify, merge, +* publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons +* to whom the Software is furnished to do so, subject to the following conditions: +* +* The above copyright notice and this permission notice shall be included in all copies or +* substantial portions of the Software. +* +* THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, +* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR +* PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE +* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, +* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +* SOFTWARE. +*/ + +#include +#include +#ifdef LV_LVGL_H_INCLUDE_SIMPLE +#include +#else +#include +#endif +#include "gt911.h" +#include "tp_i2c.h" +#include "../lvgl_i2c_conf.h" + +#define TAG "GT911" + +gt911_status_t gt911_status; + +//TODO: handle multibyte read and refactor to just one read transaction +esp_err_t gt911_i2c_read(uint8_t slave_addr, uint16_t register_addr, uint8_t *data_buf, uint8_t len) { + i2c_cmd_handle_t i2c_cmd = i2c_cmd_link_create(); + + i2c_master_start(i2c_cmd); + i2c_master_write_byte(i2c_cmd, (slave_addr << 1) | I2C_MASTER_WRITE, true); + i2c_master_write_byte(i2c_cmd, (register_addr >> 8), I2C_MASTER_ACK); + i2c_master_write_byte(i2c_cmd, (register_addr & 0xFF), I2C_MASTER_ACK); + + i2c_master_start(i2c_cmd); + i2c_master_write_byte(i2c_cmd, (slave_addr << 1) | I2C_MASTER_READ, true); + + i2c_master_read_byte(i2c_cmd, data_buf, I2C_MASTER_NACK); + i2c_master_stop(i2c_cmd); + esp_err_t ret = i2c_master_cmd_begin(TOUCH_I2C_PORT, i2c_cmd, 1000 / portTICK_RATE_MS); + i2c_cmd_link_delete(i2c_cmd); + return ret; +} + +esp_err_t gt911_i2c_write8(uint8_t slave_addr, uint16_t register_addr, uint8_t data) { + i2c_cmd_handle_t i2c_cmd = i2c_cmd_link_create(); + + i2c_master_start(i2c_cmd); + i2c_master_write_byte(i2c_cmd, (slave_addr << 1) | I2C_MASTER_WRITE, true); + i2c_master_write_byte(i2c_cmd, (register_addr >> 8), I2C_MASTER_ACK); + i2c_master_write_byte(i2c_cmd, (register_addr & 0xFF), I2C_MASTER_ACK); + i2c_master_write_byte(i2c_cmd, data, I2C_MASTER_ACK); + i2c_master_stop(i2c_cmd); + esp_err_t ret = i2c_master_cmd_begin(TOUCH_I2C_PORT, i2c_cmd, 1000 / portTICK_RATE_MS); + i2c_cmd_link_delete(i2c_cmd); + return ret; +} + +/** + * @brief Initialize for GT911 communication via I2C + * @param dev_addr: Device address on communication Bus (I2C slave address of GT911). + * @retval None + */ +void gt911_init(uint8_t dev_addr) { + if (!gt911_status.inited) { + gt911_status.i2c_dev_addr = dev_addr; + uint8_t data_buf; + esp_err_t ret; + + ESP_LOGI(TAG, "Checking for GT911 Touch Controller"); + if ((ret = gt911_i2c_read(dev_addr, GT911_PRODUCT_ID1, &data_buf, 1) != ESP_OK)) { + ESP_LOGE(TAG, "Error reading from device: %s", + esp_err_to_name(ret)); // Only show error the first time + return; + } + + // Read 4 bytes for Product ID in ASCII + for (int i = 0; i < GT911_PRODUCT_ID_LEN; i++) { + gt911_i2c_read(dev_addr, (GT911_PRODUCT_ID1 + i), (uint8_t *)&(gt911_status.product_id[i]), 1); + } + ESP_LOGI(TAG, "\tProduct ID: %s", gt911_status.product_id); + + gt911_i2c_read(dev_addr, GT911_VENDOR_ID, &data_buf, 1); + ESP_LOGI(TAG, "\tVendor ID: 0x%02x", data_buf); + + gt911_i2c_read(dev_addr, GT911_X_COORD_RES_L, &data_buf, 1); + gt911_status.max_x_coord = data_buf; + gt911_i2c_read(dev_addr, GT911_X_COORD_RES_H, &data_buf, 1); + gt911_status.max_x_coord |= ((uint16_t)data_buf << 8); + ESP_LOGI(TAG, "\tX Resolution: %d", gt911_status.max_x_coord); + + gt911_i2c_read(dev_addr, GT911_Y_COORD_RES_L, &data_buf, 1); + gt911_status.max_y_coord = data_buf; + gt911_i2c_read(dev_addr, GT911_Y_COORD_RES_H, &data_buf, 1); + gt911_status.max_y_coord |= ((uint16_t)data_buf << 8); + ESP_LOGI(TAG, "\tY Resolution: %d", gt911_status.max_y_coord); + gt911_status.inited = true; + } +} + +/** + * @brief Get the touch screen X and Y positions values. Ignores multi touch + * @param drv: + * @param data: Store data here + * @retval Always false + */ +bool gt911_read(lv_indev_drv_t *drv, lv_indev_data_t *data) { + uint8_t touch_pnt_cnt; // Number of detected touch points + static int16_t last_x = 0; // 12bit pixel value + static int16_t last_y = 0; // 12bit pixel value + uint8_t data_buf; + uint8_t status_reg; + + gt911_i2c_read(gt911_status.i2c_dev_addr, GT911_STATUS_REG, &status_reg, 1); +// ESP_LOGI(TAG, "\tstatus: 0x%02x", status_reg); + touch_pnt_cnt = status_reg & 0x0F; + if ((status_reg & 0x80) || (touch_pnt_cnt < 6)) { + //Reset Status Reg Value + gt911_i2c_write8(gt911_status.i2c_dev_addr, GT911_STATUS_REG, 0x00); + } + if (touch_pnt_cnt != 1) { // ignore no touch & multi touch + data->point.x = last_x; + data->point.y = last_y; + data->state = LV_INDEV_STATE_REL; + return false; + } + +// gt911_i2c_read(gt911_status.i2c_dev_addr, GT911_TRACK_ID1, &data_buf, 1); +// ESP_LOGI(TAG, "\ttrack_id: %d", data_buf); + + gt911_i2c_read(gt911_status.i2c_dev_addr, GT911_PT1_X_COORD_L, &data_buf, 1); + last_x = data_buf; + gt911_i2c_read(gt911_status.i2c_dev_addr, GT911_PT1_X_COORD_H, &data_buf, 1); + last_x |= ((uint16_t)data_buf << 8); + + gt911_i2c_read(gt911_status.i2c_dev_addr, GT911_PT1_Y_COORD_L, &data_buf, 1); + last_y = data_buf; + gt911_i2c_read(gt911_status.i2c_dev_addr, GT911_PT1_Y_COORD_H, &data_buf, 1); + last_y |= ((uint16_t)data_buf << 8); + +#if CONFIG_LV_GT911_INVERT_X + last_x = gt911_status.max_x_coord - last_x; +#endif +#if CONFIG_LV_GT911_INVERT_Y + last_y = gt911_status.max_y_coord - last_y; +#endif +#if CONFIG_LV_GT911_SWAPXY + int16_t swap_buf = last_x; + last_x = last_y; + last_y = swap_buf; +#endif + data->point.x = last_x; + data->point.y = last_y; + data->state = LV_INDEV_STATE_PR; + ESP_LOGI(TAG, "X=%u Y=%u", data->point.x, data->point.y); + ESP_LOGV(TAG, "X=%u Y=%u", data->point.x, data->point.y); + return false; +} diff --git a/lvgl_touch/gt911.h b/lvgl_touch/gt911.h new file mode 100644 index 00000000..6a110bdf --- /dev/null +++ b/lvgl_touch/gt911.h @@ -0,0 +1,94 @@ +#ifndef __GT911_H +/* +* Copyright © 2021 Sturnus Inc. + +* Permission is hereby granted, free of charge, to any person obtaining a copy of this +* software and associated documentation files (the “Software”), to deal in the Software +* without restriction, including without limitation the rights to use, copy, modify, merge, +* publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons +* to whom the Software is furnished to do so, subject to the following conditions: +* +* The above copyright notice and this permission notice shall be included in all copies or +* substantial portions of the Software. +* +* THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, +* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR +* PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE +* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, +* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +* SOFTWARE. +*/ + +#define __GT911_H + +#include +#include +#ifdef LV_LVGL_H_INCLUDE_SIMPLE +#include "lvgl.h" +#else +#include "lvgl/lvgl.h" +#endif + +#ifdef __cplusplus +extern "C" { +#endif + +#define GT911_I2C_SLAVE_ADDR 0x5D + +#define GT911_PRODUCT_ID_LEN 4 + +/* Register Map of GT911 */ +#define GT911_PRODUCT_ID1 0x8140 +#define GT911_PRODUCT_ID2 0x8141 +#define GT911_PRODUCT_ID3 0x8142 +#define GT911_PRODUCT_ID4 0x8143 +#define GT911_FIRMWARE_VER_L 0x8144 +#define GT911_FIRMWARE_VER_H 0x8145 +#define GT911_X_COORD_RES_L 0x8146 +#define GT911_X_COORD_RES_H 0x8147 +#define GT911_Y_COORD_RES_L 0x8148 +#define GT911_Y_COORD_RES_H 0x8149 +#define GT911_VENDOR_ID 0x814A + +#define GT911_STATUS_REG 0x814E +#define GT911_STATUS_REG_BUF 0x80 +#define GT911_STATUS_REG_LARGE 0x40 +#define GT911_STATUS_REG_PROX_VALID 0x20 +#define GT911_STATUS_REG_HAVEKEY 0x10 +#define GT911_STATUS_REG_PT_MASK 0x0F + +#define GT911_TRACK_ID1 0x814F +#define GT911_PT1_X_COORD_L 0x8150 +#define GT911_PT1_X_COORD_H 0x8151 +#define GT911_PT1_Y_COORD_L 0x8152 +#define GT911_PT1_Y_COORD_H 0x8153 +#define GT911_PT1_X_SIZE_L 0x8154 +#define GT911_PT1_X_SIZE_H 0x8155 + +typedef struct { + bool inited; + char product_id[GT911_PRODUCT_ID_LEN]; + uint16_t max_x_coord; + uint16_t max_y_coord; + uint8_t i2c_dev_addr; +} gt911_status_t; + +/** + * @brief Initialize for GT911 communication via I2C + * @param dev_addr: Device address on communication Bus (I2C slave address of GT911). + * @retval None + */ +void gt911_init(uint8_t dev_addr); + +/** + * @brief Get the touch screen X and Y positions values. Ignores multi touch + * @param drv: + * @param data: Store data here + * @retval Always false + */ +bool gt911_read(lv_indev_drv_t *drv, lv_indev_data_t *data); + +#ifdef __cplusplus +} +#endif +#endif /* __GT911_H */ diff --git a/lvgl_touch/touch_driver.c b/lvgl_touch/touch_driver.c index 6a7afb38..12125438 100644 --- a/lvgl_touch/touch_driver.c +++ b/lvgl_touch/touch_driver.c @@ -26,7 +26,11 @@ void touch_driver_init(void) #endif } +#if LVGL_VERSION_MAJOR >= 8 +void touch_driver_read(lv_indev_drv_t *drv, lv_indev_data_t *data) +#else bool touch_driver_read(lv_indev_drv_t *drv, lv_indev_data_t *data) +#endif { bool res = false; @@ -46,6 +50,10 @@ bool touch_driver_read(lv_indev_drv_t *drv, lv_indev_data_t *data) res = gt911_read(drv, data); #endif +#if LVGL_VERSION_MAJOR >= 8 + data->continue_reading = res; +#else return res; +#endif } diff --git a/lvgl_touch/touch_driver.h b/lvgl_touch/touch_driver.h index 44378db7..0d014e2e 100644 --- a/lvgl_touch/touch_driver.h +++ b/lvgl_touch/touch_driver.h @@ -44,7 +44,12 @@ extern "C" { * GLOBAL PROTOTYPES **********************/ void touch_driver_init(void); + +#if LVGL_VERSION_MAJOR >= 8 +void touch_driver_read(lv_indev_drv_t *drv, lv_indev_data_t *data); +#else bool touch_driver_read(lv_indev_drv_t *drv, lv_indev_data_t *data); +#endif #ifdef __cplusplus } /* extern "C" */ From b9cccc342fa509c0dedec75e863d572baaa17b25 Mon Sep 17 00:00:00 2001 From: C47D Date: Tue, 15 Jun 2021 21:01:36 -0500 Subject: [PATCH 18/70] Include lv_refr more easily --- lvgl_helpers.c | 12 ++---------- 1 file changed, 2 insertions(+), 10 deletions(-) diff --git a/lvgl_helpers.c b/lvgl_helpers.c index 56c9183e..a215c431 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -19,17 +19,9 @@ #include "driver/i2c.h" #ifdef LV_LVGL_H_INCLUDE_SIMPLE -#if (LVGL_VERSION_MAJOR < 8) - #include "src/lv_core/lv_refr.h" -#else - #include "src/core/lv_refr.h" -#endif +#include "lvgl.h" #else -#if (LVGL_VERSION_MAJOR < 8) - #include "lvgl/src/lv_core/lv_refr.h" -#else - #include "lvgl/src/core/lv_refr.h" -#endif +#include "lvgl/lvgl.h" #endif /********************* From a17a77b923a0fdd2e14711a5b2177b1873f43e91 Mon Sep 17 00:00:00 2001 From: Rajssss Date: Sun, 20 Jun 2021 20:20:27 +0530 Subject: [PATCH 19/70] st7735s: Added brightness control though LED pin -> Uses LED(Backlight) Pin as PWM to control the brightness Signed-off-by: Rajssss --- lvgl_tft/st7735s.c | 46 ++++++++++++++++++++++++++++++++++++++++++++++ lvgl_tft/st7735s.h | 3 +++ 2 files changed, 49 insertions(+) diff --git a/lvgl_tft/st7735s.c b/lvgl_tft/st7735s.c index 2507118b..c8d1f7a2 100644 --- a/lvgl_tft/st7735s.c +++ b/lvgl_tft/st7735s.c @@ -10,6 +10,7 @@ #include "disp_spi.h" #include "driver/i2c.h" #include "driver/gpio.h" +#include "driver/ledc.h" #include "esp_log.h" #include "freertos/FreeRTOS.h" #include "freertos/task.h" @@ -172,6 +173,51 @@ void st7735s_sleep_out() st7735s_send_cmd(0x11); } +void st7735s_brightness_control_enable(void) +{ + /* + Configure LED (Backlight) pin as PWM for Brightness control. + */ + ledc_channel_config_t LCD_backlight_channel = { + .gpio_num = ST7735S_BCKL, + .speed_mode = LEDC_LOW_SPEED_MODE, + .channel = LEDC_CHANNEL_0, + .intr_type = LEDC_INTR_DISABLE, + .timer_sel = LEDC_TIMER_0, + .duty = 0, + .hpoint = 0, + .flags.output_invert = 0 + }; + ledc_timer_config_t LCD_backlight_timer = { + .speed_mode = LEDC_LOW_SPEED_MODE, + .bit_num = LEDC_TIMER_10_BIT, + .timer_num = LEDC_TIMER_0, + .freq_hz = 5000, + .clk_cfg = LEDC_AUTO_CLK + }; + + ESP_ERROR_CHECK( ledc_timer_config(&LCD_backlight_timer) ); + ESP_ERROR_CHECK( ledc_channel_config(&LCD_backlight_channel) ); + +} + +void st7735s_set_brightness(uint16_t brightness) +{ + /* + Set brightness. + 0 -> Display off + 100 -> Full brightness + NOTE: brightness value must be between 0 - 100 + */ + if(brightness > 100) + { + ESP_LOGE(TAG, "Brightness value must be between 0 - 100"); + return; + } + ESP_ERROR_CHECK( ledc_set_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0, brightness*10) ); + ESP_ERROR_CHECK( ledc_update_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0) ); +} + /********************** * STATIC FUNCTIONS **********************/ diff --git a/lvgl_tft/st7735s.h b/lvgl_tft/st7735s.h index 71924bf3..0f1b4c37 100644 --- a/lvgl_tft/st7735s.h +++ b/lvgl_tft/st7735s.h @@ -26,6 +26,7 @@ extern "C" { #define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40) #define ST7735S_DC CONFIG_LV_DISP_PIN_DC +#define ST7735S_BCKL CONFIG_LV_DISP_PIN_BCKL #define ST7735S_RST CONFIG_LV_DISP_PIN_RST #define ST7735S_USE_RST CONFIG_LV_DISP_USE_RST @@ -137,6 +138,8 @@ void st7735s_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * col void st7735s_enable_backlight(bool backlight); void st7735s_sleep_in(void); void st7735s_sleep_out(void); +void st7735s_brightness_control_enable(void); +void st7735s_set_brightness(uint16_t brightness); /********************** * MACROS From b70d2dc151db61ec44cb5b7a2a043917a1d181a9 Mon Sep 17 00:00:00 2001 From: C47D Date: Tue, 22 Jun 2021 13:05:58 -0500 Subject: [PATCH 20/70] lvgl_helpers: Fix compilation error when using ESP-IDF v4.3 or below --- lvgl_helpers.c | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/lvgl_helpers.c b/lvgl_helpers.c index a215c431..2e78fef7 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -202,14 +202,21 @@ bool lvgl_i2c_driver_init(int port, int sda_pin, int scl_pin, int speed_hz) return ESP_OK != err; } -/* Initialize spi bus master */ +/* Initialize spi bus master + * + * NOTE: dma_chan type and value changed to int instead of spi_dma_chan_t + * for backwards compatibility with ESP-IDF versions prior v4.3. + * + * We could use the ESP_IDF_VERSION_VAL macro available in the "esp_idf_version.h" + * header available since ESP-IDF v4. + */ bool lvgl_spi_driver_init(int host, int miso_pin, int mosi_pin, int sclk_pin, int max_transfer_sz, int dma_channel, int quadwp_pin, int quadhd_pin) { - spi_dma_chan_t dma_chan = SPI_DMA_DISABLED; + int dma_chan = 0 /* SPI_DMA_DISABLED */; #if defined (CONFIG_IDF_TARGET_ESP32) assert((SPI_HOST <= host) && (VSPI_HOST >= host)); @@ -231,7 +238,7 @@ bool lvgl_spi_driver_init(int host, "SPI1_HOST", "SPI2_HOST", "SPI3_HOST" }; - dma_chan = SPI_DMA_CH_AUTO; + dma_chan = 3 /* SPI_DMA_CH_AUTO */; #else #error "Target chip not selected" #endif From 5d4334a5b9eaca15b7f9deaa0b734b23ba9ca811 Mon Sep 17 00:00:00 2001 From: Rajssss Date: Sat, 26 Jun 2021 12:10:41 +0530 Subject: [PATCH 21/70] Created separate component for backlight control -> Uses Timer 0, Channel 0 as PWM to control backlight via LED pin Signed-off-by: Rajssss --- CMakeLists.txt | 2 +- lvgl_helpers.h | 1 + lvgl_tft/esp_lcd_backlight.c | 58 ++++++++++++++++++++++++++++++++++++ lvgl_tft/esp_lcd_backlight.h | 36 ++++++++++++++++++++++ lvgl_tft/st7735s.c | 46 ---------------------------- lvgl_tft/st7735s.h | 3 -- 6 files changed, 96 insertions(+), 50 deletions(-) create mode 100644 lvgl_tft/esp_lcd_backlight.c create mode 100644 lvgl_tft/esp_lcd_backlight.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 58322335..0165b1ae 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -2,7 +2,7 @@ if(ESP_PLATFORM) file(GLOB SOURCES *.c) set(LVGL_INCLUDE_DIRS . lvgl_tft) -list(APPEND SOURCES "lvgl_tft/disp_driver.c") +list(APPEND SOURCES "lvgl_tft/disp_driver.c" "lvgl_tft/esp_lcd_backlight.c") #@todo add SimleInclude macro here diff --git a/lvgl_helpers.h b/lvgl_helpers.h index 081a8437..cfa45b52 100644 --- a/lvgl_helpers.h +++ b/lvgl_helpers.h @@ -16,6 +16,7 @@ extern "C" { #include "lvgl_spi_conf.h" #include "lvgl_tft/disp_driver.h" +#include "lvgl_tft/esp_lcd_backlight.h" #include "lvgl_touch/touch_driver.h" /********************* diff --git a/lvgl_tft/esp_lcd_backlight.c b/lvgl_tft/esp_lcd_backlight.c new file mode 100644 index 00000000..e4bf930a --- /dev/null +++ b/lvgl_tft/esp_lcd_backlight.c @@ -0,0 +1,58 @@ +/** + * @file esp_lcd_backlight.c + * + */ + +/********************* + * INCLUDES + *********************/ +#include "esp_lcd_backlight.h" +#include "driver/ledc.h" +#include "esp_log.h" + +static const char *TAG = "disp_brightness"; + +void disp_brightness_control_enable(void) +{ + /* + Configure LED (Backlight) pin as PWM for Brightness control. + */ + ledc_channel_config_t LCD_backlight_channel = { + .gpio_num = DISP_PIN_BCKL, + .speed_mode = LEDC_LOW_SPEED_MODE, + .channel = LEDC_CHANNEL_0, + .intr_type = LEDC_INTR_DISABLE, + .timer_sel = LEDC_TIMER_0, + .duty = 0, + .hpoint = 0, + .flags.output_invert = 0 + }; + ledc_timer_config_t LCD_backlight_timer = { + .speed_mode = LEDC_LOW_SPEED_MODE, + .bit_num = LEDC_TIMER_10_BIT, + .timer_num = LEDC_TIMER_0, + .freq_hz = 5000, + .clk_cfg = LEDC_AUTO_CLK + }; + + ESP_ERROR_CHECK( ledc_timer_config(&LCD_backlight_timer) ); + ESP_ERROR_CHECK( ledc_channel_config(&LCD_backlight_channel) ); + +} + +void disp_set_brightness(uint16_t brightness) +{ + /* + Set brightness. + 0 -> Display off + 100 -> Full brightness + NOTE: brightness value must be between 0 - 100 + */ + if(brightness > 100) + { + ESP_LOGE(TAG, "Brightness value must be between 0 - 100"); + return; + } + ESP_ERROR_CHECK( ledc_set_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0, brightness*10) ); + ESP_ERROR_CHECK( ledc_update_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0) ); +} diff --git a/lvgl_tft/esp_lcd_backlight.h b/lvgl_tft/esp_lcd_backlight.h new file mode 100644 index 00000000..9f4eba99 --- /dev/null +++ b/lvgl_tft/esp_lcd_backlight.h @@ -0,0 +1,36 @@ +/** + * @file esp_lcd_backlight.h + */ + +#ifndef ESP_LCD_BACKLIGHT_H +#define ESP_LCD_BACKLIGHT_H + +/********************* + * INCLUDES + *********************/ +#include +#ifdef LV_LVGL_H_INCLUDE_SIMPLE +#include "lvgl.h" +#else +#include "lvgl/lvgl.h" +#endif + + +/********************* + * DEFINES + *********************/ +#define DISP_PIN_BCKL CONFIG_LV_DISP_PIN_BCKL + + +/********************** + * GLOBAL PROTOTYPES + **********************/ +void disp_brightness_control_enable(void); +void disp_set_brightness(uint16_t brightness); + + +#ifdef __cplusplus +} /* extern "C" */ +#endif + +#endif /*ESP_LCD_BACKLIGHT_H*/ \ No newline at end of file diff --git a/lvgl_tft/st7735s.c b/lvgl_tft/st7735s.c index c8d1f7a2..2507118b 100644 --- a/lvgl_tft/st7735s.c +++ b/lvgl_tft/st7735s.c @@ -10,7 +10,6 @@ #include "disp_spi.h" #include "driver/i2c.h" #include "driver/gpio.h" -#include "driver/ledc.h" #include "esp_log.h" #include "freertos/FreeRTOS.h" #include "freertos/task.h" @@ -173,51 +172,6 @@ void st7735s_sleep_out() st7735s_send_cmd(0x11); } -void st7735s_brightness_control_enable(void) -{ - /* - Configure LED (Backlight) pin as PWM for Brightness control. - */ - ledc_channel_config_t LCD_backlight_channel = { - .gpio_num = ST7735S_BCKL, - .speed_mode = LEDC_LOW_SPEED_MODE, - .channel = LEDC_CHANNEL_0, - .intr_type = LEDC_INTR_DISABLE, - .timer_sel = LEDC_TIMER_0, - .duty = 0, - .hpoint = 0, - .flags.output_invert = 0 - }; - ledc_timer_config_t LCD_backlight_timer = { - .speed_mode = LEDC_LOW_SPEED_MODE, - .bit_num = LEDC_TIMER_10_BIT, - .timer_num = LEDC_TIMER_0, - .freq_hz = 5000, - .clk_cfg = LEDC_AUTO_CLK - }; - - ESP_ERROR_CHECK( ledc_timer_config(&LCD_backlight_timer) ); - ESP_ERROR_CHECK( ledc_channel_config(&LCD_backlight_channel) ); - -} - -void st7735s_set_brightness(uint16_t brightness) -{ - /* - Set brightness. - 0 -> Display off - 100 -> Full brightness - NOTE: brightness value must be between 0 - 100 - */ - if(brightness > 100) - { - ESP_LOGE(TAG, "Brightness value must be between 0 - 100"); - return; - } - ESP_ERROR_CHECK( ledc_set_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0, brightness*10) ); - ESP_ERROR_CHECK( ledc_update_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0) ); -} - /********************** * STATIC FUNCTIONS **********************/ diff --git a/lvgl_tft/st7735s.h b/lvgl_tft/st7735s.h index 0f1b4c37..71924bf3 100644 --- a/lvgl_tft/st7735s.h +++ b/lvgl_tft/st7735s.h @@ -26,7 +26,6 @@ extern "C" { #define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40) #define ST7735S_DC CONFIG_LV_DISP_PIN_DC -#define ST7735S_BCKL CONFIG_LV_DISP_PIN_BCKL #define ST7735S_RST CONFIG_LV_DISP_PIN_RST #define ST7735S_USE_RST CONFIG_LV_DISP_USE_RST @@ -138,8 +137,6 @@ void st7735s_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * col void st7735s_enable_backlight(bool backlight); void st7735s_sleep_in(void); void st7735s_sleep_out(void); -void st7735s_brightness_control_enable(void); -void st7735s_set_brightness(uint16_t brightness); /********************** * MACROS From 35a005a47c324c9d4896515663507e54b2ad9720 Mon Sep 17 00:00:00 2001 From: Rajssss Date: Sat, 26 Jun 2021 13:30:26 +0530 Subject: [PATCH 22/70] esp_lcd_backlight: do not build if not enabled Signed-off-by: Rajssss --- CMakeLists.txt | 7 ++++++- lvgl_tft/esp_lcd_backlight.h | 3 ++- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 0165b1ae..730a38e2 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -2,7 +2,7 @@ if(ESP_PLATFORM) file(GLOB SOURCES *.c) set(LVGL_INCLUDE_DIRS . lvgl_tft) -list(APPEND SOURCES "lvgl_tft/disp_driver.c" "lvgl_tft/esp_lcd_backlight.c") +list(APPEND SOURCES "lvgl_tft/disp_driver.c") #@todo add SimleInclude macro here @@ -79,6 +79,11 @@ if(CONFIG_LV_TOUCH_CONTROLLER) endif() endif() +# Add backlight control to compilation only if it is selected in menuconfig +if(CONFIG_LV_ENABLE_BACKLIGHT_CONTROL) + list(APPEND SOURCES "lvgl_tft/esp_lcd_backlight.c") +endif() + idf_component_register(SRCS ${SOURCES} INCLUDE_DIRS ${LVGL_INCLUDE_DIRS} REQUIRES lvgl) diff --git a/lvgl_tft/esp_lcd_backlight.h b/lvgl_tft/esp_lcd_backlight.h index 9f4eba99..b22bf9d9 100644 --- a/lvgl_tft/esp_lcd_backlight.h +++ b/lvgl_tft/esp_lcd_backlight.h @@ -19,8 +19,9 @@ /********************* * DEFINES *********************/ +#if CONFIG_LV_ENABLE_BACKLIGHT_CONTROL #define DISP_PIN_BCKL CONFIG_LV_DISP_PIN_BCKL - +#endif /********************** * GLOBAL PROTOTYPES From 55dd527e1074f90b9216507b8fe4d28817c23420 Mon Sep 17 00:00:00 2001 From: Justin Smestad Date: Sat, 26 Jun 2021 17:44:59 -0600 Subject: [PATCH 23/70] Update KConfig to remove LV_ prefix on orientation checks --- lvgl_tft/Kconfig | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 7059a6c9..7c1bd60a 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -222,15 +222,15 @@ menu "LVGL TFT Display controller" config LV_TFT_DISPLAY_X_OFFSET depends on LV_TFT_DISPLAY_OFFSETS int - default 40 if LV_PREDEFINED_DISPLAY_TTGO && (LV_DISPLAY_ORIENTATION_LANDSCAPE || LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) - default 53 if LV_PREDEFINED_DISPLAY_TTGO && (LV_DISPLAY_ORIENTATION_PORTRAIT || LV_DISPLAY_ORIENTATION_PORTRAIT_INVERTED) + default 40 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_LANDSCAPE || DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) + default 53 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_PORTRAIT || DISPLAY_ORIENTATION_PORTRAIT_INVERTED) default 0 config LV_TFT_DISPLAY_Y_OFFSET depends on LV_TFT_DISPLAY_OFFSETS int - default 53 if LV_PREDEFINED_DISPLAY_TTGO && (LV_DISPLAY_ORIENTATION_LANDSCAPE || LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) - default 40 if LV_PREDEFINED_DISPLAY_TTGO && (LV_DISPLAY_ORIENTATION_PORTRAIT || LV_DISPLAY_ORIENTATION_PORTRAIT_INVERTED) + default 53 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_LANDSCAPE || DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) + default 40 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_PORTRAIT || DISPLAY_ORIENTATION_PORTRAIT_INVERTED) default 0 From 19087aeb06fb18487c45ef063ff12d2cc3871656 Mon Sep 17 00:00:00 2001 From: Justin Smestad Date: Sat, 26 Jun 2021 17:50:28 -0600 Subject: [PATCH 24/70] Remove SPI guard for TTGO configuration Fixes remaining part of #50 --- lvgl_tft/Kconfig | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 7c1bd60a..709ca5a8 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -413,7 +413,7 @@ menu "LVGL TFT Display controller" config LV_FT81X_CONFIG_EVE_EVE2_50G bool "EVE_EVE2_50G" config LV_FT81X_CONFIG_EVE_EVE2_70 - bool "EVE_EVE2_70" + bool "EVE_EVE2_70"/ config LV_FT81X_CONFIG_EVE_EVE2_70G bool "EVE_EVE2_70G" config LV_FT81X_CONFIG_EVE_EVE3_35 @@ -459,8 +459,7 @@ menu "LVGL TFT Display controller" endchoice choice - prompt "TFT SPI Bus." if LV_TFT_DISPLAY_PROTOCOL_SPI && \ - !LV_PREDEFINED_DISPLAY_TTGO + prompt "TFT SPI Bus." if LV_TFT_DISPLAY_PROTOCOL_SPI default LV_TFT_DISPLAY_SPI_VSPI if LV_PREDEFINED_DISPLAY_TTGO && \ !IDF_TARGET_ESP32S2 default LV_TFT_DISPLAY_SPI_FSPI if IDF_TARGET_ESP32S2 From 82ba726199723b53c7aef30bb02fc01d28c676c0 Mon Sep 17 00:00:00 2001 From: Justin Smestad Date: Sat, 26 Jun 2021 17:50:56 -0600 Subject: [PATCH 25/70] Revert lvgl_tft/Kconfig --- lvgl_tft/Kconfig | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 709ca5a8..580ca541 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -413,7 +413,7 @@ menu "LVGL TFT Display controller" config LV_FT81X_CONFIG_EVE_EVE2_50G bool "EVE_EVE2_50G" config LV_FT81X_CONFIG_EVE_EVE2_70 - bool "EVE_EVE2_70"/ + bool "EVE_EVE2_70" config LV_FT81X_CONFIG_EVE_EVE2_70G bool "EVE_EVE2_70G" config LV_FT81X_CONFIG_EVE_EVE3_35 From 613787b340793716b340db68470cfda1d48fd110 Mon Sep 17 00:00:00 2001 From: Debian Date: Sun, 27 Jun 2021 11:50:19 -0500 Subject: [PATCH 26/70] enable the X and Y offset options whith TTGO TDisplay --- lvgl_tft/Kconfig | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 580ca541..0535580e 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -221,14 +221,14 @@ menu "LVGL TFT Display controller" config LV_TFT_DISPLAY_X_OFFSET depends on LV_TFT_DISPLAY_OFFSETS - int + int "X offset" default 40 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_LANDSCAPE || DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) default 53 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_PORTRAIT || DISPLAY_ORIENTATION_PORTRAIT_INVERTED) default 0 config LV_TFT_DISPLAY_Y_OFFSET depends on LV_TFT_DISPLAY_OFFSETS - int + int "Y offset" default 53 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_LANDSCAPE || DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) default 40 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_PORTRAIT || DISPLAY_ORIENTATION_PORTRAIT_INVERTED) default 0 From fa86e1d0926c3bf531442354c8d84cb6f07c330b Mon Sep 17 00:00:00 2001 From: C47D Date: Wed, 30 Jun 2021 23:02:00 -0500 Subject: [PATCH 27/70] Remove & operator when passing display driver to lv_disp_flush_ready Closes #81 --- lvgl_tft/disp_spi.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lvgl_tft/disp_spi.c b/lvgl_tft/disp_spi.c index 0e4e5486..00e91a6d 100644 --- a/lvgl_tft/disp_spi.c +++ b/lvgl_tft/disp_spi.c @@ -310,7 +310,7 @@ static void IRAM_ATTR spi_ready(spi_transaction_t *trans) disp = lv_refr_get_disp_refreshing(); #endif - lv_disp_flush_ready(&disp->driver); + lv_disp_flush_ready(disp->driver); } if (chained_post_cb) { From f32a6f57fc231f4280ec697885ae11c4a9409efe Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Wed, 7 Jul 2021 20:40:15 +0200 Subject: [PATCH 28/70] FT6X36 touch: fixed axis-swap, Kconfig defaults. --- lvgl_touch/Kconfig | 16 ++++++++-------- lvgl_touch/ft6x36.c | 12 ++++++------ 2 files changed, 14 insertions(+), 14 deletions(-) diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index 9942e0ab..d4b71fcb 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -239,20 +239,20 @@ menu "LVGL Touch controller" menu "Touchpanel Configuration (FT6X06)" depends on LV_TOUCH_CONTROLLER_FT6X06 - config LV_FT6X36_SWAPXY - bool - prompt "Swap X with Y coordinate." - default y + config LV_FT6X36_SWAPXY + bool + prompt "Swap X with Y coordinate." + default n config LV_FT6X36_INVERT_X bool prompt "Invert X coordinate value." default n - config LV_FT6X36_INVERT_Y - bool - prompt "Invert Y coordinate value." - default y + config LV_FT6X36_INVERT_Y + bool + prompt "Invert Y coordinate value." + default n endmenu diff --git a/lvgl_touch/ft6x36.c b/lvgl_touch/ft6x36.c index 6e67d291..a4d74ef1 100644 --- a/lvgl_touch/ft6x36.c +++ b/lvgl_touch/ft6x36.c @@ -182,20 +182,20 @@ bool ft6x36_read(lv_indev_drv_t *drv, lv_indev_data_t *data) { last_x = ((data_xy[0] & FT6X36_MSB_MASK) << 8) | (data_xy[1] & FT6X36_LSB_MASK); last_y = ((data_xy[2] & FT6X36_MSB_MASK) << 8) | (data_xy[3] & FT6X36_LSB_MASK); -#if CONFIG_LV_FT6X36_SWAPXY - int16_t swap_buf = last_x; - last_x = last_y; - last_y = swap_buf; -#endif #if CONFIG_LV_FT6X36_INVERT_X last_x = LV_HOR_RES - last_x; #endif #if CONFIG_LV_FT6X36_INVERT_Y last_y = LV_VER_RES - last_y; +#endif +#if CONFIG_LV_FT6X36_SWAPXY + int16_t swap_buf = last_x; + last_x = last_y; + last_y = swap_buf; #endif data->point.x = last_x; data->point.y = last_y; data->state = LV_INDEV_STATE_PR; - ESP_LOGV(TAG, "X=%u Y=%u", data->point.x, data->point.y); + ESP_LOGD(TAG, "X=%u Y=%u", data->point.x, data->point.y); return false; } From e52112376f614f9a910e9c44ea51856855ef33b1 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Thu, 8 Jul 2021 11:04:07 +0200 Subject: [PATCH 29/70] Replace allLVGL driver I2C code with I2C Manager For discussion see #70 --- CMakeLists.txt | 8 +- Kconfig | 11 +- README.md | 20 ++- component.mk | 1 - i2c_manager/Kconfig | 116 ++++++++++++ i2c_manager/README.md | 71 ++++++++ i2c_manager/i2c_manager.c | 368 ++++++++++++++++++++++++++++++++++++++ i2c_manager/i2c_manager.h | 76 ++++++++ lvgl_helpers.c | 86 ++------- lvgl_helpers.h | 4 +- lvgl_i2c_conf.h | 116 ------------ lvgl_tft/Kconfig | 110 +++++------- lvgl_tft/ili9341.h | 3 +- lvgl_tft/ssd1306.c | 48 ++--- lvgl_tft/ssd1306.h | 2 - lvgl_tft/st7735s.c | 95 +++++----- lvgl_tft/st7735s.h | 3 - lvgl_touch/Kconfig | 145 ++++++--------- lvgl_touch/ft6x36.c | 160 +++++------------ lvgl_touch/ft6x36.h | 22 +-- lvgl_touch/gt911.c | 34 +--- lvgl_touch/touch_driver.c | 1 - lvgl_touch/tp_i2c.c | 43 ----- lvgl_touch/tp_i2c.h | 36 ---- 24 files changed, 898 insertions(+), 681 deletions(-) create mode 100644 i2c_manager/Kconfig create mode 100644 i2c_manager/README.md create mode 100644 i2c_manager/i2c_manager.c create mode 100644 i2c_manager/i2c_manager.h delete mode 100644 lvgl_i2c_conf.h delete mode 100644 lvgl_touch/tp_i2c.c delete mode 100644 lvgl_touch/tp_i2c.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 10262c19..678c8943 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -76,15 +76,17 @@ if(CONFIG_LV_TOUCH_CONTROLLER) if(CONFIG_LV_TOUCH_DRIVER_PROTOCOL_SPI) list(APPEND SOURCES "lvgl_touch/tp_spi.c") - elseif(CONFIG_LV_TOUCH_DRIVER_PROTOCOL_I2C) - list(APPEND SOURCES "lvgl_touch/tp_i2c.c") endif() endif() +if(CONFIG_LV_I2C) + list(APPEND SOURCES "i2c_manager/i2c_manager.c") +endif() + idf_component_register(SRCS ${SOURCES} INCLUDE_DIRS ${LVGL_INCLUDE_DIRS} REQUIRES lvgl) - + target_compile_definitions(${COMPONENT_LIB} PUBLIC "-DLV_LVGL_H_INCLUDE_SIMPLE") else() diff --git a/Kconfig b/Kconfig index ae11925e..42c3c660 100644 --- a/Kconfig +++ b/Kconfig @@ -1,2 +1,9 @@ -rsource "lvgl_tft/Kconfig" -rsource "lvgl_touch/Kconfig" +menu "LVGL ESP Drivers" + + rsource "lvgl_tft/Kconfig" + + rsource "lvgl_touch/Kconfig" + + rsource "i2c_manager/Kconfig" + +endmenu diff --git a/README.md b/README.md index 89659a67..19084177 100644 --- a/README.md +++ b/README.md @@ -6,6 +6,7 @@ For a ready to use ESP32 project take look at the [lv_port_esp32](https://github - [Supported display controllers](#supported-display-controllers) - [Supported indev controllers](#supported-indev-controllers) - [Support for predefined development kits](#support-for-predefined-development-kits) +- [Thread-safe I2C with I2C Manager](#thread-safe-i2c-with-i2c-manager) **NOTE:** You need to set the display horizontal and vertical size, color depth and swap of RGB565 color on the LVGL configuration menuconfig (it's not handled automatically). @@ -35,8 +36,8 @@ swap of RGB565 color on the LVGL configuration menuconfig (it's not handled auto ## Supported indev controllers - XPT2046 -- FT3236 -- other FT6X36 or the FT6206 controllers should work as well (not tested) +- FT3236, FT6X36 +- FT6206 controllers should work as well (not tested) - STMPE610 - FT81x (Single, Dual, and Quad SPI) @@ -52,7 +53,7 @@ and sets the gpio numbers for the interface. |---------------------------|-----------------------|-----------|-----------|-----------| | ESP Wrover Kit v4.1 | ILI9341 | SPI | 240 | 320 | | M5Stack | ILI9341 | SPI | 240 | 320 | -| M5Core2 | ILI9341 | SPI | 240 | 320 | +| M5Stack Core2 | ILI9341 | SPI | 240 | 320 | | M5Stick | SH1107 | SPI | - | - | | M5StickC | ST7735S | SPI | 80 | 160 | | Adafruit 3.5 Featherwing | HX8357 | SPI | 480 | 320 | @@ -65,3 +66,16 @@ and sets the gpio numbers for the interface. **NOTE:** See [Supported display controllers](#supported-display-controllers) for more information on display configuration. **NOTE:** See [Supported indev controllers](#supported-indev-controllers) for more information about indev configuration. + + +## Thread-safe I2C with I2C Manager + +LVGL can use I2C to read from a touch sensor or write to a display, possibly +many times a second. Meanwhile, other tasks may also want to read from i2c +devices on the same bus. I2C using the ESP-IDF is not thread-safe. + +I2C Manager (`i2c_manager`) is a component that will let code in multiple threads +talk to devices on the I2C ports without getting in each other's way. These drivers +use a built-in copy of I2C Manager to talk to the I2C port, but you can also use +the I2C Manager component itself and have others play nice with LVGL and vice-versa. +[Click here](i2c_manager/README.md) for details. diff --git a/component.mk b/component.mk index dbd1105a..c01caba7 100644 --- a/component.mk +++ b/component.mk @@ -44,4 +44,3 @@ $(call compile_only_if,$(and $(CONFIG_LV_TOUCH_CONTROLLER),$(CONFIG_LV_TOUCH_CON $(call compile_only_if,$(and $(CONFIG_LV_TOUCH_CONTROLLER),$(CONFIG_LV_TOUCH_CONTROLLER_RA8875)), lvgl_touch/ra8875_touch.o) $(call compile_only_if,$(and $(CONFIG_LV_TOUCH_CONTROLLER),$(CONFIG_LV_TOUCH_DRIVER_PROTOCOL_SPI)), lvgl_touch/tp_spi.o) -$(call compile_only_if,$(and $(CONFIG_LV_TOUCH_CONTROLLER),$(CONFIG_LV_TOUCH_DRIVER_PROTOCOL_I2C)), lvgl_touch/tp_i2c.o) diff --git a/i2c_manager/Kconfig b/i2c_manager/Kconfig new file mode 100644 index 00000000..0c11ab13 --- /dev/null +++ b/i2c_manager/Kconfig @@ -0,0 +1,116 @@ +menu "I2C Port Settings" + depends on LV_I2C && !HAVE_I2C_MANAGER + + menu "I2C Port 0" + + config I2C_MANAGER_0_ENABLED + bool "Enable I2C port 0" + + if I2C_MANAGER_0_ENABLED + config I2C_MANAGER_0_SDA + int "SDA (GPIO pin)" + range 0 39 if IDF_TARGET_ESP32 + range 0 46 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 + config I2C_MANAGER_0_SCL + int "SCL (GPIO pin)" + range 0 39 if IDF_TARGET_ESP32 + range 0 46 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 + config I2C_MANAGER_0_FREQ_HZ + int "Frequency (Hz)" + default 400000 + range 100000 5000000 + help + The clock speed in Hz. Ranges from 100000 (100 kHz) to + 5000000 (5 Mhz). I2C busses that involve external wires may + have to be slower, and the real maximum speed the bus will + support depends on the value of the pullup resistors and the + design of the overall circuit. + config I2C_MANAGER_0_TIMEOUT + int "R/W timeout (ms)" + default 20 + range 10 1000 + help + Timeout for I2C read and write operations. This does not + include the time waiting for a lock. + config I2C_MANAGER_0_LOCK_TIMEOUT + int "Stale lock override (ms)" + default 50 + range 10 1000 + help + Timeout at which point an operation waiting for its turn on + the port will assume that whatever set the lock has died and + overrides it. Set this somewhat larger than the previous + timeout. + config I2C_MANAGER_0_PULLUPS + bool "Use ESP32 built-in bus pull-up resistors" + help + The I2C bus needs resistors to make sure it's in a defined + state when nobody is talking. Many circuits have external + pullup resistors already and turning these on will increase + power consumption slightly and may limit the speed your bus + can attain. Try with these off first if you don't know. + endif + + endmenu + + + menu "I2C Port 1" + + config I2C_MANAGER_1_ENABLED + bool "Enable I2C port 1" + + if I2C_MANAGER_1_ENABLED + config I2C_MANAGER_1_SDA + int "SDA (GPIO pin)" + default 32 + range 0 39 if IDF_TARGET_ESP32 + range 0 46 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 + config I2C_MANAGER_1_SCL + int "SCL (GPIO pin)" + default 33 + range 0 39 if IDF_TARGET_ESP32 + range 0 46 if IDF_TARGET_ESP32S2 + range 0 21 if IDF_TARGET_ESP32C3 + config I2C_MANAGER_1_FREQ_HZ + int "Frequency (Hz)" + default 1000000 + range 100000 5000000 + help + The clock speed in Hz. Ranges from 100000 (100 kHz) to + 5000000 (5 Mhz). I2C busses that involve external wires may + have to be slower, and the real maximum speed the bus will + support depends on the value of the pullup resistors and the + design of the overall circuit. + config I2C_MANAGER_1_TIMEOUT + int "R/W timeout (ms)" + default 20 + range 10 1000 + help + Timeout for I2C read and write operations. This does not + include the time waiting for a lock. Default should be fine. + config I2C_MANAGER_1_LOCK_TIMEOUT + int "Stale lock override (ms)" + default 50 + help + Timeout at which point an operation waiting for its turn on + the port will assume that whatever set the lock has died and + overrides it. Set this somewhat larger than the previous + timeout. Default should be fine. + range 30 1000 + config I2C_MANAGER_1_PULLUPS + bool "Use ESP32 built-in bus pull-up resistors" + help + The I2C bus needs resistors to make sure it's in a defined + state when nobody is talking. Many circuits have external + pullup resistors already and turning these on will increase + power consumption slightly and may limit the speed your bus + can attain. Try with these off first if you don't know. + endif + + endmenu + +endmenu + diff --git a/i2c_manager/README.md b/i2c_manager/README.md new file mode 100644 index 00000000..f9a368b4 --- /dev/null +++ b/i2c_manager/README.md @@ -0,0 +1,71 @@ +# I2C in `lvgl_esp32_drivers` + +  + + + +## Information for users + +### I2C Manager support + +`lvgl_esp32_drivers` comes with built-in I2C support by integrating I2C Manager, which is used in case your touch interface or screen uses the I2C bus. The native I2C support offered by ESP-IDF is not thread-safe. Maybe you use LVGL with a touch sensor that has an i2c port, and maybe your device also has another i2c device that needs to be read frequently, such as a 3D-accelerometer. If you read that from another task than the lvgl uses to read the touch data, you need some kind of mechanism to keep these communications from interfering. + +If you have other components that can use I2C Manager (or Mika Tuupola's I2C HAL abstraction that I2C Manager is compatible with) then put I2C Manager in your components directory by cloning the repository from below and in your main program do: + +```c +#include "i2c_manager.h" +#include "lvgl_helpers.h" + +[...] + +lvgl_locking(i2c_manager_locking()); +lv_init(); +lvgl_driver_init(); +``` + +The `lvgl_locking` part will cause the LVGL I2C driver to play nice with anything else that uses the I2C port(s) through I2C Manager. + +See the [I2C Manager GitHub repository](https://github.com/ropg/i2c_manager) for much more information. + + +  + + + +## Information for driver developers + +I2C support in the LVGL ESP drivers is provided exclusively by the files in this directory. Code from all over the project that was talking to the I2C hardware directly has been replaced by code that communicates through the functions provided in `lvgl_i2c.h`. I2C is handled by the I2C Manager that was built into lvlg_esp32_drivers, but the code would be the same if it was routed through I2C Manager as a separate component. If you are providing a driver, you need not worry about any of this. + +### Using I2C in a driver, a multi-step guide + +#### Step 1 + +The Kconfig entries for your driver only need to specify that you will be using I2C. This is done by `select LV_I2C_DISPLAY` or `select LV_I2C_TOUCH`. + +#### Step 2 + +To use the I2C port in your code you would do something like: + +```c +#include "i2c_manager/i2c_manager.h" + +uint8_t data[2]; +lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, 0x23, 0x42, &data, 2); +``` + +This causes a touch driver to read two bytes at register `0x42` from the IC at address `0x23`. Replace `CONFIG_LV_I2C_TOUCH_PORT` by `CONFIG_LV_I2C_DISPLAY_PORT` when this is a display instead of a touch driver. `lvgl_i2c_write` works much the same way, except writing the bytes from the buffer instead of reading them. + +> The example above ignores it but these functions return `esp_err_t` so you can check if the i2c communication worked. + +#### Step 3 + +There is no step 3, you are already done. + +### Behind the scenes + +If anything in `lvgl_esp32_drivers` uses I2C, the config system will pop up an extra menu. This will allow you to select an I2C port for screen and one for the touch driver, if applicable. An extra menu allows you to set the GPIO pins and bus speed of any port you have selected for use. It's perfectly fine for a display and a touch driver to use the same I2C port or different ones. + + +## More information + +If you need more documentation, please refer to the [I2C Manager GitHub repository](https://github.com/ropg/i2c_manager) for more detailed information on how I2C manager works. diff --git a/i2c_manager/i2c_manager.c b/i2c_manager/i2c_manager.c new file mode 100644 index 00000000..d301aff8 --- /dev/null +++ b/i2c_manager/i2c_manager.c @@ -0,0 +1,368 @@ +/* + +SPDX-License-Identifier: MIT + +MIT License + +Copyright (c) 2021 Rop Gonggrijp. Based on esp_i2c_helper by Mika Tuupola. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. + +*/ + +#include +#include + +#include + +#include "freertos/FreeRTOS.h" +#include "freertos/semphr.h" +#include "freertos/task.h" +#include + +#include "sdkconfig.h" + +#include "i2c_manager.h" + + +#if defined __has_include + #if __has_include ("esp_idf_version.h") + #include "esp_idf_version.h" + #if ESP_IDF_VERSION >= ESP_IDF_VERSION_VAL(4, 3, 0) + #define HAS_CLK_FLAGS + #endif + #endif +#endif + + +static const char* TAG = I2C_TAG; + +static SemaphoreHandle_t I2C_FN(_local_mutex)[2] = { NULL, NULL }; +static SemaphoreHandle_t* I2C_FN(_mutex) = &I2C_FN(_local_mutex)[0]; + +static const uint8_t ACK_CHECK_EN = 1; + +#if defined (I2C_NUM_0) && defined (CONFIG_I2C_MANAGER_0_ENABLED) + #define I2C_ZERO I2C_NUM_0 + #if defined (CONFIG_I2C_MANAGER_0_PULLUPS) + #define I2C_MANAGER_0_PULLUPS true + #else + #define I2C_MANAGER_0_PULLUPS false + #endif + + #define I2C_MANAGER_0_TIMEOUT CONFIG_I2C_MANAGER_0_TIMEOUT / portTICK_RATE_MS + #define I2C_MANAGER_0_LOCK_TIMEOUT CONFIG_I2C_MANAGER_0_LOCK_TIMEOUT / portTICK_RATE_MS +#endif + + +#if defined (I2C_NUM_1) && defined (CONFIG_I2C_MANAGER_1_ENABLED) + #define I2C_ONE I2C_NUM_1 + #if defined (CONFIG_I2C_MANAGER_1_PULLUPS) + #define I2C_MANAGER_1_PULLUPS true + #else + #define I2C_MANAGER_1_PULLUPS false + #endif + + #define I2C_MANAGER_1_TIMEOUT CONFIG_I2C_MANAGER_1_TIMEOUT / portTICK_RATE_MS + #define I2C_MANAGER_1_LOCK_TIMEOUT CONFIG_I2C_MANAGER_1_LOCK_TIMEOUT / portTICK_RATE_MS +#endif + +#define ERROR_PORT(port, fail) { \ + ESP_LOGE(TAG, "Invalid port or not configured for I2C Manager: %d", (int)port); \ + return fail; \ +} + +#if defined(I2C_ZERO) && defined (I2C_ONE) + #define I2C_PORT_CHECK(port, fail) \ + if (port != I2C_NUM_0 && port != I2C_NUM_1) ERROR_PORT(port, fail); +#else + #if defined(I2C_ZERO) + #define I2C_PORT_CHECK(port, fail) \ + if (port != I2C_NUM_0) ERROR_PORT(port, fail); + #elif defined(I2C_ONE) + #define I2C_PORT_CHECK(port, fail) \ + if (port != I2C_NUM_1) ERROR_PORT(port, fail); + #else + #define I2C_PORT_CHECK(port, fail) \ + ERROR_PORT(port, fail); + #endif +#endif + +static void i2c_send_address(i2c_cmd_handle_t cmd, uint16_t addr, i2c_rw_t rw) { + if (addr & I2C_ADDR_10) { + i2c_master_write_byte(cmd, 0xF0 | ((addr & 0x3FF) >> 7) | rw, ACK_CHECK_EN); + i2c_master_write_byte(cmd, addr & 0xFF, ACK_CHECK_EN); + } else { + i2c_master_write_byte(cmd, (addr << 1) | rw, ACK_CHECK_EN); + } +} + +static void i2c_send_register(i2c_cmd_handle_t cmd, uint32_t reg) { + if (reg & I2C_REG_16) { + i2c_master_write_byte(cmd, (reg & 0xFF00) >> 8, ACK_CHECK_EN); + } + i2c_master_write_byte(cmd, reg & 0xFF, ACK_CHECK_EN); +} + +esp_err_t I2C_FN(_init)(i2c_port_t port) { + + I2C_PORT_CHECK(port, ESP_FAIL); + + esp_err_t ret = ESP_OK; + + if (I2C_FN(_mutex)[port] == 0) { + + ESP_LOGI(TAG, "Starting I2C master at port %d.", (int)port); + + I2C_FN(_mutex)[port] = xSemaphoreCreateMutex(); + + i2c_config_t conf = {0}; + + #ifdef HAS_CLK_FLAGS + conf.clk_flags = 0; + #endif + + #if defined (I2C_ZERO) + if (port == I2C_NUM_0) { + conf.sda_io_num = CONFIG_I2C_MANAGER_0_SDA; + conf.scl_io_num = CONFIG_I2C_MANAGER_0_SCL; + conf.sda_pullup_en = I2C_MANAGER_0_PULLUPS ? GPIO_PULLUP_ENABLE : GPIO_PULLUP_DISABLE; + conf.scl_pullup_en = conf.sda_pullup_en; + conf.master.clk_speed = CONFIG_I2C_MANAGER_0_FREQ_HZ; + } + #endif + + #if defined (I2C_ONE) + if (port == I2C_NUM_1) { + conf.sda_io_num = CONFIG_I2C_MANAGER_1_SDA; + conf.scl_io_num = CONFIG_I2C_MANAGER_1_SCL; + conf.sda_pullup_en = I2C_MANAGER_1_PULLUPS ? GPIO_PULLUP_ENABLE : GPIO_PULLUP_DISABLE; + conf.scl_pullup_en = conf.sda_pullup_en; + conf.master.clk_speed = CONFIG_I2C_MANAGER_1_FREQ_HZ; + } + #endif + + conf.mode = I2C_MODE_MASTER; + + ret = i2c_param_config(port, &conf); + ret |= i2c_driver_install(port, conf.mode, 0, 0, 0); + + if (ret != ESP_OK) { + ESP_LOGE(TAG, "Failed to initialise I2C port %d.", (int)port); + ESP_LOGW(TAG, "If it was already open, we'll use it with whatever settings were used " + "to open it. See I2C Manager README for details."); + } else { + ESP_LOGI(TAG, "Initialised port %d (SDA: %d, SCL: %d, speed: %d Hz.)", + port, conf.sda_io_num, conf.scl_io_num, conf.master.clk_speed); + } + + } + + return ret; +} + +esp_err_t I2C_FN(_read)(i2c_port_t port, uint16_t addr, uint32_t reg, uint8_t *buffer, uint16_t size) { + + I2C_PORT_CHECK(port, ESP_FAIL); + + esp_err_t result; + + // May seem weird, but init starts with a check if it's needed, no need for that check twice. + I2C_FN(_init)(port); + + ESP_LOGV(TAG, "Reading port %d, addr 0x%03x, reg 0x%04x", port, addr, reg); + + TickType_t timeout = 0; + #if defined (I2C_ZERO) + if (port == I2C_NUM_0) { + timeout = (CONFIG_I2C_MANAGER_0_TIMEOUT) / portTICK_RATE_MS; + } + #endif + #if defined (I2C_ONE) + if (port == I2C_NUM_1) { + timeout = (CONFIG_I2C_MANAGER_1_TIMEOUT) / portTICK_RATE_MS; + } + #endif + + if (I2C_FN(_lock)((int)port) == ESP_OK) { + i2c_cmd_handle_t cmd = i2c_cmd_link_create(); + if (!(reg & I2C_NO_REG)) { + /* When reading specific register set the addr pointer first. */ + i2c_master_start(cmd); + i2c_send_address(cmd, addr, I2C_MASTER_WRITE); + i2c_send_register(cmd, reg); + } + /* Read size bytes from the current pointer. */ + i2c_master_start(cmd); + i2c_send_address(cmd, addr, I2C_MASTER_READ); + i2c_master_read(cmd, buffer, size, I2C_MASTER_LAST_NACK); + i2c_master_stop(cmd); + result = i2c_master_cmd_begin(port, cmd, timeout); + i2c_cmd_link_delete(cmd); + I2C_FN(_unlock)((int)port); + } else { + ESP_LOGE(TAG, "Lock could not be obtained for port %d.", (int)port); + return ESP_ERR_TIMEOUT; + } + + if (result != ESP_OK) { + ESP_LOGW(TAG, "Error: %d", result); + } + + ESP_LOG_BUFFER_HEX_LEVEL(TAG, buffer, size, ESP_LOG_VERBOSE); + + return result; +} + +esp_err_t I2C_FN(_write)(i2c_port_t port, uint16_t addr, uint32_t reg, const uint8_t *buffer, uint16_t size) { + + I2C_PORT_CHECK(port, ESP_FAIL); + + esp_err_t result; + + // May seem weird, but init starts with a check if it's needed, no need for that check twice. + I2C_FN(_init)(port); + + ESP_LOGV(TAG, "Writing port %d, addr 0x%03x, reg 0x%04x", port, addr, reg); + + TickType_t timeout = 0; + #if defined (I2C_ZERO) + if (port == I2C_NUM_0) { + timeout = (CONFIG_I2C_MANAGER_0_TIMEOUT) / portTICK_RATE_MS; + } + #endif + #if defined (I2C_ONE) + if (port == I2C_NUM_1) { + timeout = (CONFIG_I2C_MANAGER_1_TIMEOUT) / portTICK_RATE_MS; + } + #endif + + if (I2C_FN(_lock)((int)port) == ESP_OK) { + i2c_cmd_handle_t cmd = i2c_cmd_link_create(); + i2c_master_start(cmd); + i2c_send_address(cmd, addr, I2C_MASTER_WRITE); + if (!(reg & I2C_NO_REG)) { + i2c_send_register(cmd, reg); + } + i2c_master_write(cmd, (uint8_t *)buffer, size, ACK_CHECK_EN); + i2c_master_stop(cmd); + result = i2c_master_cmd_begin( port, cmd, timeout); + i2c_cmd_link_delete(cmd); + I2C_FN(_unlock)((int)port); + } else { + ESP_LOGE(TAG, "Lock could not be obtained for port %d.", (int)port); + return ESP_ERR_TIMEOUT; + } + + if (result != ESP_OK) { + ESP_LOGW(TAG, "Error: %d", result); + } + + ESP_LOG_BUFFER_HEX_LEVEL(TAG, buffer, size, ESP_LOG_VERBOSE); + + return result; +} + +esp_err_t I2C_FN(_close)(i2c_port_t port) { + I2C_PORT_CHECK(port, ESP_FAIL); + vSemaphoreDelete(I2C_FN(_mutex)[port]); + I2C_FN(_mutex)[port] = NULL; + ESP_LOGI(TAG, "Closing I2C master at port %d", port); + return i2c_driver_delete(port); +} + +esp_err_t I2C_FN(_lock)(i2c_port_t port) { + I2C_PORT_CHECK(port, ESP_FAIL); + ESP_LOGV(TAG, "Mutex lock set for %d.", (int)port); + + TickType_t timeout; + #if defined (I2C_ZERO) + if (port == I2C_NUM_0) { + timeout = (CONFIG_I2C_MANAGER_0_LOCK_TIMEOUT) / portTICK_RATE_MS; + } + #endif + #if defined (I2C_ONE) + if (port == I2C_NUM_1) { + timeout = (CONFIG_I2C_MANAGER_1_LOCK_TIMEOUT) / portTICK_RATE_MS; + } + #endif + + if (xSemaphoreTake(I2C_FN(_mutex)[port], timeout) == pdTRUE) { + return ESP_OK; + } else { + ESP_LOGE(TAG, "Removing stale mutex lock from port %d.", (int)port); + I2C_FN(_force_unlock)(port); + return (xSemaphoreTake(I2C_FN(_mutex)[port], timeout) == pdTRUE ? ESP_OK : ESP_FAIL); + } +} + +esp_err_t I2C_FN(_unlock)(i2c_port_t port) { + I2C_PORT_CHECK(port, ESP_FAIL); + ESP_LOGV(TAG, "Mutex lock removed for %d.", (int)port); + return (xSemaphoreGive(I2C_FN(_mutex)[port]) == pdTRUE) ? ESP_OK : ESP_FAIL; +} + +esp_err_t I2C_FN(_force_unlock)(i2c_port_t port) { + I2C_PORT_CHECK(port, ESP_FAIL); + if (I2C_FN(_mutex)[port]) { + vSemaphoreDelete(I2C_FN(_mutex)[port]); + } + I2C_FN(_mutex)[port] = xSemaphoreCreateMutex(); + return ESP_OK; +} + + + +#ifdef I2C_OEM + + void I2C_FN(_locking)(void* leader) { + if (leader) { + ESP_LOGI(TAG, "Now following I2C Manager for locking"); + I2C_FN(_mutex) = (SemaphoreHandle_t*)leader; + } + } + +#else + + void* i2c_manager_locking() { + return (void*)i2c_manager_mutex; + } + + int32_t i2c_hal_read(void *handle, uint8_t address, uint8_t reg, uint8_t *buffer, uint16_t size) { + return i2c_manager_read(*(i2c_port_t*)handle, address, reg, buffer, size); + } + + int32_t i2c_hal_write(void *handle, uint8_t address, uint8_t reg, const uint8_t *buffer, uint16_t size) { + return i2c_manager_write(*(i2c_port_t*)handle, address, reg, buffer, size); + } + + static i2c_port_t port_zero = (i2c_port_t)0; + static i2c_port_t port_one = (i2c_port_t)1; + + static i2c_hal_t _i2c_hal[2] = { + {&i2c_hal_read, &i2c_hal_write, &port_zero}, + {&i2c_hal_read, &i2c_hal_write, &port_one} + }; + + void* i2c_hal(i2c_port_t port) { + I2C_PORT_CHECK(port, NULL); + return (void*)&_i2c_hal[port]; + } + +#endif diff --git a/i2c_manager/i2c_manager.h b/i2c_manager/i2c_manager.h new file mode 100644 index 00000000..f9ce5850 --- /dev/null +++ b/i2c_manager/i2c_manager.h @@ -0,0 +1,76 @@ +#ifndef _I2C_MANAGER_H +#define _I2C_MANAGER_H + +#ifdef __cplusplus +extern "C" { +#endif + + +/* + + If you copy the i2c_manager files to your own component instead of + depending on i2c_manager, you MUST uncomment the define below + and put in some short string that identifies your component (such + as 'xyz'). This will cause i2c_manager to create functions named + xyz_i2c_* instead of i2c_manager_*. See README.md for details. + +*/ + +#define I2C_OEM lvgl + + +// Only here to get the I2C_NUM_0 and I2C_NUM_1 defines. +#include + +#define CONCATX(A, B) A ## B +#define CONCAT(A, B) CONCATX(A, B) +#define STR_LITERAL(s) # s +#define STR_EXPAND(s) STR_LITERAL(s) +#define STR_QUOTE(s) STR_EXPAND(STR_EXPAND(s)) + +#ifdef I2C_OEM + #define I2C_NAME_PREFIX CONCAT(I2C_OEM, _i2c) +#else + #define I2C_NAME_PREFIX i2c_manager +#endif +#define I2C_TAG STR_EXPAND(I2C_NAME_PREFIX) + +#define I2C_FN(s) CONCAT(I2C_NAME_PREFIX, s) + + +#define I2C_ADDR_10 ( 1 << 15 ) +#define I2C_REG_16 ( 1 << 31 ) +#define I2C_NO_REG ( 1 << 30 ) + +esp_err_t I2C_FN(_init)(i2c_port_t port); +esp_err_t I2C_FN(_read)(i2c_port_t port, uint16_t addr, uint32_t reg, uint8_t *buffer, uint16_t size); +esp_err_t I2C_FN(_write)(i2c_port_t port, uint16_t addr, uint32_t reg, const uint8_t *buffer, uint16_t size); +esp_err_t I2C_FN(_close)(i2c_port_t port); +esp_err_t I2C_FN(_lock)(i2c_port_t port); +esp_err_t I2C_FN(_unlock)(i2c_port_t port); +esp_err_t I2C_FN(_force_unlock)(i2c_port_t port); + + +#ifdef I2C_OEM + + void I2C_FN(_locking)(void* leader); + +#else + + void* i2c_manager_locking(); + + typedef struct { + int32_t (* read)(void *handle, uint8_t address, uint8_t reg, uint8_t *buffer, uint16_t size); + int32_t (* write)(void *handle, uint8_t address, uint8_t reg, const uint8_t *buffer, uint16_t size); + void *handle; + } i2c_hal_t; + + void* i2c_hal(i2c_port_t port); + +#endif + + +#ifdef __cplusplus +} +#endif +#endif diff --git a/lvgl_helpers.c b/lvgl_helpers.c index 2e78fef7..dc98720a 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -14,9 +14,8 @@ #include "lvgl_touch/tp_spi.h" #include "lvgl_spi_conf.h" -#include "lvgl_i2c_conf.h" -#include "driver/i2c.h" +#include "i2c_manager/i2c_manager.h" #ifdef LV_LVGL_H_INCLUDE_SIMPLE #include "lvgl.h" @@ -68,7 +67,7 @@ void lvgl_driver_init(void) DISP_SPI_MISO, DISP_SPI_MOSI, DISP_SPI_CLK, SPI_BUS_MAX_TRANSFER_SZ, 1, DISP_SPI_IO2, DISP_SPI_IO3); - + disp_spi_add_device(TFT_SPI_HOST); disp_driver_init(); @@ -86,48 +85,29 @@ void lvgl_driver_init(void) TP_SPI_MISO, DISP_SPI_MOSI, DISP_SPI_CLK, SPI_BUS_MAX_TRANSFER_SZ, 1, -1, -1); - + disp_spi_add_device(TFT_SPI_HOST); tp_spi_add_device(TOUCH_SPI_HOST); - - disp_driver_init(); - touch_driver_init(); - return; -#endif - -#if defined (SHARED_I2C_BUS) - ESP_LOGI(TAG, "Initializing shared I2C master"); - - lvgl_i2c_driver_init(DISP_I2C_PORT, - DISP_I2C_SDA, DISP_I2C_SCL, - DISP_I2C_SPEED_HZ); - disp_driver_init(); touch_driver_init(); - + return; #endif /* Display controller initialization */ #if defined CONFIG_LV_TFT_DISPLAY_PROTOCOL_SPI ESP_LOGI(TAG, "Initializing SPI master for display"); - + lvgl_spi_driver_init(TFT_SPI_HOST, DISP_SPI_MISO, DISP_SPI_MOSI, DISP_SPI_CLK, SPI_BUS_MAX_TRANSFER_SZ, 1, DISP_SPI_IO2, DISP_SPI_IO3); - + disp_spi_add_device(TFT_SPI_HOST); - + disp_driver_init(); -#elif defined (CONFIG_LV_TFT_DISPLAY_PROTOCOL_I2C) - ESP_LOGI(TAG, "Initializing I2C master for display"); - /* Init the i2c master on the display driver code */ - lvgl_i2c_driver_init(DISP_I2C_PORT, - DISP_I2C_SDA, DISP_I2C_SCL, - DISP_I2C_SPEED_HZ); - +#elif defined (CONFIG_LV_I2C_DISPLAY) disp_driver_init(); #else #error "No protocol defined for display controller" @@ -137,22 +117,16 @@ void lvgl_driver_init(void) #if CONFIG_LV_TOUCH_CONTROLLER != TOUCH_CONTROLLER_NONE #if defined (CONFIG_LV_TOUCH_DRIVER_PROTOCOL_SPI) ESP_LOGI(TAG, "Initializing SPI master for touch"); - + lvgl_spi_driver_init(TOUCH_SPI_HOST, TP_SPI_MISO, TP_SPI_MOSI, TP_SPI_CLK, 0 /* Defaults to 4094 */, 2, -1, -1); - + tp_spi_add_device(TOUCH_SPI_HOST); - + touch_driver_init(); - #elif defined (CONFIG_LV_TOUCH_DRIVER_PROTOCOL_I2C) - ESP_LOGI(TAG, "Initializing I2C master for touch"); - - lvgl_i2c_driver_init(TOUCH_I2C_PORT, - TOUCH_I2C_SDA, TOUCH_I2C_SCL, - TOUCH_I2C_SPEED_HZ); - + #elif defined (CONFIG_LV_I2C_TOUCH) touch_driver_init(); #elif defined (CONFIG_LV_TOUCH_DRIVER_ADC) touch_driver_init(); @@ -165,42 +139,6 @@ void lvgl_driver_init(void) #endif } -/* Config the i2c master - * - * This should init the i2c master to be used on display and touch controllers. - * So we should be able to know if the display and touch controllers shares the - * same i2c master. - */ -bool lvgl_i2c_driver_init(int port, int sda_pin, int scl_pin, int speed_hz) -{ - esp_err_t err; - - ESP_LOGI(TAG, "Initializing I2C master port %d...", port); - ESP_LOGI(TAG, "SDA pin: %d, SCL pin: %d, Speed: %d (Hz)", - sda_pin, scl_pin, speed_hz); - - i2c_config_t conf = { - .mode = I2C_MODE_MASTER, - .sda_io_num = sda_pin, - .sda_pullup_en = GPIO_PULLUP_ENABLE, - .scl_io_num = scl_pin, - .scl_pullup_en = GPIO_PULLUP_ENABLE, - .master.clk_speed = speed_hz, - }; - - ESP_LOGI(TAG, "Setting I2C master configuration..."); - err = i2c_param_config(port, &conf); - assert(ESP_OK == err); - - ESP_LOGI(TAG, "Installing I2C master driver..."); - err = i2c_driver_install(port, - I2C_MODE_MASTER, - 0, 0 /*I2C_MASTER_RX_BUF_DISABLE, I2C_MASTER_TX_BUF_DISABLE */, - 0 /* intr_alloc_flags */); - assert(ESP_OK == err); - - return ESP_OK != err; -} /* Initialize spi bus master * diff --git a/lvgl_helpers.h b/lvgl_helpers.h index 081a8437..8c599fef 100644 --- a/lvgl_helpers.h +++ b/lvgl_helpers.h @@ -88,14 +88,14 @@ extern "C" { * GLOBAL PROTOTYPES **********************/ +void lvgl_i2c_locking(void* leader); + /* Initialize detected SPI and I2C bus and devices */ void lvgl_driver_init(void); /* Initialize SPI master */ bool lvgl_spi_driver_init(int host, int miso_pin, int mosi_pin, int sclk_pin, int max_transfer_sz, int dma_channel, int quadwp_pin, int quadhd_pin); -/* Initialize I2C master */ -bool lvgl_i2c_driver_init(int port, int sda_pin, int scl_pin, int speed); /********************** * MACROS diff --git a/lvgl_i2c_conf.h b/lvgl_i2c_conf.h deleted file mode 100644 index cf8ac45e..00000000 --- a/lvgl_i2c_conf.h +++ /dev/null @@ -1,116 +0,0 @@ -/** - * @file lvgl_i2c_config.h - */ - -#ifndef LVGL_I2C_CONF_H -#define LVGL_I2C_CONF_H - -#ifdef __cplusplus -extern "C" { -#endif - -/********************* - * INCLUDES - *********************/ -#ifdef LV_LVGL_H_INCLUDE_SIMPLE -#include "lvgl.h" -#else -#include "lvgl/lvgl.h" -#endif - -/********************* - * DEFINES - *********************/ - -/* TODO: Define the I2C bus clock based on the selected display or touch - * controllers. */ - -/* Do both display and touch controllers uses I2C? */ -#if defined (CONFIG_LV_TOUCH_DRIVER_PROTOCOL_I2C) && \ - defined (CONFIG_LV_TFT_DISPLAY_PROTOCOL_I2C) - -#if defined (CONFIG_LV_DISPLAY_I2C_PORT_0) && \ - defined (CONFIG_LV_TOUCH_I2C_PORT_0) -#define SHARED_I2C_PORT -#define DISP_I2C_PORT I2C_NUM_0 -#endif - -#if defined (CONFIG_LV_DISPLAY_I2C_PORT_1) && \ - defined (CONFIG_LV_TOUCH_I2C_PORT_1) -#define SHARED_I2C_PORT -#define DISP_I2C_PORT I2C_NUM_1 -#endif - -#if !defined (SHARED_I2C_PORT) -#endif -#endif - -#if defined (SHARED_I2C_PORT) -/* If the port is shared the display and touch controllers must use the same - * SCL and SDA pins, otherwise let the user know with an error. */ -#if (CONFIG_LV_DISP_PIN_SDA != CONFIG_LV_TOUCH_I2C_SDA) || \ - (CONFIG_LV_DISP_PIN_SCL != CONFIG_LV_TOUCH_I2C_SCL) -#error "To share I2C port you need to choose the same SDA and SCL pins on both display and touch configurations" -#endif - -#define DISP_I2C_SDA CONFIG_LV_DISP_PIN_SDA -#define DISP_I2C_SCL CONFIG_LV_DISP_PIN_SCL -#define DISP_I2C_ORIENTATION TFT_ORIENTATION_LANDSCAPE - -/* Setting the I2C speed to the slowest one */ -#if DISP_I2C_SPEED_HZ < TOUCH_I2C_SPEED_HZ -#define DISP_I2C_SPEED_HZ 400000 /* DISP_I2C_SPEED_HZ */ -#else -#define DISP_I2C_SPEED_HZ 400000 /* DISP_I2C_SPEED_HZ */ -#endif - -#else - -/* lets check if the touch controller uses I2C... */ -#if defined (CONFIG_LV_TOUCH_DRIVER_PROTOCOL_I2C) -#if defined (CONFIG_LV_TOUCH_I2C_PORT_0) -#define TOUCH_I2C_PORT I2C_NUM_0 -#else -#define TOUCH_I2C_PORT I2C_NUM_1 -#endif -#define TOUCH_I2C_SDA CONFIG_LV_TOUCH_I2C_SDA -#define TOUCH_I2C_SCL CONFIG_LV_TOUCH_I2C_SCL -#define TOUCH_I2C_SPEED_HZ 400000 -#endif - -/* lets check if the display controller uses I2C... */ -#if defined (CONFIG_LV_TFT_DISPLAY_PROTOCOL_I2C) -#if defined (CONFIG_LV_DISPLAY_I2C_PORT_0) -#define DISP_I2C_PORT I2C_NUM_0 -#else -#define DISP_I2C_PORT I2C_NUM_1 -#endif - -#define DISP_I2C_SDA CONFIG_LV_DISP_PIN_SDA -#define DISP_I2C_SCL CONFIG_LV_DISP_PIN_SCL -#define DISP_I2C_ORIENTATION TFT_ORIENTATION_LANDSCAPE -#define DISP_I2C_SPEED_HZ 400000 -#endif - -#endif - -/********************** - * TYPEDEFS - **********************/ - - -/********************** - * GLOBAL PROTOTYPES - **********************/ - - -/********************** - * MACROS - **********************/ - - -#ifdef __cplusplus -} /* extern "C" */ -#endif - -#endif /*LVGL_I2C_CONF_H*/ diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 0535580e..19138afc 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -50,7 +50,7 @@ menu "LVGL TFT Display controller" config LV_PREDEFINED_DISPLAY_WEMOS_LOLIN bool "Wemos Lolin OLED" select LV_TFT_DISPLAY_CONTROLLER_SSD1306 - select LV_TFT_DISPLAY_PROTOCOL_I2C + select LV_I2C_DISPLAY select LV_TFT_DISPLAY_MONOCHROME select LV_THEME_MONO config LV_PREDEFINED_DISPLAY_ATAG @@ -187,7 +187,7 @@ menu "LVGL TFT Display controller" help Display controller protocol SPI - config LV_TFT_DISPLAY_PROTOCOL_I2C + config LV_I2C_DISPLAY bool help Display controller protocol I2C @@ -311,7 +311,7 @@ menu "LVGL TFT Display controller" config LV_TFT_DISPLAY_USER_CONTROLLER_SSD1306 bool "SSD1306" select LV_TFT_DISPLAY_CONTROLLER_SSD1306 - select LV_TFT_DISPLAY_PROTOCOL_I2C + select LV_I2C_DISPLAY select LV_TFT_DISPLAY_MONOCHROME config LV_TFT_DISPLAY_USER_CONTROLLER_FT81X bool "FT81X" @@ -502,18 +502,6 @@ menu "LVGL TFT Display controller" depends on LV_TFT_DISPLAY_SPI_TRANS_MODE_SIO endchoice - choice - prompt "Display I2C port" if LV_TFT_DISPLAY_PROTOCOL_I2C - default LV_DISPLAY_I2C_PORT_0 - help - Select the I2C port used by the display controller. - - config LV_DISPLAY_I2C_PORT_0 - bool "I2C PORT 0" - config LV_DISPLAY_I2C_PORT_1 - bool "I2C PORT 1" - endchoice - config LV_TFT_USE_CUSTOM_SPI_CLK_DIVIDER bool "Use custom SPI clock frequency." if LV_TFT_DISPLAY_PROTOCOL_SPI default n @@ -591,6 +579,16 @@ menu "LVGL TFT Display controller" default 80 if LV_TFT_SPI_CLK_DIVIDER_80 default 2 + config LV_M5STICKC_HANDLE_AXP192 + bool "Handle Backlight and TFT power for M5StickC using AXP192." if LV_PREDEFINED_DISPLAY_M5STICKC || LV_TFT_DISPLAY_CONTROLLER_ST7735S + default y if LV_PREDEFINED_DISPLAY_M5STICKC + select LV_I2C_DISPLAY + help + Display and TFT power supply on M5StickC is controlled using an + AXP192 Power Mangerment IC. Select yes if you want to enable TFT IC + (LDO3) and backlight power using AXP192 by LVGL, or select no if you + want to take care of power management in your own code. + config LV_INVERT_DISPLAY bool "IN DEPRECATION - Invert display." if LV_TFT_DISPLAY_CONTROLLER_RA8875 default n @@ -604,31 +602,6 @@ menu "LVGL TFT Display controller" If the colors look inverted on your display, try enabling this. If it didn't help try LVGL configuration -> Swap the 2 bytes of RGB565 color. - config LV_M5STICKC_HANDLE_AXP192 - bool "Handle Backlight and TFT power for M5StickC using AXP192." if LV_PREDEFINED_DISPLAY_M5STICKC || LV_TFT_DISPLAY_CONTROLLER_ST7735S - default y if LV_PREDEFINED_DISPLAY_M5STICKC - help - Display and TFT power supply on M5StickC is controlled using an AXP192 Power Mangerment IC. - Select yes if you want to enable TFT IC (LDO3) and backlight power using AXP192 by LVGL, or select no if you want to take care of - power management in your own code. - - config LV_AXP192_PIN_SDA - int "GPIO for AXP192 I2C SDA" - depends on LV_M5STICKC_HANDLE_AXP192 - range 0 39 - default 21 if LV_PREDEFINED_DISPLAY_M5STICKC - default 21 - help - Configure the AXP192 I2C SDA pin here. - - config LV_AXP192_PIN_SCL - int "GPIO for AXP192 I2C SCL" - depends on LV_M5STICKC_HANDLE_AXP192 - range 0 39 - default 22 if LV_PREDEFINED_DISPLAY_M5STICKC - default 22 - help - Configure the AXP192 I2C SDA pin here. # menu will be visible only when LV_PREDEFINED_DISPLAY_NONE is y menu "Display RA8875 Configuration" @@ -770,7 +743,7 @@ menu "LVGL TFT Display controller" config LV_DISP_SPI_MOSI int "GPIO for MOSI (Master Out Slave In)" if LV_TFT_DISPLAY_PROTOCOL_SPI range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 23 if LV_PREDEFINED_DISPLAY_WROVER4 @@ -800,7 +773,7 @@ menu "LVGL TFT Display controller" int "GPIO for MISO (Master In Slave Out)" if LV_TFT_DISPLAY_PROTOCOL_SPI depends on LV_DISPLAY_USE_SPI_MISO range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 19 if LV_PREDEFINED_PINS_TKOALA @@ -846,7 +819,7 @@ menu "LVGL TFT Display controller" config LV_DISP_SPI_CLK int "GPIO for CLK (SCK / Serial Clock)" if LV_TFT_DISPLAY_PROTOCOL_SPI range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 18 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK @@ -875,7 +848,7 @@ menu "LVGL TFT Display controller" int "GPIO for CS (Slave Select)" if LV_TFT_DISPLAY_PROTOCOL_SPI depends on LV_DISPLAY_USE_SPI_CS range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 5 if LV_PREDEFINED_PINS_38V1 @@ -904,7 +877,7 @@ menu "LVGL TFT Display controller" config LV_DISP_PIN_DC int "GPIO for DC (Data / Command)" if LV_TFT_DISPLAY_PROTOCOL_SPI range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 depends on LV_DISPLAY_USE_DC @@ -942,7 +915,7 @@ menu "LVGL TFT Display controller" int "GPIO for Reset" if LV_TFT_DISPLAY_PROTOCOL_SPI && !LV_DISP_ST7789_SOFT_RESET depends on LV_DISP_USE_RST range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 18 if LV_PREDEFINED_PINS_38V1 @@ -964,7 +937,7 @@ menu "LVGL TFT Display controller" config LV_DISP_PIN_BUSY int "GPIO for Busy" if LV_TFT_DISPLAY_CONTROLLER_IL3820 || LV_TFT_DISPLAY_CONTROLLER_JD79653A || LV_TFT_DISPLAY_CONTROLLER_UC8151D range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 35 if LV_TFT_DISPLAY_CONTROLLER_IL3820 || LV_TFT_DISPLAY_CONTROLLER_JD79653A || LV_TFT_DISPLAY_CONTROLLER_UC8151D @@ -1005,7 +978,7 @@ menu "LVGL TFT Display controller" int "GPIO for Backlight Control" depends on LV_ENABLE_BACKLIGHT_CONTROL range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 23 if LV_PREDEFINED_PINS_38V1 @@ -1023,30 +996,33 @@ menu "LVGL TFT Display controller" help Configure the display BCLK (LED) pin here. - config LV_DISP_PIN_SDA - int "GPIO for I2C SDA" if LV_TFT_DISPLAY_PROTOCOL_I2C - range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 + endmenu - default 5 if LV_PREDEFINED_DISPLAY_WEMOS_LOLIN - default 5 + choice + prompt "Select an I2C port for the display" + default LV_I2C_DISPLAY_PORT_0 + depends on LV_I2C_DISPLAY - help - Configure the I2C SDA pin here. + config LV_I2C_DISPLAY_PORT_0 + bool + prompt "I2C port 0" - config LV_DISP_PIN_SCL - int "GPIO for I2C SCL" if LV_TFT_DISPLAY_PROTOCOL_I2C - range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 + config LV_I2C_DISPLAY_PORT_1 + bool + prompt "I2C port 1" - default 4 if LV_PREDEFINED_DISPLAY_WEMOS_LOLIN - default 4 + endchoice - help - Configure the I2C SCL pin here. + config LV_I2C + bool + default y if LV_I2C_DISPLAY - endmenu + config LV_I2C_DISPLAY_PORT + int + default 1 if LV_I2C_DISPLAY_PORT_1 + default 0 endmenu + + + diff --git a/lvgl_tft/ili9341.h b/lvgl_tft/ili9341.h index 5768fbef..e0058b11 100644 --- a/lvgl_tft/ili9341.h +++ b/lvgl_tft/ili9341.h @@ -20,7 +20,8 @@ extern "C" { #else #include "lvgl/lvgl.h" #endif -#include "../lvgl_helpers.h" + +#include "sdkconfig.h" /********************* * DEFINES diff --git a/lvgl_tft/ssd1306.c b/lvgl_tft/ssd1306.c index 43e5966c..459cd001 100644 --- a/lvgl_tft/ssd1306.c +++ b/lvgl_tft/ssd1306.c @@ -13,10 +13,9 @@ /********************* * INCLUDES *********************/ -#include "driver/i2c.h" #include "assert.h" -#include "lvgl_i2c_conf.h" +#include "i2c_manager/i2c_manager.h" #include "ssd1306.h" @@ -25,6 +24,7 @@ *********************/ #define TAG "SSD1306" +#define OLED_I2C_PORT (CONFIG_LV_I2C_DISPLAY_PORT) // SLA (0x3C) + WRITE_MODE (0x00) = 0x78 (0b01111000) #define OLED_I2C_ADDRESS 0x3C #define OLED_WIDTH 128 @@ -70,8 +70,6 @@ // Charge Pump (pg.62) #define OLED_CMD_SET_CHARGE_PUMP 0x8D // follow with 0x14 -#define OLED_IIC_FREQ_HZ 400000 // I2C colock frequency - /********************** * TYPEDEFS **********************/ @@ -217,20 +215,22 @@ static uint8_t send_data(lv_disp_drv_t *disp_drv, void *bytes, size_t bytes_len) uint8_t *data = (uint8_t *) bytes; - i2c_cmd_handle_t cmd = i2c_cmd_link_create(); - - i2c_master_start(cmd); - i2c_master_write_byte(cmd, (OLED_I2C_ADDRESS << 1) | I2C_MASTER_WRITE, true); - - for (size_t idx = 0; idx < bytes_len; idx++) { - i2c_master_write_byte(cmd, data[idx], true); - } - - i2c_master_stop(cmd); - - /* Send queued commands */ - err = i2c_master_cmd_begin(DISP_I2C_PORT, cmd, 10 / portTICK_PERIOD_MS); - i2c_cmd_link_delete(cmd); + err = lvgl_i2c_write(OLED_I2C_PORT, OLED_I2C_ADDRESS, data[0], data + 1, bytes_len - 1 ); + +// i2c_cmd_handle_t cmd = i2c_cmd_link_create(); +// +// i2c_master_start(cmd); +// i2c_master_write_byte(cmd, (OLED_I2C_ADDRESS << 1) | I2C_MASTER_WRITE, true); +// +// for (size_t idx = 0; idx < bytes_len; idx++) { +// i2c_master_write_byte(cmd, data[idx], true); +// } +// +// i2c_master_stop(cmd); +// +// /* Send queued commands */ +// err = i2c_master_cmd_begin(DISP_I2C_PORT, cmd, 10 / portTICK_PERIOD_MS); +// i2c_cmd_link_delete(cmd); return ESP_OK == err ? 0 : 1; } @@ -240,17 +240,7 @@ static uint8_t send_pixels(lv_disp_drv_t *disp_drv, void *color_buffer, size_t b (void) disp_drv; esp_err_t err; - i2c_cmd_handle_t cmd = i2c_cmd_link_create(); - i2c_master_start(cmd); - i2c_master_write_byte(cmd, (OLED_I2C_ADDRESS << 1) | I2C_MASTER_WRITE, true); - - i2c_master_write_byte(cmd, OLED_CONTROL_BYTE_DATA_STREAM, true); - i2c_master_write(cmd, (uint8_t *) color_buffer, buffer_len, true); - i2c_master_stop(cmd); - - /* Send queued commands */ - err = i2c_master_cmd_begin(DISP_I2C_PORT, cmd, 10 / portTICK_PERIOD_MS); - i2c_cmd_link_delete(cmd); + err = lvgl_i2c_write(OLED_I2C_PORT, OLED_I2C_ADDRESS, OLED_CONTROL_BYTE_DATA_STREAM, color_buffer, buffer_len); return ESP_OK == err ? 0 : 1; } diff --git a/lvgl_tft/ssd1306.h b/lvgl_tft/ssd1306.h index 21454931..62bd0e69 100644 --- a/lvgl_tft/ssd1306.h +++ b/lvgl_tft/ssd1306.h @@ -25,8 +25,6 @@ extern "C" { /********************* * DEFINES *********************/ -#define SSD1306_SDA CONFIG_LV_DISP_PIN_SDA -#define SSD1306_SCL CONFIG_LV_DISP_PIN_SCL #define SSD1306_DISPLAY_ORIENTATION TFT_ORIENTATION_LANDSCAPE /********************** diff --git a/lvgl_tft/st7735s.c b/lvgl_tft/st7735s.c index 2507118b..d57def5e 100644 --- a/lvgl_tft/st7735s.c +++ b/lvgl_tft/st7735s.c @@ -8,12 +8,15 @@ *********************/ #include "st7735s.h" #include "disp_spi.h" -#include "driver/i2c.h" #include "driver/gpio.h" #include "esp_log.h" #include "freertos/FreeRTOS.h" #include "freertos/task.h" +#ifdef CONFIG_LV_M5STICKC_HANDLE_AXP192 + #include "i2c_manager/i2c_manager.h" +#endif + /********************* * DEFINES *********************/ @@ -38,7 +41,6 @@ static void st7735s_send_cmd(uint8_t cmd); static void st7735s_send_data(void * data, uint16_t length); static void st7735s_send_color(void * data, uint16_t length); static void st7735s_set_orientation(uint8_t orientation); -static void i2c_master_init(); static void axp192_write_byte(uint8_t addr, uint8_t data); static void axp192_init(); static void axp192_sleep_in(); @@ -60,7 +62,6 @@ uint8_t st7735s_portrait_mode = 0; void st7735s_init(void) { #ifdef CONFIG_LV_M5STICKC_HANDLE_AXP192 - i2c_master_init(); axp192_init(); #endif @@ -163,12 +164,16 @@ void st7735s_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * col void st7735s_sleep_in() { st7735s_send_cmd(0x10); - axp192_sleep_in(); + #ifdef CONFIG_LV_M5STICKC_HANDLE_AXP192 + axp192_sleep_in(); + #endif } void st7735s_sleep_out() { - axp192_sleep_out(); + #ifdef CONFIG_LV_M5STICKC_HANDLE_AXP192 + axp192_sleep_out(); + #endif st7735s_send_cmd(0x11); } @@ -218,55 +223,35 @@ static void st7735s_set_orientation(uint8_t orientation) st7735s_send_data((void *) &data[orientation], 1); } -static void i2c_master_init() -{ - i2c_config_t i2c_config = { - .mode = I2C_MODE_MASTER, - .sda_io_num = AXP192_SDA, - .scl_io_num = AXP192_SCL, - .sda_pullup_en = GPIO_PULLUP_ENABLE, - .scl_pullup_en = GPIO_PULLUP_ENABLE, - .master.clk_speed = 400000 - }; - i2c_param_config(I2C_NUM_0, &i2c_config); - i2c_driver_install(I2C_NUM_0, I2C_MODE_MASTER, 0, 0, 0); -} - -static void axp192_write_byte(uint8_t addr, uint8_t data) -{ - esp_err_t ret; - i2c_cmd_handle_t cmd = i2c_cmd_link_create(); - - i2c_master_start(cmd); - i2c_master_write_byte(cmd, (AXP192_I2C_ADDRESS << 1) | I2C_MASTER_WRITE, true); - i2c_master_write_byte(cmd, addr, true); - i2c_master_write_byte(cmd, data, true); - i2c_master_stop(cmd); - - ret = i2c_master_cmd_begin(I2C_NUM_0, cmd, 10/portTICK_PERIOD_MS); - if (ret != ESP_OK) { - ESP_LOGE(TAG, "AXP192 send failed. code: 0x%.2X", ret); - } - i2c_cmd_link_delete(cmd); -} - -static void axp192_init() -{ - // information on how to init and use AXP192 ifor M5StickC taken from - // https://forum.m5stack.com/topic/1025/m5stickc-turn-off-screen-completely +#ifdef CONFIG_LV_M5STICKC_HANDLE_AXP192 - axp192_write_byte(0x10, 0xFF); // OLED_VPP Enable - axp192_write_byte(0x28, 0xCC); // Enable LDO2&LDO3, LED&TFT 3.0V - axp192_sleep_out(); - ESP_LOGI(TAG, "AXP192 initialized, power enabled for LDO2 and LDO3"); -} + static void axp192_write_byte(uint8_t addr, uint8_t data) + { + err = lvgl_i2c_write(CONFIG_LV_I2C_DISPLAY_PORT, AXP192_I2C_ADDRESS, addr, &data, 1); + if (ret != ESP_OK) { + ESP_LOGE(TAG, "AXP192 send failed. code: 0x%.2X", ret); + } + } + + static void axp192_init() + { + // information on how to init and use AXP192 ifor M5StickC taken from + // https://forum.m5stack.com/topic/1025/m5stickc-turn-off-screen-completely + + axp192_write_byte(0x10, 0xFF); // OLED_VPP Enable + axp192_write_byte(0x28, 0xCC); // Enable LDO2&LDO3, LED&TFT 3.0V + axp192_sleep_out(); + ESP_LOGI(TAG, "AXP192 initialized, power enabled for LDO2 and LDO3"); + } + + static void axp192_sleep_in() + { + axp192_write_byte(0x12, 0x4b); + } + + static void axp192_sleep_out() + { + axp192_write_byte(0x12, 0x4d); + } -static void axp192_sleep_in() -{ - axp192_write_byte(0x12, 0x4b); -} - -static void axp192_sleep_out() -{ - axp192_write_byte(0x12, 0x4d); -} +#endif diff --git a/lvgl_tft/st7735s.h b/lvgl_tft/st7735s.h index 71924bf3..7422be6a 100644 --- a/lvgl_tft/st7735s.h +++ b/lvgl_tft/st7735s.h @@ -29,9 +29,6 @@ extern "C" { #define ST7735S_RST CONFIG_LV_DISP_PIN_RST #define ST7735S_USE_RST CONFIG_LV_DISP_USE_RST -#define AXP192_SDA CONFIG_LV_AXP192_PIN_SDA -#define AXP192_SCL CONFIG_LV_AXP192_PIN_SCL - #define ST7735S_INVERT_COLORS CONFIG_LV_INVERT_COLORS // Defines are taken from diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index d4b71fcb..da4b6612 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -23,7 +23,7 @@ menu "LVGL Touch controller" select LV_TOUCH_DRIVER_PROTOCOL_SPI bool "XPT2046" config LV_TOUCH_CONTROLLER_FT6X06 - select LV_TOUCH_DRIVER_PROTOCOL_I2C + select LV_I2C_TOUCH bool "FT6X06" config LV_TOUCH_CONTROLLER_STMPE610 select LV_TOUCH_DRIVER_PROTOCOL_SPI @@ -38,16 +38,16 @@ menu "LVGL Touch controller" select LV_TOUCH_DRIVER_DISPLAY bool "RA8875" config LV_TOUCH_CONTROLLER_GT911 - select LV_TOUCH_DRIVER_PROTOCOL_I2C + select LV_I2C_TOUCH bool "GT911" endchoice - + config LV_TOUCH_DRIVER_PROTOCOL_SPI bool help Touch controller protocol SPI - config LV_TOUCH_DRIVER_PROTOCOL_I2C + config LV_I2C_TOUCH bool help Touch controller protocol I2C @@ -62,30 +62,16 @@ menu "LVGL Touch controller" help Touch controller uses same interface/device as display (Note: Display must be initialized before touch) - - choice - prompt "Touch I2C port" - depends on LV_TOUCH_DRIVER_PROTOCOL_I2C - - default LV_TOUCH_I2C_PORT_0 - help - Select the I2C port used by the touch controller. - config LV_TOUCH_I2C_PORT_0 - bool "I2C PORT 0" - config LV_TOUCH_I2C_PORT_1 - bool "I2C PORT 1" - endchoice - choice prompt "Touch Controller SPI Bus." depends on LV_TOUCH_DRIVER_PROTOCOL_SPI - + default LV_TOUCH_CONTROLLER_SPI_VSPI if !IDF_TARGET_ESP32S2 default LV_TOUCH_CONTROLLER_SPI_FSPI if IDF_TARGET_ESP32S2 help Select the SPI Bus the TFT Display is attached to. - + config LV_TOUCH_CONTROLLER_SPI_HSPI bool "HSPI" config LV_TOUCH_CONTROLLER_SPI_VSPI @@ -93,7 +79,7 @@ menu "LVGL Touch controller" config LV_TOUCH_CONTROLLER_SPI_FSPI bool "FSPI" if IDF_TARGET_ESP32S2 endchoice - + menu "Touchpanel (XPT2046) Pin Assignments" depends on LV_TOUCH_CONTROLLER_XPT2046 @@ -101,7 +87,7 @@ menu "LVGL Touch controller" int prompt "GPIO for MISO (Master In Slave Out)" range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 35 if LV_PREDEFINED_PINS_38V1 @@ -113,7 +99,7 @@ menu "LVGL Touch controller" int prompt "GPIO for MOSI (Master Out Slave In)" range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 32 if LV_PREDEFINED_PINS_38V1 @@ -124,7 +110,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CLK int "GPIO for CLK (SCK / Serial Clock)" range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 26 if LV_PREDEFINED_PINS_38V1 @@ -135,8 +121,8 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CS int "GPIO for CS (Slave Select)" range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 - + range 0 46 if IDF_TARGET_ESP32S2 + default 33 if LV_PREDEFINED_PINS_38V1 default 5 help @@ -145,7 +131,7 @@ menu "LVGL Touch controller" config LV_TOUCH_PIN_IRQ int "GPIO for IRQ (Interrupt Request)" range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 27 if LV_PREDEFINED_PINS_38V4 @@ -153,7 +139,7 @@ menu "LVGL Touch controller" help Configure the touchpanel IRQ pin here. endmenu - + menu "Touchpanel Configuration (XPT2046)" depends on LV_TOUCH_CONTROLLER_XPT2046 @@ -180,7 +166,7 @@ menu "LVGL Touch controller" prompt "Maximum Y coordinate value." default 4095 if LV_PREDEFINED_PINS_38V4 default 1900 - + config LV_TOUCH_XY_SWAP bool prompt "Swap XY." @@ -211,31 +197,6 @@ menu "LVGL Touch controller" endchoice endmenu - menu "Touchpanel (FT6X06) Pin Assignments" - depends on LV_TOUCH_CONTROLLER_FT6X06 - - config LV_TOUCH_I2C_SDA - int - prompt "GPIO for SDA (I2C)" - range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - - default 21 - help - Configure the I2C touchpanel SDA pin here. - - config LV_TOUCH_I2C_SCL - int "GPIO for clock signal SCL (I2C)" - range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - - default 22 - help - Configure the I2C touchpanel SCL pin here. - endmenu - menu "Touchpanel Configuration (FT6X06)" depends on LV_TOUCH_CONTROLLER_FT6X06 @@ -249,13 +210,13 @@ menu "LVGL Touch controller" prompt "Invert X coordinate value." default n - config LV_FT6X36_INVERT_Y - bool - prompt "Invert Y coordinate value." - default n + config LV_FT6X36_INVERT_Y + bool + prompt "Invert Y coordinate value." + default n endmenu - + menu "Touchpanel (STMPE610) Pin Assignments" depends on LV_TOUCH_CONTROLLER_STMPE610 @@ -263,7 +224,7 @@ menu "LVGL Touch controller" int prompt "GPIO for MISO (Master In Slave Out)" range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 35 if LV_PREDEFINED_PINS_38V1 @@ -278,7 +239,7 @@ menu "LVGL Touch controller" int prompt "GPIO for MOSI (Master Out Slave In)" range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 32 if LV_PREDEFINED_PINS_38V1 @@ -291,7 +252,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CLK int "GPIO for CLK (SCK / Serial Clock)" range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 26 if LV_PREDEFINED_PINS_38V1 @@ -303,7 +264,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CS int "GPIO for CS (Slave Select)" range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 + range 0 46 if IDF_TARGET_ESP32S2 range 0 21 if IDF_TARGET_ESP32C3 default 33 if LV_PREDEFINED_PINS_38V1 @@ -335,7 +296,7 @@ menu "LVGL Touch controller" int prompt "Maximum Y coordinate value." default 3800 - + config LV_TOUCH_XY_SWAP bool prompt "Swap XY." @@ -351,7 +312,7 @@ menu "LVGL Touch controller" prompt "Invert Y coordinate value." default y endmenu - + menu "Touchpanel (ADCRAW) Pin Assignments" depends on LV_TOUCH_CONTROLLER_ADCRAW @@ -372,7 +333,7 @@ menu "LVGL Touch controller" help Configure the touchpanel Y- pin. Must be ADC input. - + config LV_TOUCHSCREEN_RESISTIVE_PIN_XL int prompt "GPIO X-" @@ -502,31 +463,6 @@ menu "LVGL Touch controller" default y endmenu - - menu "Touchpanel (GT911) Pin Assignments" - depends on LV_TOUCH_CONTROLLER_GT911 - - config LV_TOUCH_I2C_SDA - int - prompt "GPIO for SDA (I2C)" - range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - - default 2 - help - Configure the I2C touchpanel SDA pin here. - - config LV_TOUCH_I2C_SCL - int "GPIO for clock signal SCL (I2C)" - range 0 39 if IDF_TARGET_ESP32 - range 0 43 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - - default 3 - help - Configure the I2C touchpanel SCL pin here. - endmenu menu "Touchpanel Configuration (GT911)" depends on LV_TOUCH_CONTROLLER_GT911 @@ -548,4 +484,31 @@ menu "LVGL Touch controller" endmenu + choice + prompt "Select an I2C port for the touch panel" + default LV_I2C_TOUCH_PORT_0 + depends on LV_I2C_TOUCH + + config LV_I2C_TOUCH_PORT_0 + bool + prompt "I2C port 0" + + config LV_I2C_TOUCH_PORT_1 + bool + prompt "I2C port 1" + + endchoice + + config LV_I2C + bool + default y if LV_I2C_TOUCH + + config LV_I2C_TOUCH_PORT + int + default 1 if LV_I2C_TOUCH_PORT_1 + default 0 + endmenu + + + diff --git a/lvgl_touch/ft6x36.c b/lvgl_touch/ft6x36.c index a4d74ef1..c7c2f9e9 100644 --- a/lvgl_touch/ft6x36.c +++ b/lvgl_touch/ft6x36.c @@ -1,33 +1,32 @@ /* * Copyright © 2020 Wolfgang Christl -* Permission is hereby granted, free of charge, to any person obtaining a copy of this -* software and associated documentation files (the “Software”), to deal in the Software -* without restriction, including without limitation the rights to use, copy, modify, merge, -* publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons +* Permission is hereby granted, free of charge, to any person obtaining a copy of this +* software and associated documentation files (the “Software”), to deal in the Software +* without restriction, including without limitation the rights to use, copy, modify, merge, +* publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons * to whom the Software is furnished to do so, subject to the following conditions: * -* The above copyright notice and this permission notice shall be included in all copies or +* The above copyright notice and this permission notice shall be included in all copies or * substantial portions of the Software. -* -* THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, -* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR -* PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE -* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, -* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +* +* THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, +* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR +* PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE +* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, +* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ #include -#include #ifdef LV_LVGL_H_INCLUDE_SIMPLE #include #else #include #endif #include "ft6x36.h" -#include "tp_i2c.h" -#include "../lvgl_i2c_conf.h" + +#include "i2c_manager/i2c_manager.h" #define TAG "FT6X36" @@ -36,22 +35,10 @@ ft6x36_status_t ft6x36_status; uint8_t current_dev_addr; // set during init esp_err_t ft6x06_i2c_read8(uint8_t slave_addr, uint8_t register_addr, uint8_t *data_buf) { - i2c_cmd_handle_t i2c_cmd = i2c_cmd_link_create(); - - i2c_master_start(i2c_cmd); - i2c_master_write_byte(i2c_cmd, (slave_addr << 1) | I2C_MASTER_WRITE, true); - i2c_master_write_byte(i2c_cmd, register_addr, I2C_MASTER_ACK); - - i2c_master_start(i2c_cmd); - i2c_master_write_byte(i2c_cmd, (slave_addr << 1) | I2C_MASTER_READ, true); - - i2c_master_read_byte(i2c_cmd, data_buf, I2C_MASTER_NACK); - i2c_master_stop(i2c_cmd); - esp_err_t ret = i2c_master_cmd_begin(TOUCH_I2C_PORT, i2c_cmd, 1000 / portTICK_RATE_MS); - i2c_cmd_link_delete(i2c_cmd); - return ret; + return lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, slave_addr, register_addr, data_buf, 1); } + /** * @brief Read the FT6x36 gesture ID. Initialize first! * @param dev_addr: I2C FT6x36 Slave address. @@ -75,42 +62,29 @@ uint8_t ft6x36_get_gesture_id() { * @retval None */ void ft6x06_init(uint16_t dev_addr) { - if (!ft6x36_status.inited) { -/* I2C master is initialized before calling this function */ -#if 0 - esp_err_t code = i2c_master_init(); -#else - esp_err_t code = ESP_OK; -#endif + ft6x36_status.inited = true; + current_dev_addr = dev_addr; + uint8_t data_buf; + esp_err_t ret; + ESP_LOGI(TAG, "Found touch panel controller"); + if ((ret = ft6x06_i2c_read8(dev_addr, FT6X36_PANEL_ID_REG, &data_buf) != ESP_OK)) + ESP_LOGE(TAG, "Error reading from device: %s", + esp_err_to_name(ret)); // Only show error the first time + ESP_LOGI(TAG, "\tDevice ID: 0x%02x", data_buf); + + ft6x06_i2c_read8(dev_addr, FT6X36_CHIPSELECT_REG, &data_buf); + ESP_LOGI(TAG, "\tChip ID: 0x%02x", data_buf); + + ft6x06_i2c_read8(dev_addr, FT6X36_DEV_MODE_REG, &data_buf); + ESP_LOGI(TAG, "\tDevice mode: 0x%02x", data_buf); + + ft6x06_i2c_read8(dev_addr, FT6X36_FIRMWARE_ID_REG, &data_buf); + ESP_LOGI(TAG, "\tFirmware ID: 0x%02x", data_buf); + + ft6x06_i2c_read8(dev_addr, FT6X36_RELEASECODE_REG, &data_buf); + ESP_LOGI(TAG, "\tRelease code: 0x%02x", data_buf); - if (code != ESP_OK) { - ft6x36_status.inited = false; - ESP_LOGE(TAG, "Error during I2C init %s", esp_err_to_name(code)); - } else { - ft6x36_status.inited = true; - current_dev_addr = dev_addr; - uint8_t data_buf; - esp_err_t ret; - ESP_LOGI(TAG, "Found touch panel controller"); - if ((ret = ft6x06_i2c_read8(dev_addr, FT6X36_PANEL_ID_REG, &data_buf) != ESP_OK)) - ESP_LOGE(TAG, "Error reading from device: %s", - esp_err_to_name(ret)); // Only show error the first time - ESP_LOGI(TAG, "\tDevice ID: 0x%02x", data_buf); - - ft6x06_i2c_read8(dev_addr, FT6X36_CHIPSELECT_REG, &data_buf); - ESP_LOGI(TAG, "\tChip ID: 0x%02x", data_buf); - - ft6x06_i2c_read8(dev_addr, FT6X36_DEV_MODE_REG, &data_buf); - ESP_LOGI(TAG, "\tDevice mode: 0x%02x", data_buf); - - ft6x06_i2c_read8(dev_addr, FT6X36_FIRMWARE_ID_REG, &data_buf); - ESP_LOGI(TAG, "\tFirmware ID: 0x%02x", data_buf); - - ft6x06_i2c_read8(dev_addr, FT6X36_RELEASECODE_REG, &data_buf); - ESP_LOGI(TAG, "\tRelease code: 0x%02x", data_buf); - } - } } /** @@ -120,67 +94,29 @@ void ft6x06_init(uint16_t dev_addr) { * @retval Always false */ bool ft6x36_read(lv_indev_drv_t *drv, lv_indev_data_t *data) { - uint8_t data_xy[4]; // 2 bytes X | 2 bytes Y - uint8_t touch_pnt_cnt; // Number of detected touch points + if (!ft6x36_status.inited) { + ESP_LOGE(TAG, "Init first!"); + return 0x00; + } + uint8_t data_buf[5]; // 1 byte status, 2 bytes X, 2 bytes Y static int16_t last_x = 0; // 12bit pixel value static int16_t last_y = 0; // 12bit pixel value - ft6x06_i2c_read8(current_dev_addr, FT6X36_TD_STAT_REG, &touch_pnt_cnt); - if (touch_pnt_cnt != 1) { // ignore no touch & multi touch - data->point.x = last_x; - data->point.y = last_y; - data->state = LV_INDEV_STATE_REL; - return false; - } - - // Read X value - i2c_cmd_handle_t i2c_cmd = i2c_cmd_link_create(); - - i2c_master_start(i2c_cmd); - i2c_master_write_byte(i2c_cmd, (current_dev_addr << 1) | I2C_MASTER_WRITE, true); - i2c_master_write_byte(i2c_cmd, FT6X36_P1_XH_REG, I2C_MASTER_ACK); - - i2c_master_start(i2c_cmd); - i2c_master_write_byte(i2c_cmd, (current_dev_addr << 1) | I2C_MASTER_READ, true); - - i2c_master_read_byte(i2c_cmd, &data_xy[0], I2C_MASTER_ACK); // reads FT6X36_P1_XH_REG - i2c_master_read_byte(i2c_cmd, &data_xy[1], I2C_MASTER_NACK); // reads FT6X36_P1_XL_REG - i2c_master_stop(i2c_cmd); - esp_err_t ret = i2c_master_cmd_begin(TOUCH_I2C_PORT, i2c_cmd, 1000 / portTICK_RATE_MS); - i2c_cmd_link_delete(i2c_cmd); + esp_err_t ret = lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, current_dev_addr, FT6X36_TD_STAT_REG, &data_buf[0], 5); if (ret != ESP_OK) { - ESP_LOGE(TAG, "Error getting X coordinates: %s", esp_err_to_name(ret)); - data->point.x = last_x; - data->point.y = last_y; - data->state = LV_INDEV_STATE_REL; // no touch detected - return false; + ESP_LOGE(TAG, "Error talking to touch IC: %s", esp_err_to_name(ret)); } + uint8_t touch_pnt_cnt = data_buf[0]; // Number of detected touch points - // Read Y value - i2c_cmd = i2c_cmd_link_create(); - - i2c_master_start(i2c_cmd); - i2c_master_write_byte(i2c_cmd, (current_dev_addr << 1) | I2C_MASTER_WRITE, true); - i2c_master_write_byte(i2c_cmd, FT6X36_P1_YH_REG, I2C_MASTER_ACK); - - i2c_master_start(i2c_cmd); - i2c_master_write_byte(i2c_cmd, (current_dev_addr << 1) | I2C_MASTER_READ, true); - - i2c_master_read_byte(i2c_cmd, &data_xy[2], I2C_MASTER_ACK); // reads FT6X36_P1_YH_REG - i2c_master_read_byte(i2c_cmd, &data_xy[3], I2C_MASTER_NACK); // reads FT6X36_P1_YL_REG - i2c_master_stop(i2c_cmd); - ret = i2c_master_cmd_begin(TOUCH_I2C_PORT, i2c_cmd, 1000 / portTICK_RATE_MS); - i2c_cmd_link_delete(i2c_cmd); - if (ret != ESP_OK) { - ESP_LOGE(TAG, "Error getting Y coordinates: %s", esp_err_to_name(ret)); + if (ret != ESP_OK || touch_pnt_cnt != 1) { // ignore no touch & multi touch data->point.x = last_x; data->point.y = last_y; - data->state = LV_INDEV_STATE_REL; // no touch detected + data->state = LV_INDEV_STATE_REL; return false; } - last_x = ((data_xy[0] & FT6X36_MSB_MASK) << 8) | (data_xy[1] & FT6X36_LSB_MASK); - last_y = ((data_xy[2] & FT6X36_MSB_MASK) << 8) | (data_xy[3] & FT6X36_LSB_MASK); + last_x = ((data_buf[1] & FT6X36_MSB_MASK) << 8) | (data_buf[2] & FT6X36_LSB_MASK); + last_y = ((data_buf[3] & FT6X36_MSB_MASK) << 8) | (data_buf[4] & FT6X36_LSB_MASK); #if CONFIG_LV_FT6X36_INVERT_X last_x = LV_HOR_RES - last_x; diff --git a/lvgl_touch/ft6x36.h b/lvgl_touch/ft6x36.h index da466b6c..ace2997d 100644 --- a/lvgl_touch/ft6x36.h +++ b/lvgl_touch/ft6x36.h @@ -2,20 +2,20 @@ /* * Copyright © 2020 Wolfgang Christl -* Permission is hereby granted, free of charge, to any person obtaining a copy of this -* software and associated documentation files (the “Software”), to deal in the Software -* without restriction, including without limitation the rights to use, copy, modify, merge, -* publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons +* Permission is hereby granted, free of charge, to any person obtaining a copy of this +* software and associated documentation files (the “Software”), to deal in the Software +* without restriction, including without limitation the rights to use, copy, modify, merge, +* publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons * to whom the Software is furnished to do so, subject to the following conditions: * -* The above copyright notice and this permission notice shall be included in all copies or +* The above copyright notice and this permission notice shall be included in all copies or * substantial portions of the Software. -* -* THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, -* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR -* PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE -* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, -* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +* +* THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, +* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR +* PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE +* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, +* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ diff --git a/lvgl_touch/gt911.c b/lvgl_touch/gt911.c index e6cb9724..99745716 100644 --- a/lvgl_touch/gt911.c +++ b/lvgl_touch/gt911.c @@ -19,15 +19,14 @@ */ #include -#include #ifdef LV_LVGL_H_INCLUDE_SIMPLE #include #else #include #endif #include "gt911.h" -#include "tp_i2c.h" -#include "../lvgl_i2c_conf.h" + +#include "i2c_manager/i2c_manager.h" #define TAG "GT911" @@ -35,35 +34,12 @@ gt911_status_t gt911_status; //TODO: handle multibyte read and refactor to just one read transaction esp_err_t gt911_i2c_read(uint8_t slave_addr, uint16_t register_addr, uint8_t *data_buf, uint8_t len) { - i2c_cmd_handle_t i2c_cmd = i2c_cmd_link_create(); - - i2c_master_start(i2c_cmd); - i2c_master_write_byte(i2c_cmd, (slave_addr << 1) | I2C_MASTER_WRITE, true); - i2c_master_write_byte(i2c_cmd, (register_addr >> 8), I2C_MASTER_ACK); - i2c_master_write_byte(i2c_cmd, (register_addr & 0xFF), I2C_MASTER_ACK); - - i2c_master_start(i2c_cmd); - i2c_master_write_byte(i2c_cmd, (slave_addr << 1) | I2C_MASTER_READ, true); - - i2c_master_read_byte(i2c_cmd, data_buf, I2C_MASTER_NACK); - i2c_master_stop(i2c_cmd); - esp_err_t ret = i2c_master_cmd_begin(TOUCH_I2C_PORT, i2c_cmd, 1000 / portTICK_RATE_MS); - i2c_cmd_link_delete(i2c_cmd); - return ret; + return lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, slave_addr, register_addr | I2C_REG_16, data_buf, len); } esp_err_t gt911_i2c_write8(uint8_t slave_addr, uint16_t register_addr, uint8_t data) { - i2c_cmd_handle_t i2c_cmd = i2c_cmd_link_create(); - - i2c_master_start(i2c_cmd); - i2c_master_write_byte(i2c_cmd, (slave_addr << 1) | I2C_MASTER_WRITE, true); - i2c_master_write_byte(i2c_cmd, (register_addr >> 8), I2C_MASTER_ACK); - i2c_master_write_byte(i2c_cmd, (register_addr & 0xFF), I2C_MASTER_ACK); - i2c_master_write_byte(i2c_cmd, data, I2C_MASTER_ACK); - i2c_master_stop(i2c_cmd); - esp_err_t ret = i2c_master_cmd_begin(TOUCH_I2C_PORT, i2c_cmd, 1000 / portTICK_RATE_MS); - i2c_cmd_link_delete(i2c_cmd); - return ret; + uint8_t buffer = data; + return lvgl_i2c_write(CONFIG_LV_I2C_TOUCH_PORT, slave_addr, register_addr | I2C_REG_16, &buffer, 1); } /** diff --git a/lvgl_touch/touch_driver.c b/lvgl_touch/touch_driver.c index 12125438..35fcc6b8 100644 --- a/lvgl_touch/touch_driver.c +++ b/lvgl_touch/touch_driver.c @@ -4,7 +4,6 @@ #include "touch_driver.h" #include "tp_spi.h" -#include "tp_i2c.h" void touch_driver_init(void) diff --git a/lvgl_touch/tp_i2c.c b/lvgl_touch/tp_i2c.c deleted file mode 100644 index dc3371c3..00000000 --- a/lvgl_touch/tp_i2c.c +++ /dev/null @@ -1,43 +0,0 @@ -/* -* Copyright © 2020 Wolfgang Christl - -* Permission is hereby granted, free of charge, to any person obtaining a copy of this -* software and associated documentation files (the “Software”), to deal in the Software -* without restriction, including without limitation the rights to use, copy, modify, merge, -* publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons -* to whom the Software is furnished to do so, subject to the following conditions: -* -* The above copyright notice and this permission notice shall be included in all copies or -* substantial portions of the Software. -* -* THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, -* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR -* PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE -* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, -* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -* SOFTWARE. -*/ - -#include -#include - -#define I2C_MASTER_FREQ_HZ 100000 /* 100kHz*/ -#define I2C_MASTER_TX_BUF_DISABLE 0 /* I2C master doesn't need buffer */ -#define I2C_MASTER_RX_BUF_DISABLE 0 /* I2C master doesn't need buffer */ - -/** - * @brief ESP32 I2C init as master - * @ret ESP32 error code - */ -esp_err_t i2c_master_init(void) { - int i2c_master_port = I2C_NUM_0; - i2c_config_t conf; - conf.mode = I2C_MODE_MASTER; - conf.sda_io_num = CONFIG_LV_TOUCH_I2C_SDA; - conf.sda_pullup_en = GPIO_PULLUP_ENABLE; - conf.scl_io_num = CONFIG_LV_TOUCH_I2C_SCL; - conf.scl_pullup_en = GPIO_PULLUP_ENABLE; - conf.master.clk_speed = I2C_MASTER_FREQ_HZ; - i2c_param_config(i2c_master_port, &conf); - return i2c_driver_install(i2c_master_port, conf.mode, I2C_MASTER_RX_BUF_DISABLE, I2C_MASTER_TX_BUF_DISABLE, 0); -} diff --git a/lvgl_touch/tp_i2c.h b/lvgl_touch/tp_i2c.h deleted file mode 100644 index 5c1eb55f..00000000 --- a/lvgl_touch/tp_i2c.h +++ /dev/null @@ -1,36 +0,0 @@ -/* -* Copyright © 2020 Wolfgang Christl - -* Permission is hereby granted, free of charge, to any person obtaining a copy of this -* software and associated documentation files (the “Software”), to deal in the Software -* without restriction, including without limitation the rights to use, copy, modify, merge, -* publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons -* to whom the Software is furnished to do so, subject to the following conditions: -* -* The above copyright notice and this permission notice shall be included in all copies or -* substantial portions of the Software. -* -* THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, -* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR -* PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE -* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, -* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -* SOFTWARE. -*/ - -#ifndef __TS_H -#define __TS_H - -#ifdef __cplusplus -extern "C" { -#endif - -#include - -esp_err_t i2c_master_init(void); - -#ifdef __cplusplus -} -#endif - -#endif /* __TS_H */ From 8f661270be9f01666c0ee8400e8a8e0e675f972a Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Thu, 8 Jul 2021 18:08:29 +0200 Subject: [PATCH 30/70] Make it work with v7 and v8 Makes the change from #83 dependent on major version number so things work with v7 and v8. --- lvgl_tft/disp_spi.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/lvgl_tft/disp_spi.c b/lvgl_tft/disp_spi.c index 00e91a6d..9b708066 100644 --- a/lvgl_tft/disp_spi.c +++ b/lvgl_tft/disp_spi.c @@ -310,7 +310,12 @@ static void IRAM_ATTR spi_ready(spi_transaction_t *trans) disp = lv_refr_get_disp_refreshing(); #endif +#if LVGL_VERSION_MAJOR < 8 + lv_disp_flush_ready(&disp->driver); +#else lv_disp_flush_ready(disp->driver); +#endif + } if (chained_post_cb) { From 048438738c7e74e40ec90d210e9b249ad6e1b1d8 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Mon, 12 Jul 2021 10:18:20 +0200 Subject: [PATCH 31/70] Things noted by @tore-espressif See https://github.com/lvgl/lvgl_esp32_drivers/pull/70#pullrequestreview-703588587 --- i2c_manager/Kconfig | 14 -------------- i2c_manager/i2c_manager.c | 8 ++++---- lvgl_tft/ssd1306.c | 25 ++----------------------- 3 files changed, 6 insertions(+), 41 deletions(-) diff --git a/i2c_manager/Kconfig b/i2c_manager/Kconfig index 0c11ab13..72cbec2f 100644 --- a/i2c_manager/Kconfig +++ b/i2c_manager/Kconfig @@ -9,14 +9,8 @@ menu "I2C Port Settings" if I2C_MANAGER_0_ENABLED config I2C_MANAGER_0_SDA int "SDA (GPIO pin)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 config I2C_MANAGER_0_SCL int "SCL (GPIO pin)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 config I2C_MANAGER_0_FREQ_HZ int "Frequency (Hz)" default 400000 @@ -64,16 +58,8 @@ menu "I2C Port Settings" if I2C_MANAGER_1_ENABLED config I2C_MANAGER_1_SDA int "SDA (GPIO pin)" - default 32 - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 config I2C_MANAGER_1_SCL int "SCL (GPIO pin)" - default 33 - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 config I2C_MANAGER_1_FREQ_HZ int "Frequency (Hz)" default 1000000 diff --git a/i2c_manager/i2c_manager.c b/i2c_manager/i2c_manager.c index d301aff8..095143da 100644 --- a/i2c_manager/i2c_manager.c +++ b/i2c_manager/i2c_manager.c @@ -66,8 +66,8 @@ static const uint8_t ACK_CHECK_EN = 1; #define I2C_MANAGER_0_PULLUPS false #endif - #define I2C_MANAGER_0_TIMEOUT CONFIG_I2C_MANAGER_0_TIMEOUT / portTICK_RATE_MS - #define I2C_MANAGER_0_LOCK_TIMEOUT CONFIG_I2C_MANAGER_0_LOCK_TIMEOUT / portTICK_RATE_MS + #define I2C_MANAGER_0_TIMEOUT ( CONFIG_I2C_MANAGER_0_TIMEOUT / portTICK_RATE_MS ) + #define I2C_MANAGER_0_LOCK_TIMEOUT ( CONFIG_I2C_MANAGER_0_LOCK_TIMEOUT / portTICK_RATE_MS ) #endif @@ -79,8 +79,8 @@ static const uint8_t ACK_CHECK_EN = 1; #define I2C_MANAGER_1_PULLUPS false #endif - #define I2C_MANAGER_1_TIMEOUT CONFIG_I2C_MANAGER_1_TIMEOUT / portTICK_RATE_MS - #define I2C_MANAGER_1_LOCK_TIMEOUT CONFIG_I2C_MANAGER_1_LOCK_TIMEOUT / portTICK_RATE_MS + #define I2C_MANAGER_1_TIMEOUT ( CONFIG_I2C_MANAGER_1_TIMEOUT / portTICK_RATE_MS ) + #define I2C_MANAGER_1_LOCK_TIMEOUT ( CONFIG_I2C_MANAGER_1_LOCK_TIMEOUT / portTICK_RATE_MS ) #endif #define ERROR_PORT(port, fail) { \ diff --git a/lvgl_tft/ssd1306.c b/lvgl_tft/ssd1306.c index 459cd001..811f1645 100644 --- a/lvgl_tft/ssd1306.c +++ b/lvgl_tft/ssd1306.c @@ -211,36 +211,15 @@ void ssd1306_sleep_out(void) static uint8_t send_data(lv_disp_drv_t *disp_drv, void *bytes, size_t bytes_len) { (void) disp_drv; - esp_err_t err; uint8_t *data = (uint8_t *) bytes; - err = lvgl_i2c_write(OLED_I2C_PORT, OLED_I2C_ADDRESS, data[0], data + 1, bytes_len - 1 ); - -// i2c_cmd_handle_t cmd = i2c_cmd_link_create(); -// -// i2c_master_start(cmd); -// i2c_master_write_byte(cmd, (OLED_I2C_ADDRESS << 1) | I2C_MASTER_WRITE, true); -// -// for (size_t idx = 0; idx < bytes_len; idx++) { -// i2c_master_write_byte(cmd, data[idx], true); -// } -// -// i2c_master_stop(cmd); -// -// /* Send queued commands */ -// err = i2c_master_cmd_begin(DISP_I2C_PORT, cmd, 10 / portTICK_PERIOD_MS); -// i2c_cmd_link_delete(cmd); - - return ESP_OK == err ? 0 : 1; + return lvgl_i2c_write(OLED_I2C_PORT, OLED_I2C_ADDRESS, data[0], data + 1, bytes_len - 1 ); } static uint8_t send_pixels(lv_disp_drv_t *disp_drv, void *color_buffer, size_t buffer_len) { (void) disp_drv; - esp_err_t err; - err = lvgl_i2c_write(OLED_I2C_PORT, OLED_I2C_ADDRESS, OLED_CONTROL_BYTE_DATA_STREAM, color_buffer, buffer_len); - - return ESP_OK == err ? 0 : 1; + return lvgl_i2c_write(OLED_I2C_PORT, OLED_I2C_ADDRESS, OLED_CONTROL_BYTE_DATA_STREAM, color_buffer, buffer_len); } From ef76fd1056bcc4a25b1f0e7d7b757d0725ba5b51 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Mon, 12 Jul 2021 10:24:11 +0200 Subject: [PATCH 32/70] I2C Manager Kconfig now generic --- Kconfig | 7 +- i2c_manager/Kconfig | 186 +++++++++++++++++++++----------------------- 2 files changed, 96 insertions(+), 97 deletions(-) diff --git a/Kconfig b/Kconfig index 42c3c660..370ad6ee 100644 --- a/Kconfig +++ b/Kconfig @@ -4,6 +4,11 @@ menu "LVGL ESP Drivers" rsource "lvgl_touch/Kconfig" - rsource "i2c_manager/Kconfig" + menu "I2C Port Settings" + depends on LV_I2C && !HAVE_I2C_MANAGER + + rsource "i2c_manager/Kconfig" + + endmenu endmenu diff --git a/i2c_manager/Kconfig b/i2c_manager/Kconfig index 72cbec2f..4011bcf5 100644 --- a/i2c_manager/Kconfig +++ b/i2c_manager/Kconfig @@ -1,102 +1,96 @@ -menu "I2C Port Settings" - depends on LV_I2C && !HAVE_I2C_MANAGER +menu "I2C Port 0" - menu "I2C Port 0" + config I2C_MANAGER_0_ENABLED + bool "Enable I2C port 0" + + if I2C_MANAGER_0_ENABLED + config I2C_MANAGER_0_SDA + int "SDA (GPIO pin)" + config I2C_MANAGER_0_SCL + int "SCL (GPIO pin)" + config I2C_MANAGER_0_FREQ_HZ + int "Frequency (Hz)" + default 400000 + range 100000 5000000 + help + The clock speed in Hz. Ranges from 100000 (100 kHz) to + 5000000 (5 Mhz). I2C busses that involve external wires may + have to be slower, and the real maximum speed the bus will + support depends on the value of the pullup resistors and the + design of the overall circuit. + config I2C_MANAGER_0_TIMEOUT + int "R/W timeout (ms)" + default 20 + range 10 1000 + help + Timeout for I2C read and write operations. This does not + include the time waiting for a lock. + config I2C_MANAGER_0_LOCK_TIMEOUT + int "Stale lock override (ms)" + default 50 + range 10 1000 + help + Timeout at which point an operation waiting for its turn on + the port will assume that whatever set the lock has died and + overrides it. Set this somewhat larger than the previous + timeout. + config I2C_MANAGER_0_PULLUPS + bool "Use ESP32 built-in bus pull-up resistors" + help + The I2C bus needs resistors to make sure it's in a defined + state when nobody is talking. Many circuits have external + pullup resistors already and turning these on will increase + power consumption slightly and may limit the speed your bus + can attain. Try with these off first if you don't know. + endif - config I2C_MANAGER_0_ENABLED - bool "Enable I2C port 0" - - if I2C_MANAGER_0_ENABLED - config I2C_MANAGER_0_SDA - int "SDA (GPIO pin)" - config I2C_MANAGER_0_SCL - int "SCL (GPIO pin)" - config I2C_MANAGER_0_FREQ_HZ - int "Frequency (Hz)" - default 400000 - range 100000 5000000 - help - The clock speed in Hz. Ranges from 100000 (100 kHz) to - 5000000 (5 Mhz). I2C busses that involve external wires may - have to be slower, and the real maximum speed the bus will - support depends on the value of the pullup resistors and the - design of the overall circuit. - config I2C_MANAGER_0_TIMEOUT - int "R/W timeout (ms)" - default 20 - range 10 1000 - help - Timeout for I2C read and write operations. This does not - include the time waiting for a lock. - config I2C_MANAGER_0_LOCK_TIMEOUT - int "Stale lock override (ms)" - default 50 - range 10 1000 - help - Timeout at which point an operation waiting for its turn on - the port will assume that whatever set the lock has died and - overrides it. Set this somewhat larger than the previous - timeout. - config I2C_MANAGER_0_PULLUPS - bool "Use ESP32 built-in bus pull-up resistors" - help - The I2C bus needs resistors to make sure it's in a defined - state when nobody is talking. Many circuits have external - pullup resistors already and turning these on will increase - power consumption slightly and may limit the speed your bus - can attain. Try with these off first if you don't know. - endif - - endmenu - - - menu "I2C Port 1" - - config I2C_MANAGER_1_ENABLED - bool "Enable I2C port 1" +endmenu - if I2C_MANAGER_1_ENABLED - config I2C_MANAGER_1_SDA - int "SDA (GPIO pin)" - config I2C_MANAGER_1_SCL - int "SCL (GPIO pin)" - config I2C_MANAGER_1_FREQ_HZ - int "Frequency (Hz)" - default 1000000 - range 100000 5000000 - help - The clock speed in Hz. Ranges from 100000 (100 kHz) to - 5000000 (5 Mhz). I2C busses that involve external wires may - have to be slower, and the real maximum speed the bus will - support depends on the value of the pullup resistors and the - design of the overall circuit. - config I2C_MANAGER_1_TIMEOUT - int "R/W timeout (ms)" - default 20 - range 10 1000 - help - Timeout for I2C read and write operations. This does not - include the time waiting for a lock. Default should be fine. - config I2C_MANAGER_1_LOCK_TIMEOUT - int "Stale lock override (ms)" - default 50 - help - Timeout at which point an operation waiting for its turn on - the port will assume that whatever set the lock has died and - overrides it. Set this somewhat larger than the previous - timeout. Default should be fine. - range 30 1000 - config I2C_MANAGER_1_PULLUPS - bool "Use ESP32 built-in bus pull-up resistors" - help - The I2C bus needs resistors to make sure it's in a defined - state when nobody is talking. Many circuits have external - pullup resistors already and turning these on will increase - power consumption slightly and may limit the speed your bus - can attain. Try with these off first if you don't know. - endif - endmenu +menu "I2C Port 1" + + config I2C_MANAGER_1_ENABLED + bool "Enable I2C port 1" + + if I2C_MANAGER_1_ENABLED + config I2C_MANAGER_1_SDA + int "SDA (GPIO pin)" + config I2C_MANAGER_1_SCL + int "SCL (GPIO pin)" + config I2C_MANAGER_1_FREQ_HZ + int "Frequency (Hz)" + default 1000000 + range 100000 5000000 + help + The clock speed in Hz. Ranges from 100000 (100 kHz) to + 5000000 (5 Mhz). I2C busses that involve external wires may + have to be slower, and the real maximum speed the bus will + support depends on the value of the pullup resistors and the + design of the overall circuit. + config I2C_MANAGER_1_TIMEOUT + int "R/W timeout (ms)" + default 20 + range 10 1000 + help + Timeout for I2C read and write operations. This does not + include the time waiting for a lock. Default should be fine. + config I2C_MANAGER_1_LOCK_TIMEOUT + int "Stale lock override (ms)" + default 50 + help + Timeout at which point an operation waiting for its turn on + the port will assume that whatever set the lock has died and + overrides it. Set this somewhat larger than the previous + timeout. Default should be fine. + range 30 1000 + config I2C_MANAGER_1_PULLUPS + bool "Use ESP32 built-in bus pull-up resistors" + help + The I2C bus needs resistors to make sure it's in a defined + state when nobody is talking. Many circuits have external + pullup resistors already and turning these on will increase + power consumption slightly and may limit the speed your bus + can attain. Try with these off first if you don't know. + endif endmenu - From 6f2ce1307cf6ae5993675d432a6582d41af866a6 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Mon, 12 Jul 2021 10:24:24 +0200 Subject: [PATCH 33/70] Better LVGL I2C README --- i2c_manager/README.md | 57 ++++++++++++++++++++++++------------------- 1 file changed, 32 insertions(+), 25 deletions(-) diff --git a/i2c_manager/README.md b/i2c_manager/README.md index f9a368b4..12b9ca7f 100644 --- a/i2c_manager/README.md +++ b/i2c_manager/README.md @@ -1,16 +1,18 @@ # I2C in `lvgl_esp32_drivers` -  +  ## Information for users ### I2C Manager support -`lvgl_esp32_drivers` comes with built-in I2C support by integrating I2C Manager, which is used in case your touch interface or screen uses the I2C bus. The native I2C support offered by ESP-IDF is not thread-safe. Maybe you use LVGL with a touch sensor that has an i2c port, and maybe your device also has another i2c device that needs to be read frequently, such as a 3D-accelerometer. If you read that from another task than the lvgl uses to read the touch data, you need some kind of mechanism to keep these communications from interfering. +`lvgl_esp32_drivers` comes with built-in I2C support by integrating I2C Manager, which is used in case you select a touch sensor or screen that uses the I2C bus. If you're just using LVGL you don't need to do anyting special. + +I2C Manager can help if you are in a situation where you want to avoid "bus conflicts" on teh I2C bus. Suppose you use LVGL with a touch sensor that uses I2C, and your device also has another I2C device that needs to be read frequently, such as a 3D-accelerometer. ESP-IDF is not inherently "thread-safe". So if you read that from another task than the one LVGL uses to read the touch data, you need some kind of mechanism to keep these communications from interfering. -If you have other components that can use I2C Manager (or Mika Tuupola's I2C HAL abstraction that I2C Manager is compatible with) then put I2C Manager in your components directory by cloning the repository from below and in your main program do: +If you have (or write) a driver for that 3D-accelerometer that can use I2C Manager (or the I2C HAL and i2cdev abstraction layers that I2C Manager is compatible with) then put I2C Manager in your components directory by cloning the repository from below and in your main program do: ```c #include "i2c_manager.h" @@ -18,54 +20,59 @@ If you have other components that can use I2C Manager (or Mika Tuupola's I2C HAL [...] -lvgl_locking(i2c_manager_locking()); +lvgl_i2c_locking(i2c_manager_locking()); lv_init(); lvgl_driver_init(); ``` -The `lvgl_locking` part will cause the LVGL I2C driver to play nice with anything else that uses the I2C port(s) through I2C Manager. +The `lvgl_i2c_locking` part will cause the LVGL I2C driver to play nice with anything else that uses the I2C port(s) through I2C Manager. -See the [I2C Manager GitHub repository](https://github.com/ropg/i2c_manager) for much more information. +Refer to the [I2C Manager GitHub repository](https://github.com/ropg/i2c_manager) for much more information.   +## Information for LVGL driver developers -## Information for driver developers +I2C support in the LVGL ESP drivers is provided exclusively by the files in this directory. Code from all over the project that was talking to the I2C hardware directly has been replaced by code that communicates through the functions provided in `i2c_manager.h`. I2C is handled by the I2C Manager that was built into `lvlg_esp32_drivers`, but the code would be the same if it was routed through I2C Manager as a separate component. If you are providing a driver, you need not worry about any of this. -I2C support in the LVGL ESP drivers is provided exclusively by the files in this directory. Code from all over the project that was talking to the I2C hardware directly has been replaced by code that communicates through the functions provided in `lvgl_i2c.h`. I2C is handled by the I2C Manager that was built into lvlg_esp32_drivers, but the code would be the same if it was routed through I2C Manager as a separate component. If you are providing a driver, you need not worry about any of this. -### Using I2C in a driver, a multi-step guide +  -#### Step 1 -The Kconfig entries for your driver only need to specify that you will be using I2C. This is done by `select LV_I2C_DISPLAY` or `select LV_I2C_TOUCH`. +### Using I2C in an LVGL driver, a multi-step guide -#### Step 2 +Step 1 -To use the I2C port in your code you would do something like: +: The Kconfig entries for your driver only need to specify that you will be using I2C. This is done by adding `select LV_I2C_DISPLAY` or `select LV_I2C_TOUCH`. -```c -#include "i2c_manager/i2c_manager.h" +Step 2 -uint8_t data[2]; -lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, 0x23, 0x42, &data, 2); -``` +: To use the I2C port in your code you would do something like: -This causes a touch driver to read two bytes at register `0x42` from the IC at address `0x23`. Replace `CONFIG_LV_I2C_TOUCH_PORT` by `CONFIG_LV_I2C_DISPLAY_PORT` when this is a display instead of a touch driver. `lvgl_i2c_write` works much the same way, except writing the bytes from the buffer instead of reading them. + ```c + #include "i2c_manager/i2c_manager.h" -> The example above ignores it but these functions return `esp_err_t` so you can check if the i2c communication worked. + uint8_t data[2]; + lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, 0x23, 0x42, &data, 2); + ``` -#### Step 3 + This causes a touch driver to read two bytes at register `0x42` from the IC at address `0x23`. Replace `CONFIG_LV_I2C_TOUCH_PORT` by `CONFIG_LV_I2C_DISPLAY_PORT` when this is a display instead of a touch driver. `lvgl_i2c_write` works much the same way, except it writes the bytes from the buffer instead of reading them. _(It's ignored above but these functions return `esp_err_t` so you can check if the I2C communication worked.)_ -There is no step 3, you are already done. +Step 3 -### Behind the scenes +: There is no step 3, you are already done. -If anything in `lvgl_esp32_drivers` uses I2C, the config system will pop up an extra menu. This will allow you to select an I2C port for screen and one for the touch driver, if applicable. An extra menu allows you to set the GPIO pins and bus speed of any port you have selected for use. It's perfectly fine for a display and a touch driver to use the same I2C port or different ones. + +### Meanwhile, behind the scenes ... + +If any of the drivers selected by the user uses I2C, the menuconfig system will show an extra menu to select I2C port(s) for screen and/or touch sensor. An additional menu allows for setting of GPIO pins and bus speed of any port selected for use with LVGL. It's perfectly fine for a display and a touch sensor to be on the same I2C port or different ones. + + +  ## More information -If you need more documentation, please refer to the [I2C Manager GitHub repository](https://github.com/ropg/i2c_manager) for more detailed information on how I2C manager works. +If you need more documentation, please refer to the [I2C Manager GitHub repository](https://github.com/ropg/i2c_manager) for more detailed information on how I2C manager works. There are features not in the simple example above, such as reads and writes without specifying a register, 16-bit registers, 10-bit I2C addressing and more. From 5739934d1437b23018c4a8593ab3d2938b65e3ce Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Mon, 12 Jul 2021 13:00:46 +0200 Subject: [PATCH 34/70] Fix README render on GitHub --- i2c_manager/README.md | 36 ++++++++++++++++++++++++------------ 1 file changed, 24 insertions(+), 12 deletions(-) diff --git a/i2c_manager/README.md b/i2c_manager/README.md index 12b9ca7f..00a70c8d 100644 --- a/i2c_manager/README.md +++ b/i2c_manager/README.md @@ -43,26 +43,38 @@ I2C support in the LVGL ESP drivers is provided exclusively by the files in this ### Using I2C in an LVGL driver, a multi-step guide -Step 1 +
-: The Kconfig entries for your driver only need to specify that you will be using I2C. This is done by adding `select LV_I2C_DISPLAY` or `select LV_I2C_TOUCH`. +
Step 1
-Step 2 +
+The Kconfig entries for your driver only need to specify that you will be using I2C. This is done by adding `select LV_I2C_DISPLAY` or `select LV_I2C_TOUCH`. +
-: To use the I2C port in your code you would do something like: - ```c - #include "i2c_manager/i2c_manager.h" +
Step 2
- uint8_t data[2]; - lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, 0x23, 0x42, &data, 2); - ``` +
+To use the I2C port in your code you would do something like: - This causes a touch driver to read two bytes at register `0x42` from the IC at address `0x23`. Replace `CONFIG_LV_I2C_TOUCH_PORT` by `CONFIG_LV_I2C_DISPLAY_PORT` when this is a display instead of a touch driver. `lvgl_i2c_write` works much the same way, except it writes the bytes from the buffer instead of reading them. _(It's ignored above but these functions return `esp_err_t` so you can check if the I2C communication worked.)_ + +```c +#include "i2c_manager/i2c_manager.h" + +uint8_t data[2]; +lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, 0x23, 0x42, &data, 2); +``` + +This causes a touch driver to read two bytes at register `0x42` from the IC at address `0x23`. Replace `CONFIG_LV_I2C_TOUCH_PORT` by `CONFIG_LV_I2C_DISPLAY_PORT` when this is a display instead of a touch driver. `lvgl_i2c_write` works much the same way, except it writes the bytes from the buffer instead of reading them. _(It's ignored above but these functions return `esp_err_t` so you can check if the I2C communication worked.)_ +
+ +
Step 3
-Step 3 +
+There is no step 3, you are already done. +
-: There is no step 3, you are already done. +
### Meanwhile, behind the scenes ... From f7b7c99cf053ac3c475f2aabca4367945528f02a Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Mon, 12 Jul 2021 18:28:25 +0200 Subject: [PATCH 35/70] timeout duplicate division removed --- i2c_manager/i2c_manager.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/i2c_manager/i2c_manager.c b/i2c_manager/i2c_manager.c index 095143da..080d81a7 100644 --- a/i2c_manager/i2c_manager.c +++ b/i2c_manager/i2c_manager.c @@ -191,12 +191,12 @@ esp_err_t I2C_FN(_read)(i2c_port_t port, uint16_t addr, uint32_t reg, uint8_t *b TickType_t timeout = 0; #if defined (I2C_ZERO) if (port == I2C_NUM_0) { - timeout = (CONFIG_I2C_MANAGER_0_TIMEOUT) / portTICK_RATE_MS; + timeout = I2C_MANAGER_0_TIMEOUT; } #endif #if defined (I2C_ONE) if (port == I2C_NUM_1) { - timeout = (CONFIG_I2C_MANAGER_1_TIMEOUT) / portTICK_RATE_MS; + timeout = I2C_MANAGER_1_TIMEOUT; } #endif From 2a34dec70ae971d71be436606101ac41dd07ac82 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Mon, 12 Jul 2021 18:28:32 +0200 Subject: [PATCH 36/70] typo --- i2c_manager/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/i2c_manager/README.md b/i2c_manager/README.md index 00a70c8d..a0501c02 100644 --- a/i2c_manager/README.md +++ b/i2c_manager/README.md @@ -10,7 +10,7 @@ `lvgl_esp32_drivers` comes with built-in I2C support by integrating I2C Manager, which is used in case you select a touch sensor or screen that uses the I2C bus. If you're just using LVGL you don't need to do anyting special. -I2C Manager can help if you are in a situation where you want to avoid "bus conflicts" on teh I2C bus. Suppose you use LVGL with a touch sensor that uses I2C, and your device also has another I2C device that needs to be read frequently, such as a 3D-accelerometer. ESP-IDF is not inherently "thread-safe". So if you read that from another task than the one LVGL uses to read the touch data, you need some kind of mechanism to keep these communications from interfering. +I2C Manager can help if you are in a situation where you want to avoid "bus conflicts" on the I2C bus. Suppose you use LVGL with a touch sensor that uses I2C, and your device also has another I2C device that needs to be read frequently, such as a 3D-accelerometer. ESP-IDF is not inherently "thread-safe". So if you read that from another task than the one LVGL uses to read the touch data, you need some kind of mechanism to keep these communications from interfering. If you have (or write) a driver for that 3D-accelerometer that can use I2C Manager (or the I2C HAL and i2cdev abstraction layers that I2C Manager is compatible with) then put I2C Manager in your components directory by cloning the repository from below and in your main program do: From 93125f3e006c1cfc9ef9538a790f6817a3acccfa Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Tue, 13 Jul 2021 14:33:54 +0200 Subject: [PATCH 37/70] another typo --- i2c_manager/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/i2c_manager/README.md b/i2c_manager/README.md index a0501c02..b6023271 100644 --- a/i2c_manager/README.md +++ b/i2c_manager/README.md @@ -8,7 +8,7 @@ ### I2C Manager support -`lvgl_esp32_drivers` comes with built-in I2C support by integrating I2C Manager, which is used in case you select a touch sensor or screen that uses the I2C bus. If you're just using LVGL you don't need to do anyting special. +`lvgl_esp32_drivers` comes with built-in I2C support by integrating I2C Manager, which is used in case you select a touch sensor or screen that uses the I2C bus. If you're just using LVGL you don't need to do anything special. I2C Manager can help if you are in a situation where you want to avoid "bus conflicts" on the I2C bus. Suppose you use LVGL with a touch sensor that uses I2C, and your device also has another I2C device that needs to be read frequently, such as a 3D-accelerometer. ESP-IDF is not inherently "thread-safe". So if you read that from another task than the one LVGL uses to read the touch data, you need some kind of mechanism to keep these communications from interfering. From befa5d0730e9bc5af1250ce9504e49cf833455f3 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Wed, 14 Jul 2021 12:43:19 +0200 Subject: [PATCH 38/70] directory i2c_manager -> lvgl_i2c --- CMakeLists.txt | 2 +- Kconfig | 2 +- component.mk | 5 ++++- lvgl_helpers.c | 2 +- {i2c_manager => lvgl_i2c}/Kconfig | 0 {i2c_manager => lvgl_i2c}/README.md | 2 +- {i2c_manager => lvgl_i2c}/i2c_manager.c | 0 {i2c_manager => lvgl_i2c}/i2c_manager.h | 0 lvgl_tft/ssd1306.c | 2 +- lvgl_tft/st7735s.c | 2 +- lvgl_touch/ft6x36.c | 2 +- lvgl_touch/gt911.c | 2 +- 12 files changed, 12 insertions(+), 9 deletions(-) rename {i2c_manager => lvgl_i2c}/Kconfig (100%) rename {i2c_manager => lvgl_i2c}/README.md (99%) rename {i2c_manager => lvgl_i2c}/i2c_manager.c (100%) rename {i2c_manager => lvgl_i2c}/i2c_manager.h (100%) diff --git a/CMakeLists.txt b/CMakeLists.txt index 678c8943..b1ebffe2 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -80,7 +80,7 @@ if(CONFIG_LV_TOUCH_CONTROLLER) endif() if(CONFIG_LV_I2C) - list(APPEND SOURCES "i2c_manager/i2c_manager.c") + list(APPEND SOURCES "lvgl_i2c/i2c_manager.c") endif() idf_component_register(SRCS ${SOURCES} diff --git a/Kconfig b/Kconfig index 370ad6ee..48c3ce0c 100644 --- a/Kconfig +++ b/Kconfig @@ -7,7 +7,7 @@ menu "LVGL ESP Drivers" menu "I2C Port Settings" depends on LV_I2C && !HAVE_I2C_MANAGER - rsource "i2c_manager/Kconfig" + rsource "lvgl_i2c/Kconfig" endmenu diff --git a/component.mk b/component.mk index c01caba7..0017d0ba 100644 --- a/component.mk +++ b/component.mk @@ -1,7 +1,7 @@ # LVGL ESP32 drivers # Define sources and include dirs -COMPONENT_SRCDIRS := . lvgl_tft lvgl_touch +COMPONENT_SRCDIRS := . lvgl_tft lvgl_touch lvgl_i2c COMPONENT_ADD_INCLUDEDIRS := . # LVGL is supposed to be used as a ESP-IDF component @@ -44,3 +44,6 @@ $(call compile_only_if,$(and $(CONFIG_LV_TOUCH_CONTROLLER),$(CONFIG_LV_TOUCH_CON $(call compile_only_if,$(and $(CONFIG_LV_TOUCH_CONTROLLER),$(CONFIG_LV_TOUCH_CONTROLLER_RA8875)), lvgl_touch/ra8875_touch.o) $(call compile_only_if,$(and $(CONFIG_LV_TOUCH_CONTROLLER),$(CONFIG_LV_TOUCH_DRIVER_PROTOCOL_SPI)), lvgl_touch/tp_spi.o) + +# I2C Manager +$(call compile_only_if,$(CONFIG_LV_I2C), lvgl_i2c/i2c_manager.o) diff --git a/lvgl_helpers.c b/lvgl_helpers.c index dc98720a..edc522f7 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -15,7 +15,7 @@ #include "lvgl_spi_conf.h" -#include "i2c_manager/i2c_manager.h" +#include "lvgl_i2c/i2c_manager.h" #ifdef LV_LVGL_H_INCLUDE_SIMPLE #include "lvgl.h" diff --git a/i2c_manager/Kconfig b/lvgl_i2c/Kconfig similarity index 100% rename from i2c_manager/Kconfig rename to lvgl_i2c/Kconfig diff --git a/i2c_manager/README.md b/lvgl_i2c/README.md similarity index 99% rename from i2c_manager/README.md rename to lvgl_i2c/README.md index b6023271..890f8daa 100644 --- a/i2c_manager/README.md +++ b/lvgl_i2c/README.md @@ -59,7 +59,7 @@ To use the I2C port in your code you would do something like: ```c -#include "i2c_manager/i2c_manager.h" +#include "lvgl_i2c/i2c_manager.h" uint8_t data[2]; lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, 0x23, 0x42, &data, 2); diff --git a/i2c_manager/i2c_manager.c b/lvgl_i2c/i2c_manager.c similarity index 100% rename from i2c_manager/i2c_manager.c rename to lvgl_i2c/i2c_manager.c diff --git a/i2c_manager/i2c_manager.h b/lvgl_i2c/i2c_manager.h similarity index 100% rename from i2c_manager/i2c_manager.h rename to lvgl_i2c/i2c_manager.h diff --git a/lvgl_tft/ssd1306.c b/lvgl_tft/ssd1306.c index 811f1645..5953d445 100644 --- a/lvgl_tft/ssd1306.c +++ b/lvgl_tft/ssd1306.c @@ -15,7 +15,7 @@ *********************/ #include "assert.h" -#include "i2c_manager/i2c_manager.h" +#include "lvgl_i2c/i2c_manager.h" #include "ssd1306.h" diff --git a/lvgl_tft/st7735s.c b/lvgl_tft/st7735s.c index d57def5e..8be725be 100644 --- a/lvgl_tft/st7735s.c +++ b/lvgl_tft/st7735s.c @@ -14,7 +14,7 @@ #include "freertos/task.h" #ifdef CONFIG_LV_M5STICKC_HANDLE_AXP192 - #include "i2c_manager/i2c_manager.h" + #include "lvgl_i2c/i2c_manager.h" #endif /********************* diff --git a/lvgl_touch/ft6x36.c b/lvgl_touch/ft6x36.c index c7c2f9e9..9e348459 100644 --- a/lvgl_touch/ft6x36.c +++ b/lvgl_touch/ft6x36.c @@ -26,7 +26,7 @@ #endif #include "ft6x36.h" -#include "i2c_manager/i2c_manager.h" +#include "lvgl_i2c/i2c_manager.h" #define TAG "FT6X36" diff --git a/lvgl_touch/gt911.c b/lvgl_touch/gt911.c index 99745716..03c3d9d4 100644 --- a/lvgl_touch/gt911.c +++ b/lvgl_touch/gt911.c @@ -26,7 +26,7 @@ #endif #include "gt911.h" -#include "i2c_manager/i2c_manager.h" +#include "lvgl_i2c/i2c_manager.h" #define TAG "GT911" From 93a44492fc5184846b5a39221020e94ed110ca95 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Wed, 14 Jul 2021 13:12:49 +0200 Subject: [PATCH 39/70] Things suggested by @tore-espressif See [here](https://github.com/lvgl/lvgl_esp32_drivers/pull/70#pullrequestreview-704302765) in #70 --- Kconfig | 10 +++++----- lvgl_i2c/README.md | 6 ++---- lvgl_tft/Kconfig | 6 ++++++ lvgl_touch/Kconfig | 6 ++++++ 4 files changed, 19 insertions(+), 9 deletions(-) diff --git a/Kconfig b/Kconfig index 48c3ce0c..36b45268 100644 --- a/Kconfig +++ b/Kconfig @@ -4,11 +4,11 @@ menu "LVGL ESP Drivers" rsource "lvgl_touch/Kconfig" - menu "I2C Port Settings" - depends on LV_I2C && !HAVE_I2C_MANAGER +endmenu + +menu "I2C Port Settings" + depends on LV_I2C && !HAVE_I2C_MANAGER - rsource "lvgl_i2c/Kconfig" - - endmenu + rsource "lvgl_i2c/Kconfig" endmenu diff --git a/lvgl_i2c/README.md b/lvgl_i2c/README.md index 890f8daa..fb74e279 100644 --- a/lvgl_i2c/README.md +++ b/lvgl_i2c/README.md @@ -8,7 +8,7 @@ ### I2C Manager support -`lvgl_esp32_drivers` comes with built-in I2C support by integrating I2C Manager, which is used in case you select a touch sensor or screen that uses the I2C bus. If you're just using LVGL you don't need to do anything special. +`lvgl_esp32_drivers` integrates [I2C Manager](https://github.com/ropg/i2c_manager), which is used in case you select a touch sensor or screen that uses the I2C bus. If you're just using LVGL you don't need to do anything special. I2C Manager can help if you are in a situation where you want to avoid "bus conflicts" on the I2C bus. Suppose you use LVGL with a touch sensor that uses I2C, and your device also has another I2C device that needs to be read frequently, such as a 3D-accelerometer. ESP-IDF is not inherently "thread-safe". So if you read that from another task than the one LVGL uses to read the touch data, you need some kind of mechanism to keep these communications from interfering. @@ -27,15 +27,13 @@ lvgl_driver_init(); The `lvgl_i2c_locking` part will cause the LVGL I2C driver to play nice with anything else that uses the I2C port(s) through I2C Manager. -Refer to the [I2C Manager GitHub repository](https://github.com/ropg/i2c_manager) for much more information. -   ## Information for LVGL driver developers -I2C support in the LVGL ESP drivers is provided exclusively by the files in this directory. Code from all over the project that was talking to the I2C hardware directly has been replaced by code that communicates through the functions provided in `i2c_manager.h`. I2C is handled by the I2C Manager that was built into `lvlg_esp32_drivers`, but the code would be the same if it was routed through I2C Manager as a separate component. If you are providing a driver, you need not worry about any of this. +I2C support in the LVGL ESP drivers is provided exclusively by the files in this directory. Driver code that uses I2C communicates through the functions provided in `i2c_manager.h`.   diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 19138afc..f92351b5 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -1006,10 +1006,16 @@ menu "LVGL TFT Display controller" config LV_I2C_DISPLAY_PORT_0 bool prompt "I2C port 0" + help + I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu + Component config->I2C Port Settings. config LV_I2C_DISPLAY_PORT_1 bool prompt "I2C port 1" + help + I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu + Component config->I2C Port Settings. endchoice diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index da4b6612..031cfc94 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -492,10 +492,16 @@ menu "LVGL Touch controller" config LV_I2C_TOUCH_PORT_0 bool prompt "I2C port 0" + help + I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu + Component config->I2C Port Settings. config LV_I2C_TOUCH_PORT_1 bool prompt "I2C port 1" + help + I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu + Component config->I2C Port Settings. endchoice From 779bf4ecfb235beb474f6f8f714c71a8692f3c83 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Thu, 15 Jul 2021 12:31:18 +0200 Subject: [PATCH 40/70] Remove remaining IDF_TARGET-dependent GPIO ranges. See discussion in #70 --- lvgl_tft/Kconfig | 41 ----------------------------------------- lvgl_touch/Kconfig | 27 --------------------------- 2 files changed, 68 deletions(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index f92351b5..593b9481 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -742,10 +742,6 @@ menu "LVGL TFT Display controller" config LV_DISP_SPI_MOSI int "GPIO for MOSI (Master Out Slave In)" if LV_TFT_DISPLAY_PROTOCOL_SPI - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 23 if LV_PREDEFINED_DISPLAY_WROVER4 default 23 if LV_PREDEFINED_DISPLAY_ATAG default 23 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK @@ -757,7 +753,6 @@ menu "LVGL TFT Display controller" default 19 if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS default 13 if LV_PREDEFINED_DISPLAY_WT32_SC01 default 13 - help Configure the display MOSI pin here. @@ -772,10 +767,6 @@ menu "LVGL TFT Display controller" config LV_DISP_SPI_MISO int "GPIO for MISO (Master In Slave Out)" if LV_TFT_DISPLAY_PROTOCOL_SPI depends on LV_DISPLAY_USE_SPI_MISO - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 19 if LV_PREDEFINED_PINS_TKOALA default 38 if LV_PREDEFINED_DISPLAY_M5CORE2 default 0 @@ -795,10 +786,6 @@ menu "LVGL TFT Display controller" config LV_DISP_SPI_IO2 int "GPIO for Quad SPI IO2/WP" if LV_TFT_DISPLAY_PROTOCOL_SPI depends on LV_TFT_DISPLAY_SPI_TRANS_MODE_QIO - range -1 39 if IDF_TARGET_ESP32 - range -1 43 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 22 if LV_PREDEFINED_PINS_TKOALA && LV_TFT_DISPLAY_SPI_TRANS_MODE_QIO default -1 help @@ -807,10 +794,6 @@ menu "LVGL TFT Display controller" config LV_DISP_SPI_IO3 int "GPIO for Quad SPI IO3/HD" if LV_TFT_DISPLAY_PROTOCOL_SPI depends on LV_TFT_DISPLAY_SPI_TRANS_MODE_QIO - range -1 39 if IDF_TARGET_ESP32 - range -1 43 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 21 if LV_PREDEFINED_PINS_TKOALA && LV_TFT_DISPLAY_SPI_TRANS_MODE_QIO default -1 help @@ -818,10 +801,6 @@ menu "LVGL TFT Display controller" config LV_DISP_SPI_CLK int "GPIO for CLK (SCK / Serial Clock)" if LV_TFT_DISPLAY_PROTOCOL_SPI - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 18 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK default 18 if LV_PREDEFINED_DISPLAY_M5CORE2 default 13 if LV_PREDEFINED_DISPLAY_M5STICKC @@ -847,10 +826,6 @@ menu "LVGL TFT Display controller" config LV_DISP_SPI_CS int "GPIO for CS (Slave Select)" if LV_TFT_DISPLAY_PROTOCOL_SPI depends on LV_DISPLAY_USE_SPI_CS - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 5 if LV_PREDEFINED_PINS_38V1 default 14 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK default 5 if LV_PREDEFINED_DISPLAY_M5CORE2 @@ -876,10 +851,6 @@ menu "LVGL TFT Display controller" config LV_DISP_PIN_DC int "GPIO for DC (Data / Command)" if LV_TFT_DISPLAY_PROTOCOL_SPI - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - depends on LV_DISPLAY_USE_DC default 19 if LV_PREDEFINED_PINS_38V1 default 17 if LV_PREDEFINED_PINS_38V4 @@ -914,10 +885,6 @@ menu "LVGL TFT Display controller" config LV_DISP_PIN_RST int "GPIO for Reset" if LV_TFT_DISPLAY_PROTOCOL_SPI && !LV_DISP_ST7789_SOFT_RESET depends on LV_DISP_USE_RST - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 18 if LV_PREDEFINED_PINS_38V1 default 25 if LV_PREDEFINED_PINS_38V4 default 33 if LV_PREDEFINED_DISPLAY_M5STACK || LV_PREDEFINED_DISPLAY_M5STICK @@ -936,10 +903,6 @@ menu "LVGL TFT Display controller" config LV_DISP_PIN_BUSY int "GPIO for Busy" if LV_TFT_DISPLAY_CONTROLLER_IL3820 || LV_TFT_DISPLAY_CONTROLLER_JD79653A || LV_TFT_DISPLAY_CONTROLLER_UC8151D - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 35 if LV_TFT_DISPLAY_CONTROLLER_IL3820 || LV_TFT_DISPLAY_CONTROLLER_JD79653A || LV_TFT_DISPLAY_CONTROLLER_UC8151D default 35 if IDF_TARGET_ESP32 || IDF_TARGET_ESP32S2 default 21 if IDF_TARGET_ESP32C3 @@ -977,10 +940,6 @@ menu "LVGL TFT Display controller" config LV_DISP_PIN_BCKL int "GPIO for Backlight Control" depends on LV_ENABLE_BACKLIGHT_CONTROL - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 23 if LV_PREDEFINED_PINS_38V1 default 26 if LV_PREDEFINED_PINS_38V4 default 32 if LV_PREDEFINED_DISPLAY_M5STACK diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index 031cfc94..de4d17b8 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -86,9 +86,6 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_MISO int prompt "GPIO for MISO (Master In Slave Out)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 default 35 if LV_PREDEFINED_PINS_38V1 default 19 @@ -98,9 +95,6 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_MOSI int prompt "GPIO for MOSI (Master Out Slave In)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 default 32 if LV_PREDEFINED_PINS_38V1 default 23 @@ -109,9 +103,6 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CLK int "GPIO for CLK (SCK / Serial Clock)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 default 26 if LV_PREDEFINED_PINS_38V1 default 18 @@ -120,8 +111,6 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CS int "GPIO for CS (Slave Select)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 default 33 if LV_PREDEFINED_PINS_38V1 default 5 @@ -130,9 +119,6 @@ menu "LVGL Touch controller" config LV_TOUCH_PIN_IRQ int "GPIO for IRQ (Interrupt Request)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 default 27 if LV_PREDEFINED_PINS_38V4 default 25 @@ -223,9 +209,6 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_MISO int prompt "GPIO for MISO (Master In Slave Out)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 default 35 if LV_PREDEFINED_PINS_38V1 default 19 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING @@ -238,9 +221,6 @@ menu "LVGL Touch controller" # TODO Fix default for ESP32C3 int prompt "GPIO for MOSI (Master Out Slave In)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 default 32 if LV_PREDEFINED_PINS_38V1 default 18 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING @@ -251,9 +231,6 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CLK int "GPIO for CLK (SCK / Serial Clock)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 default 26 if LV_PREDEFINED_PINS_38V1 default 5 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING @@ -263,10 +240,6 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CS int "GPIO for CS (Slave Select)" - range 0 39 if IDF_TARGET_ESP32 - range 0 46 if IDF_TARGET_ESP32S2 - range 0 21 if IDF_TARGET_ESP32C3 - default 33 if LV_PREDEFINED_PINS_38V1 default 32 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING default 5 From a0e933c7e65b599c615edd9cfc53e952d9a27764 Mon Sep 17 00:00:00 2001 From: Kevin Sidwar Date: Fri, 30 Jul 2021 15:29:18 -0600 Subject: [PATCH 41/70] Fix orientation config define --- lvgl_tft/Kconfig | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 593b9481..e45db6a2 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -195,24 +195,24 @@ menu "LVGL TFT Display controller" # Used in display init function to send display orientation commands choice DISPLAY_ORIENTATION prompt "Display orientation" - default DISPLAY_ORIENTATION_PORTRAIT if !LV_TFT_DISPLAY_CONTROLLER_SSD1306 - default DISPLAY_ORIENTATION_LANDSCAPE if LV_TFT_DISPLAY_CONTROLLER_SSD1306 - config DISPLAY_ORIENTATION_PORTRAIT + default LV_DISPLAY_ORIENTATION_PORTRAIT if !LV_TFT_DISPLAY_CONTROLLER_SSD1306 + default LV_DISPLAY_ORIENTATION_LANDSCAPE if LV_TFT_DISPLAY_CONTROLLER_SSD1306 + config LV_DISPLAY_ORIENTATION_PORTRAIT bool "Portrait" if !LV_TFT_DISPLAY_CONTROLLER_SSD1306 - config DISPLAY_ORIENTATION_PORTRAIT_INVERTED + config LV_DISPLAY_ORIENTATION_PORTRAIT_INVERTED bool "Portrait inverted" if !LV_TFT_DISPLAY_CONTROLLER_SSD1306 - config DISPLAY_ORIENTATION_LANDSCAPE + config LV_DISPLAY_ORIENTATION_LANDSCAPE bool "Landscape" - config DISPLAY_ORIENTATION_LANDSCAPE_INVERTED + config LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED bool "Landscape inverted" endchoice config LV_DISPLAY_ORIENTATION int - default 0 if DISPLAY_ORIENTATION_PORTRAIT - default 1 if DISPLAY_ORIENTATION_PORTRAIT_INVERTED - default 2 if DISPLAY_ORIENTATION_LANDSCAPE - default 3 if DISPLAY_ORIENTATION_LANDSCAPE_INVERTED + default 0 if LV_DISPLAY_ORIENTATION_PORTRAIT + default 1 if LV_DISPLAY_ORIENTATION_PORTRAIT_INVERTED + default 2 if LV_DISPLAY_ORIENTATION_LANDSCAPE + default 3 if LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED config LV_TFT_DISPLAY_OFFSETS bool From fa042b0ecd1b555829d903aa734b957ce435dc09 Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Tue, 3 Aug 2021 08:59:59 +0200 Subject: [PATCH 42/70] Carve out backlight control to separate component --- CMakeLists.txt | 8 +-- lvgl_tft/Kconfig | 116 +++++++++++++++++++-------------- lvgl_tft/disp_driver.c | 32 ++++++++- lvgl_tft/disp_driver.h | 2 +- lvgl_tft/esp_lcd_backlight.c | 122 ++++++++++++++++++++++++----------- lvgl_tft/esp_lcd_backlight.h | 57 ++++++++++++---- 6 files changed, 228 insertions(+), 109 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 2dbc2f7c..78870dd6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -3,8 +3,7 @@ if(ESP_PLATFORM) file(GLOB SOURCES *.c) set(LVGL_INCLUDE_DIRS . lvgl_tft) list(APPEND SOURCES "lvgl_tft/disp_driver.c") - -#@todo add SimleInclude macro here +list(APPEND SOURCES "lvgl_tft/esp_lcd_backlight.c") # Include only the source file of the selected # display controller. @@ -79,11 +78,6 @@ if(CONFIG_LV_TOUCH_CONTROLLER) endif() endif() -# Add backlight control to compilation only if it is selected in menuconfig -if(CONFIG_LV_ENABLE_BACKLIGHT_CONTROL) - list(APPEND SOURCES "lvgl_tft/esp_lcd_backlight.c") -endif() - if(CONFIG_LV_I2C) list(APPEND SOURCES "lvgl_i2c/i2c_manager.c") endif() diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 593b9481..7b94d46b 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -910,51 +910,6 @@ menu "LVGL TFT Display controller" help Configure the display Busy pin here. - config LV_ENABLE_BACKLIGHT_CONTROL - bool "Enable control of the display backlight by using an GPIO." if \ - ( LV_PREDEFINED_DISPLAY_NONE && ! ( LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 ) ) \ - || LV_PREDEFINED_DISPLAY_RPI_MPI3501 - default y if LV_PREDEFINED_DISPLAY_M5STACK - default n if LV_PREDEFINED_DISPLAY_M5CORE2 - default y if LV_PREDEFINED_DISPLAY_WROVER4 - default y if LV_PREDEFINED_DISPLAY_ERTFT0356 - default y if LV_PREDEFINED_DISPLAY_TTGO - default y if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS - default y if LV_PREDEFINED_DISPLAY_WT32_SC01 - help - Enable controlling the display backlight using an GPIO - - config LV_BACKLIGHT_ACTIVE_LVL - bool "Is backlight turn on with a HIGH (1) logic level?" - depends on LV_ENABLE_BACKLIGHT_CONTROL - default y if LV_PREDEFINED_DISPLAY_M5STACK - default y if LV_PREDEFINED_DISPLAY_ERTFT0356 - default y if LV_PREDEFINED_DISPLAY_TTGO - default y if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS - default y if LV_PREDEFINED_DISPLAY_WT32_SC01 - help - Some backlights are turned on with a high signal, others held low. - If enabled, a value of 1 will be sent to the display to enable the backlight, - otherwise a 0 will be expected to enable it. - - config LV_DISP_PIN_BCKL - int "GPIO for Backlight Control" - depends on LV_ENABLE_BACKLIGHT_CONTROL - default 23 if LV_PREDEFINED_PINS_38V1 - default 26 if LV_PREDEFINED_PINS_38V4 - default 32 if LV_PREDEFINED_DISPLAY_M5STACK - default 5 if LV_PREDEFINED_DISPLAY_WROVER4 - default 2 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING - default 27 if LV_PREDEFINED_DISPLAY_ERTFT0356 - default 0 if LV_PREDEFINED_PINS_TKOALA - default 4 if LV_PREDEFINED_DISPLAY_TTGO - default 2 if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS - default 23 if LV_PREDEFINED_DISPLAY_WT32_SC01 - default 27 - - help - Configure the display BCLK (LED) pin here. - endmenu choice @@ -965,19 +920,86 @@ menu "LVGL TFT Display controller" config LV_I2C_DISPLAY_PORT_0 bool prompt "I2C port 0" - help + help I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu Component config->I2C Port Settings. config LV_I2C_DISPLAY_PORT_1 bool prompt "I2C port 1" - help + help I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu Component config->I2C Port Settings. endchoice + choice + prompt "Backlight Control" if \ + (! ( LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 ) ) + default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_M5STACK + default LV_DISP_BACKLIGHT_OFF if LV_PREDEFINED_DISPLAY_M5CORE2 + default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_WROVER4 + default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_ERTFT0356 + default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_TTGO + default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS + default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_WT32_SC01 + default LV_DISP_BACKLIGHT_OFF + + config LV_DISP_BACKLIGHT_OFF + bool + prompt "Not Used" + help + Display backlight is not controlled by this driver, must be hardwired in hardware. + + config LV_DISP_BACKLIGHT_SWITCH + bool + prompt "Switch control" + help + Display backlight can be switched on or off. + + config LV_DISP_BACKLIGHT_PWM + bool + prompt "PWM control" + help + Display backlight is controlled by pulse-width modulation, allowing brightness settings. + + endchoice + + config LV_BACKLIGHT_ACTIVE_LVL + bool "Is backlight turn on with a HIGH (1) logic level?" if \ + ( LV_PREDEFINED_DISPLAY_NONE && ! ( LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 ) ) \ + || LV_PREDEFINED_DISPLAY_RPI_MPI3501 + depends on !LV_DISP_BACKLIGHT_OFF + default y if LV_PREDEFINED_DISPLAY_M5STACK + default y if LV_PREDEFINED_DISPLAY_ERTFT0356 + default y if LV_PREDEFINED_DISPLAY_TTGO + default y if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS + default y if LV_PREDEFINED_DISPLAY_WT32_SC01 + help + Some backlights are turned on with a high signal, others held low. + If enabled, a value of 1 will be sent to the display to enable the backlight, + otherwise a 0 will be expected to enable it. + + config LV_DISP_PIN_BCKL + int "GPIO for Backlight Control" if \ + ( LV_PREDEFINED_DISPLAY_NONE && ! ( LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 ) ) \ + || LV_PREDEFINED_DISPLAY_RPI_MPI3501 + depends on !LV_DISP_BACKLIGHT_OFF + default 23 if LV_PREDEFINED_PINS_38V1 + default 26 if LV_PREDEFINED_PINS_38V4 + default 32 if LV_PREDEFINED_DISPLAY_M5STACK + default 5 if LV_PREDEFINED_DISPLAY_WROVER4 + default 2 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING + default 27 if LV_PREDEFINED_DISPLAY_ERTFT0356 + default 0 if LV_PREDEFINED_PINS_TKOALA + default 4 if LV_PREDEFINED_DISPLAY_TTGO + default 2 if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS + default 23 if LV_PREDEFINED_DISPLAY_WT32_SC01 + default 27 + + help + Configure the display BCLK (LED) pin here. + config LV_I2C bool default y if LV_I2C_DISPLAY diff --git a/lvgl_tft/disp_driver.c b/lvgl_tft/disp_driver.c index adae2ad7..0d771550 100644 --- a/lvgl_tft/disp_driver.c +++ b/lvgl_tft/disp_driver.c @@ -4,8 +4,10 @@ #include "disp_driver.h" #include "disp_spi.h" +#include "esp_lcd_backlight.h" +#include "sdkconfig.h" -void disp_driver_init(void) +void *disp_driver_init(void) { #if defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9341 ili9341_init(); @@ -42,6 +44,34 @@ void disp_driver_init(void) #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C ili9163c_init(); #endif + + // We still use menuconfig for these settings + // It will be set up during runtime in the future +#ifndef CONFIG_LV_DISP_BACKLIGHT_OFF + const disp_backlight_config_t bckl_config = { + .gpio_num = CONFIG_LV_DISP_PIN_BCKL, +#if defined CONFIG_LV_DISP_BACKLIGHT_PWM + .pwm_control = true, +#else + .pwm_control = false, +#endif +#if defined CONFIG_LV_BACKLIGHT_ACTIVE_LVL + .output_invert = false, // Backlight on high +#else + .output_invert = true, // Backlight on low +#endif + .timer_idx = 0, + .channel_idx = 0 // @todo this prevents us from having two PWM controlled displays + }; + const disp_backlight_config_t *bckl_config_p = &bckl_config; +#else + const disp_backlight_config_t *bckl_config_p = NULL; +#endif + + disp_backlight_h bckl_handle = disp_backlight_new(bckl_config_p); + disp_backlight_set(bckl_handle, 100); + + return bckl_handle; } void disp_driver_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map) diff --git a/lvgl_tft/disp_driver.h b/lvgl_tft/disp_driver.h index 2e369cc9..8c70fdae 100644 --- a/lvgl_tft/disp_driver.h +++ b/lvgl_tft/disp_driver.h @@ -67,7 +67,7 @@ extern "C" { **********************/ /* Initialize display */ -void disp_driver_init(void); +void *disp_driver_init(void); /* Display flush callback */ void disp_driver_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); diff --git a/lvgl_tft/esp_lcd_backlight.c b/lvgl_tft/esp_lcd_backlight.c index e4bf930a..d8724e60 100644 --- a/lvgl_tft/esp_lcd_backlight.c +++ b/lvgl_tft/esp_lcd_backlight.c @@ -8,51 +8,95 @@ *********************/ #include "esp_lcd_backlight.h" #include "driver/ledc.h" +#include "driver/gpio.h" #include "esp_log.h" +#include "esp_rom_gpio.h" // for output signal inversion -static const char *TAG = "disp_brightness"; +typedef struct { + bool pwm_control; // true: LEDC is used, false: GPIO is used + int index; // Either GPIO or LEDC channel +} disp_backlight_t; -void disp_brightness_control_enable(void) +static const char *TAG = "disp_backlight"; + +disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config) { - /* - Configure LED (Backlight) pin as PWM for Brightness control. - */ - ledc_channel_config_t LCD_backlight_channel = { - .gpio_num = DISP_PIN_BCKL, - .speed_mode = LEDC_LOW_SPEED_MODE, - .channel = LEDC_CHANNEL_0, - .intr_type = LEDC_INTR_DISABLE, - .timer_sel = LEDC_TIMER_0, - .duty = 0, - .hpoint = 0, - .flags.output_invert = 0 - }; - ledc_timer_config_t LCD_backlight_timer = { - .speed_mode = LEDC_LOW_SPEED_MODE, - .bit_num = LEDC_TIMER_10_BIT, - .timer_num = LEDC_TIMER_0, - .freq_hz = 5000, - .clk_cfg = LEDC_AUTO_CLK - }; - - ESP_ERROR_CHECK( ledc_timer_config(&LCD_backlight_timer) ); - ESP_ERROR_CHECK( ledc_channel_config(&LCD_backlight_channel) ); + if (config == NULL) + return NULL; + disp_backlight_t *bckl_dev = calloc(1, sizeof(disp_backlight_t)); + if (bckl_dev == NULL){ + ESP_LOGW(TAG, "Could not create new LCD backlight instance"); + return NULL; + } + + if (config->pwm_control){ + // Configure LED (Backlight) pin as PWM for Brightness control. + bckl_dev->pwm_control = true; + bckl_dev->index = config->channel_idx; + const ledc_channel_config_t LCD_backlight_channel = { + .gpio_num = config->gpio_num, + .speed_mode = LEDC_LOW_SPEED_MODE, + .channel = config->channel_idx, + .intr_type = LEDC_INTR_DISABLE, + .timer_sel = config->timer_idx, + .duty = 0, + .hpoint = 0, + .flags.output_invert = config->output_invert //@todo added only in recent IDF versions + }; + const ledc_timer_config_t LCD_backlight_timer = { + .speed_mode = LEDC_LOW_SPEED_MODE, + .bit_num = LEDC_TIMER_10_BIT, + .timer_num = config->timer_idx, + .freq_hz = 5000, + .clk_cfg = LEDC_AUTO_CLK}; + + ESP_ERROR_CHECK(ledc_timer_config(&LCD_backlight_timer)); + ESP_ERROR_CHECK(ledc_channel_config(&LCD_backlight_channel)); + } + else + { + // Configure GPIO for output + bckl_dev->index = config->gpio_num; + gpio_pad_select_gpio(config->gpio_num); + ESP_ERROR_CHECK(gpio_set_direction(config->gpio_num, GPIO_MODE_OUTPUT)); + esp_rom_gpio_connect_out_signal(config->gpio_num, SIG_GPIO_OUT_IDX, config->output_invert, false); + } + return (disp_backlight_h)bckl_dev; } -void disp_set_brightness(uint16_t brightness) +void disp_backlight_set(disp_backlight_h bckl, int brightness_percent) { - /* - Set brightness. - 0 -> Display off - 100 -> Full brightness - NOTE: brightness value must be between 0 - 100 - */ - if(brightness > 100) - { - ESP_LOGE(TAG, "Brightness value must be between 0 - 100"); - return; - } - ESP_ERROR_CHECK( ledc_set_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0, brightness*10) ); - ESP_ERROR_CHECK( ledc_update_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0) ); + // Check input paramters + if (bckl == NULL) + return; + if (brightness_percent > 100) + brightness_percent = 100; + if (brightness_percent < 0) + brightness_percent = 0; + + disp_backlight_t *bckl_dev = (disp_backlight_t *) bckl; + ESP_LOGI(TAG, "Setting LCD backlight: %d%%", brightness_percent); + + if (bckl_dev->pwm_control) { + uint32_t duty_cycle = (1023 * brightness_percent) / 100; // LEDC resolution set to 10bits, thus: 100% = 1023 + ESP_ERROR_CHECK(ledc_set_duty(LEDC_LOW_SPEED_MODE, bckl_dev->index, duty_cycle)); + ESP_ERROR_CHECK(ledc_update_duty(LEDC_LOW_SPEED_MODE, bckl_dev->index)); + } else { + ESP_ERROR_CHECK(gpio_set_level(bckl_dev->index, brightness_percent)); + } +} + +void disp_backlight_delete(disp_backlight_h bckl) +{ + if (bckl == NULL) + return; + + disp_backlight_t *bckl_dev = (disp_backlight_t *) bckl; + if (bckl_dev->pwm_control) { + ledc_stop(LEDC_LOW_SPEED_MODE, bckl_dev->index, 0); + } else { + gpio_reset_pin(bckl_dev->index); + } + free (bckl); } diff --git a/lvgl_tft/esp_lcd_backlight.h b/lvgl_tft/esp_lcd_backlight.h index b22bf9d9..a04817bb 100644 --- a/lvgl_tft/esp_lcd_backlight.h +++ b/lvgl_tft/esp_lcd_backlight.h @@ -9,29 +9,58 @@ * INCLUDES *********************/ #include -#ifdef LV_LVGL_H_INCLUDE_SIMPLE -#include "lvgl.h" -#else -#include "lvgl/lvgl.h" -#endif - -/********************* - * DEFINES - *********************/ -#if CONFIG_LV_ENABLE_BACKLIGHT_CONTROL -#define DISP_PIN_BCKL CONFIG_LV_DISP_PIN_BCKL +#ifdef __cplusplus +extern "C" { /* extern "C" */ #endif /********************** * GLOBAL PROTOTYPES **********************/ -void disp_brightness_control_enable(void); -void disp_set_brightness(uint16_t brightness); +/** + * @brief Display backlight controller handle + * + */ +typedef void * disp_backlight_h; + +/** + * @brief Configuration structure of backlight controller + * + */ +typedef struct { + bool pwm_control; + bool output_invert; + int gpio_num; // see gpio_num_t + + // Relevant only for PWM controlled backlight + // Ignored for switch (ON/OFF) backlight control + int timer_idx; // ledc_timer_t + int channel_idx; // ledc_channel_t +} disp_backlight_config_t; + +/** + * @brief Create new backlight controller + * + * @param[in] config Configuration structure of backlight controller + * @return Display backlight controller handle + */ +disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config); + +/** + * @brief Set backlight + * + * Brightness parameter can be 0-100 for PWM controlled backlight. + * GPIO controlled backlight (ON/OFF) is turned off witch value 0 and turned on with any positive value. + * + * @param bckl Backlight controller handle + * @param[in] brightness_percent Brightness in [%] + */ +void disp_backlight_set(disp_backlight_h bckl, int brightness_percent); +void disp_backlight_delete(disp_backlight_h bckl); #ifdef __cplusplus } /* extern "C" */ #endif -#endif /*ESP_LCD_BACKLIGHT_H*/ \ No newline at end of file +#endif /*ESP_LCD_BACKLIGHT_H*/ From 3c4399d510abedae3c8812e5405a4d8384fd81a0 Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Tue, 3 Aug 2021 14:17:58 +0200 Subject: [PATCH 43/70] Update TFT drivers for new backligh control --- lvgl_tft/GC9A01.c | 39 ++------------------------------------- lvgl_tft/GC9A01.h | 17 +++-------------- lvgl_tft/hx8357.c | 30 ++---------------------------- lvgl_tft/hx8357.h | 18 ++++-------------- lvgl_tft/il3820.c | 8 +++----- lvgl_tft/ili9163c.c | 22 ---------------------- lvgl_tft/ili9163c.h | 29 +++++++++-------------------- lvgl_tft/ili9341.c | 45 ++++----------------------------------------- lvgl_tft/ili9341.h | 11 ----------- lvgl_tft/ili9481.c | 25 ------------------------- lvgl_tft/ili9481.h | 17 ++++------------- lvgl_tft/ili9486.c | 41 +++-------------------------------------- lvgl_tft/ili9486.h | 9 --------- lvgl_tft/ili9488.c | 31 +++---------------------------- lvgl_tft/ili9488.h | 12 +----------- lvgl_tft/ra8875.c | 39 +-------------------------------------- lvgl_tft/ra8875.h | 1 - lvgl_tft/st7735s.h | 1 - lvgl_tft/st7789.c | 23 ----------------------- lvgl_tft/st7789.h | 10 ---------- lvgl_tft/st7796s.c | 35 ----------------------------------- lvgl_tft/st7796s.h | 17 ++++------------- 22 files changed, 43 insertions(+), 437 deletions(-) diff --git a/lvgl_tft/GC9A01.c b/lvgl_tft/GC9A01.c index 6f320518..c807233d 100644 --- a/lvgl_tft/GC9A01.c +++ b/lvgl_tft/GC9A01.c @@ -111,31 +111,14 @@ void GC9A01_init(void) }; -#if GC9A01_BCKL == 15 - gpio_config_t io_conf; - io_conf.intr_type = GPIO_PIN_INTR_DISABLE; - io_conf.mode = GPIO_MODE_OUTPUT; - io_conf.pin_bit_mask = GPIO_SEL_15; - io_conf.pull_down_en = GPIO_PULLDOWN_DISABLE; - io_conf.pull_up_en = GPIO_PULLUP_DISABLE; - gpio_config(&io_conf); -#endif - //Initialize non-SPI GPIOs - gpio_pad_select_gpio(GC9A01_DC); + gpio_pad_select_gpio(GC9A01_DC); gpio_set_direction(GC9A01_DC, GPIO_MODE_OUTPUT); #if GC9A01_USE_RST - gpio_pad_select_gpio(GC9A01_RST); + gpio_pad_select_gpio(GC9A01_RST); gpio_set_direction(GC9A01_RST, GPIO_MODE_OUTPUT); -#endif - -#if GC9A01_ENABLE_BACKLIGHT_CONTROL - gpio_pad_select_gpio(GC9A01_BCKL); - gpio_set_direction(GC9A01_BCKL, GPIO_MODE_OUTPUT); -#endif -#if GC9A01_USE_RST //Reset the display gpio_set_level(GC9A01_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); @@ -156,8 +139,6 @@ void GC9A01_init(void) cmd++; } - GC9A01_enable_backlight(true); - GC9A01_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); #if GC9A01_INVERT_COLORS == 1 @@ -197,22 +178,6 @@ void GC9A01_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo GC9A01_send_color((void*)color_map, size * 2); } -void GC9A01_enable_backlight(bool backlight) -{ -#if GC9A01_ENABLE_BACKLIGHT_CONTROL - ESP_LOGI(TAG, "%s backlight.", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - -#if (GC9A01_BCKL_ACTIVE_LVL==1) - tmp = backlight ? 1 : 0; -#else - tmp = backlight ? 0 : 1; -#endif - - gpio_set_level(GC9A01_BCKL, tmp); -#endif -} - void GC9A01_sleep_in() { uint8_t data[] = {0x08}; diff --git a/lvgl_tft/GC9A01.h b/lvgl_tft/GC9A01.h index 29958112..e39c14d6 100644 --- a/lvgl_tft/GC9A01.h +++ b/lvgl_tft/GC9A01.h @@ -25,19 +25,9 @@ extern "C" { /********************* * DEFINES *********************/ -#define GC9A01_DC CONFIG_LV_DISP_PIN_DC -#define GC9A01_RST CONFIG_LV_DISP_PIN_RST -#define GC9A01_USE_RST CONFIG_LV_DISP_USE_RST -#define GC9A01_BCKL CONFIG_LV_DISP_PIN_BCKL - -#define GC9A01_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL - -#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL - #define GC9A01_BCKL_ACTIVE_LVL 1 -#else - #define GC9A01_BCKL_ACTIVE_LVL 0 -#endif - +#define GC9A01_DC CONFIG_LV_DISP_PIN_DC +#define GC9A01_RST CONFIG_LV_DISP_PIN_RST +#define GC9A01_USE_RST CONFIG_LV_DISP_USE_RST #define GC9A01_INVERT_COLORS CONFIG_LV_INVERT_COLORS /********************** @@ -50,7 +40,6 @@ extern "C" { void GC9A01_init(void); void GC9A01_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); -void GC9A01_enable_backlight(bool backlight); void GC9A01_sleep_in(void); void GC9A01_sleep_out(void); diff --git a/lvgl_tft/hx8357.c b/lvgl_tft/hx8357.c index 6b6cd34f..bb9ea58b 100644 --- a/lvgl_tft/hx8357.c +++ b/lvgl_tft/hx8357.c @@ -160,20 +160,13 @@ static uint8_t displayType = HX8357D; void hx8357_init(void) { //Initialize non-SPI GPIOs - gpio_pad_select_gpio(HX8357_DC); + gpio_pad_select_gpio(HX8357_DC); gpio_set_direction(HX8357_DC, GPIO_MODE_OUTPUT); #if HX8357_USE_RST - gpio_pad_select_gpio(HX8357_RST); + gpio_pad_select_gpio(HX8357_RST); gpio_set_direction(HX8357_RST, GPIO_MODE_OUTPUT); -#endif - -#if HX8357_ENABLE_BACKLIGHT_CONTROL - gpio_pad_select_gpio(HX8357_BCKL); - gpio_set_direction(HX8357_BCKL, GPIO_MODE_OUTPUT); -#endif -#if HX8357_USE_RST //Reset the display gpio_set_level(HX8357_RST, 0); vTaskDelay(10 / portTICK_RATE_MS); @@ -210,8 +203,6 @@ void hx8357_init(void) #else hx8357_send_cmd(HX8357_INVOFF); #endif - - hx8357_enable_backlight(true); } @@ -248,23 +239,6 @@ void hx8357_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo hx8357_send_color((void*)color_map, size * 2); } -void hx8357_enable_backlight(bool backlight) -{ -#if HX8357_ENABLE_BACKLIGHT_CONTROL - ESP_LOGD(TAG, "%s backlight.\n", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - -#if (HX8357_BCKL_ACTIVE_LVL==1) - tmp = backlight ? 1 : 0; -#else - tmp = backlight ? 0 : 1; -#endif - - gpio_set_level(HX8357_BCKL, tmp); -#endif -} - - void hx8357_set_rotation(uint8_t r) { r = r & 3; // can't be higher than 3 diff --git a/lvgl_tft/hx8357.h b/lvgl_tft/hx8357.h index 1e54627f..34cbaf9e 100644 --- a/lvgl_tft/hx8357.h +++ b/lvgl_tft/hx8357.h @@ -35,19 +35,10 @@ extern "C" { /********************* * DEFINES *********************/ -#define HX8357_DC CONFIG_LV_DISP_PIN_DC -#define HX8357_RST CONFIG_LV_DISP_PIN_RST -#define HX8357_USE_RST CONFIG_LV_DISP_USE_RST -#define HX8357_BCKL CONFIG_LV_DISP_PIN_BCKL - -#define HX8357_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL -#define HX8357_INVERT_COLORS CONFIG_LV_INVERT_COLORS - -#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL - #define HX8357_BCKL_ACTIVE_LVL 1 -#else - #define HX8357_BCKL_ACTIVE_LVL 0 -#endif +#define HX8357_DC CONFIG_LV_DISP_PIN_DC +#define HX8357_RST CONFIG_LV_DISP_PIN_RST +#define HX8357_USE_RST CONFIG_LV_DISP_USE_RST +#define HX8357_INVERT_COLORS CONFIG_LV_INVERT_COLORS /******************* @@ -136,7 +127,6 @@ extern "C" { void hx8357_init(void); void hx8357_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); -void hx8357_enable_backlight(bool backlight); void hx8357_set_rotation(uint8_t r); /********************** diff --git a/lvgl_tft/il3820.c b/lvgl_tft/il3820.c index fee39e23..1ce0b395 100644 --- a/lvgl_tft/il3820.c +++ b/lvgl_tft/il3820.c @@ -199,15 +199,13 @@ void il3820_init(void) gpio_pad_select_gpio(IL3820_DC_PIN); gpio_set_direction(IL3820_DC_PIN, GPIO_MODE_OUTPUT); -#if IL3820_USE_RST - gpio_pad_select_gpio(IL3820_RST_PIN); - gpio_set_direction(IL3820_RST_PIN, GPIO_MODE_OUTPUT); -#endif - gpio_pad_select_gpio(IL3820_BUSY_PIN); gpio_set_direction(IL3820_BUSY_PIN, GPIO_MODE_INPUT); #if IL3820_USE_RST + gpio_pad_select_gpio(IL3820_RST_PIN); + gpio_set_direction(IL3820_RST_PIN, GPIO_MODE_OUTPUT); + /* Harware reset */ gpio_set_level( IL3820_RST_PIN, 0); vTaskDelay(IL3820_RESET_DELAY / portTICK_RATE_MS); diff --git a/lvgl_tft/ili9163c.c b/lvgl_tft/ili9163c.c index 77346e40..059d076c 100644 --- a/lvgl_tft/ili9163c.c +++ b/lvgl_tft/ili9163c.c @@ -143,10 +143,6 @@ void ili9163c_init(void) gpio_pad_select_gpio(ILI9163C_RST); gpio_set_direction(ILI9163C_RST, GPIO_MODE_OUTPUT); -#if ILI9163C_ENABLE_BACKLIGHT_CONTROL - gpio_pad_select_gpio(ILI9163C_BCKL); - gpio_set_direction(ILI9163C_BCKL, GPIO_MODE_OUTPUT); -#endif //Reset the display gpio_set_level(ILI9163C_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); @@ -166,8 +162,6 @@ void ili9163c_init(void) cmd++; } - ili9163c_enable_backlight(true); - ili9163c_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); } @@ -199,22 +193,6 @@ void ili9163c_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color ili9163c_send_color((void *)color_map, size * 2); } -void ili9163c_enable_backlight(bool backlight) -{ -#if ILI9163C_ENABLE_BACKLIGHT_CONTROL - ESP_LOGD(TAG, "%s backlight.", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - -#if (ILI9163C_BCKL_ACTIVE_LVL == 1) - tmp = backlight ? 1 : 0; -#else - tmp = backlight ? 0 : 1; -#endif - - gpio_set_level(ILI9163C_BCKL, tmp); -#endif -} - void ili9163c_sleep_in() { uint8_t data[] = {0x08}; diff --git a/lvgl_tft/ili9163c.h b/lvgl_tft/ili9163c.h index f164ba80..d6edf579 100644 --- a/lvgl_tft/ili9163c.h +++ b/lvgl_tft/ili9163c.h @@ -26,35 +26,24 @@ extern "C" /********************* * DEFINES *********************/ -#define ILI9163C_DC CONFIG_LV_DISP_PIN_DC -#define ILI9163C_RST CONFIG_LV_DISP_PIN_RST -#define ILI9163C_BCKL CONFIG_LV_DISP_PIN_BCKL - -#define ILI9163C_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL - -#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL -#define ILI9163C_BCKL_ACTIVE_LVL 1 -#else -#define ILI9163C_BCKL_ACTIVE_LVL 0 -#endif - +#define ILI9163C_DC CONFIG_LV_DISP_PIN_DC +#define ILI9163C_RST CONFIG_LV_DISP_PIN_RST #define ILI9163C_INVERT_COLORS CONFIG_LV_INVERT_COLORS - /********************** +/********************** * TYPEDEFS **********************/ - /********************** +/********************** * GLOBAL PROTOTYPES **********************/ - void ili9163c_init(void); - void ili9163c_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map); - void ili9163c_enable_backlight(bool backlight); - void ili9163c_sleep_in(void); - void ili9163c_sleep_out(void); +void ili9163c_init(void); +void ili9163c_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map); +void ili9163c_sleep_in(void); +void ili9163c_sleep_out(void); - /********************** +/********************** * MACROS **********************/ diff --git a/lvgl_tft/ili9341.c b/lvgl_tft/ili9341.c index 23aba09c..e91680f1 100644 --- a/lvgl_tft/ili9341.c +++ b/lvgl_tft/ili9341.c @@ -80,30 +80,14 @@ void ili9341_init(void) {0, {0}, 0xff}, }; -#if ILI9341_BCKL == 15 - gpio_config_t io_conf; - io_conf.intr_type = GPIO_PIN_INTR_DISABLE; - io_conf.mode = GPIO_MODE_OUTPUT; - io_conf.pin_bit_mask = GPIO_SEL_15; - io_conf.pull_down_en = GPIO_PULLDOWN_DISABLE; - io_conf.pull_up_en = GPIO_PULLUP_DISABLE; - gpio_config(&io_conf); -#endif - //Initialize non-SPI GPIOs - gpio_pad_select_gpio(ILI9341_DC); + gpio_pad_select_gpio(ILI9341_DC); gpio_set_direction(ILI9341_DC, GPIO_MODE_OUTPUT); + #if ILI9341_USE_RST - gpio_pad_select_gpio(ILI9341_RST); + gpio_pad_select_gpio(ILI9341_RST); gpio_set_direction(ILI9341_RST, GPIO_MODE_OUTPUT); -#endif - -#if ILI9341_ENABLE_BACKLIGHT_CONTROL - gpio_pad_select_gpio(ILI9341_BCKL); - gpio_set_direction(ILI9341_BCKL, GPIO_MODE_OUTPUT); -#endif -#if ILI9341_USE_RST //Reset the display gpio_set_level(ILI9341_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); @@ -124,9 +108,7 @@ void ili9341_init(void) cmd++; } - ili9341_enable_backlight(true); - - ili9341_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); + ili9341_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); #if ILI9341_INVERT_COLORS == 1 ili9341_send_cmd(0x21); @@ -158,29 +140,10 @@ void ili9341_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * col /*Memory write*/ ili9341_send_cmd(0x2C); - - uint32_t size = lv_area_get_width(area) * lv_area_get_height(area); - ili9341_send_color((void*)color_map, size * 2); } -void ili9341_enable_backlight(bool backlight) -{ -#if ILI9341_ENABLE_BACKLIGHT_CONTROL - ESP_LOGI(TAG, "%s backlight.", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - -#if (ILI9341_BCKL_ACTIVE_LVL==1) - tmp = backlight ? 1 : 0; -#else - tmp = backlight ? 0 : 1; -#endif - - gpio_set_level(ILI9341_BCKL, tmp); -#endif -} - void ili9341_sleep_in() { uint8_t data[] = {0x08}; diff --git a/lvgl_tft/ili9341.h b/lvgl_tft/ili9341.h index e0058b11..62317e85 100644 --- a/lvgl_tft/ili9341.h +++ b/lvgl_tft/ili9341.h @@ -29,16 +29,6 @@ extern "C" { #define ILI9341_DC CONFIG_LV_DISP_PIN_DC #define ILI9341_USE_RST CONFIG_LV_DISP_USE_RST #define ILI9341_RST CONFIG_LV_DISP_PIN_RST -#define ILI9341_BCKL CONFIG_LV_DISP_PIN_BCKL - -#define ILI9341_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL - -#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL - #define ILI9341_BCKL_ACTIVE_LVL 1 -#else - #define ILI9341_BCKL_ACTIVE_LVL 0 -#endif - #define ILI9341_INVERT_COLORS CONFIG_LV_INVERT_COLORS /********************** @@ -51,7 +41,6 @@ extern "C" { void ili9341_init(void); void ili9341_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); -void ili9341_enable_backlight(bool backlight); void ili9341_sleep_in(void); void ili9341_sleep_out(void); diff --git a/lvgl_tft/ili9481.c b/lvgl_tft/ili9481.c index f80c8108..74bda98b 100644 --- a/lvgl_tft/ili9481.c +++ b/lvgl_tft/ili9481.c @@ -80,14 +80,7 @@ void ili9481_init(void) #if ILI9481_USE_RST gpio_pad_select_gpio(ILI9481_RST); gpio_set_direction(ILI9481_RST, GPIO_MODE_OUTPUT); -#endif - -#if ILI9481_ENABLE_BACKLIGHT_CONTROL - gpio_pad_select_gpio(ILI9481_BCKL); - gpio_set_direction(ILI9481_BCKL, GPIO_MODE_OUTPUT); -#endif -#if ILI9481_USE_RST //Reset the display gpio_set_level(ILI9481_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); @@ -112,8 +105,6 @@ void ili9481_init(void) cmd++; } - ili9481_enable_backlight(true); - ili9481_set_orientation(ILI9481_DISPLAY_ORIENTATION); } @@ -173,22 +164,6 @@ void ili9481_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * col heap_caps_free(mybuf); } -void ili9481_enable_backlight(bool backlight) -{ -#if ILI9481_ENABLE_BACKLIGHT_CONTROL - ESP_LOGI(TAG, "%s backlight.", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - -#if (ILI9481_BCKL_ACTIVE_LVL==1) - tmp = backlight ? 1 : 0; -#else - tmp = backlight ? 0 : 1; -#endif - - gpio_set_level(ILI9481_BCKL, tmp); -#endif -} - /********************** * STATIC FUNCTIONS **********************/ diff --git a/lvgl_tft/ili9481.h b/lvgl_tft/ili9481.h index c0d07fe8..15623987 100644 --- a/lvgl_tft/ili9481.h +++ b/lvgl_tft/ili9481.h @@ -25,20 +25,12 @@ extern "C" { /********************* * DEFINES *********************/ -#define ILI9481_DC CONFIG_LV_DISP_PIN_DC -#define ILI9481_RST CONFIG_LV_DISP_PIN_RST -#define ILI9481_USE_RST CONFIG_LV_DISP_USE_RST -#define ILI9481_BCKL CONFIG_LV_DISP_PIN_BCKL - -#define ILI9481_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL -#define ILI9481_INVERT_COLORS CONFIG_LV_INVERT_COLORS +#define ILI9481_DC CONFIG_LV_DISP_PIN_DC +#define ILI9481_RST CONFIG_LV_DISP_PIN_RST +#define ILI9481_USE_RST CONFIG_LV_DISP_USE_RST +#define ILI9481_INVERT_COLORS CONFIG_LV_INVERT_COLORS #define ILI9481_DISPLAY_ORIENTATION CONFIG_LV_DISPLAY_ORIENTATION -#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL - #define ILI9481_BCKL_ACTIVE_LVL 1 -#else - #define ILI9481_BCKL_ACTIVE_LVL 0 -#endif /******************* * ILI9481 REGS @@ -118,7 +110,6 @@ extern "C" { void ili9481_init(void); void ili9481_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); -void ili9481_enable_backlight(bool backlight); /********************** * MACROS diff --git a/lvgl_tft/ili9486.c b/lvgl_tft/ili9486.c index 166bef87..829f0bd8 100644 --- a/lvgl_tft/ili9486.c +++ b/lvgl_tft/ili9486.c @@ -65,31 +65,14 @@ void ili9486_init(void) {0x00, {0}, 0xff}, }; -#if ILI9486_BCKL == 15 - gpio_config_t io_conf; - io_conf.intr_type = GPIO_PIN_INTR_DISABLE; - io_conf.mode = GPIO_MODE_OUTPUT; - io_conf.pin_bit_mask = GPIO_SEL_15; - io_conf.pull_down_en = GPIO_PULLDOWN_DISABLE; - io_conf.pull_up_en = GPIO_PULLUP_DISABLE; - gpio_config(&io_conf); -#endif - //Initialize non-SPI GPIOs - gpio_pad_select_gpio(ILI9486_DC); + gpio_pad_select_gpio(ILI9486_DC); gpio_set_direction(ILI9486_DC, GPIO_MODE_OUTPUT); #if ILI9486_USE_RST - gpio_pad_select_gpio(ILI9486_RST); + gpio_pad_select_gpio(ILI9486_RST); gpio_set_direction(ILI9486_RST, GPIO_MODE_OUTPUT); -#endif -#if ILI9486_ENABLE_BACKLIGHT_CONTROL - gpio_pad_select_gpio(ILI9486_BCKL); - gpio_set_direction(ILI9486_BCKL, GPIO_MODE_OUTPUT); -#endif - -#if ILI9486_USE_RST //Reset the display gpio_set_level(ILI9486_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); @@ -110,9 +93,7 @@ void ili9486_init(void) cmd++; } - ili9486_enable_backlight(true); - - ili9486_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); + ili9486_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); } void ili9486_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map) @@ -144,22 +125,6 @@ void ili9486_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * col ili9486_send_color((void*) color_map, size * 2); } -void ili9486_enable_backlight(bool backlight) -{ -#if ILI9486_ENABLE_BACKLIGHT_CONTROL - ESP_LOGI(TAG, "%s backlight.", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - -#if (ILI9486_BCKL_ACTIVE_LVL==1) - tmp = backlight ? 1 : 0; -#else - tmp = backlight ? 0 : 1; -#endif - - gpio_set_level(ILI9486_BCKL, tmp); -#endif -} - /********************** * STATIC FUNCTIONS **********************/ diff --git a/lvgl_tft/ili9486.h b/lvgl_tft/ili9486.h index 08e002f4..0b3f4fb7 100644 --- a/lvgl_tft/ili9486.h +++ b/lvgl_tft/ili9486.h @@ -28,15 +28,7 @@ extern "C" { #define ILI9486_DC CONFIG_LV_DISP_PIN_DC #define ILI9486_RST CONFIG_LV_DISP_PIN_RST #define ILI9486_USE_RST CONFIG_LV_DISP_USE_RST -#define ILI9486_BCKL CONFIG_LV_DISP_PIN_BCKL -#define ILI9486_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL - -#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL - #define ILI9486_BCKL_ACTIVE_LVL 1 -#else - #define ILI9486_BCKL_ACTIVE_LVL 0 -#endif /********************** * TYPEDEFS @@ -48,7 +40,6 @@ extern "C" { void ili9486_init(void); void ili9486_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); -void ili9486_enable_backlight(bool backlight); /********************** * MACROS diff --git a/lvgl_tft/ili9488.c b/lvgl_tft/ili9488.c index ce8bba08..feb9fbaf 100644 --- a/lvgl_tft/ili9488.c +++ b/lvgl_tft/ili9488.c @@ -76,20 +76,13 @@ void ili9488_init(void) }; //Initialize non-SPI GPIOs - gpio_pad_select_gpio(ILI9488_DC); + gpio_pad_select_gpio(ILI9488_DC); gpio_set_direction(ILI9488_DC, GPIO_MODE_OUTPUT); #if ILI9488_USE_RST - gpio_pad_select_gpio(ILI9488_RST); + gpio_pad_select_gpio(ILI9488_RST); gpio_set_direction(ILI9488_RST, GPIO_MODE_OUTPUT); -#endif - -#if ILI9488_ENABLE_BACKLIGHT_CONTROL - gpio_pad_select_gpio(ILI9488_BCKL); - gpio_set_direction(ILI9488_BCKL, GPIO_MODE_OUTPUT); -#endif -#if ILI9488_USE_RST //Reset the display gpio_set_level(ILI9488_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); @@ -114,9 +107,7 @@ void ili9488_init(void) cmd++; } - ili9488_enable_backlight(true); - - ili9488_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); + ili9488_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); } // Flush function based on mvturnho repo @@ -175,22 +166,6 @@ void ili9488_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * col heap_caps_free(mybuf); } -void ili9488_enable_backlight(bool backlight) -{ -#if ILI9488_ENABLE_BACKLIGHT_CONTROL - ESP_LOGI(TAG, "%s backlight.", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - -#if (ILI9488_BCKL_ACTIVE_LVL==1) - tmp = backlight ? 1 : 0; -#else - tmp = backlight ? 0 : 1; -#endif - - gpio_set_level(ILI9488_BCKL, tmp); -#endif -} - /********************** * STATIC FUNCTIONS **********************/ diff --git a/lvgl_tft/ili9488.h b/lvgl_tft/ili9488.h index 2ecfd447..1c6c6f93 100644 --- a/lvgl_tft/ili9488.h +++ b/lvgl_tft/ili9488.h @@ -27,16 +27,7 @@ extern "C" { *********************/ #define ILI9488_DC CONFIG_LV_DISP_PIN_DC #define ILI9488_RST CONFIG_LV_DISP_PIN_RST -#define ILI9488_USE_RST CONFIG_LV_DISP_USE_RST -#define ILI9488_BCKL CONFIG_LV_DISP_PIN_BCKL - -#define ILI9488_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL - -#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL - #define ILI9488_BCKL_ACTIVE_LVL 1 -#else - #define ILI9488_BCKL_ACTIVE_LVL 0 -#endif +#define ILI9488_USE_RST CONFIG_LV_DISP_USE_RSTS /******************* * ILI9488 REGS @@ -155,7 +146,6 @@ typedef struct { void ili9488_init(void); void ili9488_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); -void ili9488_enable_backlight(bool backlight); /********************** * MACROS diff --git a/lvgl_tft/ra8875.c b/lvgl_tft/ra8875.c index c08ff887..b4f8e2ac 100644 --- a/lvgl_tft/ra8875.c +++ b/lvgl_tft/ra8875.c @@ -148,29 +148,12 @@ void ra8875_init(void) ESP_LOGI(TAG, "Initializing RA8875..."); -#if (CONFIG_LV_DISP_PIN_BCKL == 15) - gpio_config_t io_conf; - io_conf.intr_type = GPIO_PIN_INTR_DISABLE; - io_conf.mode = GPIO_MODE_OUTPUT; - io_conf.pin_bit_mask = GPIO_SEL_15; - io_conf.pull_down_en = GPIO_PULLDOWN_DISABLE; - io_conf.pull_up_en = GPIO_PULLUP_DISABLE; - gpio_config(&io_conf); -#endif - // Initialize non-SPI GPIOs #if RA8875_USE_RST gpio_pad_select_gpio(RA8875_RST); gpio_set_direction(RA8875_RST, GPIO_MODE_OUTPUT); -#endif - -#ifdef CONFIG_LV_DISP_PIN_BCKL - gpio_pad_select_gpio(CONFIG_LV_DISP_PIN_BCKL); - gpio_set_direction(CONFIG_LV_DISP_PIN_BCKL, GPIO_MODE_OUTPUT); -#endif -#if RA8875_USE_RST // Reset the RA8875 gpio_set_level(RA8875_RST, 0); vTaskDelay(DIV_ROUND_UP(100, portTICK_RATE_MS)); @@ -200,28 +183,8 @@ void ra8875_init(void) ESP_LOGW(TAG, "WARNING: Memory clear timed out; RA8875 may be unresponsive."); } - // Enable the display and backlight + // Enable the display ra8875_enable_display(true); - ra8875_enable_backlight(true); -} - -void ra8875_enable_backlight(bool backlight) -{ -#if CONFIG_LV_ENABLE_BACKLIGHT_CONTROL - ESP_LOGI(TAG, "%s backlight.", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - - #if CONFIG_LV_BACKLIGHT_ACTIVE_LVL - tmp = backlight ? 1 : 0; - #else - tmp = backlight ? 0 : 1; - #endif - -#ifdef CONFIG_LV_DISP_PIN_BCKL - gpio_set_level(CONFIG_LV_DISP_PIN_BCKL, tmp); -#endif - -#endif } void ra8875_enable_display(bool enable) diff --git a/lvgl_tft/ra8875.h b/lvgl_tft/ra8875.h index 6942c3e9..28c77f9d 100644 --- a/lvgl_tft/ra8875.h +++ b/lvgl_tft/ra8875.h @@ -97,7 +97,6 @@ extern "C" { **********************/ void ra8875_init(void); -void ra8875_enable_backlight(bool backlight); void ra8875_enable_display(bool enable); void ra8875_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); diff --git a/lvgl_tft/st7735s.h b/lvgl_tft/st7735s.h index 7422be6a..2d02ed05 100644 --- a/lvgl_tft/st7735s.h +++ b/lvgl_tft/st7735s.h @@ -131,7 +131,6 @@ extern "C" { void st7735s_init(void); void st7735s_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); -void st7735s_enable_backlight(bool backlight); void st7735s_sleep_in(void); void st7735s_sleep_out(void); diff --git a/lvgl_tft/st7789.c b/lvgl_tft/st7789.c index 9a790227..962eb445 100644 --- a/lvgl_tft/st7789.c +++ b/lvgl_tft/st7789.c @@ -94,11 +94,6 @@ void st7789_init(void) gpio_set_direction(ST7789_RST, GPIO_MODE_OUTPUT); #endif -#if ST7789_ENABLE_BACKLIGHT_CONTROL - gpio_pad_select_gpio(ST7789_BCKL); - gpio_set_direction(ST7789_BCKL, GPIO_MODE_OUTPUT); -#endif - //Reset the display #if !defined(ST7789_SOFT_RST) gpio_set_level(ST7789_RST, 0); @@ -122,27 +117,9 @@ void st7789_init(void) cmd++; } - st7789_enable_backlight(true); - st7789_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); } -void st7789_enable_backlight(bool backlight) -{ -#if ST7789_ENABLE_BACKLIGHT_CONTROL - printf("%s backlight.\n", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - -#if (ST7789_BCKL_ACTIVE_LVL==1) - tmp = backlight ? 1 : 0; -#else - tmp = backlight ? 0 : 1; -#endif - - gpio_set_level(ST7789_BCKL, tmp); -#endif -} - /* The ST7789 display controller can drive 320*240 displays, when using a 240*240 * display there's a gap of 80px, we need to edit the coordinates to take into * account that gap, this is not necessary in all orientations. */ diff --git a/lvgl_tft/st7789.h b/lvgl_tft/st7789.h index 64ac3f12..cacb31ba 100644 --- a/lvgl_tft/st7789.h +++ b/lvgl_tft/st7789.h @@ -23,7 +23,6 @@ extern "C" #define ST7789_DC CONFIG_LV_DISP_PIN_DC #define ST7789_RST CONFIG_LV_DISP_PIN_RST -#define ST7789_BCKL CONFIG_LV_DISP_PIN_BCKL #if CONFIG_LV_DISP_USE_RST #if CONFIG_LV_DISP_ST7789_SOFT_RESET @@ -33,16 +32,8 @@ extern "C" #define ST7789_SOFT_RST #endif - -#define ST7789_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL #define ST7789_INVERT_COLORS CONFIG_LV_INVERT_COLORS -#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL - #define ST7789_BCKL_ACTIVE_LVL 1 -#else - #define ST7789_BCKL_ACTIVE_LVL 0 -#endif - /* ST7789 commands */ #define ST7789_NOP 0x00 #define ST7789_SWRESET 0x01 @@ -121,7 +112,6 @@ extern "C" void st7789_init(void); void st7789_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map); -void st7789_enable_backlight(bool backlight); void st7789_send_cmd(uint8_t cmd); void st7789_send_data(void *data, uint16_t length); diff --git a/lvgl_tft/st7796s.c b/lvgl_tft/st7796s.c index 44959f8d..7de92ef0 100644 --- a/lvgl_tft/st7796s.c +++ b/lvgl_tft/st7796s.c @@ -81,16 +81,6 @@ void st7796s_init(void) {0, {0}, 0xff}, }; -#if ST7796S_BCKL == 15 - gpio_config_t io_conf; - io_conf.intr_type = GPIO_PIN_INTR_DISABLE; - io_conf.mode = GPIO_MODE_OUTPUT; - io_conf.pin_bit_mask = GPIO_SEL_15; - io_conf.pull_down_en = GPIO_PULLDOWN_DISABLE; - io_conf.pull_up_en = GPIO_PULLUP_DISABLE; - gpio_config(&io_conf); -#endif - //Initialize non-SPI GPIOs gpio_pad_select_gpio(ST7796S_DC); gpio_set_direction(ST7796S_DC, GPIO_MODE_OUTPUT); @@ -98,14 +88,7 @@ void st7796s_init(void) #if ST7796S_USE_RST gpio_pad_select_gpio(ST7796S_RST); gpio_set_direction(ST7796S_RST, GPIO_MODE_OUTPUT); -#endif - -#if ST7796S_ENABLE_BACKLIGHT_CONTROL - gpio_pad_select_gpio(ST7796S_BCKL); - gpio_set_direction(ST7796S_BCKL, GPIO_MODE_OUTPUT); -#endif -#if ST7796S_USE_RST //Reset the display gpio_set_level(ST7796S_RST, 0); vTaskDelay(100 / portTICK_RATE_MS); @@ -128,8 +111,6 @@ void st7796s_init(void) cmd++; } - st7796s_enable_backlight(true); - st7796s_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); #if ST7796S_INVERT_COLORS == 1 @@ -167,22 +148,6 @@ void st7796s_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_ st7796s_send_color((void *)color_map, size * 2); } -void st7796s_enable_backlight(bool backlight) -{ -#if ST7796S_ENABLE_BACKLIGHT_CONTROL - ESP_LOGI(TAG, "%s backlight.", backlight ? "Enabling" : "Disabling"); - uint32_t tmp = 0; - -#if (ST7796S_BCKL_ACTIVE_LVL == 1) - tmp = backlight ? 1 : 0; -#else - tmp = backlight ? 0 : 1; -#endif - - gpio_set_level(ST7796S_BCKL, tmp); -#endif -} - void st7796s_sleep_in() { uint8_t data[] = {0x08}; diff --git a/lvgl_tft/st7796s.h b/lvgl_tft/st7796s.h index 48e566d0..95c6d4fe 100644 --- a/lvgl_tft/st7796s.h +++ b/lvgl_tft/st7796s.h @@ -26,20 +26,12 @@ extern "C" /********************* * DEFINES *********************/ -#define ST7796S_DC CONFIG_LV_DISP_PIN_DC -#define ST7796S_RST CONFIG_LV_DISP_PIN_RST -#define ST7796S_USE_RST CONFIG_LV_DISP_USE_RST -#define ST7796S_BCKL CONFIG_LV_DISP_PIN_BCKL - -#define ST7796S_ENABLE_BACKLIGHT_CONTROL CONFIG_LV_ENABLE_BACKLIGHT_CONTROL -#define ST7796S_INVERT_COLORS CONFIG_LV_INVERT_COLORS +#define ST7796S_DC CONFIG_LV_DISP_PIN_DC +#define ST7796S_RST CONFIG_LV_DISP_PIN_RST +#define ST7796S_USE_RST CONFIG_LV_DISP_USE_RST +#define ST7796S_INVERT_COLORS CONFIG_LV_INVERT_COLORS #define ST7796S_DISPLAY_ORIENTATION CONFIG_LV_DISPLAY_ORIENTATION -#if CONFIG_LV_BACKLIGHT_ACTIVE_LVL -#define ST7796S_BCKL_ACTIVE_LVL 1 -#else -#define ST7796S_BCKL_ACTIVE_LVL 0 -#endif /******************* * ST7796S REGS @@ -119,7 +111,6 @@ extern "C" void st7796s_init(void); void st7796s_flush(lv_disp_drv_t *drv, const lv_area_t *area, lv_color_t *color_map); - void st7796s_enable_backlight(bool backlight); /********************** * MACROS From 11c240daca5ed8ca13768a69be6aa8455ff5f0f2 Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Tue, 3 Aug 2021 16:59:40 +0200 Subject: [PATCH 44/70] Support IDF version < v4.3 --- lvgl_tft/esp_lcd_backlight.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/lvgl_tft/esp_lcd_backlight.c b/lvgl_tft/esp_lcd_backlight.c index d8724e60..26074051 100644 --- a/lvgl_tft/esp_lcd_backlight.c +++ b/lvgl_tft/esp_lcd_backlight.c @@ -10,7 +10,8 @@ #include "driver/ledc.h" #include "driver/gpio.h" #include "esp_log.h" -#include "esp_rom_gpio.h" // for output signal inversion +#include "esp_rom_gpio.h" // for output signal inversion +#include "soc/ledc_periph.h" // to invert LEDC output on IDF version < v4.3 typedef struct { bool pwm_control; // true: LEDC is used, false: GPIO is used @@ -40,8 +41,7 @@ disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config) .intr_type = LEDC_INTR_DISABLE, .timer_sel = config->timer_idx, .duty = 0, - .hpoint = 0, - .flags.output_invert = config->output_invert //@todo added only in recent IDF versions + .hpoint = 0 }; const ledc_timer_config_t LCD_backlight_timer = { .speed_mode = LEDC_LOW_SPEED_MODE, @@ -52,6 +52,7 @@ disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config) ESP_ERROR_CHECK(ledc_timer_config(&LCD_backlight_timer)); ESP_ERROR_CHECK(ledc_channel_config(&LCD_backlight_channel)); + 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); } else { From 2d6ea1330c8c72ec8dd8ab8527efdea4de189699 Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Wed, 4 Aug 2021 09:38:05 +0200 Subject: [PATCH 45/70] Provide README section about backlight control --- README.md | 12 ++++++++++++ lvgl_tft/esp_lcd_backlight.h | 3 ++- 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 19084177..a664636a 100644 --- a/README.md +++ b/README.md @@ -7,6 +7,7 @@ For a ready to use ESP32 project take look at the [lv_port_esp32](https://github - [Supported indev controllers](#supported-indev-controllers) - [Support for predefined development kits](#support-for-predefined-development-kits) - [Thread-safe I2C with I2C Manager](#thread-safe-i2c-with-i2c-manager) +- [Backlight control](#backlight-control) **NOTE:** You need to set the display horizontal and vertical size, color depth and swap of RGB565 color on the LVGL configuration menuconfig (it's not handled automatically). @@ -79,3 +80,14 @@ talk to devices on the I2C ports without getting in each other's way. These driv use a built-in copy of I2C Manager to talk to the I2C port, but you can also use the I2C Manager component itself and have others play nice with LVGL and vice-versa. [Click here](i2c_manager/README.md) for details. + + +## Backlight control + +Control of LCD's backlight is provided by separate module that is independent from the display driver. +Configuration of the backlight controller can be found in menuconfig `LVGL ESP Drivers -> LVGL TFT Display controller`. + +There are three modes of operation: +1. Off - No backlight control +2. Switch - Allows ON/OFF control +3. PWM - Allows brightness control (by Pulse-Width-Modulated signal) diff --git a/lvgl_tft/esp_lcd_backlight.h b/lvgl_tft/esp_lcd_backlight.h index a04817bb..8deda9fd 100644 --- a/lvgl_tft/esp_lcd_backlight.h +++ b/lvgl_tft/esp_lcd_backlight.h @@ -27,6 +27,7 @@ typedef void * disp_backlight_h; /** * @brief Configuration structure of backlight controller * + * Must be passed to disp_backlight_new() for correct configuration */ typedef struct { bool pwm_control; @@ -35,7 +36,7 @@ typedef struct { // Relevant only for PWM controlled backlight // Ignored for switch (ON/OFF) backlight control - int timer_idx; // ledc_timer_t + int timer_idx; // ledc_timer_t int channel_idx; // ledc_channel_t } disp_backlight_config_t; From 607df9ab94e932f267e56df90ce3e02d2c2828a6 Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Wed, 11 Aug 2021 09:48:49 +0200 Subject: [PATCH 46/70] Don't call backlight function when backlight is disabled --- lvgl_tft/Kconfig | 11 ++--------- lvgl_tft/disp_driver.c | 13 +++++-------- lvgl_tft/esp_lcd_backlight.c | 7 ++++++- 3 files changed, 13 insertions(+), 18 deletions(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 7b94d46b..f42351e7 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -934,16 +934,9 @@ menu "LVGL TFT Display controller" endchoice choice + default LV_DISP_BACKLIGHT_SWITCH prompt "Backlight Control" if \ (! ( LV_TFT_DISPLAY_CONTROLLER_SH1107 || LV_TFT_DISPLAY_CONTROLLER_SSD1306 ) ) - default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_M5STACK - default LV_DISP_BACKLIGHT_OFF if LV_PREDEFINED_DISPLAY_M5CORE2 - default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_WROVER4 - default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_ERTFT0356 - default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_TTGO - default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS - default LV_DISP_BACKLIGHT_SWITCH if LV_PREDEFINED_DISPLAY_WT32_SC01 - default LV_DISP_BACKLIGHT_OFF config LV_DISP_BACKLIGHT_OFF bool @@ -995,7 +988,7 @@ menu "LVGL TFT Display controller" default 4 if LV_PREDEFINED_DISPLAY_TTGO default 2 if LV_PREDEFINED_DISPLAY_TTGO_CAMERA_PLUS default 23 if LV_PREDEFINED_DISPLAY_WT32_SC01 - default 27 + default -1 help Configure the display BCLK (LED) pin here. diff --git a/lvgl_tft/disp_driver.c b/lvgl_tft/disp_driver.c index 0d771550..f62a947f 100644 --- a/lvgl_tft/disp_driver.c +++ b/lvgl_tft/disp_driver.c @@ -47,7 +47,7 @@ void *disp_driver_init(void) // We still use menuconfig for these settings // It will be set up during runtime in the future -#ifndef CONFIG_LV_DISP_BACKLIGHT_OFF +#if (defined(CONFIG_LV_DISP_BACKLIGHT_SWITCH) || defined(CONFIG_LV_DISP_BACKLIGHT_PWM)) const disp_backlight_config_t bckl_config = { .gpio_num = CONFIG_LV_DISP_PIN_BCKL, #if defined CONFIG_LV_DISP_BACKLIGHT_PWM @@ -63,15 +63,12 @@ void *disp_driver_init(void) .timer_idx = 0, .channel_idx = 0 // @todo this prevents us from having two PWM controlled displays }; - const disp_backlight_config_t *bckl_config_p = &bckl_config; -#else - const disp_backlight_config_t *bckl_config_p = NULL; -#endif - - disp_backlight_h bckl_handle = disp_backlight_new(bckl_config_p); + disp_backlight_h bckl_handle = disp_backlight_new(&bckl_config); disp_backlight_set(bckl_handle, 100); - return bckl_handle; +#else + return NULL; +#endif } void disp_driver_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map) diff --git a/lvgl_tft/esp_lcd_backlight.c b/lvgl_tft/esp_lcd_backlight.c index 26074051..d90e6718 100644 --- a/lvgl_tft/esp_lcd_backlight.c +++ b/lvgl_tft/esp_lcd_backlight.c @@ -22,11 +22,16 @@ static const char *TAG = "disp_backlight"; disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config) { + // Check input parameters if (config == NULL) return NULL; + if (!GPIO_IS_VALID_OUTPUT_GPIO(config->gpio_num)) { + ESP_LOGW(TAG, "Invalid GPIO number"); + return NULL; + } disp_backlight_t *bckl_dev = calloc(1, sizeof(disp_backlight_t)); if (bckl_dev == NULL){ - ESP_LOGW(TAG, "Could not create new LCD backlight instance"); + ESP_LOGW(TAG, "Not enough memory"); return NULL; } From 5043946699f3e34d0f90d3fa9d31aee6ae081485 Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Wed, 11 Aug 2021 22:17:02 +0200 Subject: [PATCH 47/70] Fix build on idf v4.1 and v4.2 --- lvgl_tft/esp_lcd_backlight.c | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/lvgl_tft/esp_lcd_backlight.c b/lvgl_tft/esp_lcd_backlight.c index d90e6718..f4395bda 100644 --- a/lvgl_tft/esp_lcd_backlight.c +++ b/lvgl_tft/esp_lcd_backlight.c @@ -10,7 +10,6 @@ #include "driver/ledc.h" #include "driver/gpio.h" #include "esp_log.h" -#include "esp_rom_gpio.h" // for output signal inversion #include "soc/ledc_periph.h" // to invert LEDC output on IDF version < v4.3 typedef struct { @@ -57,7 +56,7 @@ disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config) ESP_ERROR_CHECK(ledc_timer_config(&LCD_backlight_timer)); ESP_ERROR_CHECK(ledc_channel_config(&LCD_backlight_channel)); - 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); + gpio_matrix_out(config->gpio_num, ledc_periph_signal[LEDC_LOW_SPEED_MODE].sig_out0_idx + config->channel_idx, config->output_invert, 0); } else { @@ -65,7 +64,7 @@ disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config) bckl_dev->index = config->gpio_num; gpio_pad_select_gpio(config->gpio_num); ESP_ERROR_CHECK(gpio_set_direction(config->gpio_num, GPIO_MODE_OUTPUT)); - esp_rom_gpio_connect_out_signal(config->gpio_num, SIG_GPIO_OUT_IDX, config->output_invert, false); + gpio_matrix_out(config->gpio_num, SIG_GPIO_OUT_IDX, config->output_invert, false); } return (disp_backlight_h)bckl_dev; From ee36378f54a957fe025cfbfd7e67c2f8bbd01696 Mon Sep 17 00:00:00 2001 From: Kevin Sidwar Date: Thu, 12 Aug 2021 23:48:23 -0600 Subject: [PATCH 48/70] Change config naming for ssd1306 to use LV_ prefix --- lvgl_tft/Kconfig | 8 ++++---- lvgl_tft/ssd1306.c | 4 ++-- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index e45db6a2..62b7f3ad 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -222,15 +222,15 @@ menu "LVGL TFT Display controller" config LV_TFT_DISPLAY_X_OFFSET depends on LV_TFT_DISPLAY_OFFSETS int "X offset" - default 40 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_LANDSCAPE || DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) - default 53 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_PORTRAIT || DISPLAY_ORIENTATION_PORTRAIT_INVERTED) + default 40 if LV_PREDEFINED_DISPLAY_TTGO && (LV_DISPLAY_ORIENTATION_LANDSCAPE || LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) + default 53 if LV_PREDEFINED_DISPLAY_TTGO && (LV_DISPLAY_ORIENTATION_PORTRAIT || LV_DISPLAY_ORIENTATION_PORTRAIT_INVERTED) default 0 config LV_TFT_DISPLAY_Y_OFFSET depends on LV_TFT_DISPLAY_OFFSETS int "Y offset" - default 53 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_LANDSCAPE || DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) - default 40 if LV_PREDEFINED_DISPLAY_TTGO && (DISPLAY_ORIENTATION_PORTRAIT || DISPLAY_ORIENTATION_PORTRAIT_INVERTED) + default 53 if LV_PREDEFINED_DISPLAY_TTGO && (LV_DISPLAY_ORIENTATION_LANDSCAPE || LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) + default 40 if LV_PREDEFINED_DISPLAY_TTGO && (LV_DISPLAY_ORIENTATION_PORTRAIT || LV_DISPLAY_ORIENTATION_PORTRAIT_INVERTED) default 0 diff --git a/lvgl_tft/ssd1306.c b/lvgl_tft/ssd1306.c index 5953d445..c845eac6 100644 --- a/lvgl_tft/ssd1306.c +++ b/lvgl_tft/ssd1306.c @@ -99,10 +99,10 @@ void ssd1306_init(void) uint8_t orientation_1 = 0; uint8_t orientation_2 = 0; -#if defined (CONFIG_DISPLAY_ORIENTATION_LANDSCAPE) +#if defined (CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE) orientation_1 = OLED_CMD_SET_SEGMENT_REMAP; orientation_2 = OLED_CMD_SET_COM_SCAN_MODE_REMAP; -#elif defined (CONFIG_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) +#elif defined (CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) orientation_1 = 0xA0; orientation_2 = OLED_CMD_SET_COM_SCAN_MODE_NORMAL; #else From 171cd5391533a34994efeae590f53183bb2cf510 Mon Sep 17 00:00:00 2001 From: chenghongyao <1253146300@qq.com> Date: Sun, 15 Aug 2021 12:52:34 +0800 Subject: [PATCH 49/70] fix data length overflow --- lvgl_tft/st7789.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lvgl_tft/st7789.c b/lvgl_tft/st7789.c index 962eb445..3e47a596 100644 --- a/lvgl_tft/st7789.c +++ b/lvgl_tft/st7789.c @@ -35,7 +35,7 @@ typedef struct { **********************/ static void st7789_set_orientation(uint8_t orientation); -static void st7789_send_color(void *data, uint16_t length); +static void st7789_send_color(void *data, size_t length); /********************** * STATIC VARIABLES @@ -167,7 +167,7 @@ void st7789_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo /*Memory write*/ st7789_send_cmd(ST7789_RAMWR); - uint32_t size = lv_area_get_width(area) * lv_area_get_height(area); + size_t size = (size_t)lv_area_get_width(area) * (size_t)lv_area_get_height(area); st7789_send_color((void*)color_map, size * 2); @@ -190,7 +190,7 @@ void st7789_send_data(void * data, uint16_t length) disp_spi_send_data(data, length); } -static void st7789_send_color(void * data, uint16_t length) +static void st7789_send_color(void * data, size_t length) { disp_wait_for_pending_transactions(); gpio_set_level(ST7789_DC, 1); From 88628042e6d09be9fb6fd323e765b4c4038968c2 Mon Sep 17 00:00:00 2001 From: C47D Date: Tue, 28 Sep 2021 20:51:36 -0500 Subject: [PATCH 50/70] FT6X36: Fix coordinates invesion The coordinates need to be swapped before inveting them when swapping is enabled. Suggested in #118 by @wreyford --- lvgl_touch/ft6x36.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lvgl_touch/ft6x36.c b/lvgl_touch/ft6x36.c index 9e348459..fcef5966 100644 --- a/lvgl_touch/ft6x36.c +++ b/lvgl_touch/ft6x36.c @@ -118,16 +118,16 @@ bool ft6x36_read(lv_indev_drv_t *drv, lv_indev_data_t *data) { last_x = ((data_buf[1] & FT6X36_MSB_MASK) << 8) | (data_buf[2] & FT6X36_LSB_MASK); last_y = ((data_buf[3] & FT6X36_MSB_MASK) << 8) | (data_buf[4] & FT6X36_LSB_MASK); +#if CONFIG_LV_FT6X36_SWAPXY + int16_t swap_buf = last_x; + last_x = last_y; + last_y = swap_buf; +#endif #if CONFIG_LV_FT6X36_INVERT_X last_x = LV_HOR_RES - last_x; #endif #if CONFIG_LV_FT6X36_INVERT_Y last_y = LV_VER_RES - last_y; -#endif -#if CONFIG_LV_FT6X36_SWAPXY - int16_t swap_buf = last_x; - last_x = last_y; - last_y = swap_buf; #endif data->point.x = last_x; data->point.y = last_y; From 83eba9b04cc212a01051e6839fe31455ae58499b Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Fri, 15 Oct 2021 15:37:36 +0200 Subject: [PATCH 51/70] Fixes potential ESP-IDF config editor crash (#115) --- lvgl_i2c/Kconfig | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lvgl_i2c/Kconfig b/lvgl_i2c/Kconfig index 4011bcf5..48df924e 100644 --- a/lvgl_i2c/Kconfig +++ b/lvgl_i2c/Kconfig @@ -6,8 +6,10 @@ menu "I2C Port 0" if I2C_MANAGER_0_ENABLED config I2C_MANAGER_0_SDA int "SDA (GPIO pin)" + default 0 config I2C_MANAGER_0_SCL int "SCL (GPIO pin)" + default 0 config I2C_MANAGER_0_FREQ_HZ int "Frequency (Hz)" default 400000 From db3d00e3744a5884c60ba8a8c13239bdd29194d2 Mon Sep 17 00:00:00 2001 From: Rop Gonggrijp Date: Fri, 15 Oct 2021 15:38:16 +0200 Subject: [PATCH 52/70] Addresses confusion: I2C manager component install only when others need I2C too. See #115 --- lvgl_i2c/README.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/lvgl_i2c/README.md b/lvgl_i2c/README.md index fb74e279..90f37289 100644 --- a/lvgl_i2c/README.md +++ b/lvgl_i2c/README.md @@ -8,9 +8,11 @@ ### I2C Manager support -`lvgl_esp32_drivers` integrates [I2C Manager](https://github.com/ropg/i2c_manager), which is used in case you select a touch sensor or screen that uses the I2C bus. If you're just using LVGL you don't need to do anything special. +`lvgl_esp32_drivers` integrates [I2C Manager](https://github.com/ropg/i2c_manager), which is used in case you select a touch sensor or screen that uses the I2C bus. -I2C Manager can help if you are in a situation where you want to avoid "bus conflicts" on the I2C bus. Suppose you use LVGL with a touch sensor that uses I2C, and your device also has another I2C device that needs to be read frequently, such as a 3D-accelerometer. ESP-IDF is not inherently "thread-safe". So if you read that from another task than the one LVGL uses to read the touch data, you need some kind of mechanism to keep these communications from interfering. +I2C Manager is also available as a separate ESP-IDF component and can help if you are in a situation where you want to avoid "bus conflicts" on the I2C bus. **If in your application nothing outside of LVGL needs to talk to the I2C bus, you can stop reading here.** + +Suppose you use LVGL with a touch sensor that uses I2C, and your device also has another I2C device that needs to be read frequently, such as a 3D-accelerometer. ESP-IDF is not inherently "thread-safe". So if you read that from another task than the one LVGL uses to read the touch data, you need some kind of mechanism to keep these communications from interfering. If you have (or write) a driver for that 3D-accelerometer that can use I2C Manager (or the I2C HAL and i2cdev abstraction layers that I2C Manager is compatible with) then put I2C Manager in your components directory by cloning the repository from below and in your main program do: From bd445ea30ad78b4311f7b5138fd12fad4e2e5c24 Mon Sep 17 00:00:00 2001 From: Rashed Talukder <> Date: Tue, 19 Oct 2021 17:27:27 -0700 Subject: [PATCH 53/70] Add touch input values to a FreeRTOS queue --- lvgl_touch/ft6x36.c | 55 ++++++++++++++++++++++++++++----------------- lvgl_touch/ft6x36.h | 11 +++++++++ 2 files changed, 46 insertions(+), 20 deletions(-) diff --git a/lvgl_touch/ft6x36.c b/lvgl_touch/ft6x36.c index fcef5966..a12752a0 100644 --- a/lvgl_touch/ft6x36.c +++ b/lvgl_touch/ft6x36.c @@ -29,16 +29,17 @@ #include "lvgl_i2c/i2c_manager.h" #define TAG "FT6X36" +#define FT6X36_TOUCH_QUEUE_ELEMENTS 1 -ft6x36_status_t ft6x36_status; -uint8_t current_dev_addr; // set during init +static ft6x36_status_t ft6x36_status; +static uint8_t current_dev_addr; // set during init +static ft6x36_touch_t touch_inputs = { -1, -1, LV_INDEV_STATE_REL }; // -1 coordinates to designate it was never touched -esp_err_t ft6x06_i2c_read8(uint8_t slave_addr, uint8_t register_addr, uint8_t *data_buf) { +static esp_err_t ft6x06_i2c_read8(uint8_t slave_addr, uint8_t register_addr, uint8_t *data_buf) { return lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, slave_addr, register_addr, data_buf, 1); } - /** * @brief Read the FT6x36 gesture ID. Initialize first! * @param dev_addr: I2C FT6x36 Slave address. @@ -84,7 +85,14 @@ void ft6x06_init(uint16_t dev_addr) { ft6x06_i2c_read8(dev_addr, FT6X36_RELEASECODE_REG, &data_buf); ESP_LOGI(TAG, "\tRelease code: 0x%02x", data_buf); - + + ft6x36_touch_queue_handle = xQueueCreate( FT6X36_TOUCH_QUEUE_ELEMENTS, sizeof( ft6x36_touch_t )); + if( ft6x36_touch_queue_handle == NULL ) + { + ESP_LOGE( TAG, "\tError creating touch input FreeRTOS queue" ); + return; + } + xQueueSend( ft6x36_touch_queue_handle, &touch_inputs, 0 ); } /** @@ -99,8 +107,6 @@ bool ft6x36_read(lv_indev_drv_t *drv, lv_indev_data_t *data) { return 0x00; } uint8_t data_buf[5]; // 1 byte status, 2 bytes X, 2 bytes Y - static int16_t last_x = 0; // 12bit pixel value - static int16_t last_y = 0; // 12bit pixel value esp_err_t ret = lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, current_dev_addr, FT6X36_TD_STAT_REG, &data_buf[0], 5); if (ret != ESP_OK) { @@ -109,29 +115,38 @@ bool ft6x36_read(lv_indev_drv_t *drv, lv_indev_data_t *data) { uint8_t touch_pnt_cnt = data_buf[0]; // Number of detected touch points if (ret != ESP_OK || touch_pnt_cnt != 1) { // ignore no touch & multi touch - data->point.x = last_x; - data->point.y = last_y; - data->state = LV_INDEV_STATE_REL; + if ( touch_inputs.current_state != LV_INDEV_STATE_REL) + { + touch_inputs.current_state = LV_INDEV_STATE_REL; + xQueueOverwrite( ft6x36_touch_queue_handle, &touch_inputs ); + } + data->point.x = touch_inputs.last_x; + data->point.y = touch_inputs.last_y; + data->state = touch_inputs.current_state; return false; } - last_x = ((data_buf[1] & FT6X36_MSB_MASK) << 8) | (data_buf[2] & FT6X36_LSB_MASK); - last_y = ((data_buf[3] & FT6X36_MSB_MASK) << 8) | (data_buf[4] & FT6X36_LSB_MASK); + touch_inputs.current_state = LV_INDEV_STATE_PR; + touch_inputs.last_x = ((data_buf[1] & FT6X36_MSB_MASK) << 8) | (data_buf[2] & FT6X36_LSB_MASK); + touch_inputs.last_y = ((data_buf[3] & FT6X36_MSB_MASK) << 8) | (data_buf[4] & FT6X36_LSB_MASK); #if CONFIG_LV_FT6X36_SWAPXY - int16_t swap_buf = last_x; - last_x = last_y; - last_y = swap_buf; + int16_t swap_buf = touch_inputs.last_x; + touch_inputs.last_x = touch_inputs.last_y; + touch_inputs.last_y = swap_buf; #endif #if CONFIG_LV_FT6X36_INVERT_X - last_x = LV_HOR_RES - last_x; + touch_inputs.last_x = LV_HOR_RES - touch_inputs.last_x; #endif #if CONFIG_LV_FT6X36_INVERT_Y - last_y = LV_VER_RES - last_y; + touch_inputs.last_y = LV_VER_RES - touch_inputs.last_y; #endif - data->point.x = last_x; - data->point.y = last_y; - data->state = LV_INDEV_STATE_PR; + data->point.x = touch_inputs.last_x; + data->point.y = touch_inputs.last_y; + data->state = touch_inputs.current_state; ESP_LOGD(TAG, "X=%u Y=%u", data->point.x, data->point.y); + + xQueueOverwrite( ft6x36_touch_queue_handle, &touch_inputs ); + return false; } diff --git a/lvgl_touch/ft6x36.h b/lvgl_touch/ft6x36.h index ace2997d..90f15073 100644 --- a/lvgl_touch/ft6x36.h +++ b/lvgl_touch/ft6x36.h @@ -23,6 +23,8 @@ #include #include +#include "freertos/FreeRTOS.h" +#include "freertos/queue.h" #ifdef LV_LVGL_H_INCLUDE_SIMPLE #include "lvgl.h" #else @@ -145,6 +147,15 @@ typedef struct { bool inited; } ft6x36_status_t; +typedef struct +{ + int16_t last_x; + int16_t last_y; + lv_indev_state_t current_state; +} ft6x36_touch_t; + +QueueHandle_t ft6x36_touch_queue_handle; + /** * @brief Initialize for FT6x36 communication via I2C * @param dev_addr: Device address on communication Bus (I2C slave address of FT6X36). From a56b80b362dbee31c40b98a475e8664f3d5da449 Mon Sep 17 00:00:00 2001 From: Rashed Talukder <> Date: Mon, 25 Oct 2021 11:53:26 -0700 Subject: [PATCH 54/70] Add kconfig symbol for optional coordinates queue --- lvgl_touch/Kconfig | 7 +++++++ lvgl_touch/ft6x36.c | 6 ++++++ lvgl_touch/ft6x36.h | 3 ++- 3 files changed, 15 insertions(+), 1 deletion(-) diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index de4d17b8..b9908aa1 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -201,6 +201,13 @@ menu "LVGL Touch controller" prompt "Invert Y coordinate value." default n + config LV_FT6X36_COORDINATES_QUEUE + bool + prompt "Send coordinates to FreeRTOS queue." + default n + help + Receive from the FreeRTOS queue using the handle 'ft6x36_touch_queue_handle'. + endmenu menu "Touchpanel (STMPE610) Pin Assignments" diff --git a/lvgl_touch/ft6x36.c b/lvgl_touch/ft6x36.c index a12752a0..b0466e09 100644 --- a/lvgl_touch/ft6x36.c +++ b/lvgl_touch/ft6x36.c @@ -86,6 +86,7 @@ void ft6x06_init(uint16_t dev_addr) { ft6x06_i2c_read8(dev_addr, FT6X36_RELEASECODE_REG, &data_buf); ESP_LOGI(TAG, "\tRelease code: 0x%02x", data_buf); +#if CONFIG_LV_FT6X36_COORDINATES_QUEUE ft6x36_touch_queue_handle = xQueueCreate( FT6X36_TOUCH_QUEUE_ELEMENTS, sizeof( ft6x36_touch_t )); if( ft6x36_touch_queue_handle == NULL ) { @@ -93,6 +94,7 @@ void ft6x06_init(uint16_t dev_addr) { return; } xQueueSend( ft6x36_touch_queue_handle, &touch_inputs, 0 ); +#endif } /** @@ -118,7 +120,9 @@ bool ft6x36_read(lv_indev_drv_t *drv, lv_indev_data_t *data) { if ( touch_inputs.current_state != LV_INDEV_STATE_REL) { touch_inputs.current_state = LV_INDEV_STATE_REL; +#if CONFIG_LV_FT6X36_COORDINATES_QUEUE xQueueOverwrite( ft6x36_touch_queue_handle, &touch_inputs ); +#endif } data->point.x = touch_inputs.last_x; data->point.y = touch_inputs.last_y; @@ -146,7 +150,9 @@ bool ft6x36_read(lv_indev_drv_t *drv, lv_indev_data_t *data) { data->state = touch_inputs.current_state; ESP_LOGD(TAG, "X=%u Y=%u", data->point.x, data->point.y); +#if CONFIG_LV_FT6X36_COORDINATES_QUEUE xQueueOverwrite( ft6x36_touch_queue_handle, &touch_inputs ); +#endif return false; } diff --git a/lvgl_touch/ft6x36.h b/lvgl_touch/ft6x36.h index 90f15073..5152da57 100644 --- a/lvgl_touch/ft6x36.h +++ b/lvgl_touch/ft6x36.h @@ -154,8 +154,9 @@ typedef struct lv_indev_state_t current_state; } ft6x36_touch_t; +#if CONFIG_LV_FT6X36_COORDINATES_QUEUE QueueHandle_t ft6x36_touch_queue_handle; - +#endif /** * @brief Initialize for FT6x36 communication via I2C * @param dev_addr: Device address on communication Bus (I2C slave address of FT6X36). From 37548ad50fd95f742f1b1e8fa291d001a5f54252 Mon Sep 17 00:00:00 2001 From: Rashed Talukder <> Date: Wed, 27 Oct 2021 09:20:57 -0700 Subject: [PATCH 55/70] Extern the queue handle and add definition in source file. Add macro condition for dependencies. --- lvgl_touch/ft6x36.c | 6 ++++-- lvgl_touch/ft6x36.h | 4 +++- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/lvgl_touch/ft6x36.c b/lvgl_touch/ft6x36.c index b0466e09..dae736c2 100644 --- a/lvgl_touch/ft6x36.c +++ b/lvgl_touch/ft6x36.c @@ -25,7 +25,6 @@ #include #endif #include "ft6x36.h" - #include "lvgl_i2c/i2c_manager.h" #define TAG "FT6X36" @@ -35,6 +34,9 @@ static ft6x36_status_t ft6x36_status; static uint8_t current_dev_addr; // set during init static ft6x36_touch_t touch_inputs = { -1, -1, LV_INDEV_STATE_REL }; // -1 coordinates to designate it was never touched +#if CONFIG_LV_FT6X36_COORDINATES_QUEUE +QueueHandle_t ft6x36_touch_queue_handle; +#endif static esp_err_t ft6x06_i2c_read8(uint8_t slave_addr, uint8_t register_addr, uint8_t *data_buf) { return lvgl_i2c_read(CONFIG_LV_I2C_TOUCH_PORT, slave_addr, register_addr, data_buf, 1); @@ -87,7 +89,7 @@ void ft6x06_init(uint16_t dev_addr) { ESP_LOGI(TAG, "\tRelease code: 0x%02x", data_buf); #if CONFIG_LV_FT6X36_COORDINATES_QUEUE - ft6x36_touch_queue_handle = xQueueCreate( FT6X36_TOUCH_QUEUE_ELEMENTS, sizeof( ft6x36_touch_t )); + ft6x36_touch_queue_handle = xQueueCreate( FT6X36_TOUCH_QUEUE_ELEMENTS, sizeof( ft6x36_touch_t ) ); if( ft6x36_touch_queue_handle == NULL ) { ESP_LOGE( TAG, "\tError creating touch input FreeRTOS queue" ); diff --git a/lvgl_touch/ft6x36.h b/lvgl_touch/ft6x36.h index 5152da57..c4074dc3 100644 --- a/lvgl_touch/ft6x36.h +++ b/lvgl_touch/ft6x36.h @@ -23,8 +23,10 @@ #include #include +#if CONFIG_LV_FT6X36_COORDINATES_QUEUE #include "freertos/FreeRTOS.h" #include "freertos/queue.h" +#endif #ifdef LV_LVGL_H_INCLUDE_SIMPLE #include "lvgl.h" #else @@ -155,7 +157,7 @@ typedef struct } ft6x36_touch_t; #if CONFIG_LV_FT6X36_COORDINATES_QUEUE -QueueHandle_t ft6x36_touch_queue_handle; +extern QueueHandle_t ft6x36_touch_queue_handle; #endif /** * @brief Initialize for FT6x36 communication via I2C From 37a4d3a4e6c7b3313c14c4adb7532f3da06fefff Mon Sep 17 00:00:00 2001 From: Matthias Ringwald Date: Sun, 14 Nov 2021 19:15:09 +0100 Subject: [PATCH 56/70] Add PCD8544 driver --- CMakeLists.txt | 2 + lvgl_helpers.h | 2 + lvgl_spi_conf.h | 2 + lvgl_tft/Kconfig | 9 +++ lvgl_tft/disp_driver.c | 8 +++ lvgl_tft/disp_driver.h | 2 + lvgl_tft/pcd8544.c | 146 +++++++++++++++++++++++++++++++++++++++++ lvgl_tft/pcd8544.h | 57 ++++++++++++++++ 8 files changed, 228 insertions(+) create mode 100644 lvgl_tft/pcd8544.c create mode 100644 lvgl_tft/pcd8544.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 78870dd6..407802a6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -42,6 +42,8 @@ elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_GC9A01) list(APPEND SOURCES "lvgl_tft/GC9A01.c") elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C) list(APPEND SOURCES "lvgl_tft/ili9163c.c") +elseif(CONFIG_LV_TFT_DISPLAY_CONTROLLER_PCD8544) + list(APPEND SOURCES "lvgl_tft/pcd8544.c") else() message(WARNING "LVGL ESP32 drivers: Display controller not defined.") endif() diff --git a/lvgl_helpers.h b/lvgl_helpers.h index 5fd6f09c..c0101748 100644 --- a/lvgl_helpers.h +++ b/lvgl_helpers.h @@ -76,6 +76,8 @@ extern "C" { #define DISP_BUF_SIZE ((LV_VER_RES_MAX * LV_VER_RES_MAX) / 8) // 2888 bytes #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C #define DISP_BUF_SIZE (LV_HOR_RES_MAX * 40) +#elif defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_PCD8544) +#define DISP_BUF_SIZE (LV_HOR_RES_MAX * (LV_VER_RES_MAX / 8)) #else #error "No display controller selected" #endif diff --git a/lvgl_spi_conf.h b/lvgl_spi_conf.h index 240090d8..2c62c94b 100644 --- a/lvgl_spi_conf.h +++ b/lvgl_spi_conf.h @@ -166,6 +166,8 @@ extern "C" { #define SPI_TFT_CLOCK_SPEED_HZ (40 * 1000 * 1000) #elif defined(CONFIG_LV_TFT_DISPLAY_CONTROLLER_FT81X) #define SPI_TFT_CLOCK_SPEED_HZ (32*1000*1000) +#elif defined (CONFIG_LV_TFT_DISPLAY_CONTROLLER_PCD8544) +#define SPI_TFT_CLOCK_SPEED_HZ (4*1000*1000) #else #define SPI_TFT_CLOCK_SPEED_HZ (40*1000*1000) #endif diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 140c173a..b700894d 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -174,6 +174,10 @@ menu "LVGL TFT Display controller" help ILI9163C display controller. + config LV_TFT_DISPLAY_CONTROLLER_PCD8544 + bool + help + PCD8544 display controller (Nokia 3110/5110) # Display controller communication protocol # # This symbols define the communication protocol used by the @@ -340,6 +344,11 @@ menu "LVGL TFT Display controller" bool "ILI9163C" select LV_TFT_DISPLAY_CONTROLLER_ILI9163C select LV_TFT_DISPLAY_PROTOCOL_SPI + config LV_TFT_DISPLAY_USER_CONTROLLER_PCD8544 + bool "PCD8544" + select LV_TFT_DISPLAY_CONTROLLER_PCD8544 + select LV_TFT_DISPLAY_PROTOCOL_SPI + select LV_TFT_DISPLAY_MONOCHROME endchoice config CUSTOM_DISPLAY_BUFFER_SIZE diff --git a/lvgl_tft/disp_driver.c b/lvgl_tft/disp_driver.c index f62a947f..153ca31c 100644 --- a/lvgl_tft/disp_driver.c +++ b/lvgl_tft/disp_driver.c @@ -43,6 +43,8 @@ void *disp_driver_init(void) uc8151d_init(); #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C ili9163c_init(); +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_PCD8544 + pcd8544_init(); #endif // We still use menuconfig for these settings @@ -107,6 +109,8 @@ void disp_driver_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * uc8151d_lv_fb_flush(drv, area, color_map); #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C ili9163c_flush(drv, area, color_map); +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_PCD8544 + pcd8544_flush(drv, area, color_map); #endif } @@ -122,6 +126,8 @@ void disp_driver_rounder(lv_disp_drv_t * disp_drv, lv_area_t * area) jd79653a_lv_rounder_cb(disp_drv, area); #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_UC8151D uc8151d_lv_rounder_cb(disp_drv, area); +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_PCD8544 + pcd8544_rounder(disp_drv, area); #endif } @@ -138,5 +144,7 @@ void disp_driver_set_px(lv_disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t buf_ jd79653a_lv_set_fb_cb(disp_drv, buf, buf_w, x, y, color, opa); #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_UC8151D uc8151d_lv_set_fb_cb(disp_drv, buf, buf_w, x, y, color, opa); +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_PCD8544 + pcd8544_set_px_cb(disp_drv, buf, buf_w, x, y, color, opa); #endif } diff --git a/lvgl_tft/disp_driver.h b/lvgl_tft/disp_driver.h index 8c70fdae..2f5bcdf6 100644 --- a/lvgl_tft/disp_driver.h +++ b/lvgl_tft/disp_driver.h @@ -52,6 +52,8 @@ extern "C" { #include "uc8151d.h" #elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_ILI9163C #include "ili9163c.h" +#elif defined CONFIG_LV_TFT_DISPLAY_CONTROLLER_PCD8544 +#include "pcd8544.h" #endif /********************* diff --git a/lvgl_tft/pcd8544.c b/lvgl_tft/pcd8544.c new file mode 100644 index 00000000..b2a7bed4 --- /dev/null +++ b/lvgl_tft/pcd8544.c @@ -0,0 +1,146 @@ +/** + * @file pcd8544.c + * + * Roughly based on: + * https://github.com/adafruit/Adafruit-PCD8544-Nokia-5110-LCD-library + * https://github.com/olikraus/u8g2 + */ + +#include "disp_spi.h" +#include "driver/gpio.h" + +#include +#include "freertos/FreeRTOS.h" +#include "freertos/task.h" + +#include "pcd8544.h" + +#define TAG "lv_pcd8544" + +/********************** + * MACROS + **********************/ + +#define BIT_SET(a,b) ((a) |= (1U<<(b))) +#define BIT_CLEAR(a,b) ((a) &= ~(1U<<(b))) + +/********************** + * STATIC FUNCTIONS + **********************/ + +static void pcd8544_send_cmd(uint8_t cmd) +{ + disp_wait_for_pending_transactions(); + gpio_set_level(PCD8544_DC, 0); /*Command mode*/ + disp_spi_send_data(&cmd, 1); +} + +static void pcd8544_send_data(void * data, uint16_t length) +{ + disp_wait_for_pending_transactions(); + gpio_set_level(PCD8544_DC, 1); /*Data mode*/ + disp_spi_send_data(data, length); +} + +static void pcd8544_send_colors(void * data, uint16_t length) +{ + gpio_set_level(PCD8544_DC, 1); /*Data mode*/ + disp_spi_send_colors(data, length); +} + +/********************** + * GLOBAL FUNCTIONS + **********************/ + +void pcd8544_init(void){ + + // TODO: orientation + + // Initialize non-SPI GPIOs + gpio_pad_select_gpio(PCD8544_DC); + gpio_set_direction(PCD8544_DC, GPIO_MODE_OUTPUT); + gpio_pad_select_gpio(PCD8544_RST); + gpio_set_direction(PCD8544_RST, GPIO_MODE_OUTPUT); + + // Reset the display + gpio_set_level(PCD8544_RST, 0); + vTaskDelay(100 / portTICK_RATE_MS); + gpio_set_level(PCD8544_RST, 1); + vTaskDelay(100 / portTICK_RATE_MS); + + pcd8544_send_cmd(0x21); /* activate chip (PD=0), horizontal increment (V=0), enter extended command set (H=1) */ + pcd8544_send_cmd(0x06); /* temp. control: b10 = 2 */ + pcd8544_send_cmd(0x13); /* bias system 1:48 */ + pcd8544_send_cmd(0xc0); /* medium Vop = Contrast 0x40 = 64 */ + + pcd8544_send_cmd(0x20); /* activate chip (PD=0), horizontal increment (V=0), enter extended command set (H=0) */ + pcd8544_send_cmd(0x0c); /* display mode normal */ +} + +void pcd8544_set_contrast (uint8_t contrast){ + if (contrast > 0x7f){ + contrast = 0x7f; + } + pcd8544_send_cmd(0x21); /* activate chip (PD=0), horizontal increment (V=0), enter extended command set (H=1) */ + pcd8544_send_cmd(0x80 | contrast); /* medium Vop = Contrast */ +} + +void pcd8544_rounder(lv_disp_drv_t * disp_drv, lv_area_t *area){ + uint8_t hor_max = disp_drv->hor_res; + uint8_t ver_max = disp_drv->ver_res; + + area->x1 = 0; + area->y1 = 0; + area->x2 = hor_max - 1; + area->y2 = ver_max - 1; +} + +void pcd8544_set_px_cb(lv_disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y, + lv_color_t color, lv_opa_t opa){ + + uint8_t set = (color.full == 0) && (LV_OPA_TRANSP != opa); + + uint16_t byte_index = x + (( y>>3 ) * buf_w); + uint8_t bit_index = y & 0x7; + + if (set) { + BIT_SET(buf[byte_index], bit_index); + } else { + BIT_CLEAR(buf[byte_index], bit_index); + } +} + +void pcd8544_flush(lv_disp_drv_t * disp_drv, const lv_area_t * area, lv_color_t * color_map){ + + pcd8544_send_cmd(0x20); /* activate chip (PD=0), horizontal increment (V=0), enter extended command set (H=0) */ + + uint8_t * buf = (uint8_t *) color_map; + + if ((area->x1 == 0) && (area->y1 == 0) && (area->x2 == (disp_drv->hor_res - 1)) && (area->y2 == (disp_drv->ver_res - 1))){ + + // optimize flush of complete frame buffer in a single SPI transaction + + pcd8544_send_cmd(0x40); /* set Y address */ + pcd8544_send_cmd(0x80); /* set X address */ + pcd8544_send_colors(buf, disp_drv->hor_res * disp_drv->ver_res / 8); + + } else { + + // send horizontal tiles + + uint16_t bank_start = area->y1 / 8; + uint16_t bank_end = area->y2 / 8; + + uint16_t bank; + uint16_t cols_to_update = area->x2 - area->x1 + 1; + for (bank = bank_start ; bank <= bank_end ; bank++ ){ + pcd8544_send_cmd(0x40 | bank ); /* set Y address */ + pcd8544_send_cmd(0x80 | area->x1 ); /* set X address */ + uint16_t offset = bank * disp_drv->hor_res + area->x1; + pcd8544_send_data(&buf[offset], cols_to_update); + } + + lv_disp_flush_ready(disp_drv); + + } +} diff --git a/lvgl_tft/pcd8544.h b/lvgl_tft/pcd8544.h new file mode 100644 index 00000000..b9357fe9 --- /dev/null +++ b/lvgl_tft/pcd8544.h @@ -0,0 +1,57 @@ + +/** + * @file pcd8544.h + * + */ + +#ifndef PCD8544_H +#define PCD8544_H + +#ifdef __cplusplus +extern "C" { +#endif + + /********************* + * INCLUDES + *********************/ +#include + +#ifdef LV_LVGL_H_INCLUDE_SIMPLE +#include "lvgl.h" +#else +#include "lvgl/lvgl.h" +#endif + + /********************* + * DEFINES + *********************/ + +#define PCD8544_DC CONFIG_LV_DISP_PIN_DC +#define PCD8544_RST CONFIG_LV_DISP_PIN_RST +#define PCD8544_BCKL CONFIG_LV_DISP_PIN_BCKL + + /********************** + * TYPEDEFS + **********************/ + + /********************** + * GLOBAL PROTOTYPES + **********************/ + + void pcd8544_init(void); + void pcd8544_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); + void pcd8544_rounder(lv_disp_drv_t * disp_drv, lv_area_t *area); + void pcd8544_set_px_cb(lv_disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y, + lv_color_t color, lv_opa_t opa); + void pcd8544_set_contrast(uint8_t contrast); + + /********************** + * MACROS + **********************/ + + +#ifdef __cplusplus +} /* extern "C" */ +#endif + +#endif /*PCD8544_H*/ From f3f6ba6470860b8cc05f182d0f4d02a8357a5f4a Mon Sep 17 00:00:00 2001 From: Matthias Ringwald Date: Thu, 18 Nov 2021 08:58:04 +0100 Subject: [PATCH 57/70] Added PCD8544 to readme, addressed PR comments --- README.md | 1 + lvgl_tft/pcd8544.c | 8 +++++--- lvgl_tft/pcd8544.h | 42 +++++++++++++++++++++--------------------- 3 files changed, 27 insertions(+), 24 deletions(-) diff --git a/README.md b/README.md index a664636a..522c0e19 100644 --- a/README.md +++ b/README.md @@ -30,6 +30,7 @@ swap of RGB565 color on the LVGL configuration menuconfig (it's not handled auto | RA8875 | TFT | SPI | 16: RGB565 | Yes | | SH1107 | Monochrome | SPI | 1: 1byte per pixel | No | | SSD1306 | Monochrome | I2C | 1: 1byte per pixel | No | +| PCD8544 | Monochrome | SPI | 1: 1byte per pixel | No | | IL3820 | e-Paper | SPI | 1: 1byte per pixel | No | | UC8151D/ GoodDisplay GDEW0154M10 DES | e-Paper | SPI | 1: 1byte per pixel | No | | FitiPower JD79653A/ GoodDisplay GDEW0154M09 | e-Paper | SPI | 1: 1byte per pixel | No | diff --git a/lvgl_tft/pcd8544.c b/lvgl_tft/pcd8544.c index b2a7bed4..49d067eb 100644 --- a/lvgl_tft/pcd8544.c +++ b/lvgl_tft/pcd8544.c @@ -116,9 +116,12 @@ void pcd8544_flush(lv_disp_drv_t * disp_drv, const lv_area_t * area, lv_color_t uint8_t * buf = (uint8_t *) color_map; + // Check if the whole frame buffer can be sent in a single SPI transaction + if ((area->x1 == 0) && (area->y1 == 0) && (area->x2 == (disp_drv->hor_res - 1)) && (area->y2 == (disp_drv->ver_res - 1))){ - // optimize flush of complete frame buffer in a single SPI transaction + // send complete frame buffer at once. + // NOTE: disp_spi_send_colors triggers lv_disp_flush_ready pcd8544_send_cmd(0x40); /* set Y address */ pcd8544_send_cmd(0x80); /* set X address */ @@ -134,13 +137,12 @@ void pcd8544_flush(lv_disp_drv_t * disp_drv, const lv_area_t * area, lv_color_t uint16_t bank; uint16_t cols_to_update = area->x2 - area->x1 + 1; for (bank = bank_start ; bank <= bank_end ; bank++ ){ - pcd8544_send_cmd(0x40 | bank ); /* set Y address */ + pcd8544_send_cmd(0x40 | bank ); /* set Y address */ pcd8544_send_cmd(0x80 | area->x1 ); /* set X address */ uint16_t offset = bank * disp_drv->hor_res + area->x1; pcd8544_send_data(&buf[offset], cols_to_update); } lv_disp_flush_ready(disp_drv); - } } diff --git a/lvgl_tft/pcd8544.h b/lvgl_tft/pcd8544.h index b9357fe9..24fcc710 100644 --- a/lvgl_tft/pcd8544.h +++ b/lvgl_tft/pcd8544.h @@ -11,9 +11,9 @@ extern "C" { #endif - /********************* - * INCLUDES - *********************/ +/********************* + * INCLUDES + *********************/ #include #ifdef LV_LVGL_H_INCLUDE_SIMPLE @@ -22,32 +22,32 @@ extern "C" { #include "lvgl/lvgl.h" #endif - /********************* - * DEFINES - *********************/ +/********************* + * DEFINES + *********************/ #define PCD8544_DC CONFIG_LV_DISP_PIN_DC #define PCD8544_RST CONFIG_LV_DISP_PIN_RST #define PCD8544_BCKL CONFIG_LV_DISP_PIN_BCKL - /********************** - * TYPEDEFS - **********************/ +/********************** + * TYPEDEFS + **********************/ - /********************** - * GLOBAL PROTOTYPES - **********************/ +/********************** + * GLOBAL PROTOTYPES + **********************/ - void pcd8544_init(void); - void pcd8544_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); - void pcd8544_rounder(lv_disp_drv_t * disp_drv, lv_area_t *area); - void pcd8544_set_px_cb(lv_disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y, - lv_color_t color, lv_opa_t opa); - void pcd8544_set_contrast(uint8_t contrast); +void pcd8544_init(void); +void pcd8544_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map); +void pcd8544_rounder(lv_disp_drv_t * disp_drv, lv_area_t *area); +void pcd8544_set_px_cb(lv_disp_drv_t * disp_drv, uint8_t * buf, lv_coord_t buf_w, lv_coord_t x, lv_coord_t y, + lv_color_t color, lv_opa_t opa); +void pcd8544_set_contrast(uint8_t contrast); - /********************** - * MACROS - **********************/ +/********************** + * MACROS + **********************/ #ifdef __cplusplus From 31a5733c8d49f3885ce282cb1c534133fcf72240 Mon Sep 17 00:00:00 2001 From: arktrin Date: Sun, 5 Dec 2021 17:01:36 +0300 Subject: [PATCH 58/70] Fix SPI configuration for ESP32-C3 and ESP32-S2 ESP32-C3 and ESP32-S2 do not have VSPI or HSPI --- lvgl_spi_conf.h | 6 ++---- lvgl_tft/Kconfig | 6 ++++-- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/lvgl_spi_conf.h b/lvgl_spi_conf.h index 2c62c94b..f3d4a3d9 100644 --- a/lvgl_spi_conf.h +++ b/lvgl_spi_conf.h @@ -65,15 +65,13 @@ extern "C" { #define ENABLE_TOUCH_INPUT CONFIG_LV_ENABLE_TOUCH #if defined (CONFIG_LV_TFT_DISPLAY_SPI_HSPI) -#if defined (CONFIG_IDF_TARGET_ESP32C3) -#define TFT_SPI_HOST SPI2_HOST -#else #define TFT_SPI_HOST HSPI_HOST -#endif #elif defined (CONFIG_LV_TFT_DISPLAY_SPI_VSPI) #define TFT_SPI_HOST VSPI_HOST #elif defined (CONFIG_LV_TFT_DISPLAY_SPI_FSPI) #define TFT_SPI_HOST FSPI_HOST +#elif defined (CONFIG_LV_TFT_DISPLAY_SPI2) +#define TFT_SPI_HOST SPI2_HOST #endif #if defined (CONFIG_LV_TFT_DISPLAY_SPI_HALF_DUPLEX) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index b700894d..6ccf055f 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -476,11 +476,13 @@ menu "LVGL TFT Display controller" Select the SPI Bus the TFT Display is attached to. config LV_TFT_DISPLAY_SPI_HSPI - bool "HSPI" + bool "HSPI" if IDF_TARGET_ESP32 config LV_TFT_DISPLAY_SPI_VSPI - bool "VSPI" if !IDF_TARGET_ESP32S2 + bool "VSPI" if IDF_TARGET_ESP32 config LV_TFT_DISPLAY_SPI_FSPI bool "FSPI" if IDF_TARGET_ESP32S2 + config LV_TFT_DISPLAY_SPI2 + bool "SPI2" if IDF_TARGET_ESP32C3 endchoice choice From 23ee5be93bbfa823acfea2bae686c38d6379b35e Mon Sep 17 00:00:00 2001 From: arktrin Date: Mon, 13 Dec 2021 14:31:09 +0300 Subject: [PATCH 59/70] replace all specific SPI names with SPIx_HOST --- lvgl_spi_conf.h | 14 ++++++-------- lvgl_tft/Kconfig | 17 +++++++---------- 2 files changed, 13 insertions(+), 18 deletions(-) diff --git a/lvgl_spi_conf.h b/lvgl_spi_conf.h index f3d4a3d9..cab94d70 100644 --- a/lvgl_spi_conf.h +++ b/lvgl_spi_conf.h @@ -64,14 +64,12 @@ extern "C" { #define ENABLE_TOUCH_INPUT CONFIG_LV_ENABLE_TOUCH -#if defined (CONFIG_LV_TFT_DISPLAY_SPI_HSPI) -#define TFT_SPI_HOST HSPI_HOST -#elif defined (CONFIG_LV_TFT_DISPLAY_SPI_VSPI) -#define TFT_SPI_HOST VSPI_HOST -#elif defined (CONFIG_LV_TFT_DISPLAY_SPI_FSPI) -#define TFT_SPI_HOST FSPI_HOST -#elif defined (CONFIG_LV_TFT_DISPLAY_SPI2) -#define TFT_SPI_HOST SPI2_HOST +#if defined (CONFIG_LV_TFT_DISPLAY_SPI1_HOST) +#define TFT_SPI_HOST SPI1_HOST +#elif defined (CONFIG_LV_TFT_DISPLAY_SPI2_HOST) +#define TFT_SPI_HOST SPI2_HOST +#elif defined (CONFIG_LV_TFT_DISPLAY_SPI3_HOST) +#define TFT_SPI_HOST SPI3_HOST #endif #if defined (CONFIG_LV_TFT_DISPLAY_SPI_HALF_DUPLEX) diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 6ccf055f..b55f1f1c 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -469,20 +469,17 @@ menu "LVGL TFT Display controller" choice prompt "TFT SPI Bus." if LV_TFT_DISPLAY_PROTOCOL_SPI - default LV_TFT_DISPLAY_SPI_VSPI if LV_PREDEFINED_DISPLAY_TTGO && \ + default LV_TFT_DISPLAY_SPI3_HOST if LV_PREDEFINED_DISPLAY_TTGO && \ !IDF_TARGET_ESP32S2 - default LV_TFT_DISPLAY_SPI_FSPI if IDF_TARGET_ESP32S2 help Select the SPI Bus the TFT Display is attached to. - config LV_TFT_DISPLAY_SPI_HSPI - bool "HSPI" if IDF_TARGET_ESP32 - config LV_TFT_DISPLAY_SPI_VSPI - bool "VSPI" if IDF_TARGET_ESP32 - config LV_TFT_DISPLAY_SPI_FSPI - bool "FSPI" if IDF_TARGET_ESP32S2 - config LV_TFT_DISPLAY_SPI2 - bool "SPI2" if IDF_TARGET_ESP32C3 + config LV_TFT_DISPLAY_SPI1_HOST + bool "SPI1_HOST" + config LV_TFT_DISPLAY_SPI2_HOST + bool "SPI2_HOST" + config LV_TFT_DISPLAY_SPI3_HOST + bool "SPI3_HOST" endchoice choice From 22ba4161b5dae6bcd88427b7f555e9ed2e7d9574 Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Thu, 16 Dec 2021 13:36:23 +0100 Subject: [PATCH 60/70] fix spi names --- .gitignore | 4 ++++ lvgl_helpers.c | 37 +++++++------------------------------ lvgl_spi_conf.h | 16 ++++++---------- lvgl_tft/Kconfig | 5 +---- lvgl_touch/Kconfig | 29 +++++++++++++---------------- 5 files changed, 31 insertions(+), 60 deletions(-) diff --git a/.gitignore b/.gitignore index 38eeab75..c2ff946a 100644 --- a/.gitignore +++ b/.gitignore @@ -56,3 +56,7 @@ dkms.conf # ESP-IDF build dir build + +# Kconfig files +sdkconfig +sdkconfig.old diff --git a/lvgl_helpers.c b/lvgl_helpers.c index edc522f7..f65cce5f 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -154,34 +154,12 @@ bool lvgl_spi_driver_init(int host, int dma_channel, int quadwp_pin, int quadhd_pin) { - int dma_chan = 0 /* SPI_DMA_DISABLED */; - -#if defined (CONFIG_IDF_TARGET_ESP32) - assert((SPI_HOST <= host) && (VSPI_HOST >= host)); - const char *spi_names[] = { - "SPI_HOST", "HSPI_HOST", "VSPI_HOST" - }; - - dma_chan = dma_channel; -#elif defined (CONFIG_IDF_TARGET_ESP32S2) - assert((SPI_HOST <= host) && (HSPI_HOST >= host)); - const char *spi_names[] = { - "SPI_HOST", "", "" - }; - - dma_chan = dma_channel; -#elif defined (CONFIG_IDF_TARGET_ESP32C3) - assert((SPI1_HOST <= host) && (SPI3_HOST >= host)); + assert((0 <= host) && (SPI_HOST_MAX > host)); const char *spi_names[] = { "SPI1_HOST", "SPI2_HOST", "SPI3_HOST" }; - dma_chan = 3 /* SPI_DMA_CH_AUTO */; -#else -#error "Target chip not selected" -#endif - - ESP_LOGI(TAG, "Configuring SPI host %s (%d)", spi_names[host], host); + ESP_LOGI(TAG, "Configuring SPI host %s", spi_names[host]); ESP_LOGI(TAG, "MISO pin: %d, MOSI pin: %d, SCLK pin: %d, IO2/WP pin: %d, IO3/HD pin: %d", miso_pin, mosi_pin, sclk_pin, quadwp_pin, quadhd_pin); @@ -189,17 +167,16 @@ bool lvgl_spi_driver_init(int host, spi_bus_config_t buscfg = { .miso_io_num = miso_pin, - .mosi_io_num = mosi_pin, - .sclk_io_num = sclk_pin, - .quadwp_io_num = quadwp_pin, - .quadhd_io_num = quadhd_pin, + .mosi_io_num = mosi_pin, + .sclk_io_num = sclk_pin, + .quadwp_io_num = quadwp_pin, + .quadhd_io_num = quadhd_pin, .max_transfer_sz = max_transfer_sz }; ESP_LOGI(TAG, "Initializing SPI bus..."); - esp_err_t ret = spi_bus_initialize(host, &buscfg, dma_chan); + esp_err_t ret = spi_bus_initialize(host, &buscfg, (spi_dma_chan_t)dma_channel); assert(ret == ESP_OK); return ESP_OK != ret; } - diff --git a/lvgl_spi_conf.h b/lvgl_spi_conf.h index cab94d70..662be989 100644 --- a/lvgl_spi_conf.h +++ b/lvgl_spi_conf.h @@ -64,9 +64,7 @@ extern "C" { #define ENABLE_TOUCH_INPUT CONFIG_LV_ENABLE_TOUCH -#if defined (CONFIG_LV_TFT_DISPLAY_SPI1_HOST) -#define TFT_SPI_HOST SPI1_HOST -#elif defined (CONFIG_LV_TFT_DISPLAY_SPI2_HOST) +#if defined (CONFIG_LV_TFT_DISPLAY_SPI2_HOST) #define TFT_SPI_HOST SPI2_HOST #elif defined (CONFIG_LV_TFT_DISPLAY_SPI3_HOST) #define TFT_SPI_HOST SPI3_HOST @@ -86,12 +84,10 @@ extern "C" { #define DISP_SPI_TRANS_MODE_SIO #endif -#if defined (CONFIG_LV_TOUCH_CONTROLLER_SPI_HSPI) -#define TOUCH_SPI_HOST HSPI_HOST -#elif defined (CONFIG_LV_TOUCH_CONTROLLER_SPI_VSPI) -#define TOUCH_SPI_HOST VSPI_HOST -#elif defined (CONFIG_LV_TOUCH_CONTROLLER_SPI_FSPI) -#define TOUCH_SPI_HOST FSPI_HOST +#if defined (CONFIG_LV_TOUCH_CONTROLLER_SPI2_HOST) +#define TOUCH_SPI_HOST SPI2_HOST +#elif defined (CONFIG_LV_TOUCH_CONTROLLER_SPI3_HOST) +#define TOUCH_SPI_HOST SPI3_HOST #endif /* Handle the FT81X Special case */ @@ -107,7 +103,7 @@ extern "C" { // Detect the use of a shared SPI Bus and verify the user specified the same SPI bus for both touch and tft #if defined (CONFIG_LV_TOUCH_DRIVER_PROTOCOL_SPI) && TP_SPI_MOSI == DISP_SPI_MOSI && TP_SPI_CLK == DISP_SPI_CLK #if TFT_SPI_HOST != TOUCH_SPI_HOST -#error You must specify the same SPI host (HSPI, VSPI or FSPI) for both display and touch driver +#error You must specify the same SPI host (SPIx_HOST) for both display and touch driver #endif #define SHARED_SPI_BUS diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index b55f1f1c..7bfde783 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -469,13 +469,10 @@ menu "LVGL TFT Display controller" choice prompt "TFT SPI Bus." if LV_TFT_DISPLAY_PROTOCOL_SPI - default LV_TFT_DISPLAY_SPI3_HOST if LV_PREDEFINED_DISPLAY_TTGO && \ - !IDF_TARGET_ESP32S2 + default LV_TFT_DISPLAY_SPI2_HOST help Select the SPI Bus the TFT Display is attached to. - config LV_TFT_DISPLAY_SPI1_HOST - bool "SPI1_HOST" config LV_TFT_DISPLAY_SPI2_HOST bool "SPI2_HOST" config LV_TFT_DISPLAY_SPI3_HOST diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index b9908aa1..5b6eeb18 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -67,17 +67,14 @@ menu "LVGL Touch controller" prompt "Touch Controller SPI Bus." depends on LV_TOUCH_DRIVER_PROTOCOL_SPI - default LV_TOUCH_CONTROLLER_SPI_VSPI if !IDF_TARGET_ESP32S2 - default LV_TOUCH_CONTROLLER_SPI_FSPI if IDF_TARGET_ESP32S2 + default LV_TOUCH_CONTROLLER_SPI2_HOST help - Select the SPI Bus the TFT Display is attached to. - - config LV_TOUCH_CONTROLLER_SPI_HSPI - bool "HSPI" - config LV_TOUCH_CONTROLLER_SPI_VSPI - bool "VSPI" if !IDF_TARGET_ESP32S2 - config LV_TOUCH_CONTROLLER_SPI_FSPI - bool "FSPI" if IDF_TARGET_ESP32S2 + Select the SPI Bus the touch controller is attached to. + + config LV_TOUCH_CONTROLLER_SPI2_HOST + bool "SPI2_HOST" + config LV_TOUCH_CONTROLLER_SPI3_HOST + bool "SPI3_HOST" endchoice menu "Touchpanel (XPT2046) Pin Assignments" @@ -86,7 +83,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_MISO int prompt "GPIO for MISO (Master In Slave Out)" - + default 35 if LV_PREDEFINED_PINS_38V1 default 19 help @@ -103,7 +100,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CLK int "GPIO for CLK (SCK / Serial Clock)" - + default 26 if LV_PREDEFINED_PINS_38V1 default 18 help @@ -119,7 +116,7 @@ menu "LVGL Touch controller" config LV_TOUCH_PIN_IRQ int "GPIO for IRQ (Interrupt Request)" - + default 27 if LV_PREDEFINED_PINS_38V4 default 25 help @@ -216,7 +213,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_MISO int prompt "GPIO for MISO (Master In Slave Out)" - + default 35 if LV_PREDEFINED_PINS_38V1 default 19 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING default 19 @@ -472,14 +469,14 @@ menu "LVGL Touch controller" config LV_I2C_TOUCH_PORT_0 bool prompt "I2C port 0" - help + help I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu Component config->I2C Port Settings. config LV_I2C_TOUCH_PORT_1 bool prompt "I2C port 1" - help + help I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu Component config->I2C Port Settings. From d44b7e808abcf102bf5fc78f79abf7399f0d69ce Mon Sep 17 00:00:00 2001 From: Tomas Rezucha Date: Fri, 17 Dec 2021 19:18:05 +0100 Subject: [PATCH 61/70] Revert "fix spi names" --- .gitignore | 4 ---- lvgl_helpers.c | 37 ++++++++++++++++++++++++++++++------- lvgl_spi_conf.h | 16 ++++++++++------ lvgl_tft/Kconfig | 5 ++++- lvgl_touch/Kconfig | 29 ++++++++++++++++------------- 5 files changed, 60 insertions(+), 31 deletions(-) diff --git a/.gitignore b/.gitignore index c2ff946a..38eeab75 100644 --- a/.gitignore +++ b/.gitignore @@ -56,7 +56,3 @@ dkms.conf # ESP-IDF build dir build - -# Kconfig files -sdkconfig -sdkconfig.old diff --git a/lvgl_helpers.c b/lvgl_helpers.c index f65cce5f..edc522f7 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -154,12 +154,34 @@ bool lvgl_spi_driver_init(int host, int dma_channel, int quadwp_pin, int quadhd_pin) { - assert((0 <= host) && (SPI_HOST_MAX > host)); + int dma_chan = 0 /* SPI_DMA_DISABLED */; + +#if defined (CONFIG_IDF_TARGET_ESP32) + assert((SPI_HOST <= host) && (VSPI_HOST >= host)); + const char *spi_names[] = { + "SPI_HOST", "HSPI_HOST", "VSPI_HOST" + }; + + dma_chan = dma_channel; +#elif defined (CONFIG_IDF_TARGET_ESP32S2) + assert((SPI_HOST <= host) && (HSPI_HOST >= host)); + const char *spi_names[] = { + "SPI_HOST", "", "" + }; + + dma_chan = dma_channel; +#elif defined (CONFIG_IDF_TARGET_ESP32C3) + assert((SPI1_HOST <= host) && (SPI3_HOST >= host)); const char *spi_names[] = { "SPI1_HOST", "SPI2_HOST", "SPI3_HOST" }; - ESP_LOGI(TAG, "Configuring SPI host %s", spi_names[host]); + dma_chan = 3 /* SPI_DMA_CH_AUTO */; +#else +#error "Target chip not selected" +#endif + + ESP_LOGI(TAG, "Configuring SPI host %s (%d)", spi_names[host], host); ESP_LOGI(TAG, "MISO pin: %d, MOSI pin: %d, SCLK pin: %d, IO2/WP pin: %d, IO3/HD pin: %d", miso_pin, mosi_pin, sclk_pin, quadwp_pin, quadhd_pin); @@ -167,16 +189,17 @@ bool lvgl_spi_driver_init(int host, spi_bus_config_t buscfg = { .miso_io_num = miso_pin, - .mosi_io_num = mosi_pin, - .sclk_io_num = sclk_pin, - .quadwp_io_num = quadwp_pin, - .quadhd_io_num = quadhd_pin, + .mosi_io_num = mosi_pin, + .sclk_io_num = sclk_pin, + .quadwp_io_num = quadwp_pin, + .quadhd_io_num = quadhd_pin, .max_transfer_sz = max_transfer_sz }; ESP_LOGI(TAG, "Initializing SPI bus..."); - esp_err_t ret = spi_bus_initialize(host, &buscfg, (spi_dma_chan_t)dma_channel); + esp_err_t ret = spi_bus_initialize(host, &buscfg, dma_chan); assert(ret == ESP_OK); return ESP_OK != ret; } + diff --git a/lvgl_spi_conf.h b/lvgl_spi_conf.h index 662be989..cab94d70 100644 --- a/lvgl_spi_conf.h +++ b/lvgl_spi_conf.h @@ -64,7 +64,9 @@ extern "C" { #define ENABLE_TOUCH_INPUT CONFIG_LV_ENABLE_TOUCH -#if defined (CONFIG_LV_TFT_DISPLAY_SPI2_HOST) +#if defined (CONFIG_LV_TFT_DISPLAY_SPI1_HOST) +#define TFT_SPI_HOST SPI1_HOST +#elif defined (CONFIG_LV_TFT_DISPLAY_SPI2_HOST) #define TFT_SPI_HOST SPI2_HOST #elif defined (CONFIG_LV_TFT_DISPLAY_SPI3_HOST) #define TFT_SPI_HOST SPI3_HOST @@ -84,10 +86,12 @@ extern "C" { #define DISP_SPI_TRANS_MODE_SIO #endif -#if defined (CONFIG_LV_TOUCH_CONTROLLER_SPI2_HOST) -#define TOUCH_SPI_HOST SPI2_HOST -#elif defined (CONFIG_LV_TOUCH_CONTROLLER_SPI3_HOST) -#define TOUCH_SPI_HOST SPI3_HOST +#if defined (CONFIG_LV_TOUCH_CONTROLLER_SPI_HSPI) +#define TOUCH_SPI_HOST HSPI_HOST +#elif defined (CONFIG_LV_TOUCH_CONTROLLER_SPI_VSPI) +#define TOUCH_SPI_HOST VSPI_HOST +#elif defined (CONFIG_LV_TOUCH_CONTROLLER_SPI_FSPI) +#define TOUCH_SPI_HOST FSPI_HOST #endif /* Handle the FT81X Special case */ @@ -103,7 +107,7 @@ extern "C" { // Detect the use of a shared SPI Bus and verify the user specified the same SPI bus for both touch and tft #if defined (CONFIG_LV_TOUCH_DRIVER_PROTOCOL_SPI) && TP_SPI_MOSI == DISP_SPI_MOSI && TP_SPI_CLK == DISP_SPI_CLK #if TFT_SPI_HOST != TOUCH_SPI_HOST -#error You must specify the same SPI host (SPIx_HOST) for both display and touch driver +#error You must specify the same SPI host (HSPI, VSPI or FSPI) for both display and touch driver #endif #define SHARED_SPI_BUS diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index 7bfde783..b55f1f1c 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -469,10 +469,13 @@ menu "LVGL TFT Display controller" choice prompt "TFT SPI Bus." if LV_TFT_DISPLAY_PROTOCOL_SPI - default LV_TFT_DISPLAY_SPI2_HOST + default LV_TFT_DISPLAY_SPI3_HOST if LV_PREDEFINED_DISPLAY_TTGO && \ + !IDF_TARGET_ESP32S2 help Select the SPI Bus the TFT Display is attached to. + config LV_TFT_DISPLAY_SPI1_HOST + bool "SPI1_HOST" config LV_TFT_DISPLAY_SPI2_HOST bool "SPI2_HOST" config LV_TFT_DISPLAY_SPI3_HOST diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index 5b6eeb18..b9908aa1 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -67,14 +67,17 @@ menu "LVGL Touch controller" prompt "Touch Controller SPI Bus." depends on LV_TOUCH_DRIVER_PROTOCOL_SPI - default LV_TOUCH_CONTROLLER_SPI2_HOST + default LV_TOUCH_CONTROLLER_SPI_VSPI if !IDF_TARGET_ESP32S2 + default LV_TOUCH_CONTROLLER_SPI_FSPI if IDF_TARGET_ESP32S2 help - Select the SPI Bus the touch controller is attached to. - - config LV_TOUCH_CONTROLLER_SPI2_HOST - bool "SPI2_HOST" - config LV_TOUCH_CONTROLLER_SPI3_HOST - bool "SPI3_HOST" + Select the SPI Bus the TFT Display is attached to. + + config LV_TOUCH_CONTROLLER_SPI_HSPI + bool "HSPI" + config LV_TOUCH_CONTROLLER_SPI_VSPI + bool "VSPI" if !IDF_TARGET_ESP32S2 + config LV_TOUCH_CONTROLLER_SPI_FSPI + bool "FSPI" if IDF_TARGET_ESP32S2 endchoice menu "Touchpanel (XPT2046) Pin Assignments" @@ -83,7 +86,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_MISO int prompt "GPIO for MISO (Master In Slave Out)" - + default 35 if LV_PREDEFINED_PINS_38V1 default 19 help @@ -100,7 +103,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CLK int "GPIO for CLK (SCK / Serial Clock)" - + default 26 if LV_PREDEFINED_PINS_38V1 default 18 help @@ -116,7 +119,7 @@ menu "LVGL Touch controller" config LV_TOUCH_PIN_IRQ int "GPIO for IRQ (Interrupt Request)" - + default 27 if LV_PREDEFINED_PINS_38V4 default 25 help @@ -213,7 +216,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_MISO int prompt "GPIO for MISO (Master In Slave Out)" - + default 35 if LV_PREDEFINED_PINS_38V1 default 19 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING default 19 @@ -469,14 +472,14 @@ menu "LVGL Touch controller" config LV_I2C_TOUCH_PORT_0 bool prompt "I2C port 0" - help + help I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu Component config->I2C Port Settings. config LV_I2C_TOUCH_PORT_1 bool prompt "I2C port 1" - help + help I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu Component config->I2C Port Settings. From 8cbbc299e9b63b69b5de0771cef943ef2203029d Mon Sep 17 00:00:00 2001 From: arktrin Date: Sat, 18 Dec 2021 20:54:50 +0300 Subject: [PATCH 62/70] fix SPI names for touch with ESP32-C3 specific auto-dma proper selection --- .gitignore | 4 ++ lvgl_helpers.c | 40 +++++--------------- lvgl_spi_conf.h | 16 +++----- lvgl_tft/Kconfig | 10 +---- lvgl_touch/Kconfig | 93 ++++++++++++++++++++++------------------------ 5 files changed, 67 insertions(+), 96 deletions(-) diff --git a/.gitignore b/.gitignore index 38eeab75..3c4910f2 100644 --- a/.gitignore +++ b/.gitignore @@ -56,3 +56,7 @@ dkms.conf # ESP-IDF build dir build + +# Kconfig files +sdkconfig +sdkconfig.old \ No newline at end of file diff --git a/lvgl_helpers.c b/lvgl_helpers.c index edc522f7..76a0ccf1 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -154,34 +154,12 @@ bool lvgl_spi_driver_init(int host, int dma_channel, int quadwp_pin, int quadhd_pin) { - int dma_chan = 0 /* SPI_DMA_DISABLED */; - -#if defined (CONFIG_IDF_TARGET_ESP32) - assert((SPI_HOST <= host) && (VSPI_HOST >= host)); - const char *spi_names[] = { - "SPI_HOST", "HSPI_HOST", "VSPI_HOST" - }; - - dma_chan = dma_channel; -#elif defined (CONFIG_IDF_TARGET_ESP32S2) - assert((SPI_HOST <= host) && (HSPI_HOST >= host)); - const char *spi_names[] = { - "SPI_HOST", "", "" - }; - - dma_chan = dma_channel; -#elif defined (CONFIG_IDF_TARGET_ESP32C3) - assert((SPI1_HOST <= host) && (SPI3_HOST >= host)); + assert((0 <= host) && (SPI_HOST_MAX > host)); const char *spi_names[] = { "SPI1_HOST", "SPI2_HOST", "SPI3_HOST" }; - dma_chan = 3 /* SPI_DMA_CH_AUTO */; -#else -#error "Target chip not selected" -#endif - - ESP_LOGI(TAG, "Configuring SPI host %s (%d)", spi_names[host], host); + ESP_LOGI(TAG, "Configuring SPI host %s", spi_names[host]); ESP_LOGI(TAG, "MISO pin: %d, MOSI pin: %d, SCLK pin: %d, IO2/WP pin: %d, IO3/HD pin: %d", miso_pin, mosi_pin, sclk_pin, quadwp_pin, quadhd_pin); @@ -189,17 +167,19 @@ bool lvgl_spi_driver_init(int host, spi_bus_config_t buscfg = { .miso_io_num = miso_pin, - .mosi_io_num = mosi_pin, - .sclk_io_num = sclk_pin, - .quadwp_io_num = quadwp_pin, - .quadhd_io_num = quadhd_pin, + .mosi_io_num = mosi_pin, + .sclk_io_num = sclk_pin, + .quadwp_io_num = quadwp_pin, + .quadhd_io_num = quadhd_pin, .max_transfer_sz = max_transfer_sz }; ESP_LOGI(TAG, "Initializing SPI bus..."); - esp_err_t ret = spi_bus_initialize(host, &buscfg, dma_chan); + #if defined (CONFIG_IDF_TARGET_ESP32C3) + dma_channel = 3; + #endif + esp_err_t ret = spi_bus_initialize(host, &buscfg, (spi_dma_chan_t)dma_channel); assert(ret == ESP_OK); return ESP_OK != ret; } - diff --git a/lvgl_spi_conf.h b/lvgl_spi_conf.h index cab94d70..662be989 100644 --- a/lvgl_spi_conf.h +++ b/lvgl_spi_conf.h @@ -64,9 +64,7 @@ extern "C" { #define ENABLE_TOUCH_INPUT CONFIG_LV_ENABLE_TOUCH -#if defined (CONFIG_LV_TFT_DISPLAY_SPI1_HOST) -#define TFT_SPI_HOST SPI1_HOST -#elif defined (CONFIG_LV_TFT_DISPLAY_SPI2_HOST) +#if defined (CONFIG_LV_TFT_DISPLAY_SPI2_HOST) #define TFT_SPI_HOST SPI2_HOST #elif defined (CONFIG_LV_TFT_DISPLAY_SPI3_HOST) #define TFT_SPI_HOST SPI3_HOST @@ -86,12 +84,10 @@ extern "C" { #define DISP_SPI_TRANS_MODE_SIO #endif -#if defined (CONFIG_LV_TOUCH_CONTROLLER_SPI_HSPI) -#define TOUCH_SPI_HOST HSPI_HOST -#elif defined (CONFIG_LV_TOUCH_CONTROLLER_SPI_VSPI) -#define TOUCH_SPI_HOST VSPI_HOST -#elif defined (CONFIG_LV_TOUCH_CONTROLLER_SPI_FSPI) -#define TOUCH_SPI_HOST FSPI_HOST +#if defined (CONFIG_LV_TOUCH_CONTROLLER_SPI2_HOST) +#define TOUCH_SPI_HOST SPI2_HOST +#elif defined (CONFIG_LV_TOUCH_CONTROLLER_SPI3_HOST) +#define TOUCH_SPI_HOST SPI3_HOST #endif /* Handle the FT81X Special case */ @@ -107,7 +103,7 @@ extern "C" { // Detect the use of a shared SPI Bus and verify the user specified the same SPI bus for both touch and tft #if defined (CONFIG_LV_TOUCH_DRIVER_PROTOCOL_SPI) && TP_SPI_MOSI == DISP_SPI_MOSI && TP_SPI_CLK == DISP_SPI_CLK #if TFT_SPI_HOST != TOUCH_SPI_HOST -#error You must specify the same SPI host (HSPI, VSPI or FSPI) for both display and touch driver +#error You must specify the same SPI host (SPIx_HOST) for both display and touch driver #endif #define SHARED_SPI_BUS diff --git a/lvgl_tft/Kconfig b/lvgl_tft/Kconfig index b55f1f1c..4a74ad2e 100644 --- a/lvgl_tft/Kconfig +++ b/lvgl_tft/Kconfig @@ -22,7 +22,7 @@ menu "LVGL TFT Display controller" select LV_TFT_DISPLAY_CONTROLLER_ILI9341 select LV_TFT_DISPLAY_PROTOCOL_SPI config LV_PREDEFINED_DISPLAY_M5CORE2 - bool "M5Core2" + bool "M5Core2" select LV_TFT_DISPLAY_CONTROLLER_ILI9341 select LV_TFT_DISPLAY_PROTOCOL_SPI config LV_PREDEFINED_DISPLAY_M5STICK @@ -469,13 +469,10 @@ menu "LVGL TFT Display controller" choice prompt "TFT SPI Bus." if LV_TFT_DISPLAY_PROTOCOL_SPI - default LV_TFT_DISPLAY_SPI3_HOST if LV_PREDEFINED_DISPLAY_TTGO && \ - !IDF_TARGET_ESP32S2 + default LV_TFT_DISPLAY_SPI2_HOST help Select the SPI Bus the TFT Display is attached to. - config LV_TFT_DISPLAY_SPI1_HOST - bool "SPI1_HOST" config LV_TFT_DISPLAY_SPI2_HOST bool "SPI2_HOST" config LV_TFT_DISPLAY_SPI3_HOST @@ -1011,6 +1008,3 @@ menu "LVGL TFT Display controller" default 0 endmenu - - - diff --git a/lvgl_touch/Kconfig b/lvgl_touch/Kconfig index b9908aa1..b793adb8 100644 --- a/lvgl_touch/Kconfig +++ b/lvgl_touch/Kconfig @@ -1,28 +1,28 @@ menu "LVGL Touch controller" config LV_TOUCH_CONTROLLER - int - default 0 if LV_TOUCH_CONTROLLER_NONE - default 1 if LV_TOUCH_CONTROLLER_XPT2046 - default 2 if LV_TOUCH_CONTROLLER_FT6X06 - default 3 if LV_TOUCH_CONTROLLER_STMPE610 + int + default 0 if LV_TOUCH_CONTROLLER_NONE + default 1 if LV_TOUCH_CONTROLLER_XPT2046 + default 2 if LV_TOUCH_CONTROLLER_FT6X06 + default 3 if LV_TOUCH_CONTROLLER_STMPE610 default 4 if LV_TOUCH_CONTROLLER_ADCRAW default 5 if LV_TOUCH_CONTROLLER_FT81X default 6 if LV_TOUCH_CONTROLLER_RA8875 default 7 if LV_TOUCH_CONTROLLER_GT911 choice - prompt "Select a touch panel controller model." - default LV_TOUCH_CONTROLLER_NONE - help - Select the controller for your touch panel. - - config LV_TOUCH_CONTROLLER_NONE - bool "None" - config LV_TOUCH_CONTROLLER_XPT2046 + prompt "Select a touch panel controller model." + default LV_TOUCH_CONTROLLER_NONE + help + Select the controller for your touch panel. + + config LV_TOUCH_CONTROLLER_NONE + bool "None" + config LV_TOUCH_CONTROLLER_XPT2046 select LV_TOUCH_DRIVER_PROTOCOL_SPI bool "XPT2046" - config LV_TOUCH_CONTROLLER_FT6X06 + config LV_TOUCH_CONTROLLER_FT6X06 select LV_I2C_TOUCH bool "FT6X06" config LV_TOUCH_CONTROLLER_STMPE610 @@ -61,23 +61,20 @@ menu "LVGL Touch controller" bool help Touch controller uses same interface/device as display - (Note: Display must be initialized before touch) + (Note: Display must be initialized before touch) choice prompt "Touch Controller SPI Bus." depends on LV_TOUCH_DRIVER_PROTOCOL_SPI - default LV_TOUCH_CONTROLLER_SPI_VSPI if !IDF_TARGET_ESP32S2 - default LV_TOUCH_CONTROLLER_SPI_FSPI if IDF_TARGET_ESP32S2 + default LV_TOUCH_CONTROLLER_SPI2_HOST help - Select the SPI Bus the TFT Display is attached to. - - config LV_TOUCH_CONTROLLER_SPI_HSPI - bool "HSPI" - config LV_TOUCH_CONTROLLER_SPI_VSPI - bool "VSPI" if !IDF_TARGET_ESP32S2 - config LV_TOUCH_CONTROLLER_SPI_FSPI - bool "FSPI" if IDF_TARGET_ESP32S2 + Select the SPI Bus the touch controller is attached to. + + config LV_TOUCH_CONTROLLER_SPI2_HOST + bool "SPI2_HOST" + config LV_TOUCH_CONTROLLER_SPI3_HOST + bool "SPI3_HOST" endchoice menu "Touchpanel (XPT2046) Pin Assignments" @@ -86,7 +83,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_MISO int prompt "GPIO for MISO (Master In Slave Out)" - + default 35 if LV_PREDEFINED_PINS_38V1 default 19 help @@ -103,7 +100,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_CLK int "GPIO for CLK (SCK / Serial Clock)" - + default 26 if LV_PREDEFINED_PINS_38V1 default 18 help @@ -119,7 +116,7 @@ menu "LVGL Touch controller" config LV_TOUCH_PIN_IRQ int "GPIO for IRQ (Interrupt Request)" - + default 27 if LV_PREDEFINED_PINS_38V4 default 25 help @@ -153,10 +150,10 @@ menu "LVGL Touch controller" default 4095 if LV_PREDEFINED_PINS_38V4 default 1900 - config LV_TOUCH_XY_SWAP - bool - prompt "Swap XY." - default y + config LV_TOUCH_XY_SWAP + bool + prompt "Swap XY." + default y config LV_TOUCH_INVERT_X bool @@ -216,7 +213,7 @@ menu "LVGL Touch controller" config LV_TOUCH_SPI_MISO int prompt "GPIO for MISO (Master In Slave Out)" - + default 35 if LV_PREDEFINED_PINS_38V1 default 19 if LV_PREDEFINED_DISPLAY_ADA_FEATHERWING default 19 @@ -278,9 +275,9 @@ menu "LVGL Touch controller" default 3800 config LV_TOUCH_XY_SWAP - bool - prompt "Swap XY." - default n + bool + prompt "Swap XY." + default n config LV_TOUCH_INVERT_X bool @@ -379,25 +376,25 @@ menu "LVGL Touch controller" config LV_TOUCH_X_MIN int prompt "Minimum X coordinate ADC value" - range 0 1023 + range 0 1023 default 0 config LV_TOUCH_Y_MIN int prompt "Minimum Y coordinate ADC value" - range 0 1023 + range 0 1023 default 0 config LV_TOUCH_X_MAX int prompt "Maximum X coordinate ADC value" - range 0 1023 + range 0 1023 default 1023 config LV_TOUCH_Y_MAX int prompt "Maximum Y coordinate ADC value" - range 0 1023 + range 0 1023 default 1023 config LV_TOUCH_XY_SWAP @@ -418,13 +415,13 @@ menu "LVGL Touch controller" config LV_TOUCH_RA8875_SAMPLE_TIME int prompt "TP Sample Time Adjusting" - range 0 7 + range 0 7 default 0 config LV_TOUCH_RA8875_ADC_CLOCK int prompt "ADC Clock Setting" - range 0 7 + range 0 7 default 0 config LV_TOUCH_RA8875_WAKEUP_ENABLE @@ -447,10 +444,10 @@ menu "LVGL Touch controller" menu "Touchpanel Configuration (GT911)" depends on LV_TOUCH_CONTROLLER_GT911 - config LV_GT911_SWAPXY - bool - prompt "Swap X with Y coordinate." - default y + config LV_GT911_SWAPXY + bool + prompt "Swap X with Y coordinate." + default y config LV_GT911_INVERT_X bool @@ -472,14 +469,14 @@ menu "LVGL Touch controller" config LV_I2C_TOUCH_PORT_0 bool prompt "I2C port 0" - help + help I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu Component config->I2C Port Settings. config LV_I2C_TOUCH_PORT_1 bool prompt "I2C port 1" - help + help I2C is shared peripheral managed by I2C Manager. In order to configure I2C Manager (pinout, etc.) see menu Component config->I2C Port Settings. From 8d1fbcf5c4cf4762cdf7b1d488dda5f672c2b2b0 Mon Sep 17 00:00:00 2001 From: arktrin Date: Mon, 20 Dec 2021 12:38:42 +0300 Subject: [PATCH 63/70] replace hardcoded SPI DMA parameter --- lvgl_helpers.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lvgl_helpers.c b/lvgl_helpers.c index 76a0ccf1..57ab7dd1 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -176,7 +176,7 @@ bool lvgl_spi_driver_init(int host, ESP_LOGI(TAG, "Initializing SPI bus..."); #if defined (CONFIG_IDF_TARGET_ESP32C3) - dma_channel = 3; + dma_channel = SPI_DMA_CH_AUTO; #endif esp_err_t ret = spi_bus_initialize(host, &buscfg, (spi_dma_chan_t)dma_channel); assert(ret == ESP_OK); From c4cd5244870331cf865915ac2ae1ab00bdf7d643 Mon Sep 17 00:00:00 2001 From: arktrin Date: Wed, 22 Dec 2021 18:55:54 +0300 Subject: [PATCH 64/70] add offset for 240x135 displays based on ST7789 --- lvgl_tft/st7789.c | 36 ++++++++++++++++++++++++++---------- 1 file changed, 26 insertions(+), 10 deletions(-) diff --git a/lvgl_tft/st7789.c b/lvgl_tft/st7789.c index 3e47a596..b4e6de8c 100644 --- a/lvgl_tft/st7789.c +++ b/lvgl_tft/st7789.c @@ -120,9 +120,9 @@ void st7789_init(void) st7789_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); } -/* The ST7789 display controller can drive 320*240 displays, when using a 240*240 - * display there's a gap of 80px, we need to edit the coordinates to take into - * account that gap, this is not necessary in all orientations. */ +/* The ST7789 display controller can drive up to 320*240 displays, when using a 240*240 + * or 240*135 displays there's a gap of 80px or 40/52/53px respectivly, we need to edit + * the coordinates to take into account those gaps, this is not necessary in all orientations. */ void st7789_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map) { uint8_t data[4] = {0}; @@ -139,13 +139,29 @@ void st7789_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * colo offsety2 += CONFIG_LV_TFT_DISPLAY_Y_OFFSET; #elif (LV_HOR_RES_MAX == 240) && (LV_VER_RES_MAX == 240) -#if (CONFIG_LV_DISPLAY_ORIENTATION_PORTRAIT) - offsetx1 += 80; - offsetx2 += 80; -#elif (CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) - offsety1 += 80; - offsety2 += 80; -#endif + #if (CONFIG_LV_DISPLAY_ORIENTATION_PORTRAIT) + offsetx1 += 80; + offsetx2 += 80; + #elif (CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) + offsety1 += 80; + offsety2 += 80; + #endif +#elif (LV_HOR_RES_MAX == 240) && (LV_VER_RES_MAX == 135) + #if (CONFIG_LV_DISPLAY_ORIENTATION_PORTRAIT) || \ + (CONFIG_LV_DISPLAY_ORIENTATION_PORTRAIT_INVERTED) + offsetx1 += 40; + offsetx2 += 40; + offsety1 += 53; + offsety2 += 53; + #endif +#elif (LV_HOR_RES_MAX == 135) && (LV_VER_RES_MAX == 240) + #if (CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE) || \ + (CONFIG_LV_DISPLAY_ORIENTATION_LANDSCAPE_INVERTED) + offsetx1 += 52; + offsetx2 += 52; + offsety1 += 40; + offsety2 += 40; + #endif #endif /*Column addresses*/ From 26fe6e7703162ac9b0ee82405e858dc37b885d1f Mon Sep 17 00:00:00 2001 From: arktrin Date: Thu, 23 Dec 2021 22:32:23 +0300 Subject: [PATCH 65/70] clarify the 52/53 px offset oddity --- lvgl_tft/st7789.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lvgl_tft/st7789.c b/lvgl_tft/st7789.c index b4e6de8c..de7b35aa 100644 --- a/lvgl_tft/st7789.c +++ b/lvgl_tft/st7789.c @@ -120,9 +120,9 @@ void st7789_init(void) st7789_set_orientation(CONFIG_LV_DISPLAY_ORIENTATION); } -/* The ST7789 display controller can drive up to 320*240 displays, when using a 240*240 - * or 240*135 displays there's a gap of 80px or 40/52/53px respectivly, we need to edit - * the coordinates to take into account those gaps, this is not necessary in all orientations. */ +/* The ST7789 display controller can drive up to 320*240 displays, when using a 240*240 or 240*135 + * displays there's a gap of 80px or 40/52/53px respectively. 52px or 53x offset depends on display orientation. + * We need to edit the coordinates to take into account those gaps, this is not necessary in all orientations. */ void st7789_flush(lv_disp_drv_t * drv, const lv_area_t * area, lv_color_t * color_map) { uint8_t data[4] = {0}; From 799e2d7f39fde17393edd97598b45f2f06fc88c5 Mon Sep 17 00:00:00 2001 From: Luc Appelman Date: Wed, 17 May 2023 10:17:21 +0200 Subject: [PATCH 66/70] backlight fixup --- lvgl_tft/esp_lcd_backlight.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/lvgl_tft/esp_lcd_backlight.c b/lvgl_tft/esp_lcd_backlight.c index f4395bda..14e75f28 100644 --- a/lvgl_tft/esp_lcd_backlight.c +++ b/lvgl_tft/esp_lcd_backlight.c @@ -11,6 +11,8 @@ #include "driver/gpio.h" #include "esp_log.h" #include "soc/ledc_periph.h" // to invert LEDC output on IDF version < v4.3 +#include "soc/gpio_sig_map.h" +#include "esp32/rom/gpio.h" typedef struct { bool pwm_control; // true: LEDC is used, false: GPIO is used @@ -49,7 +51,6 @@ disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config) }; const ledc_timer_config_t LCD_backlight_timer = { .speed_mode = LEDC_LOW_SPEED_MODE, - .bit_num = LEDC_TIMER_10_BIT, .timer_num = config->timer_idx, .freq_hz = 5000, .clk_cfg = LEDC_AUTO_CLK}; @@ -62,7 +63,7 @@ disp_backlight_h disp_backlight_new(const disp_backlight_config_t *config) { // Configure GPIO for output bckl_dev->index = config->gpio_num; - gpio_pad_select_gpio(config->gpio_num); + gpio_reset_pin(config->gpio_num); ESP_ERROR_CHECK(gpio_set_direction(config->gpio_num, GPIO_MODE_OUTPUT)); gpio_matrix_out(config->gpio_num, SIG_GPIO_OUT_IDX, config->output_invert, false); } From 2978b21f172255747e051c09d663bf40820c03c3 Mon Sep 17 00:00:00 2001 From: Luc Appelman Date: Wed, 17 May 2023 10:17:45 +0200 Subject: [PATCH 67/70] REQUIRED driver component --- CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 407802a6..28345867 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -86,7 +86,7 @@ endif() idf_component_register(SRCS ${SOURCES} INCLUDE_DIRS ${LVGL_INCLUDE_DIRS} - REQUIRES lvgl) + REQUIRES lvgl driver) target_compile_definitions(${COMPONENT_LIB} PUBLIC "-DLV_LVGL_H_INCLUDE_SIMPLE") From f9b9d6e829107621e72f5f8403f70ea8a687aef0 Mon Sep 17 00:00:00 2001 From: Luc Appelman Date: Wed, 2 Aug 2023 08:54:46 +0200 Subject: [PATCH 68/70] fix print lines --- lvgl_i2c/i2c_manager.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lvgl_i2c/i2c_manager.c b/lvgl_i2c/i2c_manager.c index 080d81a7..fa8045ac 100644 --- a/lvgl_i2c/i2c_manager.c +++ b/lvgl_i2c/i2c_manager.c @@ -133,7 +133,7 @@ esp_err_t I2C_FN(_init)(i2c_port_t port) { I2C_FN(_mutex)[port] = xSemaphoreCreateMutex(); i2c_config_t conf = {0}; - + #ifdef HAS_CLK_FLAGS conf.clk_flags = 0; #endif @@ -168,7 +168,7 @@ esp_err_t I2C_FN(_init)(i2c_port_t port) { ESP_LOGW(TAG, "If it was already open, we'll use it with whatever settings were used " "to open it. See I2C Manager README for details."); } else { - ESP_LOGI(TAG, "Initialised port %d (SDA: %d, SCL: %d, speed: %d Hz.)", + ESP_LOGI(TAG, "Initialised port %d (SDA: %d, SCL: %d, speed: %lu Hz.)", port, conf.sda_io_num, conf.scl_io_num, conf.master.clk_speed); } @@ -186,7 +186,7 @@ esp_err_t I2C_FN(_read)(i2c_port_t port, uint16_t addr, uint32_t reg, uint8_t *b // May seem weird, but init starts with a check if it's needed, no need for that check twice. I2C_FN(_init)(port); - ESP_LOGV(TAG, "Reading port %d, addr 0x%03x, reg 0x%04x", port, addr, reg); + ESP_LOGV(TAG, "Reading port %d, addr 0x%03x, reg 0x%04lx", port, addr, reg); TickType_t timeout = 0; #if defined (I2C_ZERO) @@ -239,7 +239,7 @@ esp_err_t I2C_FN(_write)(i2c_port_t port, uint16_t addr, uint32_t reg, const uin // May seem weird, but init starts with a check if it's needed, no need for that check twice. I2C_FN(_init)(port); - ESP_LOGV(TAG, "Writing port %d, addr 0x%03x, reg 0x%04x", port, addr, reg); + ESP_LOGV(TAG, "Writing port %d, addr 0x%03x, reg 0x%04lx", port, addr, reg); TickType_t timeout = 0; #if defined (I2C_ZERO) From ab61a653db660efa0f5638e2fae912f0a473622b Mon Sep 17 00:00:00 2001 From: Luc Appelman Date: Wed, 2 Aug 2023 09:16:25 +0200 Subject: [PATCH 69/70] portTICK_RATE_MS has been renamed --- lvgl_i2c/i2c_manager.c | 16 ++++++++-------- lvgl_tft/ili9163c.c | 6 +++--- lvgl_tft/pcd8544.c | 4 ++-- 3 files changed, 13 insertions(+), 13 deletions(-) diff --git a/lvgl_i2c/i2c_manager.c b/lvgl_i2c/i2c_manager.c index fa8045ac..e17f48c6 100644 --- a/lvgl_i2c/i2c_manager.c +++ b/lvgl_i2c/i2c_manager.c @@ -66,8 +66,8 @@ static const uint8_t ACK_CHECK_EN = 1; #define I2C_MANAGER_0_PULLUPS false #endif - #define I2C_MANAGER_0_TIMEOUT ( CONFIG_I2C_MANAGER_0_TIMEOUT / portTICK_RATE_MS ) - #define I2C_MANAGER_0_LOCK_TIMEOUT ( CONFIG_I2C_MANAGER_0_LOCK_TIMEOUT / portTICK_RATE_MS ) + #define I2C_MANAGER_0_TIMEOUT ( CONFIG_I2C_MANAGER_0_TIMEOUT / portTICK_PERIOD_MS ) + #define I2C_MANAGER_0_LOCK_TIMEOUT ( CONFIG_I2C_MANAGER_0_LOCK_TIMEOUT / portTICK_PERIOD_MS ) #endif @@ -79,8 +79,8 @@ static const uint8_t ACK_CHECK_EN = 1; #define I2C_MANAGER_1_PULLUPS false #endif - #define I2C_MANAGER_1_TIMEOUT ( CONFIG_I2C_MANAGER_1_TIMEOUT / portTICK_RATE_MS ) - #define I2C_MANAGER_1_LOCK_TIMEOUT ( CONFIG_I2C_MANAGER_1_LOCK_TIMEOUT / portTICK_RATE_MS ) + #define I2C_MANAGER_1_TIMEOUT ( CONFIG_I2C_MANAGER_1_TIMEOUT / portTICK_PERIOD_MS ) + #define I2C_MANAGER_1_LOCK_TIMEOUT ( CONFIG_I2C_MANAGER_1_LOCK_TIMEOUT / portTICK_PERIOD_MS ) #endif #define ERROR_PORT(port, fail) { \ @@ -244,12 +244,12 @@ esp_err_t I2C_FN(_write)(i2c_port_t port, uint16_t addr, uint32_t reg, const uin TickType_t timeout = 0; #if defined (I2C_ZERO) if (port == I2C_NUM_0) { - timeout = (CONFIG_I2C_MANAGER_0_TIMEOUT) / portTICK_RATE_MS; + timeout = (CONFIG_I2C_MANAGER_0_TIMEOUT) / portTICK_PERIOD_MS; } #endif #if defined (I2C_ONE) if (port == I2C_NUM_1) { - timeout = (CONFIG_I2C_MANAGER_1_TIMEOUT) / portTICK_RATE_MS; + timeout = (CONFIG_I2C_MANAGER_1_TIMEOUT) / portTICK_PERIOD_MS; } #endif @@ -294,12 +294,12 @@ esp_err_t I2C_FN(_lock)(i2c_port_t port) { TickType_t timeout; #if defined (I2C_ZERO) if (port == I2C_NUM_0) { - timeout = (CONFIG_I2C_MANAGER_0_LOCK_TIMEOUT) / portTICK_RATE_MS; + timeout = (CONFIG_I2C_MANAGER_0_LOCK_TIMEOUT) / portTICK_PERIOD_MS; } #endif #if defined (I2C_ONE) if (port == I2C_NUM_1) { - timeout = (CONFIG_I2C_MANAGER_1_LOCK_TIMEOUT) / portTICK_RATE_MS; + timeout = (CONFIG_I2C_MANAGER_1_LOCK_TIMEOUT) / portTICK_PERIOD_MS; } #endif diff --git a/lvgl_tft/ili9163c.c b/lvgl_tft/ili9163c.c index 29416362..13f22b70 100644 --- a/lvgl_tft/ili9163c.c +++ b/lvgl_tft/ili9163c.c @@ -145,9 +145,9 @@ void ili9163c_init(void) //Reset the display gpio_set_level(ILI9163C_RST, 0); - vTaskDelay(100 / portTICK_RATE_MS); + vTaskDelay(100 / portTICK_PERIOD_MS); gpio_set_level(ILI9163C_RST, 1); - vTaskDelay(150 / portTICK_RATE_MS); + vTaskDelay(150 / portTICK_PERIOD_MS); //Send all the commands uint16_t cmd = 0; @@ -157,7 +157,7 @@ void ili9163c_init(void) ili9163c_send_data(ili_init_cmds[cmd].data, ili_init_cmds[cmd].databytes & 0x1F); if (ili_init_cmds[cmd].databytes & 0x80) { - vTaskDelay(150 / portTICK_RATE_MS); + vTaskDelay(150 / portTICK_PERIOD_MS); } cmd++; } diff --git a/lvgl_tft/pcd8544.c b/lvgl_tft/pcd8544.c index 13b357c1..10684c1c 100644 --- a/lvgl_tft/pcd8544.c +++ b/lvgl_tft/pcd8544.c @@ -64,9 +64,9 @@ void pcd8544_init(void){ // Reset the display gpio_set_level(PCD8544_RST, 0); - vTaskDelay(100 / portTICK_RATE_MS); + vTaskDelay(100 / portTICK_PERIOD_MS); gpio_set_level(PCD8544_RST, 1); - vTaskDelay(100 / portTICK_RATE_MS); + vTaskDelay(100 / portTICK_PERIOD_MS); pcd8544_send_cmd(0x21); /* activate chip (PD=0), horizontal increment (V=0), enter extended command set (H=1) */ pcd8544_send_cmd(0x06); /* temp. control: b10 = 2 */ From 2da44d8c2e6089d1891854c9afc9531baaf219b9 Mon Sep 17 00:00:00 2001 From: Luc Appelman Date: Wed, 2 Aug 2023 09:16:39 +0200 Subject: [PATCH 70/70] automatically select DMA channel --- lvgl_helpers.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lvgl_helpers.c b/lvgl_helpers.c index 57ab7dd1..4c8f8a8d 100644 --- a/lvgl_helpers.c +++ b/lvgl_helpers.c @@ -101,7 +101,7 @@ void lvgl_driver_init(void) lvgl_spi_driver_init(TFT_SPI_HOST, DISP_SPI_MISO, DISP_SPI_MOSI, DISP_SPI_CLK, - SPI_BUS_MAX_TRANSFER_SZ, 1, + SPI_BUS_MAX_TRANSFER_SZ, SPI_DMA_CH_AUTO, DISP_SPI_IO2, DISP_SPI_IO3); disp_spi_add_device(TFT_SPI_HOST);