diff --git a/.cargo/config.toml b/.cargo/config.toml index 8f0cb18..ec66039 100644 --- a/.cargo/config.toml +++ b/.cargo/config.toml @@ -10,8 +10,8 @@ linker = "ldproxy" runner = "espflash flash --monitor" # Select this runner for espflash v2.x.x rustflags = [ "--cfg", "espidf_time64"] # Extending time_t for ESP IDF 5: https://github.com/esp-rs/rust/issues/110 -[unstable] -build-std = ["std", "panic_abort"] +#[unstable] +#build-std = ["std", "panic_abort"] [env] # Note: this variable is not used by the pio builder (`cargo build --features pio`) diff --git a/Build/src/Main.rs b/Build/src/Main.rs index e91a5cb..98aabbb 100644 --- a/Build/src/Main.rs +++ b/Build/src/Main.rs @@ -9,7 +9,7 @@ mod Log; fn main() { let Target = Target_type::Get_current(); - + Print_line!("Start Xila build"); Print_line!("Target architecture: {:?}", Target); diff --git a/Cargo.toml b/Cargo.toml index d8e47c1..2e503e0 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -40,9 +40,12 @@ embedded-sdmmc = "0.6.0" embedded-hal = "0.2.7" fatfs = { version = "0.3.6" } byteorder = "1.5.0" +sdl2 = "0.36.0" [build-dependencies] embuild = { version = "0.31.4", features = ["espidf"] } [target.'cfg(target_arch = "x86_64")'.dependencies] byteorder = "1.5.0" +sdl2 = { version = "0.36.0", features = [] } +lvgl = { version="0.6.2", features = [] } \ No newline at end of file diff --git a/Export.sh b/Export.sh index 21e191d..3055c45 100644 --- a/Export.sh +++ b/Export.sh @@ -5,15 +5,16 @@ clear && echo "Setting up environment variables for Rust cross-compilation" # Variables +Linux_environment_variables="DEP_LV_CONFIG_PATH=\"$PWD\"" Linux_target="--target x86_64-unknown-linux-gnu" Windows_target="--target x86_64-pc-windows-gnu" -ESP32_environment_variables="MCU=esp32" +ESP32_environment_variables="MCU=esp32 DEP_LV_CONFIG_PATH='pwd'" ESP32_target="--target xtensa-esp32-espidf --features ESP32" -ESP32_S3_environment_variables="MCU=esp32s3" +ESP32_S3_environment_variables="MCU=esp32s3 DEP_LV_CONFIG_PATH='pwd'" ESP32_S3_target="--target xtensa-esp32s3-espidf --features ESP32_S3" -Cargo="clear && cargo" +Cargo="cargo" # Remove all aliases { @@ -25,33 +26,42 @@ unalias run_linux unalias run_windows unalias run_esp32 unalias run_esp32_s3 +unalias test_linux +unalias test_windows +unalias test_esp32 +unalias test_esp32_s3 +unalias check_linux +unalias check_windows +unalias check_esp32 +unalias check_esp32_s3 unalias clean } &> /dev/null # Aliases +Clear="clear &&" Cargo_build="$Cargo build" -alias build_linux="$Cargo_build $Linux_target" -alias build_windows="$Cargo_build $Windows_target" -alias build_esp32="$ESP32_environment_variables $Cargo_build $ESP32_target" -alias build_esp32_s3="$ESP32_S3_environment_variables $Cargo_build $ESP32_S3_target" - -Cargo_run="$Cargo run" -alias run_linux="$Cargo_run $Linux_target" -alias run_windows="$Cargo_run $Windows_target" -alias run_esp32="$ESP32_environment_variables $Cargo_run $ESP32_target" -alias run_esp32_s3="$ESP32_S3_environment_variables $Cargo_run $ESP32_S3_target" - -Cargo_test="$Cargo test" -alias test_linux="$Cargo_test $Linux_target" -alias test_windows="$Cargo_test $Windows_target" -alias test_esp32="$ESP32_environment_variables $Cargo_test $ESP32_target" -alias test_esp32_s3="$ESP32_S3_environment_variables $Cargo_test $ESP32_S3_target" - -Cargo_check="$Cargo check" -alias check_linux="$Cargo_check $Linux_target" -alias check_windows="$Cargo_check $Windows_target" -alias check_esp32="$ESP32_environment_variables $Cargo_check $ESP32_target" -alias check_esp32_s3="$ESP32_S3_environment_variables $Cargo_check $ESP32_S3_target" +alias build_linux="$Clear $Linux_environment_variables $Cargo_build $Linux_target" +alias build_windows="$Clear $Cargo_build $Windows_target" +alias build_esp32="$Clear $ESP32_environment_variables $Cargo_build $ESP32_target" +alias build_esp32_s3="$Clear $ESP32_S3_environment_variables $Cargo_build $ESP32_S3_target" + +Cargo_run="$Clear $Cargo run" +alias run_linux="$Clear $Linux_environment_variables $Cargo_run $Linux_target" +alias run_windows="$Clear $Cargo_run $Windows_target" +alias run_esp32="$Clear $ESP32_environment_variables $Cargo_run $ESP32_target" +alias run_esp32_s3="$Clear $ESP32_S3_environment_variables $Cargo_run $ESP32_S3_target" + +Cargo_test="$Clear $Cargo test" +alias test_linux="$Clear $Linux_environment_variables $Cargo_test $Linux_target" +alias test_windows="$Clear $Cargo_test $Windows_target" +alias test_esp32="$Clear $ESP32_environment_variables $Cargo_test $ESP32_target" +alias test_esp32_s3="$Clear $ESP32_S3_environment_variables $Cargo_test $ESP32_S3_target" + +Cargo_check="$Clear $Cargo check" +alias check_linux="$Clear $Linux_environment_variables $Cargo_check $Linux_target" +alias check_windows="$Clear $Cargo_check $Windows_target" +alias check_esp32="$Clear $ESP32_environment_variables $Cargo_check $ESP32_target" +alias check_esp32_s3="$Clear $ESP32_S3_environment_variables $Cargo_check $ESP32_S3_target" alias clean="$Cargo clean" diff --git a/lv_conf.h b/lv_conf.h new file mode 100644 index 0000000..ec245c4 --- /dev/null +++ b/lv_conf.h @@ -0,0 +1,762 @@ +/** + * @file lv_conf.h + * Configuration file for v8.3.5 + */ + +/* + * Copy this file as `lv_conf.h` + * 1. simply next to the `lvgl` folder + * 2. or any other places and + * - define `LV_CONF_INCLUDE_SIMPLE` + * - add the path as include path + */ + +/* clang-format off */ +#if 1 /*Set it to "1" to enable content*/ + +#ifndef LV_CONF_H +#define LV_CONF_H + +#include + +/*==================== + COLOR SETTINGS + *====================*/ + +/*Color depth: 1 (1 byte per pixel), 8 (RGB332), 16 (RGB565), 32 (ARGB8888)*/ +#define LV_COLOR_DEPTH 16 + +/*Swap the 2 bytes of RGB565 color. Useful if the display has an 8-bit interface (e.g. SPI)*/ +#define LV_COLOR_16_SWAP 0 + +/*Enable features to draw on transparent background. + *It's required if opa, and transform_* style properties are used. + *Can be also used if the UI is above another layer, e.g. an OSD menu or video player.*/ +#define LV_COLOR_SCREEN_TRANSP 0 + +/* Adjust color mix functions rounding. GPUs might calculate color mix (blending) differently. + * 0: round down, 64: round up from x.75, 128: round up from half, 192: round up from x.25, 254: round up */ +#define LV_COLOR_MIX_ROUND_OFS 0 + +/*Images pixels with this color will not be drawn if they are chroma keyed)*/ +#define LV_COLOR_CHROMA_KEY lv_color_hex(0x00ff00) /*pure green*/ + +/*========================= + MEMORY SETTINGS + *=========================*/ + +/*1: use custom malloc/free, 0: use the built-in `lv_mem_alloc()` and `lv_mem_free()`*/ +#define LV_MEM_CUSTOM 0 +#if LV_MEM_CUSTOM == 0 + /*Size of the memory available for `lv_mem_alloc()` in bytes (>= 2kB)*/ + #define LV_MEM_SIZE (1024U * 1024U) /*[bytes]*/ + + /*Set an address for the memory pool instead of allocating it as a normal array. Can be in external SRAM too.*/ + #define LV_MEM_ADR 0 /*0: unused*/ + /*Instead of an address give a memory allocator that will be called to get a memory pool for LVGL. E.g. my_malloc*/ + #if LV_MEM_ADR == 0 + #undef LV_MEM_POOL_INCLUDE + #undef LV_MEM_POOL_ALLOC + #endif + +#else /*LV_MEM_CUSTOM*/ + #define LV_MEM_CUSTOM_INCLUDE /*Header for the dynamic memory function*/ + #define LV_MEM_CUSTOM_ALLOC malloc + #define LV_MEM_CUSTOM_FREE free + #define LV_MEM_CUSTOM_REALLOC realloc +#endif /*LV_MEM_CUSTOM*/ + +/*Number of the intermediate memory buffer used during rendering and other internal processing mechanisms. + *You will see an error log message if there wasn't enough buffers. */ +#define LV_MEM_BUF_MAX_NUM 16 + +/*Use the standard `memcpy` and `memset` instead of LVGL's own functions. (Might or might not be faster).*/ +#define LV_MEMCPY_MEMSET_STD 0 + +/*==================== + HAL SETTINGS + *====================*/ + +/*Default display refresh period. LVG will redraw changed areas with this period time*/ +#define LV_DISP_DEF_REFR_PERIOD 30 /*[ms]*/ + +/*Input device read period in milliseconds*/ +#define LV_INDEV_DEF_READ_PERIOD 30 /*[ms]*/ + +/*Use a custom tick source that tells the elapsed time in milliseconds. + *It removes the need to manually update the tick with `lv_tick_inc()`)*/ +#define LV_TICK_CUSTOM 0 +#if LV_TICK_CUSTOM + #define LV_TICK_CUSTOM_INCLUDE /*Header for the system time function*/ + #define LV_TICK_CUSTOM_SYS_TIME_EXPR (rs_lv_timer()) /*Expression evaluating to current system time in ms*/ + /*If using lvgl as ESP32 component*/ + // #define LV_TICK_CUSTOM_INCLUDE "esp_timer.h" + // #define LV_TICK_CUSTOM_SYS_TIME_EXPR ((esp_timer_get_time() / 1000LL)) +#endif /*LV_TICK_CUSTOM*/ + +/*Default Dot Per Inch. Used to initialize default sizes such as widgets sized, style paddings. + *(Not so important, you can adjust it to modify default sizes and spaces)*/ +#define LV_DPI_DEF 130 /*[px/inch]*/ + +/*======================= + * FEATURE CONFIGURATION + *=======================*/ + +/*------------- + * Drawing + *-----------*/ + +/*Enable complex draw engine. + *Required to draw shadow, gradient, rounded corners, circles, arc, skew lines, image transformations or any masks*/ +#define LV_DRAW_COMPLEX 1 +#if LV_DRAW_COMPLEX != 0 + + /*Allow buffering some shadow calculation. + *LV_SHADOW_CACHE_SIZE is the max. shadow size to buffer, where shadow size is `shadow_width + radius` + *Caching has LV_SHADOW_CACHE_SIZE^2 RAM cost*/ + #define LV_SHADOW_CACHE_SIZE 0 + + /* Set number of maximally cached circle data. + * The circumference of 1/4 circle are saved for anti-aliasing + * radius * 4 bytes are used per circle (the most often used radiuses are saved) + * 0: to disable caching */ + #define LV_CIRCLE_CACHE_SIZE 4 +#endif /*LV_DRAW_COMPLEX*/ + +/** + * "Simple layers" are used when a widget has `style_opa < 255` to buffer the widget into a layer + * and blend it as an image with the given opacity. + * Note that `bg_opa`, `text_opa` etc don't require buffering into layer) + * The widget can be buffered in smaller chunks to avoid using large buffers. + * + * - LV_LAYER_SIMPLE_BUF_SIZE: [bytes] the optimal target buffer size. LVGL will try to allocate it + * - LV_LAYER_SIMPLE_FALLBACK_BUF_SIZE: [bytes] used if `LV_LAYER_SIMPLE_BUF_SIZE` couldn't be allocated. + * + * Both buffer sizes are in bytes. + * "Transformed layers" (where transform_angle/zoom properties are used) use larger buffers + * and can't be drawn in chunks. So these settings affects only widgets with opacity. + */ +#define LV_LAYER_SIMPLE_BUF_SIZE (24 * 1024) +#define LV_LAYER_SIMPLE_FALLBACK_BUF_SIZE (3 * 1024) + +/*Default image cache size. Image caching keeps the images opened. + *If only the built-in image formats are used there is no real advantage of caching. (I.e. if no new image decoder is added) + *With complex image decoders (e.g. PNG or JPG) caching can save the continuous open/decode of images. + *However the opened images might consume additional RAM. + *0: to disable caching*/ +#define LV_IMG_CACHE_DEF_SIZE 0 + +/*Number of stops allowed per gradient. Increase this to allow more stops. + *This adds (sizeof(lv_color_t) + 1) bytes per additional stop*/ +#define LV_GRADIENT_MAX_STOPS 2 + +/*Default gradient buffer size. + *When LVGL calculates the gradient "maps" it can save them into a cache to avoid calculating them again. + *LV_GRAD_CACHE_DEF_SIZE sets the size of this cache in bytes. + *If the cache is too small the map will be allocated only while it's required for the drawing. + *0 mean no caching.*/ +#define LV_GRAD_CACHE_DEF_SIZE 0 + +/*Allow dithering the gradients (to achieve visual smooth color gradients on limited color depth display) + *LV_DITHER_GRADIENT implies allocating one or two more lines of the object's rendering surface + *The increase in memory consumption is (32 bits * object width) plus 24 bits * object width if using error diffusion */ +#define LV_DITHER_GRADIENT 0 +#if LV_DITHER_GRADIENT + /*Add support for error diffusion dithering. + *Error diffusion dithering gets a much better visual result, but implies more CPU consumption and memory when drawing. + *The increase in memory consumption is (24 bits * object's width)*/ + #define LV_DITHER_ERROR_DIFFUSION 0 +#endif + +/*Maximum buffer size to allocate for rotation. + *Only used if software rotation is enabled in the display driver.*/ +#define LV_DISP_ROT_MAX_BUF (10*1024) + +/*------------- + * GPU + *-----------*/ + +/*Use Arm's 2D acceleration library Arm-2D */ +#define LV_USE_GPU_ARM2D 0 + +/*Use STM32's DMA2D (aka Chrom Art) GPU*/ +#define LV_USE_GPU_STM32_DMA2D 0 +#if LV_USE_GPU_STM32_DMA2D + /*Must be defined to include path of CMSIS header of target processor + e.g. "stm32f769xx.h" or "stm32f429xx.h"*/ + #define LV_GPU_DMA2D_CMSIS_INCLUDE +#endif + +/*Use SWM341's DMA2D GPU*/ +#define LV_USE_GPU_SWM341_DMA2D 0 +#if LV_USE_GPU_SWM341_DMA2D + #define LV_GPU_SWM341_DMA2D_INCLUDE "SWM341.h" +#endif + +/*Use NXP's PXP GPU iMX RTxxx platforms*/ +#define LV_USE_GPU_NXP_PXP 0 +#if LV_USE_GPU_NXP_PXP + /*1: Add default bare metal and FreeRTOS interrupt handling routines for PXP (lv_gpu_nxp_pxp_osa.c) + * and call lv_gpu_nxp_pxp_init() automatically during lv_init(). Note that symbol SDK_OS_FREE_RTOS + * has to be defined in order to use FreeRTOS OSA, otherwise bare-metal implementation is selected. + *0: lv_gpu_nxp_pxp_init() has to be called manually before lv_init() + */ + #define LV_USE_GPU_NXP_PXP_AUTO_INIT 0 +#endif + +/*Use NXP's VG-Lite GPU iMX RTxxx platforms*/ +#define LV_USE_GPU_NXP_VG_LITE 0 + +/*Use SDL renderer API*/ +#define LV_USE_GPU_SDL 0 +#if LV_USE_GPU_SDL + #define LV_GPU_SDL_INCLUDE_PATH + /*Texture cache size, 8MB by default*/ + #define LV_GPU_SDL_LRU_SIZE (1024 * 1024 * 8) + /*Custom blend mode for mask drawing, disable if you need to link with older SDL2 lib*/ + #define LV_GPU_SDL_CUSTOM_BLEND_MODE (SDL_VERSION_ATLEAST(2, 0, 6)) +#endif + +/*------------- + * Logging + *-----------*/ + +/*Enable the log module*/ +#define LV_USE_LOG 1 +#if LV_USE_LOG + + /*How important log should be added: + *LV_LOG_LEVEL_TRACE A lot of logs to give detailed information + *LV_LOG_LEVEL_INFO Log important events + *LV_LOG_LEVEL_WARN Log if something unwanted happened but didn't cause a problem + *LV_LOG_LEVEL_ERROR Only critical issue, when the system may fail + *LV_LOG_LEVEL_USER Only logs added by the user + *LV_LOG_LEVEL_NONE Do not log anything*/ + #define LV_LOG_LEVEL LV_LOG_LEVEL_INFO + + /*1: Print the log with 'printf'; + *0: User need to register a callback with `lv_log_register_print_cb()`*/ + #define LV_LOG_PRINTF 1 + + /*Enable/disable LV_LOG_TRACE in modules that produces a huge number of logs*/ + #define LV_LOG_TRACE_MEM 1 + #define LV_LOG_TRACE_TIMER 1 + #define LV_LOG_TRACE_INDEV 1 + #define LV_LOG_TRACE_DISP_REFR 1 + #define LV_LOG_TRACE_EVENT 1 + #define LV_LOG_TRACE_OBJ_CREATE 1 + #define LV_LOG_TRACE_LAYOUT 1 + #define LV_LOG_TRACE_ANIM 1 + +#endif /*LV_USE_LOG*/ + +/*------------- + * Asserts + *-----------*/ + +/*Enable asserts if an operation is failed or an invalid data is found. + *If LV_USE_LOG is enabled an error message will be printed on failure*/ +#define LV_USE_ASSERT_NULL 1 /*Check if the parameter is NULL. (Very fast, recommended)*/ +#define LV_USE_ASSERT_MALLOC 1 /*Checks is the memory is successfully allocated or no. (Very fast, recommended)*/ +#define LV_USE_ASSERT_STYLE 0 /*Check if the styles are properly initialized. (Very fast, recommended)*/ +#define LV_USE_ASSERT_MEM_INTEGRITY 0 /*Check the integrity of `lv_mem` after critical operations. (Slow)*/ +#define LV_USE_ASSERT_OBJ 0 /*Check the object's type and existence (e.g. not deleted). (Slow)*/ + +/*Add a custom handler when assert happens e.g. to restart the MCU*/ +#define LV_ASSERT_HANDLER_INCLUDE +#define LV_ASSERT_HANDLER while(1); /*Halt by default*/ + +/*------------- + * Others + *-----------*/ + +/*1: Show CPU usage and FPS count*/ +#define LV_USE_PERF_MONITOR 0 +#if LV_USE_PERF_MONITOR + #define LV_USE_PERF_MONITOR_POS LV_ALIGN_BOTTOM_RIGHT +#endif + +/*1: Show the used memory and the memory fragmentation + * Requires LV_MEM_CUSTOM = 0*/ +#define LV_USE_MEM_MONITOR 1 +#if LV_USE_MEM_MONITOR + #define LV_USE_MEM_MONITOR_POS LV_ALIGN_BOTTOM_LEFT +#endif + +/*1: Draw random colored rectangles over the redrawn areas*/ +#define LV_USE_REFR_DEBUG 0 + +/*Change the built in (v)snprintf functions*/ +#define LV_SPRINTF_CUSTOM 0 +#if LV_SPRINTF_CUSTOM + #define LV_SPRINTF_INCLUDE + #define lv_snprintf snprintf + #define lv_vsnprintf vsnprintf +#else /*LV_SPRINTF_CUSTOM*/ + #define LV_SPRINTF_USE_FLOAT 0 +#endif /*LV_SPRINTF_CUSTOM*/ + +#define LV_USE_USER_DATA 1 + +/*Garbage Collector settings + *Used if lvgl is bound to higher level language and the memory is managed by that language*/ +#define LV_ENABLE_GC 0 +#if LV_ENABLE_GC != 0 + #define LV_GC_INCLUDE "gc.h" /*Include Garbage Collector related things*/ +#endif /*LV_ENABLE_GC*/ + +/*===================== + * COMPILER SETTINGS + *====================*/ + +/*For big endian systems set to 1*/ +#define LV_BIG_ENDIAN_SYSTEM 0 + +/*Define a custom attribute to `lv_tick_inc` function*/ +#define LV_ATTRIBUTE_TICK_INC + +/*Define a custom attribute to `lv_timer_handler` function*/ +#define LV_ATTRIBUTE_TIMER_HANDLER + +/*Define a custom attribute to `lv_disp_flush_ready` function*/ +#define LV_ATTRIBUTE_FLUSH_READY + +/*Required alignment size for buffers*/ +#define LV_ATTRIBUTE_MEM_ALIGN_SIZE 1 + +/*Will be added where memories needs to be aligned (with -Os data might not be aligned to boundary by default). + * E.g. __attribute__((aligned(4)))*/ +#define LV_ATTRIBUTE_MEM_ALIGN + +/*Attribute to mark large constant arrays for example font's bitmaps*/ +#define LV_ATTRIBUTE_LARGE_CONST + +/*Compiler prefix for a big array declaration in RAM*/ +#define LV_ATTRIBUTE_LARGE_RAM_ARRAY + +/*Place performance critical functions into a faster memory (e.g RAM)*/ +#define LV_ATTRIBUTE_FAST_MEM + +/*Prefix variables that are used in GPU accelerated operations, often these need to be placed in RAM sections that are DMA accessible*/ +#define LV_ATTRIBUTE_DMA + +/*Export integer constant to binding. This macro is used with constants in the form of LV_ that + *should also appear on LVGL binding API such as Micropython.*/ +#define LV_EXPORT_CONST_INT(int_value) struct _silence_gcc_warning /*The default value just prevents GCC warning*/ + +/*Extend the default -32k..32k coordinate range to -4M..4M by using int32_t for coordinates instead of int16_t*/ +#define LV_USE_LARGE_COORD 0 + +/*================== + * FONT USAGE + *===================*/ + +/*Montserrat fonts with ASCII range and some symbols using bpp = 4 + *https://fonts.google.com/specimen/Montserrat*/ +#define LV_FONT_MONTSERRAT_8 0 +#define LV_FONT_MONTSERRAT_10 0 +#define LV_FONT_MONTSERRAT_12 0 +#define LV_FONT_MONTSERRAT_14 1 +#define LV_FONT_MONTSERRAT_16 0 +#define LV_FONT_MONTSERRAT_18 0 +#define LV_FONT_MONTSERRAT_20 0 +#define LV_FONT_MONTSERRAT_22 0 +#define LV_FONT_MONTSERRAT_24 0 +#define LV_FONT_MONTSERRAT_26 0 +#define LV_FONT_MONTSERRAT_28 0 +#define LV_FONT_MONTSERRAT_30 0 +#define LV_FONT_MONTSERRAT_32 0 +#define LV_FONT_MONTSERRAT_34 0 +#define LV_FONT_MONTSERRAT_36 0 +#define LV_FONT_MONTSERRAT_38 0 +#define LV_FONT_MONTSERRAT_40 0 +#define LV_FONT_MONTSERRAT_42 0 +#define LV_FONT_MONTSERRAT_44 0 +#define LV_FONT_MONTSERRAT_46 0 +#define LV_FONT_MONTSERRAT_48 0 + +/*Demonstrate special features*/ +#define LV_FONT_MONTSERRAT_12_SUBPX 0 +#define LV_FONT_MONTSERRAT_28_COMPRESSED 0 /*bpp = 3*/ +#define LV_FONT_DEJAVU_16_PERSIAN_HEBREW 0 /*Hebrew, Arabic, Persian letters and all their forms*/ +#define LV_FONT_SIMSUN_16_CJK 0 /*1000 most common CJK radicals*/ + +/*Pixel perfect monospace fonts*/ +#define LV_FONT_UNSCII_8 0 +#define LV_FONT_UNSCII_16 0 + +/*Optionally declare custom fonts here. + *You can use these fonts as default font too and they will be available globally. + *E.g. #define LV_FONT_CUSTOM_DECLARE LV_FONT_DECLARE(my_font_1) LV_FONT_DECLARE(my_font_2)*/ +#define LV_FONT_CUSTOM_DECLARE + +/*Always set a default font*/ +#define LV_FONT_DEFAULT &lv_font_montserrat_14 + +/*Enable handling large font and/or fonts with a lot of characters. + *The limit depends on the font size, font face and bpp. + *Compiler error will be triggered if a font needs it.*/ +#define LV_FONT_FMT_TXT_LARGE 0 + +/*Enables/disables support for compressed fonts.*/ +#define LV_USE_FONT_COMPRESSED 0 + +/*Enable subpixel rendering*/ +#define LV_USE_FONT_SUBPX 0 +#if LV_USE_FONT_SUBPX + /*Set the pixel order of the display. Physical order of RGB channels. Doesn't matter with "normal" fonts.*/ + #define LV_FONT_SUBPX_BGR 0 /*0: RGB; 1:BGR order*/ +#endif + +/*Enable drawing placeholders when glyph dsc is not found*/ +#define LV_USE_FONT_PLACEHOLDER 1 + +/*================= + * TEXT SETTINGS + *=================*/ + +/** + * Select a character encoding for strings. + * Your IDE or editor should have the same character encoding + * - LV_TXT_ENC_UTF8 + * - LV_TXT_ENC_ASCII + */ +#define LV_TXT_ENC LV_TXT_ENC_UTF8 + +/*Can break (wrap) texts on these chars*/ +#define LV_TXT_BREAK_CHARS " ,.;:-_" + +/*If a word is at least this long, will break wherever "prettiest" + *To disable, set to a value <= 0*/ +#define LV_TXT_LINE_BREAK_LONG_LEN 0 + +/*Minimum number of characters in a long word to put on a line before a break. + *Depends on LV_TXT_LINE_BREAK_LONG_LEN.*/ +#define LV_TXT_LINE_BREAK_LONG_PRE_MIN_LEN 3 + +/*Minimum number of characters in a long word to put on a line after a break. + *Depends on LV_TXT_LINE_BREAK_LONG_LEN.*/ +#define LV_TXT_LINE_BREAK_LONG_POST_MIN_LEN 3 + +/*The control character to use for signalling text recoloring.*/ +#define LV_TXT_COLOR_CMD "#" + +/*Support bidirectional texts. Allows mixing Left-to-Right and Right-to-Left texts. + *The direction will be processed according to the Unicode Bidirectional Algorithm: + *https://www.w3.org/International/articles/inline-bidi-markup/uba-basics*/ +#define LV_USE_BIDI 0 +#if LV_USE_BIDI + /*Set the default direction. Supported values: + *`LV_BASE_DIR_LTR` Left-to-Right + *`LV_BASE_DIR_RTL` Right-to-Left + *`LV_BASE_DIR_AUTO` detect texts base direction*/ + #define LV_BIDI_BASE_DIR_DEF LV_BASE_DIR_AUTO +#endif + +/*Enable Arabic/Persian processing + *In these languages characters should be replaced with an other form based on their position in the text*/ +#define LV_USE_ARABIC_PERSIAN_CHARS 0 + +/*================== + * WIDGET USAGE + *================*/ + +/*Documentation of the widgets: https://docs.lvgl.io/latest/en/html/widgets/index.html*/ + +#define LV_USE_ARC 1 + +#define LV_USE_BAR 1 + +#define LV_USE_BTN 1 + +#define LV_USE_BTNMATRIX 1 + +#define LV_USE_CANVAS 1 + +#define LV_USE_CHECKBOX 1 + +#define LV_USE_DROPDOWN 1 /*Requires: lv_label*/ + +#define LV_USE_IMG 1 /*Requires: lv_label*/ + +#define LV_USE_LABEL 1 +#if LV_USE_LABEL + #define LV_LABEL_TEXT_SELECTION 1 /*Enable selecting text of the label*/ + #define LV_LABEL_LONG_TXT_HINT 1 /*Store some extra info in labels to speed up drawing of very long texts*/ +#endif + +#define LV_USE_LINE 1 + +#define LV_USE_ROLLER 1 /*Requires: lv_label*/ +#if LV_USE_ROLLER + #define LV_ROLLER_INF_PAGES 7 /*Number of extra "pages" when the roller is infinite*/ +#endif + +#define LV_USE_SLIDER 1 /*Requires: lv_bar*/ + +#define LV_USE_SWITCH 1 + +#define LV_USE_TEXTAREA 1 /*Requires: lv_label*/ +#if LV_USE_TEXTAREA != 0 + #define LV_TEXTAREA_DEF_PWD_SHOW_TIME 1500 /*ms*/ +#endif + +#define LV_USE_TABLE 1 + +/*================== + * EXTRA COMPONENTS + *==================*/ + +/*----------- + * Widgets + *----------*/ +#define LV_USE_ANIMIMG 1 + +#define LV_USE_CALENDAR 1 +#if LV_USE_CALENDAR + #define LV_CALENDAR_WEEK_STARTS_MONDAY 0 + #if LV_CALENDAR_WEEK_STARTS_MONDAY + #define LV_CALENDAR_DEFAULT_DAY_NAMES {"Mo", "Tu", "We", "Th", "Fr", "Sa", "Su"} + #else + #define LV_CALENDAR_DEFAULT_DAY_NAMES {"Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"} + #endif + + #define LV_CALENDAR_DEFAULT_MONTH_NAMES {"January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"} + #define LV_USE_CALENDAR_HEADER_ARROW 1 + #define LV_USE_CALENDAR_HEADER_DROPDOWN 1 +#endif /*LV_USE_CALENDAR*/ + +#define LV_USE_CHART 1 + +#define LV_USE_COLORWHEEL 1 + +#define LV_USE_IMGBTN 1 + +#define LV_USE_KEYBOARD 1 + +#define LV_USE_LED 1 + +#define LV_USE_LIST 1 + +#define LV_USE_MENU 1 + +#define LV_USE_METER 1 + +#define LV_USE_MSGBOX 1 + +#define LV_USE_SPAN 1 +#if LV_USE_SPAN + /*A line text can contain maximum num of span descriptor */ + #define LV_SPAN_SNIPPET_STACK_SIZE 64 +#endif + +#define LV_USE_SPINBOX 1 + +#define LV_USE_SPINNER 1 + +#define LV_USE_TABVIEW 1 + +#define LV_USE_TILEVIEW 1 + +#define LV_USE_WIN 1 + +/*----------- + * Themes + *----------*/ + +/*A simple, impressive and very complete theme*/ +#define LV_USE_THEME_DEFAULT 1 +#if LV_USE_THEME_DEFAULT + + /*0: Light mode; 1: Dark mode*/ + #define LV_THEME_DEFAULT_DARK 0 + + /*1: Enable grow on press*/ + #define LV_THEME_DEFAULT_GROW 1 + + /*Default transition time in [ms]*/ + #define LV_THEME_DEFAULT_TRANSITION_TIME 80 +#endif /*LV_USE_THEME_DEFAULT*/ + +/*A very simple theme that is a good starting point for a custom theme*/ +#define LV_USE_THEME_BASIC 1 + +/*A theme designed for monochrome displays*/ +#define LV_USE_THEME_MONO 1 + +/*----------- + * Layouts + *----------*/ + +/*A layout similar to Flexbox in CSS.*/ +#define LV_USE_FLEX 1 + +/*A layout similar to Grid in CSS.*/ +#define LV_USE_GRID 1 + +/*--------------------- + * 3rd party libraries + *--------------------*/ + +/*File system interfaces for common APIs */ + +/*API for fopen, fread, etc*/ +#define LV_USE_FS_STDIO 0 +#if LV_USE_FS_STDIO + #define LV_FS_STDIO_LETTER '\0' /*Set an upper cased letter on which the drive will accessible (e.g. 'A')*/ + #define LV_FS_STDIO_PATH "" /*Set the working directory. File/directory paths will be appended to it.*/ + #define LV_FS_STDIO_CACHE_SIZE 0 /*>0 to cache this number of bytes in lv_fs_read()*/ +#endif + +/*API for open, read, etc*/ +#define LV_USE_FS_POSIX 0 +#if LV_USE_FS_POSIX + #define LV_FS_POSIX_LETTER '\0' /*Set an upper cased letter on which the drive will accessible (e.g. 'A')*/ + #define LV_FS_POSIX_PATH "" /*Set the working directory. File/directory paths will be appended to it.*/ + #define LV_FS_POSIX_CACHE_SIZE 0 /*>0 to cache this number of bytes in lv_fs_read()*/ +#endif + +/*API for CreateFile, ReadFile, etc*/ +#define LV_USE_FS_WIN32 0 +#if LV_USE_FS_WIN32 + #define LV_FS_WIN32_LETTER '\0' /*Set an upper cased letter on which the drive will accessible (e.g. 'A')*/ + #define LV_FS_WIN32_PATH "" /*Set the working directory. File/directory paths will be appended to it.*/ + #define LV_FS_WIN32_CACHE_SIZE 0 /*>0 to cache this number of bytes in lv_fs_read()*/ +#endif + +/*API for FATFS (needs to be added separately). Uses f_open, f_read, etc*/ +#define LV_USE_FS_FATFS 0 +#if LV_USE_FS_FATFS + #define LV_FS_FATFS_LETTER '\0' /*Set an upper cased letter on which the drive will accessible (e.g. 'A')*/ + #define LV_FS_FATFS_CACHE_SIZE 0 /*>0 to cache this number of bytes in lv_fs_read()*/ +#endif + +/*PNG decoder library*/ +#define LV_USE_PNG 0 + +/*BMP decoder library*/ +#define LV_USE_BMP 0 + +/* JPG + split JPG decoder library. + * Split JPG is a custom format optimized for embedded systems. */ +#define LV_USE_SJPG 0 + +/*GIF decoder library*/ +#define LV_USE_GIF 0 + +/*QR code library*/ +#define LV_USE_QRCODE 0 + +/*FreeType library*/ +#define LV_USE_FREETYPE 0 +#if LV_USE_FREETYPE + /*Memory used by FreeType to cache characters [bytes] (-1: no caching)*/ + #define LV_FREETYPE_CACHE_SIZE (16 * 1024) + #if LV_FREETYPE_CACHE_SIZE >= 0 + /* 1: bitmap cache use the sbit cache, 0:bitmap cache use the image cache. */ + /* sbit cache:it is much more memory efficient for small bitmaps(font size < 256) */ + /* if font size >= 256, must be configured as image cache */ + #define LV_FREETYPE_SBIT_CACHE 0 + /* Maximum number of opened FT_Face/FT_Size objects managed by this cache instance. */ + /* (0:use system defaults) */ + #define LV_FREETYPE_CACHE_FT_FACES 0 + #define LV_FREETYPE_CACHE_FT_SIZES 0 + #endif +#endif + +/*Rlottie library*/ +#define LV_USE_RLOTTIE 0 + +/*FFmpeg library for image decoding and playing videos + *Supports all major image formats so do not enable other image decoder with it*/ +#define LV_USE_FFMPEG 0 +#if LV_USE_FFMPEG + /*Dump input information to stderr*/ + #define LV_FFMPEG_DUMP_FORMAT 0 +#endif + +/*----------- + * Others + *----------*/ + +/*1: Enable API to take snapshot for object*/ +#define LV_USE_SNAPSHOT 0 + +/*1: Enable Monkey test*/ +#define LV_USE_MONKEY 0 + +/*1: Enable grid navigation*/ +#define LV_USE_GRIDNAV 0 + +/*1: Enable lv_obj fragment*/ +#define LV_USE_FRAGMENT 0 + +/*1: Support using images as font in label or span widgets */ +#define LV_USE_IMGFONT 0 + +/*1: Enable a published subscriber based messaging system */ +#define LV_USE_MSG 0 + +/*1: Enable Pinyin input method*/ +/*Requires: lv_keyboard*/ +#define LV_USE_IME_PINYIN 0 +#if LV_USE_IME_PINYIN + /*1: Use default thesaurus*/ + /*If you do not use the default thesaurus, be sure to use `lv_ime_pinyin` after setting the thesauruss*/ + #define LV_IME_PINYIN_USE_DEFAULT_DICT 1 + /*Set the maximum number of candidate panels that can be displayed*/ + /*This needs to be adjusted according to the size of the screen*/ + #define LV_IME_PINYIN_CAND_TEXT_NUM 6 + + /*Use 9 key input(k9)*/ + #define LV_IME_PINYIN_USE_K9_MODE 1 + #if LV_IME_PINYIN_USE_K9_MODE == 1 + #define LV_IME_PINYIN_K9_CAND_TEXT_NUM 3 + #endif // LV_IME_PINYIN_USE_K9_MODE +#endif + +/*================== +* EXAMPLES +*==================*/ + +/*Enable the examples to be built with the library*/ +#define LV_BUILD_EXAMPLES 1 + +/*=================== + * DEMO USAGE + ====================*/ + +/*Show some widget. It might be required to increase `LV_MEM_SIZE` */ +#define LV_USE_DEMO_WIDGETS 0 +#if LV_USE_DEMO_WIDGETS +#define LV_DEMO_WIDGETS_SLIDESHOW 0 +#endif + +/*Demonstrate the usage of encoder and keyboard*/ +#define LV_USE_DEMO_KEYPAD_AND_ENCODER 0 + +/*Benchmark your system*/ +#define LV_USE_DEMO_BENCHMARK 0 +#if LV_USE_DEMO_BENCHMARK +/*Use RGB565A8 images with 16 bit color depth instead of ARGB8565*/ +#define LV_DEMO_BENCHMARK_RGB565A8 0 +#endif + +/*Stress test for LVGL*/ +#define LV_USE_DEMO_STRESS 0 + +/*Music player demo*/ +#define LV_USE_DEMO_MUSIC 0 +#if LV_USE_DEMO_MUSIC + #define LV_DEMO_MUSIC_SQUARE 0 + #define LV_DEMO_MUSIC_LANDSCAPE 0 + #define LV_DEMO_MUSIC_ROUND 0 + #define LV_DEMO_MUSIC_LARGE 0 + #define LV_DEMO_MUSIC_AUTO_PLAY 0 +#endif + +/*--END OF LV_CONF_H--*/ + +#endif /*LV_CONF_H*/ + +#endif /*End of "Content enable"*/ \ No newline at end of file diff --git a/lv_drv_conf.h b/lv_drv_conf.h new file mode 100644 index 0000000..6280a1e --- /dev/null +++ b/lv_drv_conf.h @@ -0,0 +1,494 @@ +/** + * @file lv_drv_conf.h + * Configuration file for v8.3.0 + */ + +/* + * COPY THIS FILE AS lv_drv_conf.h + */ + +/* clang-format off */ +#if 1 /*Set it to "1" to enable the content*/ + +#ifndef LV_DRV_CONF_H +#define LV_DRV_CONF_H + +#include "lv_conf.h" + +/********************* + * DELAY INTERFACE + *********************/ +#define LV_DRV_DELAY_INCLUDE /*Dummy include by default*/ +#define LV_DRV_DELAY_US(us) /*delay_us(us)*/ /*Delay the given number of microseconds*/ +#define LV_DRV_DELAY_MS(ms) /*delay_ms(ms)*/ /*Delay the given number of milliseconds*/ + +/********************* + * DISPLAY INTERFACE + *********************/ + +/*------------ + * Common + *------------*/ +#define LV_DRV_DISP_INCLUDE /*Dummy include by default*/ +#define LV_DRV_DISP_CMD_DATA(val) /*pin_x_set(val)*/ /*Set the command/data pin to 'val'*/ +#define LV_DRV_DISP_RST(val) /*pin_x_set(val)*/ /*Set the reset pin to 'val'*/ + +/*--------- + * SPI + *---------*/ +#define LV_DRV_DISP_SPI_CS(val) /*spi_cs_set(val)*/ /*Set the SPI's Chip select to 'val'*/ +#define LV_DRV_DISP_SPI_WR_BYTE(data) /*spi_wr(data)*/ /*Write a byte the SPI bus*/ +#define LV_DRV_DISP_SPI_WR_ARRAY(adr, n) /*spi_wr_mem(adr, n)*/ /*Write 'n' bytes to SPI bus from 'adr'*/ + +/*------------------ + * Parallel port + *-----------------*/ +#define LV_DRV_DISP_PAR_CS(val) /*par_cs_set(val)*/ /*Set the Parallel port's Chip select to 'val'*/ +#define LV_DRV_DISP_PAR_SLOW /*par_slow()*/ /*Set low speed on the parallel port*/ +#define LV_DRV_DISP_PAR_FAST /*par_fast()*/ /*Set high speed on the parallel port*/ +#define LV_DRV_DISP_PAR_WR_WORD(data) /*par_wr(data)*/ /*Write a word to the parallel port*/ +#define LV_DRV_DISP_PAR_WR_ARRAY(adr, n) /*par_wr_mem(adr,n)*/ /*Write 'n' bytes to Parallel ports from 'adr'*/ + +/*************************** + * INPUT DEVICE INTERFACE + ***************************/ + +/*---------- + * Common + *----------*/ +#define LV_DRV_INDEV_INCLUDE /*Dummy include by default*/ +#define LV_DRV_INDEV_RST(val) /*pin_x_set(val)*/ /*Set the reset pin to 'val'*/ +#define LV_DRV_INDEV_IRQ_READ 0 /*pn_x_read()*/ /*Read the IRQ pin*/ + +/*--------- + * SPI + *---------*/ +#define LV_DRV_INDEV_SPI_CS(val) /*spi_cs_set(val)*/ /*Set the SPI's Chip select to 'val'*/ +#define LV_DRV_INDEV_SPI_XCHG_BYTE(data) 0 /*spi_xchg(val)*/ /*Write 'val' to SPI and give the read value*/ + +/*--------- + * I2C + *---------*/ +#define LV_DRV_INDEV_I2C_START /*i2c_start()*/ /*Make an I2C start*/ +#define LV_DRV_INDEV_I2C_STOP /*i2c_stop()*/ /*Make an I2C stop*/ +#define LV_DRV_INDEV_I2C_RESTART /*i2c_restart()*/ /*Make an I2C restart*/ +#define LV_DRV_INDEV_I2C_WR(data) /*i2c_wr(data)*/ /*Write a byte to the I1C bus*/ +#define LV_DRV_INDEV_I2C_READ(last_read) 0 /*i2c_rd()*/ /*Read a byte from the I2C bud*/ + + +/********************* + * DISPLAY DRIVERS + *********************/ + +/*------------------- + * SDL + *-------------------*/ + +/* SDL based drivers for display, mouse, mousewheel and keyboard*/ +#ifndef USE_SDL +# define USE_SDL 1 +#endif + +/* Hardware accelerated SDL driver */ +#ifndef USE_SDL_GPU +# define USE_SDL_GPU 0 +#endif + +#if USE_SDL || USE_SDL_GPU +# define SDL_HOR_RES 240 +# define SDL_VER_RES 240 + +/* Scale window by this factor (useful when simulating small screens) */ +# define SDL_ZOOM 1 + +/* Used to test true double buffering with only address changing. + * Use 2 draw buffers, bith with SDL_HOR_RES x SDL_VER_RES size*/ +# define SDL_DOUBLE_BUFFERED 0 + +/*Eclipse: Visual Studio: */ +# define SDL_INCLUDE_PATH + +/*Open two windows to test multi display support*/ +# define SDL_DUAL_DISPLAY 0 +#endif + +/*------------------- + * Monitor of PC + *-------------------*/ + +/*DEPRECATED: Use the SDL driver instead. */ +#ifndef USE_MONITOR +# define USE_MONITOR 0 +#endif + +#if USE_MONITOR +# define MONITOR_HOR_RES 480 +# define MONITOR_VER_RES 320 + +/* Scale window by this factor (useful when simulating small screens) */ +# define MONITOR_ZOOM 1 + +/* Used to test true double buffering with only address changing. + * Use 2 draw buffers, bith with MONITOR_HOR_RES x MONITOR_VER_RES size*/ +# define MONITOR_DOUBLE_BUFFERED 0 + +/*Eclipse: Visual Studio: */ +# define MONITOR_SDL_INCLUDE_PATH + +/*Open two windows to test multi display support*/ +# define MONITOR_DUAL 0 +#endif + +/*----------------------------------- + * Native Windows (including mouse) + *----------------------------------*/ +#ifndef USE_WINDOWS +# define USE_WINDOWS 0 +#endif + +#if USE_WINDOWS +# define WINDOW_HOR_RES 480 +# define WINDOW_VER_RES 320 +#endif + +/*---------------------------- + * Native Windows (win32drv) + *---------------------------*/ +#ifndef USE_WIN32DRV +# define USE_WIN32DRV 0 +#endif + +#if USE_WIN32DRV +/* Scale window by this factor (useful when simulating small screens) */ +# define WIN32DRV_MONITOR_ZOOM 1 +#endif + +/*---------------------------------------- + * GTK drivers (monitor, mouse, keyboard + *---------------------------------------*/ +#ifndef USE_GTK +# define USE_GTK 0 +#endif + +/*---------------------------------------- + * Wayland drivers (monitor, mouse, keyboard, touchscreen) + *---------------------------------------*/ +#ifndef USE_WAYLAND +# define USE_WAYLAND 0 +#endif + +#if USE_WAYLAND +/* Support for client-side decorations */ +# ifndef LV_WAYLAND_CLIENT_SIDE_DECORATIONS +# define LV_WAYLAND_CLIENT_SIDE_DECORATIONS 1 +# endif +/* Support for (deprecated) wl-shell protocol */ +# ifndef LV_WAYLAND_WL_SHELL +# define LV_WAYLAND_WL_SHELL 1 +# endif +/* Support for xdg-shell protocol */ +# ifndef LV_WAYLAND_XDG_SHELL +# define LV_WAYLAND_XDG_SHELL 0 +# endif +#endif + +/*---------------- + * SSD1963 + *--------------*/ +#ifndef USE_SSD1963 +# define USE_SSD1963 0 +#endif + +#if USE_SSD1963 +# define SSD1963_HOR_RES LV_HOR_RES +# define SSD1963_VER_RES LV_VER_RES +# define SSD1963_HT 531 +# define SSD1963_HPS 43 +# define SSD1963_LPS 8 +# define SSD1963_HPW 10 +# define SSD1963_VT 288 +# define SSD1963_VPS 12 +# define SSD1963_FPS 4 +# define SSD1963_VPW 10 +# define SSD1963_HS_NEG 0 /*Negative hsync*/ +# define SSD1963_VS_NEG 0 /*Negative vsync*/ +# define SSD1963_ORI 0 /*0, 90, 180, 270*/ +# define SSD1963_COLOR_DEPTH 16 +#endif + +/*---------------- + * R61581 + *--------------*/ +#ifndef USE_R61581 +# define USE_R61581 0 +#endif + +#if USE_R61581 +# define R61581_HOR_RES LV_HOR_RES +# define R61581_VER_RES LV_VER_RES +# define R61581_HSPL 0 /*HSYNC signal polarity*/ +# define R61581_HSL 10 /*HSYNC length (Not Implemented)*/ +# define R61581_HFP 10 /*Horitontal Front poarch (Not Implemented)*/ +# define R61581_HBP 10 /*Horitontal Back poarch (Not Implemented */ +# define R61581_VSPL 0 /*VSYNC signal polarity*/ +# define R61581_VSL 10 /*VSYNC length (Not Implemented)*/ +# define R61581_VFP 8 /*Vertical Front poarch*/ +# define R61581_VBP 8 /*Vertical Back poarch */ +# define R61581_DPL 0 /*DCLK signal polarity*/ +# define R61581_EPL 1 /*ENABLE signal polarity*/ +# define R61581_ORI 0 /*0, 180*/ +# define R61581_LV_COLOR_DEPTH 16 /*Fix 16 bit*/ +#endif + +/*------------------------------ + * ST7565 (Monochrome, low res.) + *-----------------------------*/ +#ifndef USE_ST7565 +# define USE_ST7565 0 +#endif + +#if USE_ST7565 +/*No settings*/ +#endif /*USE_ST7565*/ + +/*------------------------------ + * GC9A01 (color, low res.) + *-----------------------------*/ +#ifndef USE_GC9A01 +# define USE_GC9A01 0 +#endif + +#if USE_GC9A01 +/*No settings*/ +#endif /*USE_GC9A01*/ + +/*------------------------------------------ + * UC1610 (4 gray 160*[104|128]) + * (EA DOGXL160 160x104 tested) + *-----------------------------------------*/ +#ifndef USE_UC1610 +# define USE_UC1610 0 +#endif + +#if USE_UC1610 +# define UC1610_HOR_RES LV_HOR_RES +# define UC1610_VER_RES LV_VER_RES +# define UC1610_INIT_CONTRAST 33 /* init contrast, values in [%] */ +# define UC1610_INIT_HARD_RST 0 /* 1 : hardware reset at init, 0 : software reset */ +# define UC1610_TOP_VIEW 0 /* 0 : Bottom View, 1 : Top View */ +#endif /*USE_UC1610*/ + +/*------------------------------------------------- + * SHARP memory in pixel monochrome display series + * LS012B7DD01 (184x38 pixels.) + * LS013B7DH03 (128x128 pixels.) + * LS013B7DH05 (144x168 pixels.) + * LS027B7DH01 (400x240 pixels.) (tested) + * LS032B7DD02 (336x536 pixels.) + * LS044Q7DH01 (320x240 pixels.) + *------------------------------------------------*/ +#ifndef USE_SHARP_MIP +# define USE_SHARP_MIP 0 +#endif + +#if USE_SHARP_MIP +# define SHARP_MIP_HOR_RES LV_HOR_RES +# define SHARP_MIP_VER_RES LV_VER_RES +# define SHARP_MIP_SOFT_COM_INVERSION 0 +# define SHARP_MIP_REV_BYTE(b) /*((uint8_t) __REV(__RBIT(b)))*/ /*Architecture / compiler dependent byte bits order reverse*/ +#endif /*USE_SHARP_MIP*/ + +/*------------------------------------------------- + * ILI9341 240X320 TFT LCD + *------------------------------------------------*/ +#ifndef USE_ILI9341 +# define USE_ILI9341 0 +#endif + +#if USE_ILI9341 +# define ILI9341_HOR_RES LV_HOR_RES +# define ILI9341_VER_RES LV_VER_RES +# define ILI9341_GAMMA 1 +# define ILI9341_TEARING 0 +#endif /*USE_ILI9341*/ + +/*----------------------------------------- + * Linux frame buffer device (/dev/fbx) + *-----------------------------------------*/ +#ifndef USE_FBDEV +# define USE_FBDEV 1 +#endif + +#if USE_FBDEV +# define FBDEV_PATH "/dev/fb0" +#endif + +/*----------------------------------------- + * FreeBSD frame buffer device (/dev/fbx) + *.........................................*/ +#ifndef USE_BSD_FBDEV +# define USE_BSD_FBDEV 0 +#endif + +#if USE_BSD_FBDEV +# define FBDEV_PATH "/dev/fb0" +#endif + +/*----------------------------------------- + * DRM/KMS device (/dev/dri/cardX) + *-----------------------------------------*/ +#ifndef USE_DRM +# define USE_DRM 0 +#endif + +#if USE_DRM +# define DRM_CARD "/dev/dri/card0" +# define DRM_CONNECTOR_ID -1 /* -1 for the first connected one */ +#endif + +/********************* + * INPUT DEVICES + *********************/ + +/*-------------- + * XPT2046 + *--------------*/ +#ifndef USE_XPT2046 +# define USE_XPT2046 0 +#endif + +#if USE_XPT2046 +# define XPT2046_HOR_RES 480 +# define XPT2046_VER_RES 320 +# define XPT2046_X_MIN 200 +# define XPT2046_Y_MIN 200 +# define XPT2046_X_MAX 3800 +# define XPT2046_Y_MAX 3800 +# define XPT2046_AVG 4 +# define XPT2046_X_INV 0 +# define XPT2046_Y_INV 0 +# define XPT2046_XY_SWAP 0 +#endif + +/*----------------- + * FT5406EE8 + *-----------------*/ +#ifndef USE_FT5406EE8 +# define USE_FT5406EE8 0 +#endif + +#if USE_FT5406EE8 +# define FT5406EE8_I2C_ADR 0x38 /*7 bit address*/ +#endif + +/*--------------- + * AD TOUCH + *--------------*/ +#ifndef USE_AD_TOUCH +# define USE_AD_TOUCH 0 +#endif + +#if USE_AD_TOUCH +/*No settings*/ +#endif + + +/*--------------------------------------- + * Mouse or touchpad on PC (using SDL) + *-------------------------------------*/ +/*DEPRECATED: Use the SDL driver instead. */ +#ifndef USE_MOUSE +# define USE_MOUSE 0 +#endif + +#if USE_MOUSE +/*No settings*/ +#endif + +/*------------------------------------------- + * Mousewheel as encoder on PC (using SDL) + *------------------------------------------*/ +/*DEPRECATED: Use the SDL driver instead. */ +#ifndef USE_MOUSEWHEEL +# define USE_MOUSEWHEEL 0 +#endif + +#if USE_MOUSEWHEEL +/*No settings*/ +#endif + +/*------------------------------------------------- + * Touchscreen, mouse/touchpad or keyboard as libinput interface (for Linux based systems) + *------------------------------------------------*/ +#ifndef USE_LIBINPUT +# define USE_LIBINPUT 0 +#endif + +#ifndef USE_BSD_LIBINPUT +# define USE_BSD_LIBINPUT 0 +#endif + +#if USE_LIBINPUT || USE_BSD_LIBINPUT +/*If only a single device of the same type is connected, you can also auto detect it, e.g.: + *#define LIBINPUT_NAME libinput_find_dev(LIBINPUT_CAPABILITY_TOUCH, false)*/ +# define LIBINPUT_NAME "/dev/input/event0" /*You can use the "evtest" Linux tool to get the list of devices and test them*/ + +#endif /*USE_LIBINPUT || USE_BSD_LIBINPUT*/ + +/*------------------------------------------------- + * Mouse or touchpad as evdev interface (for Linux based systems) + *------------------------------------------------*/ +#ifndef USE_EVDEV +# define USE_EVDEV 0 +#endif + +#ifndef USE_BSD_EVDEV +# define USE_BSD_EVDEV 0 +#endif + +#if USE_EVDEV || USE_BSD_EVDEV +# define EVDEV_NAME "/dev/input/event0" /*You can use the "evtest" Linux tool to get the list of devices and test them*/ +# define EVDEV_SWAP_AXES 0 /*Swap the x and y axes of the touchscreen*/ + +# define EVDEV_CALIBRATE 0 /*Scale and offset the touchscreen coordinates by using maximum and minimum values for each axis*/ + +# if EVDEV_CALIBRATE +# define EVDEV_HOR_MIN 0 /*to invert axis swap EVDEV_XXX_MIN by EVDEV_XXX_MAX*/ +# define EVDEV_HOR_MAX 4096 /*"evtest" Linux tool can help to get the correct calibraion values>*/ +# define EVDEV_VER_MIN 0 +# define EVDEV_VER_MAX 4096 +# endif /*EVDEV_CALIBRATE*/ +#endif /*USE_EVDEV*/ + +/*------------------------------------------------- + * Full keyboard support for evdev and libinput interface + *------------------------------------------------*/ +# ifndef USE_XKB +# define USE_XKB 0 +# endif + +#if USE_LIBINPUT || USE_BSD_LIBINPUT || USE_EVDEV || USE_BSD_EVDEV +# if USE_XKB +# define XKB_KEY_MAP { .rules = NULL, \ + .model = "pc101", \ + .layout = "us", \ + .variant = NULL, \ + .options = NULL } /*"setxkbmap -query" can help find the right values for your keyboard*/ +# endif /*USE_XKB*/ +#endif /*USE_LIBINPUT || USE_BSD_LIBINPUT || USE_EVDEV || USE_BSD_EVDEV*/ + +/*------------------------------- + * Keyboard of a PC (using SDL) + *------------------------------*/ +/*DEPRECATED: Use the SDL driver instead. */ +#ifndef USE_KEYBOARD +# define USE_KEYBOARD 0 +#endif + +#if USE_KEYBOARD +/*No settings*/ +#endif + +#endif /*LV_DRV_CONF_H*/ + +#endif /*End of "Content enable"*/ \ No newline at end of file diff --git a/output.txt b/output.txt new file mode 100644 index 0000000..57eebe8 --- /dev/null +++ b/output.txt @@ -0,0 +1,1233 @@ +==278249== Memcheck, a memory error detector +==278249== Copyright (C) 2002-2022, and GNU GPL'd, by Julian Seward et al. +==278249== Using Valgrind-3.21.0 and LibVEX; rerun with -h for copyright info +==278249== Command: target/x86_64-unknown-linux-gnu/debug/Xila +==278249== Parent PID: 173098 +==278249== +==278249== realloc() with size 0 +==278249== at 0x484ABC0: realloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81B9C3F: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x685D996: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x68B6411: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x685D012: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== Address 0x5d8da10 is 0 bytes after a block of size 0 alloc'd +==278249== at 0x4845828: malloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81B9C2F: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x685D996: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x68B6411: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x685D012: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11A9AF: lv_obj_get_scrollbar_area (lv_obj_scroll.c:530) +==278249== by 0x11A9AF: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11A9CC: lv_obj_get_scrollbar_area (lv_obj_scroll.c:530) +==278249== by 0x11A9CC: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11A9EA: lv_obj_get_scrollbar_area (lv_obj_scroll.c:530) +==278249== by 0x11A9EA: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AA01: lv_obj_get_scrollbar_area (lv_obj_scroll.c:530) +==278249== by 0x11AA01: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AB46: lv_obj_get_scrollbar_area (lv_obj_scroll.c:552) +==278249== by 0x11AB46: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AB60: lv_obj_get_scrollbar_area (lv_obj_scroll.c:552) +==278249== by 0x11AB60: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AB88: lv_obj_get_scrollbar_area (lv_obj_scroll.c:553) +==278249== by 0x11AB88: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11ABA2: lv_obj_get_scrollbar_area (lv_obj_scroll.c:553) +==278249== by 0x11ABA2: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AC36: lv_obj_get_scrollbar_area (lv_obj_scroll.c:568) +==278249== by 0x11AC36: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AC50: lv_obj_get_scrollbar_area (lv_obj_scroll.c:568) +==278249== by 0x11AC50: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AC71: lv_obj_get_scrollbar_area (lv_obj_scroll.c:568) +==278249== by 0x11AC71: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AC83: lv_obj_get_scrollbar_area (lv_obj_scroll.c:568) +==278249== by 0x11AC83: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AEB8: lv_obj_get_scrollbar_area (lv_obj_scroll.c:613) +==278249== by 0x11AEB8: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AED2: lv_obj_get_scrollbar_area (lv_obj_scroll.c:613) +==278249== by 0x11AED2: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AEF8: lv_obj_get_scrollbar_area (lv_obj_scroll.c:614) +==278249== by 0x11AEF8: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115F04: lv_disp_get_dpi (lv_hal_disp.c:505) +==278249== by 0x11AF12: lv_obj_get_scrollbar_area (lv_obj_scroll.c:614) +==278249== by 0x11AF12: lv_obj_get_scrollbar_area (lv_obj_scroll.c:448) +==278249== by 0x11DA5E: lv_obj_clear_flag (lv_obj.c:254) +==278249== by 0x12BF2E: lv_btn_constructor (lv_btn.c:66) +==278249== by 0x11CD16: lv_obj_class_init_obj (lv_obj_class.c:110) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x115E8F: lv_disp_get_hor_res (lv_hal_disp.c:352) +==278249== by 0x119042: _lv_inv_area (lv_refr.c:225) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11C328: lv_obj_refresh_ext_draw_size (lv_obj_draw.c:388) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:207) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:167) +==278249== by 0x11CD32: lv_obj_class_init_obj (lv_obj_class.c:113) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767856 bytes below stack pointer +==278249== +==278249== Invalid read of size 4 +==278249== at 0x115E9B: lv_disp_get_hor_res (lv_hal_disp.c:357) +==278249== by 0x119042: _lv_inv_area (lv_refr.c:225) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11C328: lv_obj_refresh_ext_draw_size (lv_obj_draw.c:388) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:207) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:167) +==278249== by 0x11CD32: lv_obj_class_init_obj (lv_obj_class.c:113) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== Address 0x1ffef43c20 is on thread 1's stack +==278249== 767880 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x115ED1: lv_disp_get_ver_res (lv_hal_disp.c:375) +==278249== by 0x119050: _lv_inv_area (lv_refr.c:226) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11C328: lv_obj_refresh_ext_draw_size (lv_obj_draw.c:388) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:207) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:167) +==278249== by 0x11CD32: lv_obj_class_init_obj (lv_obj_class.c:113) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767856 bytes below stack pointer +==278249== +==278249== Invalid read of size 2 +==278249== at 0x115EDB: lv_disp_get_ver_res (lv_hal_disp.c:380) +==278249== by 0x119050: _lv_inv_area (lv_refr.c:226) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11C328: lv_obj_refresh_ext_draw_size (lv_obj_draw.c:388) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:207) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:167) +==278249== by 0x11CD32: lv_obj_class_init_obj (lv_obj_class.c:113) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== Address 0x1ffef43c22 is on thread 1's stack +==278249== 767878 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x119071: _lv_inv_area (lv_refr.c:235) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11C328: lv_obj_refresh_ext_draw_size (lv_obj_draw.c:388) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:207) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:167) +==278249== by 0x11CD32: lv_obj_class_init_obj (lv_obj_class.c:113) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767864 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x11908A: _lv_inv_area (lv_refr.c:242) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11C328: lv_obj_refresh_ext_draw_size (lv_obj_draw.c:388) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:207) +==278249== by 0x11735A: lv_obj_refresh_style (lv_obj_style.c:167) +==278249== by 0x11CD32: lv_obj_class_init_obj (lv_obj_class.c:113) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== Address 0x1ffef43c48 is on thread 1's stack +==278249== 767848 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x119071: _lv_inv_area (lv_refr.c:235) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x117362: lv_obj_refresh_style (lv_obj_style.c:209) +==278249== by 0x117362: lv_obj_refresh_style (lv_obj_style.c:167) +==278249== by 0x11CD32: lv_obj_class_init_obj (lv_obj_class.c:113) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767912 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x11908A: _lv_inv_area (lv_refr.c:242) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x117362: lv_obj_refresh_style (lv_obj_style.c:209) +==278249== by 0x117362: lv_obj_refresh_style (lv_obj_style.c:167) +==278249== by 0x11CD32: lv_obj_class_init_obj (lv_obj_class.c:113) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== Address 0x1ffef43c48 is on thread 1's stack +==278249== 767896 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x119071: _lv_inv_area (lv_refr.c:235) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 768024 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x11908A: _lv_inv_area (lv_refr.c:242) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x12BF8F: lv_btn_create (lv_btn.c:53) +==278249== by 0x115676: lvgl::widgets::Btn::create (generated.rs:2) +==278249== by 0x11550C: Xila::main (main.rs:54) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c48 is on thread 1's stack +==278249== 768008 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x119071: _lv_inv_area (lv_refr.c:235) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11FC87: lv_obj_refr_size (lv_obj_pos.c:169) +==278249== by 0x11FDCF: layout_update_core (lv_obj_pos.c:1144) +==278249== by 0x11FDB8: layout_update_core (lv_obj_pos.c:1137) +==278249== by 0x11FE83: lv_obj_update_layout (lv_obj_pos.c:316) +==278249== by 0x11FE83: lv_obj_update_layout (lv_obj_pos.c:301) +==278249== by 0x119179: _lv_disp_refr_timer (lv_refr.c:308) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767592 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x11908A: _lv_inv_area (lv_refr.c:242) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11FC87: lv_obj_refr_size (lv_obj_pos.c:169) +==278249== by 0x11FDCF: layout_update_core (lv_obj_pos.c:1144) +==278249== by 0x11FDB8: layout_update_core (lv_obj_pos.c:1137) +==278249== by 0x11FE83: lv_obj_update_layout (lv_obj_pos.c:316) +==278249== by 0x11FE83: lv_obj_update_layout (lv_obj_pos.c:301) +==278249== by 0x119179: _lv_disp_refr_timer (lv_refr.c:308) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== Address 0x1ffef43c48 is on thread 1's stack +==278249== 767576 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x119071: _lv_inv_area (lv_refr.c:235) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11FD31: lv_obj_refr_size (lv_obj_pos.c:201) +==278249== by 0x11FDCF: layout_update_core (lv_obj_pos.c:1144) +==278249== by 0x11FDB8: layout_update_core (lv_obj_pos.c:1137) +==278249== by 0x11FE83: lv_obj_update_layout (lv_obj_pos.c:316) +==278249== by 0x11FE83: lv_obj_update_layout (lv_obj_pos.c:301) +==278249== by 0x119179: _lv_disp_refr_timer (lv_refr.c:308) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 767592 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x11908A: _lv_inv_area (lv_refr.c:242) +==278249== by 0x11EF5E: lv_obj_invalidate_area (lv_obj_pos.c:848) +==278249== by 0x11EFD0: lv_obj_invalidate (lv_obj_pos.c:864) +==278249== by 0x11FD31: lv_obj_refr_size (lv_obj_pos.c:201) +==278249== by 0x11FDCF: layout_update_core (lv_obj_pos.c:1144) +==278249== by 0x11FDB8: layout_update_core (lv_obj_pos.c:1137) +==278249== by 0x11FE83: lv_obj_update_layout (lv_obj_pos.c:316) +==278249== by 0x11FE83: lv_obj_update_layout (lv_obj_pos.c:301) +==278249== by 0x119179: _lv_disp_refr_timer (lv_refr.c:308) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== Address 0x1ffef43c48 is on thread 1's stack +==278249== 767576 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x119340: refr_invalid_areas (lv_refr.c:518) +==278249== by 0x119340: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c80 is on thread 1's stack +==278249== 767952 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x119355: refr_invalid_areas (lv_refr.c:522) +==278249== by 0x119355: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c30 is on thread 1's stack +==278249== 768032 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x1193A5: refr_invalid_areas (lv_refr.c:530) +==278249== by 0x1193A5: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c30 is on thread 1's stack +==278249== 768032 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x1193D8: refr_area (lv_refr.c:547) +==278249== by 0x1193D8: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x1193D8: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c90 is on thread 1's stack +==278249== 767936 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x1193DF: refr_area (lv_refr.c:552) +==278249== by 0x1193DF: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x1193DF: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 768024 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x115ED1: lv_disp_get_ver_res (lv_hal_disp.c:375) +==278249== by 0x11949E: refr_area (lv_refr.c:574) +==278249== by 0x11949E: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x11949E: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 768016 bytes below stack pointer +==278249== +==278249== Invalid read of size 2 +==278249== at 0x115EDB: lv_disp_get_ver_res (lv_hal_disp.c:380) +==278249== by 0x11949E: refr_area (lv_refr.c:574) +==278249== by 0x11949E: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x11949E: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c22 is on thread 1's stack +==278249== 768038 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x1194D0: get_max_row (lv_refr.c:970) +==278249== by 0x1194D0: refr_area (lv_refr.c:577) +==278249== by 0x1194D0: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x1194D0: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c30 is on thread 1's stack +==278249== 768032 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x1194E1: get_max_row (lv_refr.c:975) +==278249== by 0x1194E1: refr_area (lv_refr.c:577) +==278249== by 0x1194E1: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x1194E1: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c48 is on thread 1's stack +==278249== 768008 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x1195B7: refr_area (lv_refr.c:590) +==278249== by 0x1195B7: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x1195B7: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c30 is on thread 1's stack +==278249== 768032 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x115F53: lv_disp_get_draw_buf (lv_hal_disp.c:549) +==278249== by 0x1185F7: refr_area_part (lv_refr.c:614) +==278249== by 0x119616: refr_area (lv_refr.c:594) +==278249== by 0x119616: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x119616: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c30 is on thread 1's stack +==278249== 767768 bytes below stack pointer +==278249== +==278249== Invalid read of size 2 +==278249== at 0x118661: refr_area_part (lv_refr.c:622) +==278249== by 0x119616: refr_area (lv_refr.c:594) +==278249== by 0x119616: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x119616: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c20 is on thread 1's stack +==278249== 767792 bytes below stack pointer +==278249== +==278249== Invalid read of size 2 +==278249== at 0x118664: refr_area_part (lv_refr.c:622) +==278249== by 0x119616: refr_area (lv_refr.c:594) +==278249== by 0x119616: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x119616: _lv_disp_refr_timer (lv_refr.c:324) +==278249== by 0x12EF9A: lv_timer_exec (lv_timer.c:313) +==278249== by 0x12EF9A: lv_timer_handler (lv_timer.c:109) +==278249== by 0x11553E: task_handler (functions.rs:63) +==278249== by 0x11553E: Xila::main (main.rs:61) +==278249== by 0x1151ED: call_once (function.rs:250) +==278249== by 0x1151ED: std::sys_common::backtrace::__rust_begin_short_backtrace (backtrace.rs:154) +==278249== by 0x114F8B: std::rt::lang_start::{{closure}} (rt.rs:166) +==278249== by 0x158E06: std::rt::lang_start_internal (in /home/alix_anneraud/Git/Personnel/Xila/New-Code/target/x86_64-unknown-linux-gnu/debug/Xila) +==278249== by 0x114F80: std::rt::lang_start (rt.rs:165) +==278249== by 0x4B830CF: (below main) (libc_start_call_main.h:58) +==278249== Address 0x1ffef43c22 is on thread 1's stack +==278249== 767790 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x1454A4: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:119) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== by 0x119616: refr_area (lv_refr.c:594) +==278249== by 0x119616: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x119616: _lv_disp_refr_timer (lv_refr.c:324) +==278249== Address 0x1ffef43c50 is on thread 1's stack +==278249== 766272 bytes below stack pointer +==278249== +==278249== Invalid read of size 1 +==278249== at 0x1454C9: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:120) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== by 0x119616: refr_area (lv_refr.c:594) +==278249== by 0x119616: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x119616: _lv_disp_refr_timer (lv_refr.c:324) +==278249== Address 0x1ffef43c38 is on thread 1's stack +==278249== 766296 bytes below stack pointer +==278249== +==278249== Invalid read of size 8 +==278249== at 0x1455CA: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:164) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== by 0x119616: refr_area (lv_refr.c:594) +==278249== by 0x119616: refr_invalid_areas (lv_refr.c:532) +==278249== by 0x119616: _lv_disp_refr_timer (lv_refr.c:324) +==278249== Address 0x1ffef43c50 is on thread 1's stack +==278249== 766272 bytes below stack pointer +==278249== +==278249== Invalid write of size 4 +==278249== at 0x12E333: lv_color_fill (lv_color.c:50) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa1918 is on thread 1's stack +==278249== 382064 bytes below stack pointer +==278249== +==278249== Invalid write of size 4 +==278249== at 0x12E33C: lv_color_fill (lv_color.c:52) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa191c is on thread 1's stack +==278249== 382060 bytes below stack pointer +==278249== +==278249== Invalid write of size 4 +==278249== at 0x12E33F: lv_color_fill (lv_color.c:54) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa1920 is on thread 1's stack +==278249== 382056 bytes below stack pointer +==278249== +==278249== Invalid write of size 4 +==278249== at 0x12E342: lv_color_fill (lv_color.c:56) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa1924 is on thread 1's stack +==278249== 382052 bytes below stack pointer +==278249== +==278249== Invalid write of size 4 +==278249== at 0x12E345: lv_color_fill (lv_color.c:59) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa1928 is on thread 1's stack +==278249== 382048 bytes below stack pointer +==278249== +==278249== Invalid write of size 4 +==278249== at 0x12E348: lv_color_fill (lv_color.c:61) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa192c is on thread 1's stack +==278249== 382044 bytes below stack pointer +==278249== +==278249== Invalid write of size 4 +==278249== at 0x12E34B: lv_color_fill (lv_color.c:63) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa1930 is on thread 1's stack +==278249== 382040 bytes below stack pointer +==278249== +==278249== Invalid write of size 4 +==278249== at 0x12E34E: lv_color_fill (lv_color.c:65) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa1934 is on thread 1's stack +==278249== 382036 bytes below stack pointer +==278249== +==278249== Invalid write of size 2 +==278249== at 0x12E35C: lv_color_fill (lv_color.c:74) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa1f38 is on thread 1's stack +==278249== 380496 bytes below stack pointer +==278249== +==278249== Invalid write of size 2 +==278249== at 0x12E35A: lv_color_fill (lv_color.c:73) +==278249== by 0x145849: fill_normal (lv_draw_sw_blend.c:253) +==278249== by 0x145849: lv_draw_sw_blend_basic (lv_draw_sw_blend.c:184) +==278249== by 0x1453EE: lv_draw_sw_blend (lv_draw_sw_blend.c:101) +==278249== by 0x14217D: draw_bg (lv_draw_sw_rect.c:131) +==278249== by 0x1447EC: lv_draw_sw_rect (lv_draw_sw_rect.c:75) +==278249== by 0x11D3ED: lv_obj_draw (lv_obj.c:537) +==278249== by 0x116014: lv_obj_event_base (lv_event.c:98) +==278249== by 0x1160E0: event_send_core (lv_event.c:458) +==278249== by 0x116223: lv_event_send (lv_event.c:75) +==278249== by 0x117F0A: lv_obj_redraw (lv_refr.c:147) +==278249== by 0x118522: refr_obj_and_children (lv_refr.c:770) +==278249== by 0x118836: refr_area_part (lv_refr.c:705) +==278249== Address 0x1ffefa1f3a is on thread 1's stack +==278249== 380494 bytes below stack pointer +==278249== +==278249== Jump to the invalid address stated on the next line +==278249== at 0xF7BEF7BEF7BEF7BE: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== Address 0xf7bef7bef7bef7be is not stack'd, malloc'd or (recently) free'd +==278249== +==278249== +==278249== Process terminating with default action of signal 11 (SIGSEGV) +==278249== Bad permissions for mapped region at address 0xF7BEF7BEF7BEF7BE +==278249== at 0xF7BEF7BEF7BEF7BE: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== by 0xF7BEF7BEF7BEF7BD: ??? +==278249== +==278249== HEAP SUMMARY: +==278249== in use at exit: 6,631,269 bytes in 6,403 blocks +==278249== total heap usage: 34,416 allocs, 28,013 frees, 1,327,115,658 bytes allocated +==278249== +==278249== 80 bytes in 1 blocks are possibly lost in loss record 1,679 of 2,497 +==278249== at 0x4845828: malloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x6764026: ??? (in /usr/lib/x86_64-linux-gnu/libGLdispatch.so.0.0.0) +==278249== by 0x67646DB: __glDispatchInit (in /usr/lib/x86_64-linux-gnu/libGLdispatch.so.0.0.0) +==278249== by 0x67DD769: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x400536D: call_init.part.0 (dl-init.c:90) +==278249== by 0x4005472: call_init (dl-init.c:136) +==278249== by 0x4005472: _dl_init (dl-init.c:137) +==278249== by 0x4001561: _dl_catch_exception (dl-catch.c:211) +==278249== by 0x400C5C5: dl_open_worker (dl-open.c:810) +==278249== by 0x400C5C5: dl_open_worker (dl-open.c:773) +==278249== by 0x40014DC: _dl_catch_exception (dl-catch.c:237) +==278249== by 0x400C91B: _dl_open (dl-open.c:886) +==278249== by 0x4BEE4EB: dlopen_doit (dlopen.c:56) +==278249== by 0x40014DC: _dl_catch_exception (dl-catch.c:237) +==278249== +==278249== 80 bytes in 1 blocks are possibly lost in loss record 1,680 of 2,497 +==278249== at 0x4845828: malloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x6764026: ??? (in /usr/lib/x86_64-linux-gnu/libGLdispatch.so.0.0.0) +==278249== by 0x676490E: __glDispatchRegisterStubCallbacks (in /usr/lib/x86_64-linux-gnu/libGLdispatch.so.0.0.0) +==278249== by 0x66DE218: ??? (in /usr/lib/x86_64-linux-gnu/libGL.so.1.7.0) +==278249== by 0x400536D: call_init.part.0 (dl-init.c:90) +==278249== by 0x4005472: call_init (dl-init.c:136) +==278249== by 0x4005472: _dl_init (dl-init.c:137) +==278249== by 0x4001561: _dl_catch_exception (dl-catch.c:211) +==278249== by 0x400C5C5: dl_open_worker (dl-open.c:810) +==278249== by 0x400C5C5: dl_open_worker (dl-open.c:773) +==278249== by 0x40014DC: _dl_catch_exception (dl-catch.c:237) +==278249== by 0x400C91B: _dl_open (dl-open.c:886) +==278249== by 0x4BEE4EB: dlopen_doit (dlopen.c:56) +==278249== by 0x40014DC: _dl_catch_exception (dl-catch.c:237) +==278249== +==278249== 167 bytes in 1 blocks are possibly lost in loss record 1,913 of 2,497 +==278249== at 0x484A993: calloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81A119D: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x7E696A8: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x820583E: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x8203C0F: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x81AFA1B: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x686026F: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x688D23A: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x67EE4F2: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F086B: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F5376: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x497F2C0: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== +==278249== 311 bytes in 1 blocks are possibly lost in loss record 2,054 of 2,497 +==278249== at 0x484A993: calloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81A119D: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x7E69A19: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x820583E: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x8203C0F: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x81AFA1B: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x686026F: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x688D23A: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x67EE4F2: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F086B: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F5376: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x497F2C0: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== +==278249== 599 bytes in 1 blocks are possibly lost in loss record 2,168 of 2,497 +==278249== at 0x484A993: calloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81A119D: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x7E69676: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x820583E: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x8203C0F: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x81AFA1B: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x686026F: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x688D23A: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x67EE4F2: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F086B: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F5376: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x497F2C0: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== +==278249== 1,127 bytes in 1 blocks are possibly lost in loss record 2,332 of 2,497 +==278249== at 0x4845828: malloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81A0EE1: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x8216A32: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x81AF854: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x685FF5F: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x688B88D: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x687E3A3: glXCreateContext (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x67F5A35: glXCreateContext (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x4980ABD: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== by 0x4955D6F: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== by 0x48ED261: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== by 0x48E296F: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== +==278249== 1,336 bytes in 8 blocks are possibly lost in loss record 2,343 of 2,497 +==278249== at 0x484A993: calloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81A119D: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x7E69A51: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x820583E: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x8203C0F: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x81AFA1B: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x686026F: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x688D23A: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x67EE4F2: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F086B: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F5376: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x497F2C0: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== +==278249== 4,608 bytes in 2 blocks are possibly lost in loss record 2,416 of 2,497 +==278249== at 0x4845828: malloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x4004CEB: malloc (rtld-malloc.h:56) +==278249== by 0x4004CEB: _dlfo_mappings_segment_allocate (dl-find_object.c:217) +==278249== by 0x4004CEB: _dl_find_object_update_1 (dl-find_object.c:671) +==278249== by 0x4004CEB: _dl_find_object_update (dl-find_object.c:805) +==278249== by 0x400D277: dl_open_worker_begin (dl-open.c:737) +==278249== by 0x40014DC: _dl_catch_exception (dl-catch.c:237) +==278249== by 0x400C569: dl_open_worker (dl-open.c:784) +==278249== by 0x40014DC: _dl_catch_exception (dl-catch.c:237) +==278249== by 0x400C91B: _dl_open (dl-open.c:886) +==278249== by 0x4BEE4EB: dlopen_doit (dlopen.c:56) +==278249== by 0x40014DC: _dl_catch_exception (dl-catch.c:237) +==278249== by 0x4001602: _dl_catch_error (dl-catch.c:256) +==278249== by 0x4BEDFE6: _dlerror_run (dlerror.c:138) +==278249== by 0x4BEE5A0: dlopen_implementation (dlopen.c:71) +==278249== by 0x4BEE5A0: dlopen@@GLIBC_2.34 (dlopen.c:81) +==278249== +==278249== 4,631 bytes in 1 blocks are possibly lost in loss record 2,417 of 2,497 +==278249== at 0x484A993: calloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81A119D: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x7E69644: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x820583E: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x8203C0F: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x81AFA1B: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x686026F: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x688D23A: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x67EE4F2: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F086B: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F5376: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x497F2C0: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== +==278249== 4,631 bytes in 1 blocks are possibly lost in loss record 2,418 of 2,497 +==278249== at 0x484A993: calloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81A119D: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x7E69A8E: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x820583E: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x8203C0F: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x81AFA1B: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x686026F: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x688D23A: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x67EE4F2: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F086B: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F5376: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x497F2C0: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== +==278249== 11,704 bytes in 8 blocks are possibly lost in loss record 2,446 of 2,497 +==278249== at 0x484A993: calloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81A119D: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x7E69752: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x820583E: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x8203C0F: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x81AFA1B: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x686026F: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x688D23A: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x67EE4F2: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F086B: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x67F5376: ??? (in /usr/lib/x86_64-linux-gnu/libGLX.so.0.0.0) +==278249== by 0x497F2C0: ??? (in /usr/lib/x86_64-linux-gnu/libSDL2-2.0.so.0.2800.3) +==278249== +==278249== 307,127 bytes in 1 blocks are possibly lost in loss record 2,494 of 2,497 +==278249== at 0x484A993: calloc (in /usr/libexec/valgrind/vgpreload_memcheck-amd64-linux.so) +==278249== by 0x81A119D: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x7E6EAAB: ??? (in /usr/lib/x86_64-linux-gnu/libnvidia-glcore.so.535.129.03) +==278249== by 0x6886DDF: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x688FBCE: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x685DAED: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x68B6411: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== by 0x685D012: ??? (in /usr/lib/x86_64-linux-gnu/libGLX_nvidia.so.535.129.03) +==278249== +==278249== LEAK SUMMARY: +==278249== definitely lost: 0 bytes in 0 blocks +==278249== indirectly lost: 0 bytes in 0 blocks +==278249== possibly lost: 336,401 bytes in 27 blocks +==278249== still reachable: 6,294,868 bytes in 6,376 blocks +==278249== of which reachable via heuristic: +==278249== multipleinheritance: 192 bytes in 1 blocks +==278249== suppressed: 0 bytes in 0 blocks +==278249== Reachable blocks (those to which a pointer was found) are not shown. +==278249== To see them, rerun with: --leak-check=full --show-leak-kinds=all +==278249== +==278249== For lists of detected and suppressed errors, rerun with: -s +==278249== ERROR SUMMARY: 101273 errors from 70 contexts (suppressed: 0 from 0) diff --git a/src/Graphics/mod.rs b/src/Graphics/mod.rs new file mode 100644 index 0000000..87541b9 --- /dev/null +++ b/src/Graphics/mod.rs @@ -0,0 +1,82 @@ +use std::usize; + +use lvgl; +use sdl2::sys::Screen; + +use crate::Screen::Prelude::*; + +pub struct Display_type { + Display: lvgl::Display, +} + +impl Display_type { + pub fn New(Screen: &mut S) -> Result + where + S: Screen_traits, + { + let Resolution = match Screen.Get_resolution() { + Ok(Resolution) => Resolution, + Err(_) => return Err(()), + }; + + let Binding_function = |Refresh: &lvgl::DisplayRefresh| { + + print!("Binding function called.\n"); + + let Area = Area_type { + Position: Coordinates_type { + X: Refresh.area.x1, + Y: Refresh.area.y1, + }, + Size: Coordinates_type { + X: (Refresh.area.x2 - Refresh.area.x1) as i16, + Y: (Refresh.area.y2 - Refresh.area.y1) as i16, + }, + }; + + let mut Buffer = [Color_type { + Red: 0, + Green: 0, + Blue: 0, + }; Buffer_size]; + + for i in 0..Buffer_size { + let Color = Refresh.colors[i]; + let Color = Color_type { + Red: Color.r(), + Green: Color.g(), + Blue: Color.b(), + }; + + Buffer[i] = Color; + } + + let mut Refresh_area = Refresh_area_type:: { Area, Buffer }; + + Screen.Update(&Refresh_area); + }; + + let Buffer = lvgl::DrawBuffer::::default(); + + let LVGL_display = match lvgl::Display::register( + Buffer, + Resolution.X as u32, + Resolution.Y as u32, + Binding_function, + ) { + Ok(Display) => Display, + Err(_) => return Err(()), + }; + + Ok(Self { + Display: LVGL_display, + }) + } + + pub fn Get_object(&self) -> Result { + match self.Display.get_scr_act() { + Ok(Object) => Ok(Object), + Err(_) => Err(()), + } + } +} diff --git a/src/Screen/Drivers/SDL2/mod.rs b/src/Screen/Drivers/SDL2/mod.rs new file mode 100644 index 0000000..6fbfa35 --- /dev/null +++ b/src/Screen/Drivers/SDL2/mod.rs @@ -0,0 +1,79 @@ +use crate::Screen::Generics; + +use Generics::Coordinates_type; +use sdl2::{event, keyboard, pixels, render, video}; +use std::sync::RwLock; + +pub struct Screen_type(RwLock>); + +impl Screen_type { + pub fn New(Size : Coordinates_type) -> Result { + let Context = match sdl2::init() { + Ok(Context) => Context, + Err(_) => return Err(()), + }; + + let Video_subsystem = match Context.video() { + Ok(Video_subsystem) => Video_subsystem, + Err(_) => return Err(()), + }; + + let Window = match Video_subsystem + .window("Xila", Size.X as u32, Size.Y as u32) + .position_centered() + .build() + { + Ok(Window) => Window, + Err(_) => return Err(()), + }; + + let mut Canvas = match Window.into_canvas().build() { + Ok(Canvas) => Canvas, + Err(_) => return Err(()), + }; + + Canvas.set_draw_color(pixels::Color::RGB(0, 0, 0)); + Canvas.clear(); + Canvas.present(); + + Ok(Self(RwLock::new(Canvas))) + } +} + +impl Generics::Screen_traits for Screen_type { + fn Update(&mut self, Refresh_area: &Generics::Refresh_area_type) { + let mut Canvas = match self.0.write() { + Ok(Canvas) => Canvas, + Err(_) => return, + }; + + for Y in + Refresh_area.Area.Position.Y..Refresh_area.Area.Position.Y + Refresh_area.Area.Size.Y + { + for X in Refresh_area.Area.Position.X + ..Refresh_area.Area.Position.X + Refresh_area.Area.Size.X + { + let Color = &Refresh_area.Buffer[(Y * Refresh_area.Area.Size.X + X) as usize]; + + print!("At : {}, {} - Print color : {}, {}, {}\n", X, Y, Color.Red, Color.Green, Color.Blue); + Canvas.set_draw_color(pixels::Color::RGB(Color.Red, Color.Green, Color.Blue)); + let _ = Canvas.draw_point(sdl2::rect::Point::new(X as i32, Y as i32)); + } + } + + Canvas.present(); + } + + fn Get_resolution(&self) -> Result { + match self.0.read() { + Ok(Canvas) => match Canvas.output_size() { + Ok(Resolution) => Ok(Generics::Coordinates_type { + X: Resolution.0 as i16, + Y: Resolution.1 as i16, + }), + Err(_) => Err(()), + }, + Err(_) => Err(()), + } + } +} diff --git a/src/Screen/Drivers/mod.rs b/src/Screen/Drivers/mod.rs new file mode 100644 index 0000000..78c8e73 --- /dev/null +++ b/src/Screen/Drivers/mod.rs @@ -0,0 +1,5 @@ + +#[cfg(target_os = "linux")] +pub mod SDL2; + + diff --git a/src/Screen/Generics/mod.rs b/src/Screen/Generics/mod.rs new file mode 100644 index 0000000..0c6ba84 --- /dev/null +++ b/src/Screen/Generics/mod.rs @@ -0,0 +1,26 @@ +pub struct Coordinates_type { + pub X : i16, + pub Y : i16, +} + +pub struct Area_type { + pub Position : Coordinates_type, + pub Size : Coordinates_type, +} + +#[derive(Clone, Copy)] +pub struct Color_type { + pub Red : u8, + pub Green : u8, + pub Blue : u8, +} + +pub struct Refresh_area_type { + pub Area : Area_type, + pub Buffer : [Color_type; Buffer_size], +} + +pub trait Screen_traits { + fn Update(&mut self, Refresh_area : &Refresh_area_type); + fn Get_resolution(&self) -> Result; +} diff --git a/src/Screen/Prelude.rs b/src/Screen/Prelude.rs new file mode 100644 index 0000000..fcc593b --- /dev/null +++ b/src/Screen/Prelude.rs @@ -0,0 +1,3 @@ + +pub use super::Generics::*; + diff --git a/src/Screen/mod.rs b/src/Screen/mod.rs new file mode 100644 index 0000000..3516124 --- /dev/null +++ b/src/Screen/mod.rs @@ -0,0 +1,6 @@ + +pub mod Generics; + +pub mod Drivers; + +pub mod Prelude; diff --git a/src/main.rs b/src/main.rs index 4502f48..057ca1d 100644 --- a/src/main.rs +++ b/src/main.rs @@ -2,23 +2,17 @@ #![allow(non_snake_case)] #![allow(non_upper_case_globals)] -use embedded_sdmmc::{TimeSource, Directory}; +use std::time::{Duration, Instant}; + #[cfg(target_os = "espidf")] use esp_idf_sys as _; // If using the `binstart` feature of `esp-idf-sys`, always keep this module imported - -mod File_system; -use File_system::*; - +#[cfg(target_os = "espidf")] use esp_idf_hal::{prelude::*, gpio::{OutputPin, Pin, PinDriver}}; #[cfg(target_os = "espidf")] use esp_idf_hal::sys; -struct D { - -} - - - +mod Screen; +mod Graphics; fn main() { // It is necessary to call this function once. Otherwise some patches to the runtime @@ -36,73 +30,42 @@ fn main() { #[cfg(target_os = "linux")] println!("Hello, world!"); - let peripherals = esp_idf_hal::peripherals::Peripherals::take().unwrap(); - - let SPI = esp_idf_hal::spi::SpiDriver::new::( - peripherals.spi3, - peripherals.pins.gpio4, // SCK - peripherals.pins.gpio5, // PICO - Some(peripherals.pins.gpio27), // POCI - &esp_idf_hal::spi::config::DriverConfig::new(), - ) - .unwrap(); - - let mut SPI_Config = esp_idf_hal::spi::config::Config::new().baudrate(4_u32.MHz().into()); - let SPI_Device = esp_idf_hal::spi::SpiDeviceDriver::new( - SPI, - Option::::None, - &SPI_Config, - ) - .unwrap(); + const Horizontal_resolution: u32 = 800; + const Vertical_resolution: u32 = 480; + const Buffer_size: usize = (Horizontal_resolution * Vertical_resolution / 2) as usize; - unsafe { - let conf = esp_idf_hal::sys::sdspi_device_config_t { - host_id: esp_idf_hal::sys::spi_host_device_t_SPI3_HOST, - gpio_cs: esp_idf_hal::sys::gpio_num_t_GPIO_NUM_2, - gpio_cd: esp_idf_hal::sys::gpio_num_t_GPIO_NUM_NC, - gpio_wp: esp_idf_hal::sys::gpio_num_t_GPIO_NUM_NC, - gpio_int: esp_idf_hal::sys::gpio_num_t_GPIO_NUM_NC, - }; - let mut handle : i32 = 0; - - if esp_idf_hal::sys::sdspi_host_init_device( - &conf as *const esp_idf_hal::sys::sdspi_device_config_t, - &mut handle as *mut i32, - ) == esp_idf_hal::sys::ESP_OK - { - log::info!("sdspi_host_init_device success"); - } else { - log::info!("sdspi_host_init_device failed"); - } - - let del = D; - - let cs = esp_idf_hal::gpio::PinDriver::output(peripherals.pins.gpio2).unwrap(); - - let mut card = embedded_sdmmc::sdcard::SdCard::new(SPI_Device, - cs, - del); - - - let mut volume_mgr = embedded_sdmmc::VolumeManager::new(card, SdMmcClock{}); - - log::info!("Card size is still {} bytes", volume_mgr.device().num_bytes().unwrap()); - - let volume0 = volume_mgr.open_volume(embedded_sdmmc::VolumeIdx(0)).unwrap(); + let mut Screen = match Screen::Drivers::SDL2::Screen_type::New(Screen::Prelude::Coordinates_type { X: Horizontal_resolution as i16, Y: Vertical_resolution as i16 }) { + Ok(Screen) => Screen, + Err(_) => panic!("Error while initializing screen.") + }; - log::info!("Volume 0: {:?}", volume0); + let Display = match Graphics::Display_type::New::(&mut Screen) { + Ok(Display) => Display, + Err(_) => panic!("Error while initializing display.") + }; - let mut root = volume_mgr.open_root_dir(volume0).unwrap(); + + let mut Display_object = match Display.Get_object() { + Ok(Display_object) => Display_object, + Err(_) => panic!("Error while getting display object.") + }; + + let Calendar = match lvgl::widgets::Btn::create(&mut Display_object) { + Ok(Calendar) => Calendar, + Err(_) => panic!("Error while initializing calendar.") + }; - volume_mgr.iterate_dir(root, |entry| { - log::info!("Entry: {:?}", entry); - - }); - - //sys::gpio_install_isr_service(0); + loop { + let start = Instant::now(); + lvgl::task_handler(); + std::thread::sleep(Duration::from_millis(5)); + lvgl::tick_inc(Instant::now().duration_since(start)); } + + + } /*