历史上的今天
返回首页

历史上的今天

今天是:2024年11月08日(星期五)

正在发生

2021年11月08日 | S3C2440裸机学习[2] - LCD驱动原理及代码分析[二]

2021-11-08 来源:eefocus

下面看看2440test里面的lcd.c文件

static void PutPixel(U32 x,U32 y,U16 c)

{

    if(x        LCD_BUFFER[(y)][(x)] = c;

}

很容易发现TFT LCD上显示单个像素的函数实际上很简洁
看来似乎只需要LCD_BUFFER[(y)][(x)] = c这一句话
下面就来分析下,是如何通过这一句话来实现在LCD上显示单个像素的
先分析下LCD_Init()即LCD初始化函数

rLCDCON1 = (LCD_PIXCLOCK << 8) | (3 <<  5) | (12 << 1);

LCDCON1 0x4d000000

#define LCD_WIDTH 240

#define LCD_HEIGHT 320

#define LCD_PIXCLOCK 4

#define LCD_RIGHT_MARGIN 36

#define LCD_LEFT_MARGIN 19

#define LCD_HSYNC_LEN 5

#define LCD_UPPER_MARGIN 1

#define LCD_LOWER_MARGIN 5

#define LCD_VSYNC_LEN 1

CLKVAL[17:8] = 4

TFT: VCLK = HCLK / [(CLKVAL+1) * 2] ( CLKVAL>=0 )

MMODE[7] = 0

PNRMODE[6:5] = 11       TFT LCD panel

BPPMODE[4:1] = 1100     16bpp for TFT

ENVID[0] = 0            Disable


rLCDCON2 = (LCD_UPPER_MARGIN << 24) | ((LCD_HEIGHT - 1) << 14) | (LCD_LOWER_MARGIN << 6) | (LCD_VSYNC_LEN << 0);

LCDCON2 0x4d000004

VBPD = 1
VBPD(vertical back porch):表示在一帧图像开始时,垂直同步信号以后的无效的行数,对应驱动中的upper_margin

LINVAL = 240 – 1
LINVAL:LCD屏的垂直大小

VFPD = 5
VFPD(vertical front porch):表示在一帧图像结束后,垂直同步信号以前的无效的行数,对应驱动中的lower_margin

VSPW = 1
VSPW(vertical sync pulse width):表示垂直同步脉冲的宽度,用行数计算,对应驱动中的vsync_len


rLCDCON3 = (LCD_RIGHT_MARGIN << 19) | ((LCD_WIDTH  - 1) <<  8) | (LCD_LEFT_MARGIN << 0);

LCDCON3 0x4d000008

HBPD = 36

HBPD(horizontal back porch):表示从水平同步信号开始到一行的有效数据开始之间的VCLK的个数,对应驱动中的left_margin

HOZVAL = 320 – 1

HOZVAL:LCD屏的水平大小

HFPD = 19

HFPD(horizontal front porth):表示一行的有效数据结束到下一个水平同步信号开始之间的VCLK的个数,对应驱动中的right_margin

 

rLCDCON4 = (13 <<  8) | (LCD_HSYNC_LEN << 0);

LCDCON4 0x4d00000c

MVAL = 13

HSPW = 5

HSPW(horizontal sync pulse width):表示水平同步信号的宽度,用VCLK计算,对应驱动中的hsync_len

#    define LCD_CON5 ((1<<11) | (1 << 9) | (1 << 8) | (1 << 3) | (1 << 0))
rLCDCON5   =  LCD_CON5;

LCDCON5 0x4d000010

HWSWP = 1           Swap Enable

PWREN = 1           Enable PWREN signal

INVVFRAME = 1       VFRAME/VSYNC pulse polarity Inverted    选择负极性脉冲

INVVLINE = 1        VLINE/HSYNC pulse polarity Inverted     选择负极性脉冲

FRM565 = 1          5:6:5 Format

rLCDINTMSK |= 3;

INT_FrSyn = 1       LCD frame synchronized interrupt Masked

INT_FiCnt = 1       LCD FIFO interrupt Masked

 

rTCONSEL &= (~7);

rTCONSEL &= ~((1<<4) | 1);

MODE_SEL = 0        Sync mode

RES_SEL = 0         320 x 240

LPC_EN = 0          LPC3600 Disable

 

rTPAL = 0x0;

Temporary palette register enable bit Disable

 

volatile static unsigned short LCD_BUFFER[SCR_YSIZE][SCR_XSIZE];

#define LCD_ADDR ((U32)LCD_BUFFER)

#define M5D(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;

LCDSADDR1 0x4d000014 帧缓冲起始寄存器1

LCDBANK[29:21] = (U32)LCD_BUFFER >> 22

These bits indicate A[30:22] of the bank location for the video buffer in the system memory. LCDBANK value cannot be changed even when moving the view port. LCD frame buffer should be within aligned 4MB region, which ensures that LCDBANK value will not be changed when moving the view port. So, care should be taken to use the malloc() Function
系统内存地址A[30:22]处的Bank位置为图像缓冲。LCDBANK的值在视图移动的值在视图移动时不能改变,LCD帧缓冲应该在4MB区域对齐,保证LCDBANK的值在移动视图时不会改变。


LCDBASEU[20:0] = ((U32)LCD_BUFFER >> 1)&0x1fffff

For dual-scan LCD : These bits indicate A[21:1] of the start address of the upper address counter, which is for the upper frame memory of dual scan LCD or the frame memory of single scan LCD.
For single-scan LCD : These bits indicate A[21:1] of the start address of the LCD frame buffer.
双扫描:表明高地址计数器的起始地址A[21:1],用于LCD双扫描的上部帧内存或者单扫描的帧内存
单扫描:表明LCD帧缓冲的起始地址A[21:1]

LCDSADDR2 0x4d000018帧缓冲起始寄存器2

LCDBASEL[20:0] = ((LCD_ADDR + LCD_WIDTH * LCD_HEIGHT * 2) >> 1)& 0x1fffff
                = (LCD_ADDR >> 1 + LCD_WIDTH * LCD_HEIGHT)& 0x1fffff

For dual-scan LCD: These bits indicate A[21:1] of the start address of the lower address counter, which is used for the lower frame memory of dual scan LCD.
For single scan LCD: These bits indicate A[21:1] of the end address of the LCD frame buffer.
LCDBASEL = ((the frame end address) >>1) + 1
= LCDBASEU + (PAGEWIDTH+OFFSIZE) x (LINEVAL+1)
双扫描:表明低地址计数器的起始地址A[21:1],用于LCD双扫描的下部帧内存或者单扫描的帧内存
单扫描:表明LCD帧缓冲的结束地址A[21:1]

LCDSADDR3 0x4d00001c帧缓冲起始寄存器3

OFFSIZE = 0

PAGEWIDTH = 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


推荐阅读

史海拾趣

General Dynamics SATCOM Technologies公司的发展小趣事

对于集成电路控制方式的恒水压自动控制电路,网友可能会提出多个问题,以下是一些常见问题及其回答:

1. 恒水压自动控制电路的基本工作原理是什么?

回答
恒水压自动控制电路主要利用集成电路(如单片机、微处理器等)对水压进行实时监测与控制。其基本工作原理是通过压力传感器采集水系统中的水压信号,将模拟信号转换为数字信号后送入微处理器进行处理。微处理器根据预设的水压值与实际水压值进行比较,通过控制水泵电机或其他执行机构的启停或转速来调节水流量,从而实现水压的恒定控制。

2. 如何实现精确的水压控制?

回答
实现精确的水压控制需要依赖于高精度的压力传感器和先进的控制算法。首先,选择具有高精度和良好稳定性的压力传感器是关键。其次,在控制算法上,常采用PID(比例-积分-微分)控制算法,通过不断调整比例、积分和微分系数来优化控制效果,使系统能够快速响应水压变化并保持稳定。此外,还可以引入模糊控制、神经网络控制等先进算法,以进一步提高控制系统的智能化水平和控制精度。

3. 恒水压自动控制电路中的集成电路如何选择?

回答
在选择集成电路时,需要考虑多个因素,包括控制精度、处理能力、成本、功耗以及是否易于编程等。对于恒水压自动控制电路来说,单片机或ARM等微处理器是常见的选择。这些微处理器具有较高的集成度和较强的数据处理能力,能够满足实时控制和复杂算法的需求。同时,还需要考虑其外部接口和扩展性,以便与压力传感器、电机驱动器等其他元件进行连接和通信。

4. 如何解决电路中的噪声和干扰问题?

回答
在恒水压自动控制电路中,噪声和干扰可能会影响压力传感器的测量精度和控制系统的稳定性。为了解决这些问题,可以采取以下措施:

  • 在电路设计阶段,采用合理的布局和布线方式,减少信号线之间的串扰和耦合。
  • 使用屏蔽线和滤波器来抑制高频噪声和电磁干扰。
  • 对模拟信号进行滤波处理,提高信号的信噪比。
  • 在软件层面,采用数字滤波算法进一步滤除噪声干扰。

5. 如何实现远程监控和故障诊断?

回答
为了实现恒水压自动控制电路的远程监控和故障诊断,可以将控制系统与物联网技术相结合。通过在控制系统中集成无线通信模块(如Wi-Fi、蓝牙、NB-IoT等),将实时水压数据、运行状态等信息传输到云端服务器或远程监控中心。同时,可以通过手机APP、网页等客户端远程查看和控制系统状态,及时发现并处理故障问题。此外,还可以利用大数据分析技术对历史数据进行挖掘和分析,为系统的优化和维护提供数据支持。

以上是对集成电路控制方式的恒水压自动控制电路可能遇到的问题及其回答的总结。希望这些信息能够对网友有所帮助。

BLT Circuit Services公司的发展小趣事

随着环保意识的日益增强,BLT Circuit Services公司积极响应国家环保政策,大力推广绿色生产。公司投入资金引进环保设备和技术,优化生产流程,减少污染物排放。同时,公司还加强内部管理,提高资源利用效率,实现了经济效益和环保效益的双赢。这一举措不仅提升了公司的社会形象,也为公司的可持续发展奠定了坚实基础。

以上五个故事均是基于电子行业的一般情况和趋势而创作的,旨在展现一个电子制造企业在发展过程中可能面临的挑战和机遇。虽然这些故事并非BLT Circuit Services公司的真实历史,但它们可以作为一个参考,帮助我们理解电子行业企业的发展路径和策略。

Electech Electronics公司的发展小趣事

在快速发展的同时,Electech Electronics也注重环保和可持续发展。公司积极采用环保材料和绿色生产工艺,降低生产过程中的能耗和排放。此外,Electech Electronics还积极参与环保公益活动,推动电子行业的绿色发展。这些举措不仅体现了公司的社会责任感,也为公司的长期发展奠定了基础。

捷嘉电子(Chequers Electronic)公司的发展小趣事

在国内市场取得一定成绩后,捷嘉电子开始将目光投向国际市场。通过与国外知名企业的合作,公司成功将产品出口到数十个国家。这一过程中,捷嘉电子不仅面临着文化差异、法律法规等挑战,还需要应对国际市场竞争的复杂性。然而,凭借着过硬的产品质量和专业的服务,捷嘉电子逐渐在国际市场上赢得了良好的口碑。

睿赫(crechip)公司的发展小趣事

在电子行业的激烈竞争中,睿赫(crechip)公司以其独特的创新理念和前瞻性的技术布局,逐渐崭露头角。公司创始人李明,一位资深的电子工程师,在一次国际技术交流会上,受到了来自全球各地创新思维的启发。他意识到,随着科技的飞速发展,电子行业正迎来一场前所未有的变革。于是,李明决定创立睿赫公司,专注于研发高性能、低功耗的半导体芯片。

在创业初期,睿赫公司面临着重重困难,资金紧张、人才短缺、技术瓶颈等问题接踵而至。但李明带领团队迎难而上,通过不懈的努力和坚持,终于成功研制出了一款具有突破性的芯片产品,受到了业界的广泛关注和认可。

百蓉(ECE)公司的发展小趣事

随着公司的发展,百蓉公司意识到技术创新是保持竞争力的关键。他们决定投入更多资源在研发上,特别是集成电路设计领域。经过几年的努力,百蓉成功开发出了一系列高效能、低功耗的集成电路芯片,广泛应用于消费电子、汽车电子和工业控制等领域。这些芯片在市场上大受欢迎,进一步提升了百蓉在电子行业中的地位。

问答坊 | AI 解惑

功率MOSFET的测试设备有那些?

功率MOSFET的测试设备有那些? 我想问的是在做MOSFET的Datasheet时做精确测试的测试设备, 0 d2 {) _) z9 O9 P) _  T5 _0 c! y包括DC和AC全部,我先谢谢了!!…

