diff mbox series

[meta-oe,5/9] lvgl: Use Kconfig to configure

Message ID 20251025031748.2728416-5-pkj@axis.com
State Under Review
Headers show
Series [meta-oe,1/9] python3-pcpp: Add recipe for https://github.com/ned14/pcpp | expand

Commit Message

Peter Kjellerstedt Oct. 25, 2025, 3:17 a.m. UTC
This switches the recipe from manipulating the lv_conf.h file directly,
to instead using Kconfig to configure lvgl.

* Drop configuration of LV_TICK_CUSTOM* as they were removed in 9.0.0.
* Drop configuration options that match their defaults.

Co-authored-by: Adam x Nilsson <adam.x.nilsson@axis.com>
Signed-off-by: Peter Kjellerstedt <peter.kjellerstedt@axis.com>
---
 meta-oe/recipes-graphics/lvgl/files/debug.cfg |   3 +
 meta-oe/recipes-graphics/lvgl/files/defconfig |   1 +
 meta-oe/recipes-graphics/lvgl/files/drm.cfg   |   2 +
 meta-oe/recipes-graphics/lvgl/files/fbdev.cfg |   2 +
 .../recipes-graphics/lvgl/files/gridnav.cfg   |   1 +
 meta-oe/recipes-graphics/lvgl/files/sdl.cfg   |   3 +
 .../recipes-graphics/lvgl/files/thorvg.cfg    |   3 +
 meta-oe/recipes-graphics/lvgl/lv-conf.inc     | 106 +++++-------------
 8 files changed, 41 insertions(+), 80 deletions(-)
 create mode 100644 meta-oe/recipes-graphics/lvgl/files/debug.cfg
 create mode 100644 meta-oe/recipes-graphics/lvgl/files/defconfig
 create mode 100644 meta-oe/recipes-graphics/lvgl/files/drm.cfg
 create mode 100644 meta-oe/recipes-graphics/lvgl/files/fbdev.cfg
 create mode 100644 meta-oe/recipes-graphics/lvgl/files/gridnav.cfg
 create mode 100644 meta-oe/recipes-graphics/lvgl/files/sdl.cfg
 create mode 100644 meta-oe/recipes-graphics/lvgl/files/thorvg.cfg
diff mbox series

Patch

