arm/stm32h753bi: Add support to lvgl
Some checks failed
Build Documentation / build-html (push) Has been cancelled

Signed-off-by: Jorge Guzman <jorge.gzm@gmail.com>
This commit is contained in:
Jorge Guzman 2024-09-22 11:43:46 -03:00 committed by Alan C. Assis
parent e26e8bda0e
commit e55966d3dc
9 changed files with 253 additions and 94 deletions

View file

@ -813,3 +813,57 @@ Configures the board to use the SPI4 and enables RFID driver with MFRC522::
MOSI PE6 MOSI PE6
CS PE4 CS PE4
======== ===== ======== =====
lvgl
----
Configures the board to use display of 7 inch with lvgl example.
To verify if the display is functioning correctly, use the **fb** command. You should see the display change colors.::
nsh> fb
VideoInfo:
fmt: 11
xres: 1024
yres: 600
nplanes: 1
noverlays: 1
OverlayInfo (overlay 0):
fbmem: 0xc0000000
fblen: 1228800
stride: 2048
overlay: 0
bpp: 16
blank: 0
chromakey: 0x00000000
color: 0x00000000
transp: 0xff
mode: 0
area: (0,0) => (1024,600)
accl: 1
PlaneInfo (plane 0):
fbmem: 0xc0000000
fblen: 1228800
stride: 2048
display: 0
bpp: 16
Mapped FB: 0xc0000000
0: ( 0, 0) (1024,600)
1: ( 93, 54) (838,492)
2: (186,108) (652,384)
3: (279,162) (466,276)
4: (372,216) (280,168)
5: (465,270) ( 94, 60)
Test finished
Once the **fd** command work, run the lvgl exemple. ::
nsh> lvgldemo
**WARNING:** This example at the moment is not working correctly yet and have a bug fix to be done.
In the lvgl file **./apps/graphics/lvgl/lvgl/src/drivers/nuttx/lv_nuttx_fbdev.c**
search the function **lv_nuttx_fbdev_set_file** and modify line 156 as follows:
dsc->mem_off_screen = malloc(data_size);
to
dsc->mem_off_screen = (void*)0xC00000000;

View file

