LCD驅(qū)動(dòng)程序移植
2.6.14的內(nèi)核,按照網(wǎng)上的帖子,要做的工作量不是很大,現(xiàn)在先整理一下思路,我們從硬件開(kāi)始,我用的LCD型號(hào)是LTV350QV-F04。320×240,這里的320×240是像素點(diǎn)數(shù),其中320是水平方向,240是垂直方向??刂菩盘?hào)我們先不去管它,我們先來(lái)看一下數(shù)據(jù)線,也就是RGB(red green and blue)線,此處的硬件連接決定了LCD的BPP,16BPP或24BPP,我的開(kāi)發(fā)板上采用的是5:6:5的16BPP的連接。關(guān)于BPP和連線的關(guān)系可以參考2410手冊(cè)的387~390頁(yè)。
接下來(lái)要配置和LCD相關(guān)的寄存器,這部分配置要參考2410的p397開(kāi)始的關(guān)于LCD控制寄存器的說(shuō)明。以下代碼是網(wǎng)上一位大俠做的,拿來(lái)一用,解釋一下寄存器的初始化方法:
在/linux/arch/arm/mach-s3c2410/mach-smdk2410.c中添加如下內(nèi)容。
static struct s3c2410fb_mach_info smdk2410_lcdcfg __initdata = {
.regs = {
.lcdcon1 = S3C2410_LCDCON1_TFT16BPP |
S3C2410_LCDCON1_TFT |
S3C2410_LCDCON1_CLKVAL(0x03),
.lcdcon2 = S3C2410_LCDCON2_VBPD(3) |
S3C2410_LCDCON2_LINEVAL(239) |
S3C2410_LCDCON2_VFPD(5) |
S3C2410_LCDCON2_VSPW(15),
.lcdcon3 = S3C2410_LCDCON3_HBPD(5) |
S3C2410_LCDCON3_HOZVAL(319) |
S3C2410_LCDCON3_HFPD(15),
.lcdcon4 = S3C2410_LCDCON4_MVAL(13) |
S3C2410_LCDCON4_HSPW(8),
.lcdcon5 = S3C2410_LCDCON5_FRM565 |
S3C2410_LCDCON5_INVVLINE |
S3C2410_LCDCON5_INVVFRAME |
S3C2410_LCDCON5_PWREN |
S3C2410_LCDCON5_HWSWP,
},
.lpcsel = 0xf82,
.gpccon = 0xaa955699,
.gpccon_mask = 0xffc003cc,
.gpcup = 0x0000ffff,
.gpcup_mask = 0xffffffff,
.gpdcon = 0xaa95aaa1,
.gpdcon_mask = 0xffc0fff0,
.gpdup = 0x0000faff,
.gpdup_mask = 0xffffffff,
.fixed_syncs = 1,
.width = 320,
.height = 240,
.xres = {
.min = 320,
.max = 320,
.defval = 320,
},
.yres = {
.max = 240,
.min = 240,
.defval = 240,
},
.bpp = {
.min = 16,
.max = 16,
.defval = 16,
},
};首先我們應(yīng)該慶幸在內(nèi)核中給我們提供了s3c2410fb_mach_info結(jié)構(gòu)體(該結(jié)構(gòu)體定義于/include/asm/arch-s3c2410/fb.h),讓我們可以簡(jiǎn)單的把相關(guān)的參數(shù)添加上就行了(這讓我想起本科那會(huì)兒啥也不會(huì),但給個(gè)試驗(yàn)箱照樣做實(shí)驗(yàn))。對(duì)于LCDCON1,前兩項(xiàng)沒(méi)啥好說(shuō)的,最后一項(xiàng)關(guān)于CLKVAL的確定很重要,我的開(kāi)發(fā)板自帶的驅(qū)動(dòng)程序中將該值設(shè)為10,而華恒的一位老兄說(shuō)對(duì)于320×240的板子,一般設(shè)為7 就可以,先設(shè)為10試試看吧。
再來(lái)看LCDCON2,VBPD、VFPD、VSPW和LINEVAL這四個(gè)值,LCD的手冊(cè)中竟然沒(méi)有典型值,只好再去參考原來(lái)的驅(qū)動(dòng)程序了。原來(lái)的驅(qū)動(dòng)如下:lcdcon2:LCD2_VBPD(3) | LCD2_VFPD(5) | LCD2_VSPW(15),沒(méi)有賦予LINEVAL值,難道在2.4內(nèi)核中沒(méi)有這一項(xiàng),還是默認(rèn)的就滿足要求。來(lái)看手冊(cè)中的LINEVAL
LINEVAL [23:14] TFT/STN: These bits determine the vertical size of LCD panel. 0000000000(initial)還是加上該條保險(xiǎn)。同樣的,在LCDCON3中,也沒(méi)有HOZVAL的影子,也加上,其他的都是和這位大俠的一樣,包括LCDCON4和LCDCON5。
接下來(lái)的lpcsel用來(lái)確定是否選用lpc3600芯片,我的好像不用選,先置零,有問(wèn)題再說(shuō)。
下面的就是GPIO口的配置了,這些GPIO口都是多功能IO,這里將其配置為VDn。根據(jù)我的開(kāi)發(fā)板,GPCCON配置為全a就行,因?yàn)槌四?6根用于LCD的管腳,其它的都空閑,不必為其花費(fèi)心思。GPCCON_MASK不知是干什么的?多數(shù)帖子上是全f。GPCUP是上拉電阻功能,我用不到,全f。
fixed_syncs不知是什么東西,自帶的驅(qū)動(dòng)有一個(gè)syncs為0,這里也取為0。剩下的就不用解釋了。
再往后就是添加初始化代碼了,還是在mach-smdk2410.c中,添加如下代碼:
static void __init sdmk2410_lcdinit(void)
{
set_s3c2410fb_info(&smdk2410_lcdcfg __initdata );
}
然后再M(fèi)ACHINE_START(SMDK2410, "SMDK2410") 中添加對(duì)LCD的初始化。
.init_machine = sdmk2410_lcdinit,
也有為大俠把set_s3c2410fb_info(&smdk2410_lcdcfg __initdata );直接加到了static void __init smdk2410_map_io(void)中,個(gè)人認(rèn)為更合理一些。接下來(lái)就是添加必要的頭文件了:
#include
#include
#include gpio.h>
#include
#include timer.h>
#include
//#include
//#include
//#include
#include
#include
#include nand.h>
#include
#include
#include
#include
#include
好了,我要開(kāi)始編譯內(nèi)核了?。?!
注意了,我給出的頭文件有些會(huì)引起編譯的錯(cuò)誤,凡是引起錯(cuò)誤的頭文件,將它注釋掉就行了,我哥們說(shuō)就加上一個(gè)fb.h就行了,不過(guò)我沒(méi)試,只是把一起錯(cuò)誤的頭文件注釋掉了。然后就看到了小企鵝。