LCD编程_LCD控制器

CLKVAL :
VCLK = HCLK / [(CLKVAL+1) x 2]--------> CLKVAL = HCLK/VCLK/2-1
在这个地方HCLK=100M,那么VLCK等于多少呢?需要打开lcd的芯片手册

从中可以看出,5<= vclk<=12,正常情况是取9.
当VCLK =9 时,CLKVAL = 4.5 。取一个整数为5。当CLKVAL取为5时,再判断一下,VCLK是否在5到12之间。
PNRMODE:取11 = TFT LCD panel
BPPMODE :只支持8bpp/16bpp/24bpp
ENVID:LCD video output and the logic enable/disable. 用来使能LCD控制器本身,是否输出信号。在这个地方暂不设置,后面初始化函数中再进行设置。
将上一篇博客中led.h文件中的time_sequence增加一个数据成员vclk。

因此就有了下面这样的代码:

2、垂直方向和水平方向上一些参数的设置
垂直:

水平:



从上面的图可以看出:
垂直:
VBPD+1 = tvb -------->VBPD = tvb - 1
VFPD+1 = tvf --------->VFPD = tvf - 1
VSPW+1 = tvp --------->VSPW = tvp - 1
LINEVAL+1 = line ----->LINEVAL = line -1
水平:
HBPD+1 = thb
HBPD+1 = thb -------->HBPD= thb - 1
HFPD+1 = thf --------->HFPD = thf - 1
HOZVAL +1 = line ----->HOZVAL = 列 -1
注意在这个地方水平方向的同步脉冲宽度并没有设置,别急它是在另一个寄存器中设置的。

HSPW+1 = thp ------>HSPW = thp - 1
因此有了下面的代码:

3、


BPP24BL : This bit determines the order of 24 bpp video memory 。这一位只对24bpp中数据的存放格式有影响,对16bpp/8bpp都是没有影响的。
如果采用的是24bpp,在这里我们采用第一种方式,即将BPP24BL设置为0

那如果是16bpp,应该设置什么东西,使其指定数据的存放格式呢?

对于16bpp来说,是通过HWSWP来进行指定数据存放格式的,在此将HWSWP取为1
对于8bpp来说,又是通过什么来进行指定呢?

对于8bpp来说,是通过BSWP来进行指定数据存放格式的,在此将BSWP取为1

在这个地方,我们用pixelplace来指定数据存放的格式。
FRM565 : This bit selects the format of 16 bpp output video data. 用来设置16bpp数据输出的格式的,采用565格式。
INVVCLK:This bit controls the polarity of the VCLK active edge 。这一位控制着VCLK是上升沿有效还是下降沿有效。
INVVLINE :水平同步信号的极性
INVVFRAME:垂直同步信号的极性
INVVD :数据的极性
INVVDEN :数据使能信号的极性
INVPWREN :电源信号的极性
因此有了下面的程序:

4、framebuffer地址




至此,根据传入的LCD参数设置LCD控制器就已经完成了。
5、
接下来完成s3c2440_lcd_controller_enalbe,首先来看一下,lcd的原理图。

LED是lCD的背光驱动的电源。LED的背光驱动电路:

当KEYBOARD为高电平时,它可以给背光驱动电路提供电源,此时LCD才会亮起来。
那KEYBOARD又接在哪里呢?搜索一下:

可以看到KEYBOARD接的是GPB0,用于控制背光灯。需要设置为输出,需要设置GPBCON寄存器


使GPB0输出为1,需要设置GPBDAT寄存器

LCDCON1中的bit0,用来使能LCD控制器本身,是否输出信号。需要设置为1

LCDCON5中的PWREN
PWREN:LCD_PWREN output signal enable/disable.

6、
再看一下lcd的原理图,对于lcd用到的那些引脚也需要进行设置。
比如说VD19这样的引脚,搜索VD19

从这个图可以看出,对于VD[23:0],用到了两组寄存器 GPD和GPC。

对于VM,需要设置GPC4;
对于VLINE,需要设置GPC2
对于LCD_LPCREVB,需要设置GPC7
对于LCD_LPCREV,需要设置GPC6
对于VFRAME,需要设置GPC3
对于VCLK,需要设置GPC1
对于LEND,需要设置GPC0
打开GPDCON和GPCCON寄存器,看一下:

可以看到相邻的两位取10即可。

可以看到相邻的两位取10即可。
对于LCD_PWREN,需要设置GPG4。

因此就有了下面的代码:

