详细文档(带图片):http://download.csdn.net/detail/xuehui869/5268852

1.LCM之Fmark功能

http://blog.csdn.net/zhandoushi1982/article/details/6011241

最近调试R61509V这颗LCM驱动芯片时,出现在纯色测试画面下画面刷新有残留(tearing effect,即TE)的问题。根本原因是主控写图像数据的速度与LCM刷屏的速度不一致造成的,具体是刷屏速度要快于主控写速度。好在很多LCM驱动芯片都有一个Fmark脚,用来与主控同步,当Fmark发出一个信号给主控时,主控才开始写一帧数据,这样就可以保证两边同步。讲述前首先对几个概念描述:

(1)刷屏速度

刷屏率是指LCM刷新的速度,这个值一般在LCM的初始化CODE中会设定好。对于瑞萨的R61509V这颗LCD驱动,设定0x0010寄存器就是设定刷屏速度。根据公式:帧率=678KHZ/{(RTN)*DIV*(432+8+8)},其中678K是LCM内部的时钟源,RTN是每行的时钟数,DIV是分频系数,(432+8+8)则是行像素。测得的结果是:

0X011F  20HZ,最小频率.

0X011A  29HZ
0X0115  36HZ 
0X0110  52HZ

0X001C  60HZ  
0X0018  70HZ

0X0014  80HZ

刷屏率太低会导致出现flicker现象,所以一般要设定在60HZ以上。

(2)主控写速度WR跟片选CS

这两个PIN脚对每个DBI的LCM都具备,两者的工作频率是一致的。主控每次写一帧数据时,会有一个片选信号,同时对应一个WR的写有效信号。主控的写频率的变化是由工作状态决定的,比如摄像时,拍摄动态物体的显示写速度就快于拍摄静态物体的显示写速度。

如果屏幕的画面没有更新,就会70ms update一次lcd,如果画面有动,就是最多33ms刷一次屏。意思就是CS频率只能限定在1/70到1/30,14.28HZ至33.33HZ之间。最高频率已经快于PAL或者NTSC的帧频,可以保证摄像头工作或者播放视频时不会出现丢帧现象。

(3)Fmark功能

要使能fmark,首先要保证主控的fmark脚与LCM的fmark脚是正确连接的;其次要在LCM初始化中使能屏的fmark功能,保证LCM周期性发出信号给主控,同时使能主控的fmark功能,保证主控收到一个fmark信号才写一帧数据。

LCM的fmark有两个参数可以配置:一是刷多少次屏发出一个fmark信号,比如不一定要每次刷屏都发fmark信号,可以刷几次屏发一次fmark信号;二是fmark的位置参数,可以让fmark迟滞几条线输出,目的是让主控晚点写数据到GRAM,避免TE。

举例:存在这样的情况,就是IC在从GRAM读完最后一行就输出te信号,此时BB开始写GRAM。但可能还要有一两条line的时间,IC才开始从GRAM的第一行读数据刷下二桢,而写GRAM的速度要慢于IC读GRAM的速度,此时可能还没有开始写。导致读GRAM超过写GRAM,所以会在上方产生tearing。要避免TE输出太早,导致写GRAM先开始,所以要加延迟,保证读老旧数据开始后,写GRAM才开始。[x1]

(4)fmark周期与CS周期

出现TE现象的根本原因是两边速度不一致,具体是LCM的刷新速度要快于主控送数据的速度,两者的速度要符合一定的范围才行。只要保证CS的周期在两个TE周期之间即可,也就是CS的写频率不能低于TE读频率的二分之一,Tearing出现的根本条件是读写有交叉。通常都是写Gram速度(WR)慢于lcd刷屏速度(TE)[x2] ,只要刷屏的位置不超过写Gram位置就不会有切屏现象[x3] 
      举个实例:比如CS差不多就比两个TE周期小一点,要刷两桢数据,首先第一桢刷屏开始刷屏了,表示读GRAM开始,它的速度比较快,它读的是老旧数据;紧接着主控开始写GRAM,大概写到GRAM的快一半时,这时候已经刷完一桢,然后开始刷第二桢,即又从GRAM的最上方开始读并刷屏,此时读出来的才是刚写入的新数据,在写完GRAM之前,读的步骤永远跟不上写的步骤,就不会出现tearing。

如果CS比两个TE周期大,假设相当于三个TE周期,那么只有在第三个TE读周期时,显示的数据才是写好的GRAM的数据;第一个TE读的是老旧的数据,第二个TE周期由于GRAM还没有写完,但读步骤赶上写GRAM步骤了,导致显式一部分是旧的一部分是新的,所以出现TE。此即本质。
(5) TE类型

TE显示使能时,必须保证CPU的LCD TE使能和LCM驱动的TE功能都打开。LCM的TM使能有两种:VSYSC,VSYNC&HSYNC。图示如下:

另外:

http://blog.csdn.net/zhandoushi1982/article/details/5908490

2 me的总结

注意:

作为帧同步信号的VSYNC,每发出一个脉冲,都意味着新的一屏图像数据开始发送。而作为行同步信号的HSYNC,每发出一个脉冲都表明新的一行图像资料开始发送

分析

切屏:中间有一条线,这应该是LCD显示丢了几行数据造成的,根本原因是LCD显示的速度慢与主控写的速度,而两者又没有使用Tearing effect out line的机制

分屏:就是下面的图像显示到了上面去,本来上面的图像显示到了LCD下面。看来君正N800C的瑞鼎屏在播放视频时出现分屏,应该就是这个原因。根本原因是LCD显示的速度快与主控写的速度,而两者又没有使用Tearing effect out line的机制

原文:http://blog.csdn.net/xuehui869/article/details/8814911

最新文章

  1. 《Web开发过滤Javascript、HTML的方法》
  2. log4net 配置应用
  3. RDIFramework.NET V2.9版本 WinFom部分新增与修正的功能
  4. 记在centos中连接无线网络的一次过程
  5. bzoj 1965: [Ahoi2005]SHUFFLE 洗牌
  6. Android 签名(4)验证是否签名
  7. linux的nohup命令的用法
  8. Access获取新插入数据的自增长主键Id
  9. Plotting trees from Random Forest models with ggraph
  10. 小程序的get和post请求头的区别
  11. 修复Java使用POI合并Excel单元格后,边框不显示的问题
  12. Centos下安装破解confluence6.3的操作记录
  13. 什么是Unicode
  14. linux中的软、硬链接
  15. hdu4292 Food 最大流
  16. 求XF+闭包(第十一届河南省省赛真题)
  17. 关于xmlhttp会使用ie的缓存的问题及解决
  18. oracle 触发器 pragma autonomous_transaction
  19. Castle.Windsor IOC/AOP的使用
  20. Dubbo源代码实现三:注册中心Registry

热门文章

  1. Oralce生成前N年的年数据
  2. js中style的属性
  3. 单词缩写(abbr.cpp)每日一题
  4. win7远程连接ubuntu14.04.1桌面
  5. 给图片使用border-radius 图片会变成圆的。
  6. 第14天dbutils与案例
  7. centsOS下安装vsftp的配置
  8. SDCC 2016中国软件开发者大会十三大主题
  9. php 随笔
  10. jQuery获取元素的兄弟节点的几种方法