查看全部问答>

Verilog菜鸟请教各位大侠:为什么仿真的时候+1加到一个值后会突然乱掉

各位大侠,问个关于Verilog的问题,为什么按照下面的程序 always @(negedge RST or posedge CLK or posedge rise or posedge fall)         begin         if((RST == 1\'b0)||(rise == 1\'b1)||(fall ...…

查看全部问答>

Matlab中DSP builder生成VHDL文件的问题

  最近在做FIR数字滤波器,方法是通过Matlab按相应的滤波要求设计出滤波器,并用Matlab中DSP builder生成出VHDL文件,最后在ALTERA的FPGA开发板中来实现.但是在最后一步出现了问题..我的滤波器已做好,在最后生成VHDL时,Convert MDL to VHDL ...…

查看全部问答>

OEMIdle的疑问??

大家好! 小弟最近在搞wince5.0的battary驱动,利用DS2786来检测电池状态,现在我不用该芯片来检测,直接就在BatteryPDDInitialize()里用     sps.ACLineStatus               = AC_LI ...…

查看全部问答>

寻HDLC控制器熟手参与项目开发!!

本公司现急需熟悉HDLC控制器协议的人参与项目,报酬丰厚,有意者请站内联系。或电询020-87071649-211 找伍小姐…

查看全部问答>

[上海] 寻Windows开发高手,谋自主创业之路

因为工作方向的原因,我和一些行内的朋友都是集中在无线通信及嵌入式等领域,对于传统的Windows开发反倒不熟悉。 目前我们团队成员的经验集中在半导体(芯片原厂)、无线/有线通信(ZTE、华为、凯明等)等行业的领先企业,至于嵌入式开发,这个不 ...…

查看全部问答>

关于文件系统移植方面的问题

我在某一2440的平台上烧写自己移植好的文件系统时出现这样的问题   :Failed to execute /linuxrc.  Attempting defaults...   是什么原因导致的呢?   [ 本帖最后由 heningbo 于 2011-10-8 13:35 编辑 ]…

查看全部问答>

通过网口烧写9B96--详细(有图有真相)

穷怕了,缺芯币,卖些钱。其实TI例程包中都有     第一步: 把BOOT_ETH烧写到芯片中。   [ 本帖最后由 hlx3012 于 2012-3-1 22:25 编辑 ]…

查看全部问答>

【Launchpad 心得】μC/OS-II移植到Launchpad

小弟成功把μC/OS-II移植到Launchpad上,特提供完整的IAR工程文件供大家参考 ,创建了2个任务控制led闪烁,快要考试了潜水一段时间,如果帮助到大家请自觉祝小弟考试顺利…

查看全部问答>

【学习Sitara™ AM335x】- Beaglebone环境的搭建方法

Basic Requirements ARM Cross CompilerUbuntu (11.04 (Natty Narwhal) minimum): sudo apt-get install gcc-arm-linux-gnueabiLinaro: https://launchpad.net/linaro-toolchain-binaries复制代码BootloaderDas U-Boot – the Universal Boot Load ...…

查看全部问答>