diff --git a/meta-oe/recipes-graphics/lvgl/files/debug.cfg b/meta-oe/recipes-graphics/lvgl/files/debug.cfg
new file mode 100644
index 0000000000..022375d4ae
--- /dev/null
+++ b/meta-oe/recipes-graphics/lvgl/files/debug.cfg
@@ -0,0 +1,3 @@ 
+CONFIG_LV_USE_ASSERT_STYLE=y
+CONFIG_LV_USE_ASSERT_MEM_INTEGRITY=y
+CONFIG_LV_USE_ASSERT_OBJ=y
diff --git a/meta-oe/recipes-graphics/lvgl/files/defconfig b/meta-oe/recipes-graphics/lvgl/files/defconfig
new file mode 100644
index 0000000000..1f42f11f7a
--- /dev/null
+++ b/meta-oe/recipes-graphics/lvgl/files/defconfig
@@ -0,0 +1 @@ 
+CONFIG_LV_COLOR_DEPTH_32=y
diff --git a/meta-oe/recipes-graphics/lvgl/files/drm.cfg b/meta-oe/recipes-graphics/lvgl/files/drm.cfg
new file mode 100644
index 0000000000..c2387087f2
--- /dev/null
+++ b/meta-oe/recipes-graphics/lvgl/files/drm.cfg
@@ -0,0 +1,2 @@ 
+CONFIG_LV_USE_LINUX_DRM=y
+CONFIG_LV_USE_EVDEV=y
diff --git a/meta-oe/recipes-graphics/lvgl/files/fbdev.cfg b/meta-oe/recipes-graphics/lvgl/files/fbdev.cfg
new file mode 100644
index 0000000000..4ba7f8f5ad
--- /dev/null
+++ b/meta-oe/recipes-graphics/lvgl/files/fbdev.cfg
@@ -0,0 +1,2 @@ 
+CONFIG_LV_USE_LINUX_FBDEV=y
+CONFIG_LV_USE_EVDEV=y
diff --git a/meta-oe/recipes-graphics/lvgl/files/gridnav.cfg b/meta-oe/recipes-graphics/lvgl/files/gridnav.cfg
new file mode 100644
index 0000000000..02b80c3e57
--- /dev/null
+++ b/meta-oe/recipes-graphics/lvgl/files/gridnav.cfg
@@ -0,0 +1 @@ 
+CONFIG_LV_USE_GRIDNAV=y
diff --git a/meta-oe/recipes-graphics/lvgl/files/sdl.cfg b/meta-oe/recipes-graphics/lvgl/files/sdl.cfg
new file mode 100644
index 0000000000..3ba28d7b01
--- /dev/null
+++ b/meta-oe/recipes-graphics/lvgl/files/sdl.cfg
@@ -0,0 +1,3 @@ 
+CONFIG_LV_USE_DRAW_SDL=y
+CONFIG_LV_USE_SDL=y
+CONFIG_LV_SDL_DOUBLE_BUFFER=y
diff --git a/meta-oe/recipes-graphics/lvgl/files/thorvg.cfg b/meta-oe/recipes-graphics/lvgl/files/thorvg.cfg
new file mode 100644
index 0000000000..4dbffdfe09
--- /dev/null
+++ b/meta-oe/recipes-graphics/lvgl/files/thorvg.cfg
@@ -0,0 +1,3 @@ 
+CONFIG_LV_USE_VECTOR_GRAPHIC=y
+CONFIG_LV_USE_LOTTIE=y
+CONFIG_LV_USE_THORVG=y
diff --git a/meta-oe/recipes-graphics/lvgl/lv-conf.inc b/meta-oe/recipes-graphics/lvgl/lv-conf.inc
index 7c16eb3936..ab3ad01a5a 100644
--- a/meta-oe/recipes-graphics/lvgl/lv-conf.inc
+++ b/meta-oe/recipes-graphics/lvgl/lv-conf.inc
@@ -1,3 +1,18 @@ 
+# SPDX-FileCopyrightText: Axis Communication AB <https://www.axis.com/>
+# SPDX-License-Identifier: MIT
+
+DEPENDS += "python3-kconfiglib-native python3-pcpp-native"
+
+SRC_URI += " \
+    file://defconfig \
+    ${@oe.utils.vartrue('DEBUG_BUILD', 'file://debug.cfg', '', d)} \
+    ${@bb.utils.contains('PACKAGECONFIG', 'drm', 'file://drm.cfg', '', d)} \
+    ${@bb.utils.contains('PACKAGECONFIG', 'fbdev', 'file://fbdev.cfg', '', d)} \
+    ${@bb.utils.contains('PACKAGECONFIG', 'gridnav', 'file://gridnav.cfg', '', d)} \
+    ${@bb.utils.contains('PACKAGECONFIG', 'sdl', 'file://sdl.cfg', '', d)} \
+    ${@bb.utils.contains('PACKAGECONFIG', 'thorvg', 'file://thorvg.cfg', '', d)} \
+"
+
 PACKAGECONFIG ??= "drm"
 
 PACKAGECONFIG[drm] = ",,libdrm libevdev"
@@ -6,6 +21,10 @@  PACKAGECONFIG[gridnav] = ",,"
 PACKAGECONFIG[thorvg] = ",,"
 PACKAGECONFIG[sdl] = ",,virtual/libsdl2 libsdl2-image"
 
+inherit python3native
+
+EXTRA_OECMAKE += "-DLV_BUILD_USE_KCONFIG=ON"
+
 # Add libdrm include if drm is selected in PACKAGECONFIG
 LVGL_FLAGS += " \
     ${@bb.utils.contains('PACKAGECONFIG', 'drm', '-I${STAGING_INCDIR}/libdrm', '', d)} \
@@ -13,86 +32,13 @@  LVGL_FLAGS += " \
 CFLAGS += "${LVGL_FLAGS}"
 CXXFLAGS += "${LVGL_FLAGS}"
 
