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)
    {
    }
}

猜你喜欢

转载自www.cnblogs.com/jiangzhaowei/p/10868610.html
今日推荐