首页 s3c2440LCD控制器设置及代码详解

s3c2440LCD控制器设置及代码详解

举报
开通vip

s3c2440LCD控制器设置及代码详解s3c2440LCD控制器设置及代码详解要使一块LCD正常的显示文字或图像,不仅需要LCD驱动器,而且还需要相应的LCD操纵器。在通常情形下,生产厂商把LCD驱动器会以COF/COG的形式与LCD玻璃基板制作在一起,而LCD操纵器则是由外部的电路来实现,现在专门多的MCU内部都集成了LCD操纵器,如S3C2410/2440等。通过LCD操纵器就能够产生LCD驱动器所需要的操纵信号来操纵STN/TFT屏了。2.S3C2440内部LCD操纵器结构图:我们按照数据手册来描述一下那个集成在S3C2440内部的LCD操纵器:...

s3c2440LCD控制器设置及代码详解
s3c2440LCD控制器设置及代码详解要使一块LCD正常的显示文字或图像,不仅需要LCD驱动器,而且还需要相应的LCD操纵器。在通常情形下,生产厂商把LCD驱动器会以COF/COG的形式与LCD玻璃基板制作在一起,而LCD操纵器则是由外部的电路来实现,现在专门多的MCU内部都集成了LCD操纵器,如S3C2410/2440等。通过LCD操纵器就能够产生LCD驱动器所需要的操纵信号来操纵STN/TFT屏了。2.S3C2440内部LCD操纵器结构图:我们按照数据手册来描述一下那个集成在S3C2440内部的LCD操纵器:a:LCD操纵器由REGBANK、LCDCDMA、TIMEGEN、VIDPRCS寄存器组成;b:REGBANK由17个可编程的寄存器组和一块256*16的调色板内存组成,它们用来配置LCD操纵器的;c:LCDCDMA是一个专用的DMA,它能自动地把在侦内存中的视频数据传送到LCD驱动器,通过使用那个DMA通道,视频数据在不需要CPU的干预的情形下显示在LCD屏上;d:VIDPRCS接收来自LCDCDMA的数据,将数据转换为合适的数据格式,例如讲4/8位单扫,4位双扫显示模式,然后通过数据端口VD[23:0]传送视频数据到LCD驱动器;e:TIMEGEN由可编程的逻辑组成,他生成LCD驱动器需要的操纵信号,例如VSYNC、HSYNC、VCLK和LEND等等,而这些操纵信号又与REGBANK寄存器组中的LCDCON1/2/3/4/5的配置紧密有关,通过不同的配置,TIMEGEN就能产生这些信号的不同形状,从而支持不同的LCD驱动器(即不同的STN/TFT屏)。3.常见TFT屏工作时序 分析 定性数据统计分析pdf销售业绩分析模板建筑结构震害分析销售进度分析表京东商城竞争战略分析 :LCD提供的外部接口信号:VSYNC/VFRAME/STV:垂直同步信号(TFT)/帧同步信号(STN)/SECTFT信号;HSYNC/VLINE/CPV:水平同步信号(TFT)/行同步脉冲信号(STN)/SECTFT信号;VCLK/LCD_HCLK:象素时钟信号(TFT/STN)/SECTFT信号;VD[23:0]:LCD像素数据输出端口(TFT/STN/SECTFT);VDEN/VM/TP:数据使能信号(TFT)/LCD驱动交流偏置信号(STN)/SECTFT信号;LEND/STH:行终止信号(TFT)/SECTFT信号;LCD_LPCOE:SECTFTOE信号;LCD_LPCREV:SECTFTREV信号;LCD_LPCREVB:SECTFTREVB信号。所有显示器显示图像的原理差不多上从上到下,从左到右的。这是什么意思呢?这么讲吧,一副图像能够看做是一个矩形,由专门多排列整齐的点一行一行组成,这些点称之为像素。那么这幅图在LCD上的显示原理确实是:A:显示指针从矩形左上角的第一行第一个点开始,一个点一个点的在LCD上显示,在上面的时序图上用时刻线 关于同志近三年现实表现材料材料类招标技术评分表图表与交易pdf视力表打印pdf用图表说话 pdf 示就为VCLK,我们称之为像素时钟信号;B:当显示指针一直显示到矩形的右边就终止这一行,那么这一行的动作在上面的时序图中就称之为1Line;C:接下来显示指针又回到矩形的左边从第二行开始显示,注意,显示指针在从第一行的右边回到第二行的左边是需要一定的时刻的,我们称之为行切换;D:如此类推,显示指针就如此一行一行的显示至矩形的右下角才把一副图显示完成。因此,这一行一行的显示在时刻线上看,确实是时序图上的HSYNC;E:然而,LCD的显示并不是对一副图像快速的显示一下,为了连续和稳固的在LCD上显示,就需要切换到另一幅图上(另一幅图能够和上一副图一样或者不一样,目的只是为了将图像连续的显示在LCD上)。那么这一副一副的图像就称之为帧,在时序图上就表示为1Frame,因此从时序图上能够看出1Line只是1Frame中的一行;F:同样的,在帧与帧切换之间也是需要一定的时刻的,我们称之为帧切换,那么LCD整个显示的过程在时刻线上看,就可表示为时序图上的VSYNC。上面时序图上各时钟延时参数的含义如下:(这些参数的值,LCD产生厂商会提供相应的数据手册)VBPD(verticalbackporch):表示在一帧图像开始时,垂直同步信号以后的无效的行数,对应驱动中的upper_margin;VFBD(verticalfrontporch):表示在一帧图像终止后,垂直同步信号往常的无效的行数,对应驱动中的lower_margin;VSPW(verticalsyncpulsewidth):表示垂直同步脉冲的宽度,用行数运算,对应驱动中的vsync_len;HBPD(horizontalbackporch):表示从水平同步信号开始到一行的有效数据开始之间的VCLK的个数,对应驱动中的left_margin;HFPD(horizontalfrontporth):表示一行的有效数据终止到下一个水平同步信号开始之间的VCLK的个数,对应驱动中的right_margin;HSPW(horizontalsyncpulsewidth):表示水平同步信号的宽度,用VCLK运算,对应驱动中的hsync_len;关于以上这些参数的值将分别储存到REGBANK寄存器组中的LCDCON1/2/3/4/5寄存器中:(对寄存器的操作请查看S3c2440数据手册LCD部分)LCDCON1:17-8位CLKVAL-5位扫描模式(关于STN屏:4位单/双扫、8位单扫)-1位色位模式(1BPP、8BPP、16BPP等)LCDCON2:31-24位VBPD-14位LINEVAL-6位VFPD-0位VSPWLCDCON3:25-19位HBPD-8位HOZVAL-0位HFPDLCDCON4:7-0位HSPWLCDCON5:4.帧缓冲(FrameBuffer):帧缓冲是Linux为显示设备提供的一个接口,它把一些显示设备描述成一个缓冲区,承诺应用程序通过FrameBuffer定义好的接口访咨询这些图形设备,从而不用去关怀具体的硬件细节。关于帧缓冲设备而言,只要在显示缓冲区与显示点对应的区域写入颜色值,对应的颜色就会自动的在屏幕上显示。下面来看一下在不同色位模式下缓冲区与显示点的对应关系:下面看看2440test里面的lcd.c文件staticvoidPutPixel(U32x,U32y,U16c){if(x=0)MMODE[7]=0PNRMODE[6:5]=11TFTLCDpanelBPPMODE[4:1]=110016bppforTFTENVID[0]=0DisablerLCDCON2=(LCD_UPPER_MARGIN<<24)|((LCD_HEIGHT-1)<<14)|(LCD_LOWER_MARGIN<<6)|(LCD_VSYNC_LEN<<0);LCDCON20x4d000004VBPD=1VBPD(verticalbackporch):表示在一帧图像开始时,垂直同步信号以后的无效的行数,对应驱动中的upper_marginLINVAL=240–1LINVAL:LCD屏的垂直大小VFPD=5VFPD(verticalfrontporch):表示在一帧图像终止后,垂直同步信号往常的无效的行数,对应驱动中的lower_marginVSPW=1VSPW(verticalsyncpulsewidth):表示垂直同步脉冲的宽度,用行数运算,对应驱动中的vsync_lenrLCDCON3=(LCD_RIGHT_MARGIN<<19)|((LCD_WIDTH-1)<<8)|(LCD_LEFT_MARGIN<<0);LCDCON30x4d000008HBPD=36HBPD(horizontalbackporch):表示从水平同步信号开始到一行的有效数据开始之间的VCLK的个数,对应驱动中的left_marginHOZVAL=320–1HOZVAL:LCD屏的水平大小HFPD=19HFPD(horizontalfrontporth):表示一行的有效数据终止到下一个水平同步信号开始之间的VCLK的个数,对应驱动中的right_marginrLCDCON4=(13<<8)|(LCD_HSYNC_LEN<<0);LCDCON40x4d00000cMVAL=13HSPW=5HSPW(horizontalsyncpulsewidth):表示水平同步信号的宽度,用VCLK运算,对应驱动中的hsync_lendefineLCD_CON5((1<<11)|(1<<9)|(1<<8)|(1<<3)|(1<<0))rLCDCON5=LCD_CON5;LCDCON50x4d000010HWSWP=1SwapEnablePWREN=1EnablePWRENsignalINVVFRAME=1VFRAME/VSYNCpulsepolarityInverted选择负极性脉冲INVVLINE=1VLINE/HSYNCpulsepolarityInverted选择负极性脉冲FRM565=15:6:5FormatrLCDINTMSK|=3;INT_FrSyn=1LCDframesynchronizedinterruptMaskedINT_FiCnt=1LCDFIFOinterruptMaskedrTCONSEL&=(~7);rTCONSEL&=~((1<<4)|1);MODE_SEL=0RES_SEL=0LPC_EN=0Syncmode320x240LPC3600DisablerTPAL=0x0;TemporarypaletteregisterenablebitDisablevolatilestaticunsignedshortLCD_BUFFER[SCR_YSIZE][SCR_XSIZE];#defineLCD_ADDR((U32)LCD_BUFFER)#defineM5D(n)((n)&0x1fffff)rLCDSADDR1=((LCD_ADDR>>22)<<21)|((M5D(LCD_ADDR>>1))<<0);rLCDSADDR2=M5D((LCD_ADDR+LCD_WIDTH*LCD_HEIGHT*2)>>1);rLCDSADDR3=LCD_WIDTH;LCDSADDR10x4d000014帧缓冲起始寄存器1LCDBANK[29:21]=(U32)LCD_BUFFER>>22ThesebitsindicateA[30:22]ofthebanklocationforthevideobufferinthesystemmemory.LCDBANKvaluecannotbechangedevenwhenmovingtheviewport.LCDframebuffershouldbewithinaligned4MBregion,whichensuresthatLCDBANKvaluewillnotbechangedwhenmovingtheviewport.So,careshouldbetakentousethemalloc()Function系统内存地址A[30:22]处的Bank位置为图像缓冲。LCDBANK的值在视图移动的值在视图移动时不能改变,LCD帧缓冲应该在4MB区域对齐,保证LCDBANK的值在移动视图时可不能改变。LCDBASEU[20:0]=((U32)LCD_BUFFER>>1)&0x1fffffFordual-scanLCD:ThesebitsindicateA[21:1]ofthestartaddressoftheupperaddresscounter,whichisfortheupperframememoryofdualscanLCDortheframememoryofsinglescanLCD.Forsingle-scanLCD:ThesebitsindicateA[21:1]ofthestartaddressoftheLCDframebuffer.双扫描:表明高地址计数器的起始地址A[21:1],用于LCD双扫描的上部帧内存或者单扫描的帧内存单扫描:表明LCD帧缓冲的起始地址A[21:1]LCDSADDR20x4d000018帧缓冲起始寄存器2LCDBASEL[20:0]=((LCD_ADDR+LCD_WIDTH*LCD_HEIGHT*2)>>1)&0x1fffff=(LCD_ADDR>>1+LCD_WIDTH*LCD_HEIGHT)&0x1fffffFordual-scanLCD:ThesebitsindicateA[21:1]ofthestartaddressoftheloweraddresscounter,whichisusedforthelowerframememoryofdualscanLCD.ForsinglescanLCD:ThesebitsindicateA[21:1]oftheendaddressoftheLCDframebuffer.LCDBASEL=((theframeendaddress)>>1)+1=LCDBASEU+(PAGEWIDTH+OFFSIZE)x(LINEVAL+1)双扫描:表明低地址计数器的起始地址A[21:1],用于LCD双扫描的下部帧内存或者单扫描的帧内存单扫描:表明LCD帧缓冲的终止地址A[21:1]LCDSADDR30x4d00001c帧缓冲起始寄存器3OFFSIZE=0PAGEWIDTH=320虚拟屏页宽(半字数量)定义了帧中的视图域宽度程序分析至此,大致差不多清晰是如何通过LCD_BUFFER[(y)][(x)]=c来实现在LCD上显示单个像素了。确实是在设置好各个LCD寄存器之后,通过将LCD_BUFFER地址与LCDBANK以及LCDBASEU、LCDBASEL对应之后,通过改变LCD_BUFFER里不同单元储备的值(即像素的颜色),即可在LCD相应位置上做出显示。那么在应用不同LCD的时候,只需对LCDCONx以及LCDSADDRx做出相应的配置,在创建一个数组,做出上述的地址映射即可。关于VCLK运算,由于配置的是TFT,可用到公式VCLK=HCLK/[(CLKVAL+1)*2](CLKVAL>=0)设置的FLK为400MHz,HCLK为100MHz,CLKVAL=4,因此VLCK=10MHz
本文档为【s3c2440LCD控制器设置及代码详解】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
个人认证用户
is_090281
常年从事设计、施工及相关教育工作,一线工作经验丰富。
格式:doc
大小:315KB
软件:Word
页数:0
分类:
上传时间:2021-09-19
浏览量:0