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 + *(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 = ;
DMA2D_InitStruct.DMA2D_OutputBlue = ;
DMA2D_InitStruct.DMA2D_OutputRed = ;
DMA2D_InitStruct.DMA2D_OutputAlpha = ; /* 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加速的更多相关文章
- STM32F429的LTDC和DMA2D ***
		
在阅读了STM32F429的手册之后,对LTDC与DMA2D有了一点认识. STM32F429与之前的系列强大之处就在于增加了LTDC个功能,从手册上看STM32F429的LTDC可以用于驱动1024 ...
 - 【Chromium中文文档】Chrom{e,ium}{,OS}中的硬件视频加速
		
Chrom{e,ium}{,OS}中的硬件视频加速 转载请注明出处:https://ahangchen.gitbooks.io/chromium_doc_zh/content/zh//General_ ...
 - 利用NVIDIA-NGC中的MATLAB容器加速语义分割
		
利用NVIDIA-NGC中的MATLAB容器加速语义分割 Speeding Up Semantic Segmentation Using MATLAB Container from NVIDIA NG ...
 - c/c++ 代码中使用sse指令集加速
		
使用SSE指令,首先要了解这一类用于进行初始化加载数据以及将暂存器的数据保存到内存相关的指令, 我们知道,大多数SSE指令是使用的xmm0到xmm8的暂存器,那么使用之前,就需要将数据从内存加载到这些 ...
 - unity中鼠标按下加速漫游,鼠标抬起减速漫游。
		
private bool IsMouseUpOrDown=true; //一开始默认是鼠标抬起状态 if (Input.GetMouseButtonDown(1)) //鼠标按下的瞬间状态 { IsM ...
 - 第27章 	LTDC/DMA2D—液晶显示—零死角玩转STM32-F429系列
		
第27章 LTDC/DMA2D—液晶显示 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.co ...
 - 第27章 LTDC/DMA2D—液晶显示
		
本章参考资料:<STM32F76xxx参考手册2>.<STM32F7xx规格书>.库帮助文档<STM32F779xx_User_Manual.chm>. 关于开发板 ...
 - LTDC/DMA2D——液晶显示
		
1.显示器的基本参数 (1) 像素像素是组成图像的最基本单元要素,显示器的像素指它成像最小的点. (2) 分辨率一些嵌入式设备的显示器常常以“行像素值 x列像素值”表示屏幕的分辨率.如分辨率 800x ...
 - DMA2D 图形加速器简介
		
在实际使用 LTDC 控制器控制液晶屏时,使 LTDC 正常工作后,往配置好的显存地址写入要显示的像素数据, LTDC 就会把这些数据从显存搬运到液晶面板进行显示,而显示数据的容量非常大,所以我们希望 ...
 
随机推荐
- java网络编程--httpurlconnection
			
HttpURLConnection是基于HTTP协议的,其底层通过socket通信实现.如果不设置超时(timeout),在网络异常的情况下,可能会导致程序僵死而不继续往下执行.可以通过以下两个语句来 ...
 - javascript_03-数据类型
			
数据类型 JavaScript 和 Java 一样,也是有基本数据类型的.但也是有区别的. JavaScript中的数据类型 简单(基本.值)数据类型 number string boolean un ...
 - Django 中使用权限认证
			
权限认证 权限概念 """ 在实际开发中,项目中都有后台运营站点,运营站点里面会存在多个管理员, 那么不同的管理员会具备不同的任务和能力,那么要实现这样的管理员功能,那么 ...
 - XSS挑战之旅平台通关练习
			
1.第一关 比较简单,测试语句: <svg/onload=alert(1)> <script>confirm(1)</script> <script>p ...
 - 运维开发笔记整理-JsonResponse对象
			
运维开发笔记整理-JsonResponse对象 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.使用HttpResponse发送json格式的数据 1>.HttpRespo ...
 - python-----图像去重(imagededup)
			
安装库: pip install imagededup 安装可能遇到的问题参考: Cannot uninstall 'wrapt'. It is a distutils installed proje ...
 - k8s的认证授权
			
一.ServiceAccount Service account是为了方便Pod里面的进程调用Kubernetes API或其他外部服务而设计的.它与User account不同 User acc ...
 - Poj-3286- How many 0's? - 【基础数位DP】
			
How many 0's? Description A Benedict monk No.16 writes down the decimal representations of all natur ...
 - msaa mrt load store action unity
			
unity buildin renderpipeline 和lightweight rp 对于开了msaa的rt 的load store action设置失效 buildin的时候set render ...
 - [SCSS] SASS dynamic class properties
			
@mixin generateModifers($property) { #{$property}: $padding; &-large { #{$property}: $padding-la ...