2022-01-19 21:31:02 +00:00
|
|
|
# How to Create CMSIS-Pack
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## STEP 1 Update 'lv_conf_cmsis.h'
|
|
|
|
|
|
|
|
1. Copy the **lv_conf_template.h** to '**cmsis-pack**' directory
|
|
|
|
|
2022-04-14 12:28:34 +01:00
|
|
|
2. Set the macro protector to '1'
|
2022-01-19 21:31:02 +00:00
|
|
|
|
|
|
|
```c
|
|
|
|
...
|
|
|
|
/* clang-format off */
|
|
|
|
#if 1 /*Set it to "1" to enable content*/
|
|
|
|
...
|
|
|
|
```
|
|
|
|
|
2022-04-14 12:28:34 +01:00
|
|
|
remove the misleading guide above this code segment.
|
|
|
|
|
|
|
|
```c
|
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
```
|
|
|
|
|
2022-01-19 21:31:02 +00:00
|
|
|
|
|
|
|
3. Add including for '**RTE_Components.h**'
|
|
|
|
|
|
|
|
```c
|
|
|
|
#ifndef LV_CONF_H
|
|
|
|
#define LV_CONF_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "RTE_Components.h"
|
|
|
|
...
|
|
|
|
```
|
|
|
|
|
2022-03-21 18:25:51 +08:00
|
|
|
4. Remove macro definitions for
|
2022-01-19 21:31:02 +00:00
|
|
|
- LV_USE_GPU_STM32_DMA2D
|
|
|
|
- LV_USE_GPU_NXP_PXP
|
|
|
|
- LV_USE_GPU_NXP_VG_LITE
|
2022-04-27 13:29:01 +01:00
|
|
|
- LV_USE_GPU_SWM341_DMA2D
|
|
|
|
5. Update macro `LV_ATTRIBUTE_MEM_ALIGN` and `LV_ATTRIBUTE_MEM_ALIGN_SIZE` to force a WORD alignment.
|
2022-01-19 21:31:02 +00:00
|
|
|
```c
|
2022-04-27 13:29:01 +01:00
|
|
|
#define LV_ATTRIBUTE_MEM_ALIGN_SIZE 4
|
|
|
|
#define LV_ATTRIBUTE_MEM_ALIGN __attribute__((aligned(4)))
|
2022-01-19 21:31:02 +00:00
|
|
|
```
|
|
|
|
6. Update Theme related macros:
|
|
|
|
|
|
|
|
```c
|
|
|
|
#ifdef RTE_GRAPHICS_LVGL_USE_EXTRA_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
|
|
|
|
#else
|
|
|
|
#define LV_USE_THEME_DEFAULT 0
|
|
|
|
#define LV_USE_THEME_BASIC 0
|
|
|
|
#define LV_USE_THEME_MONO 0
|
|
|
|
#endif
|
|
|
|
```
|
2022-03-01 17:49:05 +00:00
|
|
|
7. Update `LV_TICK_CUSTOM` related macros:
|
2022-01-31 12:15:27 +00:00
|
|
|
```c
|
|
|
|
/*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()`)*/
|
|
|
|
#ifdef __PERF_COUNTER__
|
|
|
|
#define LV_TICK_CUSTOM 1
|
|
|
|
#if LV_TICK_CUSTOM
|
|
|
|
extern uint32_t SystemCoreClock;
|
2022-04-14 12:28:34 +01:00
|
|
|
#define LV_TICK_CUSTOM_INCLUDE "perf_counter.h"
|
2022-03-21 18:25:51 +08:00
|
|
|
|
2022-03-01 17:49:05 +00:00
|
|
|
#if __PER_COUNTER_VER__ < 10902ul
|
|
|
|
#define LV_TICK_CUSTOM_SYS_TIME_EXPR ((uint32_t)get_system_ticks() / (SystemCoreClock / 1000ul))
|
|
|
|
#else
|
|
|
|
#define LV_TICK_CUSTOM_SYS_TIME_EXPR get_system_ms()
|
|
|
|
#endif
|
2022-01-31 12:15:27 +00:00
|
|
|
#endif /*LV_TICK_CUSTOM*/
|
|
|
|
#else
|
|
|
|
#define LV_TICK_CUSTOM 0
|
|
|
|
#if LV_TICK_CUSTOM
|
|
|
|
#define LV_TICK_CUSTOM_INCLUDE "Arduino.h" /*Header for the system time function*/
|
|
|
|
#define LV_TICK_CUSTOM_SYS_TIME_EXPR (millis()) /*Expression evaluating to current system time in ms*/
|
|
|
|
#endif /*LV_TICK_CUSTOM*/
|
|
|
|
#endif /*__PERF_COUNTER__*/
|
|
|
|
```
|
2022-03-01 17:49:05 +00:00
|
|
|
9. Thoroughly remove the `DEMO USAGE` section.
|
2022-01-31 12:15:27 +00:00
|
|
|
10. Thoroughly remove the '3rd party libraries' section.
|
|
|
|
10. rename '**lv_conf_template.h**' to '**lv_conf_cmsis.h**'.
|
2022-01-19 21:31:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## STEP 2 Check, Update and Run the 'gen_pack.sh'
|
|
|
|
|
|
|
|
```sh
|
|
|
|
if [ `uname -s` = "Linux" ]
|
|
|
|
then
|
|
|
|
CMSIS_PACK_PATH="/home/$USER/.arm/Packs/ARM/CMSIS/5.7.0/"
|
|
|
|
PATH_TO_ADD="$CMSIS_PACK_PATH/CMSIS/Utilities/Linux64/"
|
|
|
|
else
|
|
|
|
CMSIS_PACK_PATH="/C/Users/gabriel/AppData/Local/Arm/Packs/ARM/CMSIS/5.7.0"
|
|
|
|
PATH_TO_ADD="/C/Program Files (x86)/7-Zip/:$CMSIS_PACK_PATH/CMSIS/Utilities/Win32/:/C/xmllint/"
|
|
|
|
fi
|
|
|
|
[[ ":$PATH:" != *":$PATH_TO_ADD}:"* ]] && PATH="${PATH}:${PATH_TO_ADD}"
|
|
|
|
echo $PATH_TO_ADD appended to PATH
|
|
|
|
echo " "
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### A. For Windows users
|
|
|
|
|
|
|
|
Update the '**CMSIS_PACK_PATH**' accordingly (Usually just replace the name gabriel with your own windows account name is sufficient.).
|
|
|
|
|
2022-03-21 18:25:51 +08:00
|
|
|
Update the '**PATH_TO_ADD**' to point to the installation folders of **7Zip** and **xmllint**.
|
2022-01-19 21:31:02 +00:00
|
|
|
|
2022-03-21 18:25:51 +08:00
|
|
|
Launch the git-bash and go to the cmsis-pack folder.
|
2022-01-19 21:31:02 +00:00
|
|
|
|
|
|
|
enter the following command:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
./gen_pack.sh
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### B. For Linux Users
|
|
|
|
|
2022-03-21 18:25:51 +08:00
|
|
|
Update '**PATH_TO_ADD**' if necessary.
|
2022-01-19 21:31:02 +00:00
|
|
|
|
2022-03-21 18:25:51 +08:00
|
|
|
go to the **cmsis-pack** folder.
|
2022-01-19 21:31:02 +00:00
|
|
|
|
|
|
|
enter the following command:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
./gen_pack.sh
|
|
|
|
```
|
|
|
|
|