skyeye上的s3c2410 lcd移植
扫描二维码
随时随地手机看文章
今天终于把s3c2410的lcd在skyeye上搞出来了。看到网上还有朋友在发贴询问,所以在这里与大家分亨一下。
首先,我的skyeye是1.2.3版的,linux内核版本是2.6.16.21-0.8 ,suse 10.0自带的。u-boot-1.1.6为引导程序。u-boot在skyeye
上的移植网上有,我也是在网上学来的,如果你还不清楚,可以到网上google一下。具体的地址我也不记得了。
下面主要说下我自己在skyeye上移植s3c2410的经历。
先声明一下本人也是初学者,有很多东西都 不是很清楚。在配置内核的时候l看到 linux2.6 自带了s3c2410的驱动,以为只要把它编译进
内核就可以了,可是在启动的时候检测不到设备,后来到网上找了下lcd的移植过程,原来还要在平台初始化文件中对lcd进行设置,初始
化即可。
修改文件为arch/arm/mach-s3c2410/mach-smdk2410.c
添加头文件:
#inlcude
#include
添加初始化代码:
static struct s3c2410fb_mach_info s3c2410_lcd_info __initdata = {
.fixed_syncs = 0,
.regs = {
.lcdcon1 = S3C2410_LCDCON1_TFT16BPP |
S3C2410_LCDCON1_TFT |
//S3C2410_LCDCON1_ENVID |
S3C2410_LCDCON1_CLKVAL(6),
.lcdcon2 = S3C2410_LCDCON2_VBPD(0) |
S3C2410_LCDCON2_LINEVAL(239) |
S3C2410_LCDCON2_VFPD(10) |
S3C2410_LCDCON2_VSPW(1),
.lcdcon3 = S3C2410_LCDCON3_HBPD(6) |
S3C2410_LCDCON3_HOZVAL(319) |
S3C2410_LCDCON3_HFPD(15),
.lcdcon4 = S3C2410_LCDCON4_MVAL(13) |
S3C2410_LCDCON4_HSPW(28),
.lcdcon5 = S3C2410_LCDCON5_FRM565 |
S3C2410_LCDCON5_INVVLINE |
// S3C2410_LCDCON5_INVVCLK |
S3C2410_LCDCON5_INVVFRAME |
//S3C2410_LCDCON5_INVLEND|
S3C2410_LCDCON5_PWREN |
S3C2410_LCDCON5_HWSWP,
},
.lpcsel = 0,// ((0xCE6) & ~7) | 1<<4,
.gpccon= 0xaaaaaaaa,
.gpccon_mask= 0xffffffff,
.gpcup= 0xffffffff,
.gpcup_mask= 0xffffffff,
.gpdcon= 0xaaaaaaaa,
.gpdup= 0xFFFFFFFF,
.gpdup_mask= 0xffffffff,
.width = 320,
.height = 240,
.yres = {
.min = 240,
.max = 240,
.defval = 240,
},
.xres = {
.min = 320,
.max = 320,
.defval = 320,
},
.bpp = {
.min = 16,
.max = 16,
.defval = 16,
},
};
static void __init smdk2410_lcd_init(void)
{
s3c24xx_fb_set_platdata(&s3c2410_lcd_info);
}
最后在MACHINE_START与MACHINE_END中添加如下代码:
.init_machine = smdk2410_lcd_init,
//到此修改完毕
以上s3c2410_lcd_info结构体的初始化在网上找的,着了点修改。
其中主要是寄存器的问,在skyeye中只使用了其中4个寄存器
lcdcon1的第1位启动和关闭lcd功能
lcdcon2中有关lcd 高度的设置
lcdcon3中有关lcd 宽度的设置
lcdsaddr1 中有关显存地址的值
查看skyeye的源代码发现,在s3c2410的lcd的模拟中将颜色的深度直接设置成了16,所以,以上代码中bpp的值也为16,
如果你感兴趣,可以查看s3c2410的手册中有关lcd寄存器的说明,对skyeye修改一下。
skyeye的lcd模拟中没有用到两个寄存器,所以在lcd的初始化过程中会有以下两个错误:
ERROR: s3c2410x_io_write_word(0x4d000060) = 0x00000000
ERROR: s3c2410x_io_write_word(0x4d000050) = 0x00000000
这对skyeye的模拟和以驱动程序不会有影响。
基本上就这些了。
顺便提下,不知各位在skyeye下模拟的s3c2410的主频是多少?
我一开始用u-boot引导的时候有有3个s3c2410x_io_write_word错误,s3c2410的主频也只有62MZ多。
后来看了下s3c2410x_io_write_word的代码,发现有三个寄存器LOCKTIME,MPLLCON, UPLLCON在头文件中定义了
,但在skyeye的
switch语句中并没有相关的写操作。具体的寄存器作用我并不清楚,也没有查手册,但应该与时钟用关。所以就在switch
语句里添加了以下代码:
case LOCKTIME:
io.clkpower.locktime = data;
break;
case MPLLCON:
io.clkpower.mpllcon = data;
break;
case UPLLCON:
io.clkpower.upllcon = data;
break;
现在我的skyeye模拟出来s3c2410的主频是202.800MZ了。
下一步打算把触摸屏的驱动也移植上来,还有网络。
如果你还有什么问题可以跟我联系。liren0@126.com
也可直接在此回复。
以下是skyeye上s3c2410的截图