-LVGL_CONFIG_USE_DRM = "${@bb.utils.contains('PACKAGECONFIG', 'drm', '1', '0', d)}"
-
-LVGL_CONFIG_USE_EVDEV = "${@bb.utils.contains_any('PACKAGECONFIG', 'drm fbdev', '1', '0', d)}"
-
-LVGL_CONFIG_USE_FBDEV = "${@bb.utils.contains('PACKAGECONFIG', 'fbdev', '1', '0', d)}"
-
-LVGL_CONFIG_USE_SDL = "${@bb.utils.contains('PACKAGECONFIG', 'sdl', '1', '0', d)}"
-
-LVGL_CONFIG_SDL_FULLSCREEN ?= "0"
-
-LVGL_CONFIG_LV_MEM_CUSTOM ?= "0"
-LVGL_CONFIG_LV_MEM_SIZE ?= "(64 * 1024U)"
-LVGL_CONFIG_LV_COLOR_DEPTH ?= "32"
-
-LVGL_CONFIG_LV_USE_LOG    ?= "0"
-LVGL_CONFIG_LV_LOG_LEVEL  ?= "LV_LOG_LEVEL_WARN"
-LVGL_CONFIG_LV_LOG_PRINTF ?= "0"
-
-LVGL_CONFIG_LV_USE_FONT_COMPRESSED ?= "0"
-
-LVGL_CONFIG_LV_USE_GRIDNAV = "${@bb.utils.contains('PACKAGECONFIG', 'gridnav', '1', '0', d)}"
-
-LVGL_CONFIG_LV_THEME_DEFAULT_DARK ?= "0"
-
-LVGL_CONFIG_USE_LOTTIE = "${@bb.utils.contains('PACKAGECONFIG', 'thorvg', '1', '0', d)}"
-
-LVGL_CONFIG_USE_VECTOR_GRAPHICS = "${@bb.utils.contains('PACKAGECONFIG', 'thorvg', '1', '0', d)}"
-
-LVGL_CONFIG_USE_THORVG_INTERNAL = "${@bb.utils.contains('PACKAGECONFIG', 'thorvg', '1', '0', d)}"
-
-LVGL_CONFIG_USE_MATRIX = "${@bb.utils.contains('PACKAGECONFIG', 'thorvg', '1', '0', d)}"
-
-LVGL_CONFIG_USE_FLOAT = "${@bb.utils.contains('PACKAGECONFIG', 'thorvg', '1', '0', d)}"
-
-DEBUG_BUILD ??= "0"
+KCONFIG_CONFIG_ROOTDIR ?= "${S}"
+KCONFIG_FILE ?= "${KCONFIG_CONFIG_ROOTDIR}/Kconfig"
+export KCONFIG_CONFIG ?= "${KCONFIG_CONFIG_ROOTDIR}/.config"
 
