STM32F429中LTDC的DMA2D加速
Posted jiangzhaowei
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了STM32F429中LTDC的DMA2D加速相关的知识,希望对你有一定的参考价值。
液晶屏的时序问题?
每个液晶屏的时序都不一样,但总体上是类似的。如下图:
VDEN: 数据使能信号。
HSYNC: 每一行扫描的起始点, 在扫描过程中, 不会管上一行扫描有没有结束, 当出现这一个信号,即开始新一行的扫描.
VSYNC: 每一场扫描的起始点, 这与HSYNC相似的.
BACK PROCH: 因为有不同tft屏和不同扫描硬件, 并且HSYNC和VSYNC对于时序的约束力有限, 所以会加入一些容错的时间, 因此行扫描和场扫描都会有BACK PROCH: 和FRONT PROCH: , 并且会在HSYNC,VSYNC出现之后, 和正常分辨率扫描之后都将容错时序, 也就是在正常扫描的前后都加入容错时间, BACK PROCH: 虽然从字面上理解是后容错, 但通常会放在正常描述之前, 当然这还要看具体TFT屏的规格书.
FRONT PROCH: 也就是放在正常描述之后的容错时间. 同上.
CLK: 也就是正常扫描的时钟, 一个上升沿只会扫描一个pixel.
从下面这个示意图可以比较直观的看出:
注意:有些液晶屏给的参数单位可能不一样,需要自己计算。
各参数值确定方法如下:
VBPD:确定帧同步信号和帧数据传输前的一段延迟时间,是帧数据传输前延迟时间和行同步时钟间隔宽度的比值,如图,VBPD=t3/t6=1.02 mS/31.77μs=32。
VFPD:确定帧数据传输完成后到下一帧同步信号到来的一段延迟时间,是帧数据传输后延迟时间和行同步时钟间隔宽度的比值,如图,VFPD=t5/t6=0.35 ms/31.77μs=11。
VSPW:确定帧同步时钟脉冲宽度,是帧同步信号时钟宽度和行同步时钟间隔宽度的比值。如图,VSPW=t2/t6=0.06 ms/31.77μs=2。
HBPD:确定行同步信号和行数据传输前的一段延迟时间,描述行数据传输前延迟时间内VCLK脉冲个数,如图,VBPD=t7×VCLK=1.89 μs×25MHz=47。
HFPD:确定行数据传输完成后到下一行同步信号到来的一段延迟时间,描述行数据传输后延迟时间内VCLK脉冲个数,如图,HFPD=t9×VCLK=0.94 μs×25 MHz=24。
HSPW:确定行同步时钟脉冲宽度。描述行同步脉冲宽度时间内VCLK脉冲个数,如图,HSPW=3.77μs×25 MHz=94。
LTDC的使用问题?
可参考官方例程的配置,需要注意的是,它只是一个LCD控制器,需要定义缓存的地址。可以设置在flash里,但是不便于操作,一般还是建议设置外部SDRAM里。可参考下面这个PDF文档。
LTDC中DMA2D的使用问题?
429中LTDC的2D加速功能还比较简单,只有以下4种模式
DMA2D功能:
DMA2D_M2M 从flash拷贝至显存
DMA2D_M2M_PFC 从flash拷贝至显存,并可以进行颜色的格式转换,替换/不更改/混合
DMA2D_M2M_BLEND 从flash拷贝至显存,并先进行前景与后景色混合
DMA2D_R2M 拷贝固定颜色至显存
使用方式:
uint32_t DMA2D_OutAdd; uint32_t DMA2D_InAdd; void DMA2D_M2M_Config(uint16_t Xpos, uint16_t Ypos, uint16_t Width, uint16_t Height) { DMA2D_InitTypeDef DMA2D_InitStruct; DMA2D_FG_InitTypeDef DMA2D_FG_InitStruct; /* Enable the DMA2D Clock */ RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_DMA2D, ENABLE); /* DMA2D configuration */ DMA2D_DeInit(); /* Transfer mode */ DMA2D_InitStruct.DMA2D_Mode = DMA2D_M2M; /* Color mode */ DMA2D_InitStruct.DMA2D_CMode = DMA2D_RGB565; DMA2D_OutAdd = CurrentFrameBuffer + 2*(LCD_PIXEL_WIDTH*Ypos + Xpos); /* Output Address */ DMA2D_InitStruct.DMA2D_OutputMemoryAdd = DMA2D_OutAdd; /* Number of lines : height */ DMA2D_InitStruct.DMA2D_NumberOfLine = Height; /* Number of pixel per line : width */ DMA2D_InitStruct.DMA2D_PixelPerLine = Width; /* Initialize the alpha and RGB values */ DMA2D_InitStruct.DMA2D_OutputGreen = 0; DMA2D_InitStruct.DMA2D_OutputBlue = 0; DMA2D_InitStruct.DMA2D_OutputRed = 0; DMA2D_InitStruct.DMA2D_OutputAlpha = 0; /* Initialize the output offset */ DMA2D_InitStruct.DMA2D_OutputOffset = (LCD_PIXEL_WIDTH - Width); /* Initialize DMA2D */ DMA2D_Init(&DMA2D_InitStruct); /* Configure default values for foreground */ DMA2D_FG_StructInit(&DMA2D_FG_InitStruct); /* Configure DMA2D foreground color mode */ DMA2D_FG_InitStruct.DMA2D_FGCM = DMA2D_RGB565; /* Configure Input Address */ DMA2D_FG_InitStruct.DMA2D_FGMA = CurrentFrameBuffer+BUFFER_OFFSET; /* Initialize foreground */ DMA2D_FGConfig(&DMA2D_FG_InitStruct); /* Start Transfer */ DMA2D_StartTransfer(); /* Wait for CTC Flag activation */ while(DMA2D_GetFlagStatus(DMA2D_FLAG_TC) == RESET) { } }
以上是关于STM32F429中LTDC的DMA2D加速的主要内容,如果未能解决你的问题,请参考以下文章
ThreadX GUIX上手之STM32F429 DMA2D加速
STM32CubeMX | 42 - 使用DMA2D加速显存数据传输