现将整个代码贴出来:
#define HCLK 100 void jz2440_lcd_pin_init(void)
{
/* 初始化引脚 : 背光引脚 */
GPBCON &= ~0x3;
GPBCON |= 0x01; /* LCD专用引脚 */
GPCCON = 0xaaaaaaaa;
GPDCON = 0xaaaaaaaa; /* PWREN */
GPGCON |= (<<);
} /* 根据传入的LCD参数设置LCD控制器 */
void s3c2440_lcd_controller_init(p_lcd_params plcdparams)
{
int pixelplace;
unsigned int addr; jz2440_lcd_pin_init(); /* [17:8]: clkval, vclk = HCLK / [(CLKVAL+1) x 2]
* 9 = 100M /[(CLKVAL+1) x 2], clkval = 4.5 = 5
* CLKVAL = 100/vclk/2-1
* [6:5]: 0b11, tft lcd
* [4:1]: bpp mode
* [0] : LCD video output and the logic enable/disable
*/
int clkval = (double)HCLK/plcdparams->time_seq.vclk/-+0.5;
int bppmode = plcdparams->bpp == ? 0xb :\
plcdparams->bpp == ? 0xc :\
0xd; /* 0xd: 24bpp */
LCDCON1 = (clkval<<) | (<<) | (bppmode<<) ; /* [31:24] : VBPD = tvb - 1
* [23:14] : LINEVAL = line - 1
* [13:6] : VFPD = tvf - 1
* [5:0] : VSPW = tvp - 1
*/
LCDCON2 = ((plcdparams->time_seq.tvb - )<<) | \
((plcdparams->yres - )<<) | \
((plcdparams->time_seq.tvf - )<<) | \
((plcdparams->time_seq.tvp - )<<); /* [25:19] : HBPD = thb - 1
* [18:8] : HOZVAL = 列 - 1
* [7:0] : HFPD = thf - 1
*/
LCDCON3 = ((plcdparams->time_seq.thb - )<<) | \
((plcdparams->xres - )<<) | \
((plcdparams->time_seq.thf - )<<); /*
* [7:0] : HSPW = thp - 1
*/
LCDCON4 = ((plcdparams->time_seq.thp - )<<); /* 用来设置引脚极性, 设置16bpp, 设置内存中象素存放的格式
* [12] : BPP24BL
* [11] : FRM565, 1-565
* [10] : INVVCLK, 0 = The video data is fetched at VCLK falling edge
* [9] : HSYNC是否反转
* [8] : VSYNC是否反转
* [7] : INVVD, rgb是否反转
* [6] : INVVDEN
* [5] : INVPWREN
* [4] : INVLEND
* [3] : PWREN, LCD_PWREN output signal enable/disable
* [2] : ENLEND
* [1] : BSWP
* [0] : HWSWP
*/ pixelplace = plcdparams->bpp == ? (<<) : |\
plcdparams->bpp == ? (<<) : |\
(<<); /* 8bpp */
LCDCON5 = (plcdparams->pins_pol.vclk<<) |\
(plcdparams->pins_pol.rgb<<) |\
(plcdparams->pins_pol.hsync<<) |\
(plcdparams->pins_pol.vsync<<) |\
(plcdparams->pins_pol.de<<) |\
(plcdparams->pins_pol.pwren<<) |\
(<<) | pixelplace; /* framebuffer地址 */
/*
* [29:21] : LCDBANK, A[30:22] of fb
* [20:0] : LCDBASEU, A[21:1] of fb
*/
addr = plcdparams->fb_base & ~(<<);
LCDSADDR1 = (addr >> ); /*
* [20:0] : LCDBASEL, A[21:1] of end addr
*/
addr = plcdparams->fb_base + plcdparams->xres*plcdparams->yres*plcdparams->bpp/;
addr >>=;
addr &= 0x1fffff;
LCDSADDR2 = addr;//
} void s3c2440_lcd_controller_enalbe(void)
{
/* 背光引脚 : GPB0 */
GPBDAT |= (<<); /* pwren : 给LCD提供AVDD */
LCDCON5 |= (<<); /* LCDCON1'BIT 0 : 设置LCD控制器是否输出信号 */
LCDCON1 |= (<<);
} void s3c2440_lcd_controller_disable(void)
{
/* 背光引脚 : GPB0 */
GPBDAT &= ~(<<); /* pwren : 给LCD提供AVDD */
LCDCON5 &= ~(<<); /* LCDCON1'BIT 0 : 设置LCD控制器是否输出信号 */
LCDCON1 &= ~(<<);
} struct lcd_controller s3c2440_lcd_controller = {
.init = s3c2440_lcd_controller_init,
.enalbe = s3c2440_lcd_controller_enalbe,
.disable = s3c2440_lcd_controller_disable,
};
LCD编程_LCD控制器的更多相关文章
- LCD编程_使用调色板
在前面的博客中,使用的像素格式都是16bpp,24bpp(24bpp实际实际上就是32bpp)?如果想使用8bpp时,就需要使用调色板. 在以前的博客中,曾经说过,在framebuffer中如果每个像 ...
- LCD编程_简单测试
首先,需要编写一个led_test.c的文件,依据代码框架,在led_test.c中我们能够看到的只是led.c.我们是看不到led_controller.c的.比如说,在led_test.c中,需要 ...
- LCD编程框架组织
看下面的代码,你会发现韦老师这种组织与内核框架的组织是一脉相承的. led.c #define LCD_NUM 10 static p_lcd_params p_array_lcd[LCD_NUM]; ...
- LCD编程_显示文字
在上篇博客中,实现了画点操作,然后在画点的基础上实现了画线.画圆的操作.实际上显示文字也是在画点的基础上实现的. 文字是由点组成的,那么这些点阵是在哪里获得的呢? 随便打开一个内核文件,搜索font, ...
- LCD编程_画点线圆
上篇博客中进行了lcd的简单测试,这篇博客将进行更加复杂的测试——画点.画线.画圆.画线和画圆是在画点的基础上实现的,因此本篇博客重点实现画点操作. 先抛出这样的一个问题,已知: (x,y)的坐标: ...
- LCD控制器与驱动器
这回我再讲讲从 MCU 到 LCD 之间是怎样一个控制流程,即我们的位图数据是怎样显示到 LCD 上的.前面我们了解到 LCD 显示是用动态扫描的方式来实现的,每次显示一整行,在一帧里每行一次扫描一遍 ...
- LCD framebuffer驱动设计文档
内容提要:1. android display相关的名词2. 调试LCD驱动需要注意的步骤3. 关于帧缓冲区及I/O内存---------------------------------------- ...
- LCD硬件原理
想象一下,屏幕的后面有一个电子枪,电子枪位于某个像素的背后,然后向这个像素发射红绿蓝三原色,从而就可以组成任意一种颜色.简单的说,电子枪在像素的背后一边移动,一边向像素发射红绿蓝. 如果要编写出LCD ...
- FL2440驱动添加(3)LCD驱动添加学习笔记
FL2440 LCD内置控制器,320*240 TFT型LCD. 自我理解总结的两种添加驱动模式: 非platform方式添加驱动: 加载驱动: 1,硬件初始化,申请内存,并作地址映射 2,分配设备号 ...
随机推荐
- IntelliJ idea 创建Web项目后web文件夹下没有WEB-INF的解决方法
1.Ctrl+Shift+Alt+S快捷键进入Project structure(项目结构)管理的界面 2.选择左边菜单栏里的Facet,点击后能看到有Deployment Descriptors的输 ...
- UVA10559 方块消除 Blocks 题解
设g[i][j][k]为消去区间[i,j]中的方块,只留下k个与a[i]颜色相同的方块的最大价值,f[i][j]为将[i,j]中所有方块消去的价值,转移自己yy一下即可. 为什么这样是对的?因为对于一 ...
- 热情组——项目冲刺 Day6
项目相关 作业相关 具体描述 班级 班级链接 作业要求 链接地址 团队名称 热情组 作业目标 实现软件制作,以及在福大的传播 Github链接 链接地址 SCRUM部分: 成员昵称 昨日目标 开始时间 ...
- oracle --工具 ODU
一,什么是ODU ODU全称为Oracle Data ba se Unloader ,是用于Oracle 数据库紧急恢复的软件,在各种原因 造成的数据库不能打开或数据删除后没有备份时,使用ODU抢救数 ...
- 第27课 “共享状态”及其管理者(std::future/std::shared_future)
一. “共享状态” (一)“共享状态”对象 1. 用于保存线程函数及其参数.返回值以及新线程状态等信息.该对象通常创建在堆上,由std::async.std::promise和std::package ...
- 如何用代码设置机器人初始坐标实现 2D Pose Estimate功能
前言:ROS机器人有时候会遇到极端的情况:比如地面打滑严重,IMU精度差,导致积累误差严重,或是amcl匹配错误,导致机器人定位失败, 这时候如何矫正机器人位置变得非常重要,我的思路是利用相机或是在地 ...
- 2017 ACM/ICPC Asia Regional Shenyang Online E number number number 题解
分析: 当n=1时ans=4=f(5)-1; n=2,ans=12=f(7)-1; n=3,ans=33=f(9)-1; 于是大胆猜想ans=f(2*k+3)-1. 之后用矩阵快速幂求解f(n)即可, ...
- Hash函数浅谈
Hash函数是指把一个大范围映射到一个小范围.把大范围映射到一个小范围的目的往往是为了节省空间,使得数据容易保存. 除此以外,Hash函数往往应用于查找上.所以,在考虑使用Hash函数之前,需要明白它 ...
- 使用excel中的数据快速生成sql语句
在小公司的话,总是会有要开发去导入历史数据(数据从旧系统迁移到新系统上)的时候.这个时候,现场实施或客户会给你一份EXCEL文档,里面包含了一些别的系统上的历史数据,然后就让你导入到现在的系统上面去. ...
- MonkeyDev安装--逆向开发
MonkeyDev是原有iOS OpenDev的升级,非越狱插件的开发集成神器! 可以使用Xcode开发CaptainHook Tweak.Logos Tweak 和 Command-line Too ...