LCD驱动分析(一):时序的分析

25 篇文章 0 订阅

原文地址:LCD驱动分析(一):时序的分析 作者:huabinbin00

第一次调试lcd驱动的话是不是对下面的结构有点陌生,不知道那些值是如何得来的,当然我就属于其中的一个

点击(此处)折叠或打开

  1. static struct s3cfb_lcd lte480wv = {
  2.     .width    = 1024,//800,
  3.     .height    = 600,//480,
  4.     .bpp    = 24,//24,//32,
  5.     .freq    = 45,//45,//60

  6.     .timing = {  //这里主要会影响图像在LCD上显示的位置,偏移啥的
  7.         .h_fp    = 160,//210,//8,
  8.         .h_bp    = 160,//46,//13,
  9.         .h_sw    = 16,    // 3
  10.         .v_fp    = 12,//12,//15,//22, liao
  11.         .v_fpe    = 0,/*1,//0,*/
  12.         .v_bp    = 23,//22, liao
  13.         .v_bpe    = 0,/*1,//0,*/
  14.         .v_sw    = 2,//
  15.     },

  16.     .polarity = {  //这几个参数挺重要的,判断你极性是否要反转(0--normal,1---inverted)
  17.         .rise_vclk    = 0,
  18.         .inv_hsync    = 1,
  19.         .inv_vsync    = 1,
  20.         .inv_vden    = 0,
  21.     },
  22. };
好吧,言归正传,首先有必要理解几个定义:

一般TFT型LCD时序图如下所示

图1

我们先来理解下面引脚有寄存器中相关参数的意义吧

 

外部引脚信号:

 

VSYNC: 帧同步信号,表示扫描1帧的开始,一帧也就是LCD显示的一个画面。

HSYNC: 行同步信号,表示扫描1行的开始。

VDEN数据使能信号。

VD[23:0] : LCD像素数据输出端口。

VCLK像素时钟信号。

 

寄存器参数:

 

VSPW帧同步信号的脉宽,单位为1行(Line)的时间。

VFPD: 帧同步信号的前肩,单位为1行(Line)的时间。

VBPD: 帧同步信号的后肩,单位为1行(Line)的时间。

LINEVAL 帧显示尺寸-1,即屏行宽-1,对于800*480分配率的LCD屏,那么LINEVAL=480-1=479,请记住,是屏行宽,也就是LCD屏显示一帧数据所需要的行的数目。

 

HBPD行同步信号的后肩,单位为1VCLK的时间。

HFPD行同步信号的前肩,单位为1VCLK的时间。

HSPW行同步信号的脉宽,单位为1VCLK的时间。

HOZVAL行显示尺寸-1,即屏列宽-1,对于800*480分配率的LCD屏,那么HOZVAL=800-1=799,请记住,是屏列宽,也就是LCD屏显示一行数据所需要的像素(pixel)的数目。

 

由图1可知:

扫描一帧所需的时间:

=((VSPW+1)+(VBPD+1)+( LINEVAL+1)+(VFPD+1))个行时间。

 

扫描一行所所需的时间:

= ((HSPW+1)+(HSPD+1)+(HFPD+1)+ (HOZVAL+1))个VCLK时间。

 

而一个VCLK时间由LCD寄存器VIDCON0内的CLKVAL决定:

=HCLK/(CLKVAL+1)  ------>这个公式是S3C2443的LCD控制器的,其他CPU的不一定一样

 

因此扫描一帧所需的时间:

T=[(VSPW+1)+(VBPD+1)+(LINEVAL+1)+(VFPD+1)]*[(HSPW+1)+(HSPD+1)+(HFPD+1)+ (HOZVAL+1)]* HCLK/ (CLKVAL+1)

 

即帧频率为:1/T

 

1.首先来判断 HSYNC,VSYNC,VCLK, VDEN信号是否需要反转

 

这个其实还挺好判断的,主要就是通过你主控的介绍lcd的时序图,在结合你屏厂的spec文档的时序图就可以完全判断出来了

先看LCD控制器默认情况下送出来的TFT LCD屏的时序图:

再来看屏厂的提供的时序图

看上面的介绍应该知道需要反转HSYNC,VSYNC,VCLK信号输出,这样才能输出满足lcd所需要的时序图

 

再来看看timing这个结构体如何配置,如果提供下面这个参数就很好确定相关的数值了

 

h_fp  = (horizontal total time)- 1024

f_sw  =  (horizontal total time)- 1024 - h_fp    

 

当然,如果没有上面的介绍,其实也是可以通过时序图来得到的,不过限于篇幅的原因在这里就介绍了,有需要的话可以联系我huabinbin00@gmail.com

  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值