-do_configure:prepend() {
-    # If there is a configuration template, start from that
-    [ -r "${S}/lv_conf_template.h" ] && cp -Lv "${S}/lv_conf_template.h" "${S}/lv_conf.h"
+do_configure() {
+    cat ${UNPACKDIR}/defconfig ${@" ".join(find_cfgs(d))} > ${B}/defconfig
+    defconfig --kconfig ${KCONFIG_FILE} ${B}/defconfig
 
-    sed -r -e "s|#if 0 .*Set it to \"1\" to enable content.*|#if 1 // Enabled by ${PN}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_USE_LINUX_DRM[[:space:]]).*|\1${LVGL_CONFIG_USE_DRM}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_USE_LINUX_FBDEV[[:space:]]).*|\1${LVGL_CONFIG_USE_FBDEV}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_USE_SDL[[:space:]]).*|\1${LVGL_CONFIG_USE_SDL}|" \
-        -e "s|^([[:space:]]*#define LV_USE_DRAW_SDL[[:space:]]).*|\1${LVGL_CONFIG_USE_SDL}|" \
-        -e "s|^([[:space:]]*#define LV_SDL_BUF_COUNT[[:space:]]).*|\1 2|" \
-        -e "s|^([[:space:]]*#define LV_SDL_FULLSCREEN[[:space:]]).*|\1${LVGL_CONFIG_SDL_FULLSCREEN}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_COLOR_DEPTH[[:space:]]).*|\1${LVGL_CONFIG_LV_COLOR_DEPTH}|" \
-        -e "s|^([[:space:]]*#define LV_MEM_CUSTOM[[:space:]]).*|\1${LVGL_CONFIG_LV_MEM_CUSTOM}|" \
-        -e "s|^([[:space:]]*#define LV_MEM_SIZE[[:space:]]).*|\1${LVGL_CONFIG_LV_MEM_SIZE}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_TICK_CUSTOM[[:space:]]).*|\1 1|" \
-        -e "s|^([[:space:]]*#define LV_TICK_CUSTOM_INCLUDE[[:space:]]).*|\1 <stdint.h>|" \
-        -e "s|^([[:space:]]*#define LV_TICK_CUSTOM_SYS_TIME_EXPR[[:space:]]).*|extern uint32_t custom_tick_get(void);\n\1 (custom_tick_get())|" \
-        \
-        -e "s|^([[:space:]]*#define LV_USE_EVDEV[[:space:]]).*|\1${LVGL_CONFIG_USE_EVDEV}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_USE_ASSERT_NULL[[:space:]]).*|\1${DEBUG_BUILD}|" \
-        -e "s|^([[:space:]]*#define LV_USE_ASSERT_MALLOC[[:space:]]).*|\1${DEBUG_BUILD}|" \
-        -e "s|^([[:space:]]*#define LV_USE_ASSERT_STYLE[[:space:]]).*|\1${DEBUG_BUILD}|" \
-        -e "s|^([[:space:]]*#define LV_USE_ASSERT_MEM_INTEGRITY[[:space:]]).*|\1${DEBUG_BUILD}|" \
-        -e "s|^([[:space:]]*#define LV_USE_ASSERT_OBJ[[:space:]]).*|\1${DEBUG_BUILD}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_USE_LOG[[:space:]]).*|\1${LVGL_CONFIG_LV_USE_LOG}|" \
-        -e "s|^([[:space:]]*#define LV_LOG_LEVEL[[:space:]]).*|\1${LVGL_CONFIG_LV_LOG_LEVEL}|" \
-        -e "s|^([[:space:]]*#define LV_LOG_PRINTF[[:space:]]).*|\1${LVGL_CONFIG_LV_LOG_PRINTF}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_USE_FONT_COMPRESSED[[:space:]]).*|\1${LVGL_CONFIG_LV_USE_FONT_COMPRESSED}|" \
-        -e "s|^([[:space:]]*#define LV_USE_GRIDNAV[[:space:]]).*|\1${LVGL_CONFIG_LV_USE_GRIDNAV}|" \
-        -e "s|^([[:space:]]*#define LV_THEME_DEFAULT_DARK[[:space:]]).*|\1${LVGL_CONFIG_LV_THEME_DEFAULT_DARK}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_USE_VECTOR_GRAPHIC[[:space:]]).*|\1${LVGL_CONFIG_USE_VECTOR_GRAPHICS}|" \
-        -e "s|^([[:space:]]*#define LV_USE_THORVG_INTERNAL[[:space:]]).*|\1${LVGL_CONFIG_USE_THORVG_INTERNAL}|" \
-        -e "s|^([[:space:]]*#define LV_USE_MATRIX[[:space:]]).*|\1${LVGL_CONFIG_USE_MATRIX}|" \
-        -e "s|^([[:space:]]*#define LV_USE_FLOAT[[:space:]]).*|\1${LVGL_CONFIG_USE_FLOAT}|" \
-        \
-        -e "s|^([[:space:]]*#define LV_USE_LOTTIE[[:space:]]).*|\1${LVGL_CONFIG_USE_LOTTIE}|" \
-        -i "${S}/lv_conf.h"
+    cmake_do_configure
 }