@ -2623,7 +2623,7 @@ static int stm32_setchromakey(struct fb_vtable_s *vtable,
struct stm32_ltdcdev_s *priv = (struct stm32_ltdcdev_s *)vtable; struct stm32_ltdcdev_s *priv = (struct stm32_ltdcdev_s *)vtable;
DEBUGASSERT(vtable != NULL && priv == &g_vtable && oinfo != NULL); DEBUGASSERT(vtable != NULL && priv == &g_vtable && oinfo != NULL);
lcdinfo("vtable=%p, overlay=%d, chromakey=%08x\n", vtable, lcdinfo("vtable=%p, overlay=%d, chromakey=%08" PRIx32 "\n", vtable,
oinfo->overlay, oinfo->chromakey); oinfo->overlay, oinfo->chromakey);
if (oinfo->overlay < LTDC_NLAYERS) if (oinfo->overlay < LTDC_NLAYERS)
@ -2689,7 +2689,8 @@ static int stm32_setcolor(struct fb_vtable_s *vtable,
const struct fb_overlayinfo_s *oinfo) const struct fb_overlayinfo_s *oinfo)
{ {
DEBUGASSERT(vtable != NULL && vtable == &g_vtable.vtable && oinfo != NULL); DEBUGASSERT(vtable != NULL && vtable == &g_vtable.vtable && oinfo != NULL);
lcdinfo("vtable=%p, overlay=%d, color=%08x\n", vtable, oinfo->color); lcdinfo("vtable=%p, overlay=%d, color=%08" PRIx32 "\n",
vtable, oinfo->overlay, oinfo->color);
if (oinfo->overlay < LTDC_NOVERLAYS) if (oinfo->overlay < LTDC_NOVERLAYS)
{ {
@ -2737,7 +2738,8 @@ static int stm32_setblank(struct fb_vtable_s *vtable,
struct stm32_ltdcdev_s *priv = (struct stm32_ltdcdev_s *)vtable; struct stm32_ltdcdev_s *priv = (struct stm32_ltdcdev_s *)vtable;
DEBUGASSERT(vtable != NULL && priv == &g_vtable && oinfo != NULL); DEBUGASSERT(vtable != NULL && priv == &g_vtable && oinfo != NULL);
lcdinfo("vtable=%p, overlay=%d, blank=%02x\n", vtable, oinfo->blank); lcdinfo("vtable=%p, overlay=%d, blank=%02x\n",
vtable, oinfo->overlay, oinfo->blank);
if (oinfo->overlay < LTDC_NLAYERS) if (oinfo->overlay < LTDC_NLAYERS)
{ {

View file

@ -2626,7 +2626,7 @@ static int stm32_setchromakey(struct fb_vtable_s *vtable,
struct stm32_ltdcdev_s *priv = (struct stm32_ltdcdev_s *)vtable; struct stm32_ltdcdev_s *priv = (struct stm32_ltdcdev_s *)vtable;
DEBUGASSERT(vtable != NULL && priv == &g_vtable && oinfo != NULL); DEBUGASSERT(vtable != NULL && priv == &g_vtable && oinfo != NULL);
lcdinfo("vtable=%p, overlay=%d, chromakey=%08x\n", vtable, lcdinfo("vtable=%p, overlay=%d, chromakey=%08" PRIx32 "\n", vtable,
oinfo->overlay, oinfo->chromakey); oinfo->overlay, oinfo->chromakey);
if (oinfo->overlay < LTDC_NLAYERS) if (oinfo->overlay < LTDC_NLAYERS)
@ -2692,7 +2692,8 @@ static int stm32_setcolor(struct fb_vtable_s *vtable,
const struct fb_overlayinfo_s *oinfo) const struct fb_overlayinfo_s *oinfo)
{ {
DEBUGASSERT(vtable != NULL && vtable == &g_vtable.vtable && oinfo != NULL); DEBUGASSERT(vtable != NULL && vtable == &g_vtable.vtable && oinfo != NULL);
lcdinfo("vtable=%p, overlay=%d, color=%08x\n", vtable, oinfo->color); lcdinfo("vtable=%p, overlay=%d, color=%08" PRIx32 "\n",
vtable, oinfo->overlay, oinfo->color);
if (oinfo->overlay < LTDC_NOVERLAYS) if (oinfo->overlay < LTDC_NOVERLAYS)
{ {
@ -2739,7 +2740,8 @@ static int stm32_setblank(struct fb_vtable_s *vtable,
struct stm32_ltdcdev_s *priv = (struct stm32_ltdcdev_s *)vtable; struct stm32_ltdcdev_s *priv = (struct stm32_ltdcdev_s *)vtable;
DEBUGASSERT(vtable != NULL && priv == &g_vtable && oinfo != NULL); DEBUGASSERT(vtable != NULL && priv == &g_vtable && oinfo != NULL);
lcdinfo("vtable=%p, overlay=%d, blank=%02x\n", vtable, oinfo->blank); lcdinfo("vtable=%p, overlay=%d, blank=%02x\n",
vtable, oinfo->overlay, oinfo->blank);
if (oinfo->overlay < LTDC_NLAYERS) if (oinfo->overlay < LTDC_NLAYERS)
{ {

View file

@ -0,0 +1,74 @@
#
# This file is autogenerated: PLEASE DO NOT EDIT IT.
#
# You can use "make menuconfig" to make any modifications to the installed .config file.
# You can then do "make savedefconfig" to generate a new defconfig file that includes your
# modifications.
#
# CONFIG_STANDARD_SERIAL is not set
# CONFIG_STM32H7_FB_CMAP is not set
# CONFIG_STM32H7_LTDC_L1_CHROMAKEYEN is not set
# CONFIG_STM32H7_LTDC_L2 is not set
# CONFIG_STM32H7_USE_LEGACY_PINMAP is not set
CONFIG_ARCH="arm"
CONFIG_ARCH_BOARD="linum-stm32h753bi"
CONFIG_ARCH_BOARD_LINUM_STM32H753BI=y
CONFIG_ARCH_CHIP="stm32h7"
CONFIG_ARCH_CHIP_STM32H753BI=y
CONFIG_ARCH_CHIP_STM32H7=y
CONFIG_ARCH_CHIP_STM32H7_CORTEXM7=y
CONFIG_ARCH_STACKDUMP=y
CONFIG_ARMV7M_DCACHE=y
CONFIG_ARMV7M_DCACHE_WRITETHROUGH=y
CONFIG_ARMV7M_DTCM=y
CONFIG_ARMV7M_ICACHE=y
CONFIG_BOARD_LOOPSPERMSEC=43103
CONFIG_BUILTIN=y
CONFIG_DEBUG_FEATURES=y
CONFIG_DEBUG_SYMBOLS=y
CONFIG_DRIVERS_VIDEO=y
CONFIG_EXAMPLES_ALARM=y
CONFIG_EXAMPLES_FB=y
CONFIG_EXAMPLES_LVGLDEMO=y
CONFIG_FB_OVERLAY=y
CONFIG_FS_PROCFS=y
CONFIG_GRAPHICS_LVGL=y
CONFIG_INIT_ENTRYPOINT="nsh_main"
CONFIG_INTELHEX_BINARY=y
CONFIG_LIBM=y
CONFIG_LV_USE_CLIB_MALLOC=y
CONFIG_LV_USE_CLIB_SPRINTF=y
CONFIG_LV_USE_CLIB_STRING=y
CONFIG_LV_USE_DEMO_WIDGETS=y
CONFIG_LV_USE_NUTTX=y
CONFIG_MM_REGIONS=5
CONFIG_NSH_ARCHINIT=y
CONFIG_NSH_BUILTIN_APPS=y
CONFIG_NSH_DISABLE_IFUPDOWN=y
CONFIG_NSH_FILEIOSIZE=512
CONFIG_NSH_LINELEN=64
CONFIG_NSH_READLINE=y
CONFIG_PREALLOC_TIMERS=4
CONFIG_RAM_SIZE=245760
CONFIG_RAM_START=0x20010000
CONFIG_RAW_BINARY=y
CONFIG_RR_INTERVAL=200
CONFIG_RTC_ALARM=y
CONFIG_RTC_DATETIME=y
CONFIG_RTC_DRIVER=y
CONFIG_SCHED_WAITPID=y
CONFIG_START_DAY=6
CONFIG_START_MONTH=12
CONFIG_START_YEAR=2011
CONFIG_STM32H7_FMC=y
CONFIG_STM32H7_LTDC=y
CONFIG_STM32H7_LTDC_FB_BASE=0xC0000000
CONFIG_STM32H7_LTDC_FB_SIZE=1228800
CONFIG_STM32H7_PWR=y
CONFIG_STM32H7_RTC=y
CONFIG_STM32H7_USART1=y
CONFIG_SYSTEM_NSH=y
CONFIG_TASK_NAME_SIZE=0
CONFIG_TESTING_RAMTEST=y
CONFIG_USART1_SERIAL_CONSOLE=y
CONFIG_VIDEO_FB=y

View file

@ -88,13 +88,13 @@
#define STM32_PLLCFG_PLLSRC RCC_PLLCKSELR_PLLSRC_HSE #define STM32_PLLCFG_PLLSRC RCC_PLLCKSELR_PLLSRC_HSE
/* PLL1, wide 4 - 8 MHz input, enable DIVP, DIVQ, DIVR /* PLL1 - 25 MHz input, enable DIVP, DIVQ, DIVR
* *
* PLL1_VCO = (25 MHz / 5) * 192 = 960 MHz * PLL1_VCO = (25 MHz / 5) * 192 = 960 MHz
* *
* PLL1P = PLL1_VCO/2 = 800 MHz / 2 = 480 MHz * PLL1P = PLL1_VCO/2 = 800 MHz / 2 = 480 MHz
* PLL1Q = PLL1_VCO/4 = 800 MHz / 4 = 240 MHz * PLL1Q = PLL1_VCO/4 = 800 MHz / 4 = 240 MHz
* PLL1R = PLL1_VCO/8 = 800 MHz / 4 = 240 MHz * PLL1R = PLL1_VCO/4 = 800 MHz / 4 = 240 MHz
*/ */
#define STM32_PLLCFG_PLL1CFG (RCC_PLLCFGR_PLL1VCOSEL_WIDE| \ #define STM32_PLLCFG_PLL1CFG (RCC_PLLCFGR_PLL1VCOSEL_WIDE| \
@ -103,24 +103,24 @@
RCC_PLLCFGR_DIVQ1EN| \ RCC_PLLCFGR_DIVQ1EN| \
RCC_PLLCFGR_DIVR1EN) RCC_PLLCFGR_DIVR1EN)
#define STM32_VCO1_FREQUENCY ((STM32_HSE_FREQUENCY / 5) * 192)
#define STM32_PLL1P_FREQUENCY (STM32_VCO1_FREQUENCY / 2)
#define STM32_PLL1Q_FREQUENCY (STM32_VCO1_FREQUENCY / 4)
#define STM32_PLL1R_FREQUENCY (STM32_VCO1_FREQUENCY / 4)
#define STM32_PLLCFG_PLL1M RCC_PLLCKSELR_DIVM1(5) #define STM32_PLLCFG_PLL1M RCC_PLLCKSELR_DIVM1(5)
#define STM32_PLLCFG_PLL1N RCC_PLL1DIVR_N1(192) #define STM32_PLLCFG_PLL1N RCC_PLL1DIVR_N1(192)
#define STM32_PLLCFG_PLL1P RCC_PLL1DIVR_P1(2) #define STM32_PLLCFG_PLL1P RCC_PLL1DIVR_P1(2)
#define STM32_PLLCFG_PLL1Q RCC_PLL1DIVR_Q1(4) #define STM32_PLLCFG_PLL1Q RCC_PLL1DIVR_Q1(4)
#define STM32_PLLCFG_PLL1R RCC_PLL1DIVR_R1(4) #define STM32_PLLCFG_PLL1R RCC_PLL1DIVR_R1(4)
/* PLL2, wide 4 - 8 MHz input, enable DIVP, DIVQ, DIVR #define STM32_VCO1_FREQUENCY ((STM32_HSE_FREQUENCY / 5) * 192)
#define STM32_PLL1P_FREQUENCY (STM32_VCO1_FREQUENCY / 2)
#define STM32_PLL1Q_FREQUENCY (STM32_VCO1_FREQUENCY / 4)
#define STM32_PLL1R_FREQUENCY (STM32_VCO1_FREQUENCY / 4)
/* PLL2 - 25 MHz input, enable DIVP, DIVQ, DIVR
* *
* PLL1_VCO = (25 MHz / 2) * 48 = 600 MHz * PLL2_VCO = (25 MHz / 2) * 48 = 600 MHz
* *
* PLL2P = PLL2_VCO/2 = 600 MHz / 8 = 75 MHz * PLL2P = PLL2_VCO/8 = 600 MHz / 8 = 75 MHz
* PLL2Q = PLL2_VCO/4 = 600 MHz / 40 = 15 MHz * PLL2Q = PLL2_VCO/40 = 600 MHz / 40 = 15 MHz
* PLL2R = PLL2_VCO/8 = 600 MHz / 3 = 200 MHz * PLL2R = PLL2_VCO/3 = 600 MHz / 3 = 200 MHz
*/ */
#define STM32_PLLCFG_PLL2CFG (RCC_PLLCFGR_PLL2VCOSEL_WIDE| \ #define STM32_PLLCFG_PLL2CFG (RCC_PLLCFGR_PLL2VCOSEL_WIDE| \
RCC_PLLCFGR_PLL2RGE_4_8_MHZ| \ RCC_PLLCFGR_PLL2RGE_4_8_MHZ| \
@ -128,30 +128,41 @@
RCC_PLLCFGR_DIVQ2EN| \ RCC_PLLCFGR_DIVQ2EN| \
RCC_PLLCFGR_DIVR2EN) RCC_PLLCFGR_DIVR2EN)
#define STM32_VCO2_FREQUENCY ((STM32_HSE_FREQUENCY / 2) * 48)
#define STM32_PLL2P_FREQUENCY (STM32_VCO2_FREQUENCY / 8)
#define STM32_PLL2Q_FREQUENCY (STM32_VCO2_FREQUENCY / 40)
#define STM32_PLL2R_FREQUENCY (STM32_VCO2_FREQUENCY / 3)
#define STM32_PLLCFG_PLL2M RCC_PLLCKSELR_DIVM2(2) #define STM32_PLLCFG_PLL2M RCC_PLLCKSELR_DIVM2(2)
#define STM32_PLLCFG_PLL2N RCC_PLL2DIVR_N2(48) #define STM32_PLLCFG_PLL2N RCC_PLL2DIVR_N2(48)
#define STM32_PLLCFG_PLL2P RCC_PLL2DIVR_P2(8) #define STM32_PLLCFG_PLL2P RCC_PLL2DIVR_P2(8)
#define STM32_PLLCFG_PLL2Q RCC_PLL2DIVR_Q2(40) #define STM32_PLLCFG_PLL2Q RCC_PLL2DIVR_Q2(40)
#define STM32_PLLCFG_PLL2R RCC_PLL2DIVR_R2(3) #define STM32_PLLCFG_PLL2R RCC_PLL2DIVR_R2(3)
/* PLL3 */ #define STM32_VCO2_FREQUENCY ((STM32_HSE_FREQUENCY / 2) * 48)
#define STM32_PLL2P_FREQUENCY (STM32_VCO2_FREQUENCY / 8)
#define STM32_PLL2Q_FREQUENCY (STM32_VCO2_FREQUENCY / 40)
#define STM32_PLL2R_FREQUENCY (STM32_VCO2_FREQUENCY / 3)
#define STM32_PLLCFG_PLL3CFG 0 /* PLL3 - 25 MHz input, enable DIVP, DIVQ, DIVR
#define STM32_PLLCFG_PLL3M 0 *
#define STM32_PLLCFG_PLL3N 0 * PLL3_VCO = (25 MHz / 1) * 35 = 875 MHz
#define STM32_PLLCFG_PLL3P 0 *
#define STM32_PLLCFG_PLL3Q 0 * PLL3P = PLL3_VCO/2 = 875 MHz / 2 = 437.7 MHz
#define STM32_PLLCFG_PLL3R 0 * PLL3Q = PLL3_VCO/1 = 875 MHz / 1 = 875 MHz
* PLL3R = PLL3_VCO/20 = 875 MHz / 20 = 43.75 MHz
*/
#define STM32_PLLCFG_PLL3CFG (RCC_PLLCFGR_PLL3VCOSEL_WIDE| \
RCC_PLLCFGR_PLL3RGE_8_16_MHZ| \
RCC_PLLCFGR_DIVP3EN| \
RCC_PLLCFGR_DIVQ3EN| \
RCC_PLLCFGR_DIVR3EN)
#define STM32_VCO3_FREQUENCY #define STM32_PLLCFG_PLL3M RCC_PLLCKSELR_DIVM3(1)
#define STM32_PLL3P_FREQUENCY #define STM32_PLLCFG_PLL3N RCC_PLL3DIVR_N3(35)
#define STM32_PLL3Q_FREQUENCY #define STM32_PLLCFG_PLL3P RCC_PLL3DIVR_P3(2)
#define STM32_PLL3R_FREQUENCY #define STM32_PLLCFG_PLL3Q RCC_PLL3DIVR_Q3(1)
#define STM32_PLLCFG_PLL3R RCC_PLL3DIVR_R3(20)
#define STM32_VCO3_FREQUENCY ((STM32_HSE_FREQUENCY / 1) * 35)
#define STM32_PLL3P_FREQUENCY (STM32_VCO3_FREQUENCY / 2)
#define STM32_PLL3Q_FREQUENCY (STM32_VCO3_FREQUENCY / 1)
#define STM32_PLL3R_FREQUENCY (STM32_VCO3_FREQUENCY / 20)
/* SYSCLK = PLL1P = 480 MHz /* SYSCLK = PLL1P = 480 MHz
* CPUCLK = SYSCLK / 1 = 480 MHz * CPUCLK = SYSCLK / 1 = 480 MHz
@ -163,7 +174,7 @@
/* Configure Clock Assignments */ /* Configure Clock Assignments */
/* AHB clock (HCLK) is SYSCLK/2 (480 MHz max) /* AHB clock (HCLK) is SYSCLK/2 (240 MHz max)
* HCLK1 = HCLK2 = HCLK3 = HCLK4 * HCLK1 = HCLK2 = HCLK3 = HCLK4
*/ */
@ -246,6 +257,17 @@
#define STM32_RCC_D3CCIPR_ADCSRC RCC_D3CCIPR_ADCSEL_PLL2 #define STM32_RCC_D3CCIPR_ADCSRC RCC_D3CCIPR_ADCSEL_PLL2
/* FDCAN 1 2 clock source, use STM32_HSE_FREQUENCY */
#define STM32_RCC_D2CCIP1R_FDCANSEL RCC_D2CCIP1R_FDCANSEL_HSE
/* SDMMC 1 2 clock source, use STM32_PLL1Q_FREQUENCY */
#define STM32_RCC_D1CCIPR_SDMMCSEL RCC_D1CCIPR_SDMMC_PLL1
/* FMC clock source, use STM32_PLL1Q_FREQUENCY */
#define BOARD_FMC_CLK RCC_D1CCIPR_FMCSEL_HCLK
/* FLASH wait states /* FLASH wait states
* *
* ------------ ---------- ----------- * ------------ ---------- -----------
@ -268,21 +290,6 @@
#define BOARD_FLASH_WAITSTATES 4 #define BOARD_FLASH_WAITSTATES 4
/* SDMMC definitions ********************************************************/
/* Init 400 kHz, PLL1Q/(2*300) = 240 MHz / (2*300) = 400 Khz */
#define STM32_SDMMC_INIT_CLKDIV (300 << STM32_SDMMC_CLKCR_CLKDIV_SHIFT)
/* Just set these to 24 MHz for now,
* PLL1Q/(2*5) = 240 MHz / (2*5) = 24 MHz
*/
#define STM32_SDMMC_MMCXFR_CLKDIV (5 << STM32_SDMMC_CLKCR_CLKDIV_SHIFT)
#define STM32_SDMMC_SDXFR_CLKDIV (5 << STM32_SDMMC_CLKCR_CLKDIV_SHIFT)
#define STM32_SDMMC_CLKCR_EDGE STM32_SDMMC_CLKCR_NEGEDGE
/* LED definitions **********************************************************/ /* LED definitions **********************************************************/
/* The board has 1 user LED RGB that could be used this diagnostic LED too. /* The board has 1 user LED RGB that could be used this diagnostic LED too.
@ -386,6 +393,18 @@
/* SDMMC1 - Used SD Card memory */ /* SDMMC1 - Used SD Card memory */
/* Init 400 kHz, PLL1Q/(2*300) = 240 MHz / (2*300) = 400 Khz */
#define STM32_SDMMC_INIT_CLKDIV (300 << STM32_SDMMC_CLKCR_CLKDIV_SHIFT)
/* Just set these to 24 MHz for now,
* PLL1Q/(2*5) = 240 MHz / (2*5) = 24 MHz
*/
#define STM32_SDMMC_MMCXFR_CLKDIV (5 << STM32_SDMMC_CLKCR_CLKDIV_SHIFT)
#define STM32_SDMMC_SDXFR_CLKDIV (5 << STM32_SDMMC_CLKCR_CLKDIV_SHIFT)
#define STM32_SDMMC_CLKCR_EDGE STM32_SDMMC_CLKCR_NEGEDGE
#define GPIO_SDMMC1_CK (GPIO_SDMMC1_CK_0|GPIO_SPEED_100MHz) /* PC12 */ #define GPIO_SDMMC1_CK (GPIO_SDMMC1_CK_0|GPIO_SPEED_100MHz) /* PC12 */
#define GPIO_SDMMC1_CMD (GPIO_SDMMC1_CMD_0|GPIO_SPEED_100MHz) /* PD2 */ #define GPIO_SDMMC1_CMD (GPIO_SDMMC1_CMD_0|GPIO_SPEED_100MHz) /* PD2 */
#define GPIO_SDMMC1_D0 (GPIO_SDMMC1_D0_0|GPIO_SPEED_100MHz) /* PC8 */ #define GPIO_SDMMC1_D0 (GPIO_SDMMC1_D0_0|GPIO_SPEED_100MHz) /* PC8 */
@ -450,15 +469,13 @@
/* SDRAM FMC definitions ****************************************************/ /* SDRAM FMC definitions ****************************************************/
/* The following settings correspond to W9864G6KH-6 SDRAM /* The following settings correspond to IS42S16400J SDRAM
* part-number ("-6" speed grades ) and FMC_SDCLK frequency of 166 MHz * part-number and FMC_SDCLK frequency of 120 MHz
* (period is ~ 6.25 ns).
*/ */
/* Though W9864G6KH-6 SDRAM itself provides 16-bit data bus, /* Though IS42S16400J SDRAM itself provides 16-bit data bus,
* linum board routes only DQ[15:0] bits. * linum board routes only DQ[15:0] bits.
*/ */
#define BOARD_FMC_CLK RCC_D1CCIPR_FMCSEL_HCLK
#if CONFIG_STM32H7_FMC #if CONFIG_STM32H7_FMC
# define FMC_SDCLK_FREQUENCY (STM32_HCLK_FREQUENCY / 2) # define FMC_SDCLK_FREQUENCY (STM32_HCLK_FREQUENCY / 2)
@ -559,37 +576,37 @@
/* LTDC */ /* LTDC */
#define GPIO_LTDC_R0 (GPIO_LTDC_R0_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_R0 (GPIO_LTDC_R0_3|GPIO_SPEED_100MHz) /* PI15 */
#define GPIO_LTDC_R1 (GPIO_LTDC_R1_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_R1 (GPIO_LTDC_R1_3|GPIO_SPEED_100MHz) /* PJ0 */
#define GPIO_LTDC_R2 (GPIO_LTDC_R2_4|GPIO_SPEED_100MHz) #define GPIO_LTDC_R2 (GPIO_LTDC_R2_4|GPIO_SPEED_100MHz) /* PJ1 */
#define GPIO_LTDC_R3 (GPIO_LTDC_R3_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_R3 (GPIO_LTDC_R3_2|GPIO_SPEED_100MHz) /* PJ2 */
#define GPIO_LTDC_R4 (GPIO_LTDC_R4_4|GPIO_SPEED_100MHz) #define GPIO_LTDC_R4 (GPIO_LTDC_R4_4|GPIO_SPEED_100MHz) /* PJ3 */
#define GPIO_LTDC_R5 (GPIO_LTDC_R5_4|GPIO_SPEED_100MHz) #define GPIO_LTDC_R5 (GPIO_LTDC_R5_5|GPIO_SPEED_100MHz) /* PJ4 */
#define GPIO_LTDC_R6 (GPIO_LTDC_R6_4|GPIO_SPEED_100MHz) #define GPIO_LTDC_R6 (GPIO_LTDC_R6_3|GPIO_SPEED_100MHz) /* PJ5 */
#define GPIO_LTDC_R7 (GPIO_LTDC_R7_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_R7 (GPIO_LTDC_R7_3|GPIO_SPEED_100MHz) /* PJ6 */
#define GPIO_LTDC_G0 (GPIO_LTDC_G0_2|GPIO_SPEED_100MHz) #define GPIO_LTDC_G0 (GPIO_LTDC_G0_3|GPIO_SPEED_100MHz) /* PJ7 */
#define GPIO_LTDC_G1 (GPIO_LTDC_G1_2|GPIO_SPEED_100MHz) #define GPIO_LTDC_G1 (GPIO_LTDC_G1_3|GPIO_SPEED_100MHz) /* PJ8 */
#define GPIO_LTDC_G2 (GPIO_LTDC_G2_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_G2 (GPIO_LTDC_G2_3|GPIO_SPEED_100MHz) /* PJ9 */
#define GPIO_LTDC_G3 (GPIO_LTDC_G3_4|GPIO_SPEED_100MHz) #define GPIO_LTDC_G3 (GPIO_LTDC_G3_4|GPIO_SPEED_100MHz) /* PJ10 */
#define GPIO_LTDC_G4 (GPIO_LTDC_G4_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_G4 (GPIO_LTDC_G4_4|GPIO_SPEED_100MHz) /* PJ11 */
#define GPIO_LTDC_G5 (GPIO_LTDC_G5_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_G5 (GPIO_LTDC_G5_3|GPIO_SPEED_100MHz) /* PK0 */
#define GPIO_LTDC_G6 (GPIO_LTDC_G6_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_G6 (GPIO_LTDC_G6_3|GPIO_SPEED_100MHz) /* PK1 */
#define GPIO_LTDC_G7 (GPIO_LTDC_G7_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_G7 (GPIO_LTDC_G7_4|GPIO_SPEED_100MHz) /* PK2 */
#define GPIO_LTDC_B0 (GPIO_LTDC_B0_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_B0 (GPIO_LTDC_B0_3|GPIO_SPEED_100MHz) /* PJ12 */
#define GPIO_LTDC_B1 (GPIO_LTDC_B1_2|GPIO_SPEED_100MHz) #define GPIO_LTDC_B1 (GPIO_LTDC_B1_3|GPIO_SPEED_100MHz) /* PJ13 */
#define GPIO_LTDC_B2 (GPIO_LTDC_B2_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_B2 (GPIO_LTDC_B2_4|GPIO_SPEED_100MHz) /* PJ14 */
#define GPIO_LTDC_B3 (GPIO_LTDC_B3_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_B3 (GPIO_LTDC_B3_4|GPIO_SPEED_100MHz) /* PJ15 */
#define GPIO_LTDC_B4 (GPIO_LTDC_B4_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_B4 (GPIO_LTDC_B4_4|GPIO_SPEED_100MHz) /* PK3 */
#define GPIO_LTDC_B5 (GPIO_LTDC_B5_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_B5 (GPIO_LTDC_B5_3|GPIO_SPEED_100MHz) /* PK4 */
#define GPIO_LTDC_B6 (GPIO_LTDC_B6_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_B6 (GPIO_LTDC_B6_3|GPIO_SPEED_100MHz) /* PK5 */
#define GPIO_LTDC_B7 (GPIO_LTDC_B7_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_B7 (GPIO_LTDC_B7_3|GPIO_SPEED_100MHz) /* PK6 */
#define GPIO_LTDC_VSYNC (GPIO_LTDC_VSYNC_2|GPIO_SPEED_100MHz) #define GPIO_LTDC_DE (GPIO_LTDC_DE_3|GPIO_SPEED_100MHz) /* PK7 */
#define GPIO_LTDC_HSYNC (GPIO_LTDC_HSYNC_2|GPIO_SPEED_100MHz) #define GPIO_LTDC_CLK (GPIO_LTDC_CLK_3|GPIO_SPEED_100MHz) /* PI14 */
#define GPIO_LTDC_DE (GPIO_LTDC_DE_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_VSYNC (GPIO_LTDC_VSYNC_3|GPIO_SPEED_100MHz) /* PI9 */
#define GPIO_LTDC_CLK (GPIO_LTDC_CLK_3|GPIO_SPEED_100MHz) #define GPIO_LTDC_HSYNC (GPIO_LTDC_HSYNC_2|GPIO_SPEED_100MHz) /* PI10 */
/* LCD definitions **********************************************************/ /* LCD definitions **********************************************************/
@ -598,14 +615,12 @@
#define BOARD_LTDC_OUTPUT_BPP 16 #define BOARD_LTDC_OUTPUT_BPP 16
#define BOARD_LTDC_HFP 160 #define BOARD_LTDC_HFP 160
#define BOARD_LTDC_HBP 160 #define BOARD_LTDC_HBP 160 /* AccumulatedHBP */
#define BOARD_LTDC_VFP 1 #define BOARD_LTDC_VFP 1
#define BOARD_LTDC_VBP 23 #define BOARD_LTDC_VBP 23 /* AccumulatedVBP */
#define BOARD_LTDC_HSYNC 0
#define BOARD_LTDC_VSYNC 0
#define BOARD_LTDC_PLLSAIN 192 #define BOARD_LTDC_HSYNC 1 /* HorizontalSync */
#define BOARD_LTDC_PLLSAIR 5 #define BOARD_LTDC_VSYNC 1 /* VerticalSync */
/* Pixel Clock Polarity */ /* Pixel Clock Polarity */

View file

@ -70,6 +70,10 @@ if(CONFIG_CL_MFRC522)
list(APPEND SRCS stm32_mfrc522.c) list(APPEND SRCS stm32_mfrc522.c)
endif() endif()
if(CONFIG_STM32H7_LTDC)
list(APPEND SRCS stm32_lcd.c)
endif()
target_sources(board PRIVATE ${SRCS}) target_sources(board PRIVATE ${SRCS})
set_property(GLOBAL PROPERTY LD_SCRIPT "${NUTTX_BOARD_DIR}/scripts/flash.ld") set_property(GLOBAL PROPERTY LD_SCRIPT "${NUTTX_BOARD_DIR}/scripts/flash.ld")

View file

@ -72,4 +72,8 @@ ifeq ($(CONFIG_BOARDCTL),y)
CSRCS += stm32_appinitialize.c CSRCS += stm32_appinitialize.c
endif endif
ifeq ($(CONFIG_STM32H7_LTDC),y)
CSRCS += stm32_lcd.c
endif
include $(TOPDIR)/boards/Board.mk include $(TOPDIR)/boards/Board.mk

View file

@ -120,11 +120,13 @@
#define LINUMSTM32H753BI_QETIMER 5 #define LINUMSTM32H753BI_QETIMER 5
/* LCD */ /* DISP_RESET */
#define GPIO_LCD_DISP (GPIO_OUTPUT|GPIO_PUSHPULL|GPIO_SPEED_50MHz|\ #define GPIO_LCD_DISP (GPIO_OUTPUT|GPIO_PUSHPULL|GPIO_SPEED_50MHz|\
GPIO_OUTPUT_SET|GPIO_PORTI|GPIO_PIN7) GPIO_OUTPUT_SET|GPIO_PORTI|GPIO_PIN7)
/* DISP_PWM */
#define GPIO_LCD_BL (GPIO_OUTPUT|GPIO_PUSHPULL|GPIO_SPEED_50MHz|\ #define GPIO_LCD_BL (GPIO_OUTPUT|GPIO_PUSHPULL|GPIO_SPEED_50MHz|\
GPIO_OUTPUT_SET|GPIO_PORTH|GPIO_PIN6) GPIO_OUTPUT_SET|GPIO_PORTH|GPIO_PIN6)

View file

@ -75,10 +75,12 @@ static void convert_lcd_rgb565(void)
stm32_gpiowrite(GPIO_LTDC_R1, 0); stm32_gpiowrite(GPIO_LTDC_R1, 0);
stm32_configgpio(GPIO_LTDC_R2); stm32_configgpio(GPIO_LTDC_R2);
stm32_gpiowrite(GPIO_LTDC_R2, 0); stm32_gpiowrite(GPIO_LTDC_R2, 0);
stm32_configgpio(GPIO_LTDC_G0); stm32_configgpio(GPIO_LTDC_G0);
stm32_gpiowrite(GPIO_LTDC_G0, 0); stm32_gpiowrite(GPIO_LTDC_G0, 0);
stm32_configgpio(GPIO_LTDC_G1); stm32_configgpio(GPIO_LTDC_G1);
stm32_gpiowrite(GPIO_LTDC_G1, 0); stm32_gpiowrite(GPIO_LTDC_G1, 0);
stm32_configgpio(GPIO_LTDC_B0); stm32_configgpio(GPIO_LTDC_B0);
stm32_gpiowrite(GPIO_LTDC_B0, 0); stm32_gpiowrite(GPIO_LTDC_B0, 0);
stm32_configgpio(GPIO_LTDC_B1); stm32_configgpio(GPIO_LTDC_B1);