u-boot-在2440上的移植详解(一)
0x14800014 /* clock divisor register */
#else //下面2410和2440的寄存器地址是一致的
# define pWTCON 0x53000000
# define INTMSK 0x4A000008 /* Interupt-Controller base addresses */
# define INTSUBMSK 0x4A00001C
# define CLKdivN 0x4C000014 /* clock divisor register */
# endif
ldr r0, =pWTCON
mov r1, #0x0
str r1, [r0]
/*
* mask all IRQs by setting all bits in the INTMR - default
*/
mov r1, #0xffffffff
ldr r0, =INTMSK
str r1, [r0]
# if defined(CONFIG_S3C2410)
ldr r1, =0x3ff
ldr r0, =INTSUBMSK
str r1, [r0]
# endif
# if defined(CONFIG_S3C2440)//添加s3c2440的中断禁止部分
ldr r1, =0x7fff //根据2440芯片手册,INTSUBMSK寄存器有15位可用
ldr r0, =INTSUBMSK
str r1, [r0]
# endif
# if defined(CONFIG_S3C2440) //添加s3c2440的时钟部分
#define MPLLCON 0x4C000004 //系统主频配置寄存器基地址
#define UPLLCON 0x4C000008 //USB时钟频率配置寄存器基地址
ldr r0, =CLKdivN //设置分频系数FCLK:HCLK:PCLK = 1:4:8
mov r1, #5
str r1, [r0]
ldr r0, =MPLLCON //设置系统主频为405MHz
ldr r1, =0x7F021 //这个值参考芯片手册“PLL VALUE SELECTION TABLE”部分
str r1, [r0]
ldr r0, =UPLLCON //设置USB时钟频率为48MHz
ldr r1, =0x38022 //这个值参考芯片手册“PLL VALUE SELECTION TABLE”部分
str r1, [r0]
# else //其他开发板的时钟部分,这里就不用管了,我们现在是做2440的
/* FCLK:HCLK:PCLK = 1:2:4 */
/* default FCLK is 120 MHz ! */
ldr r0, =CLKdivN
mov r1, #3
str r1, [r0]
# endif
#endif /* CONFIG_S3C2400 || CONFIG_S3C2410 || CONFIG_S3C2440 */
S3C2440的时钟部分除了在start.S中添加外,还要分别在board/samsung/my2440/my2440.c和cpu/arm920t/s3c24x0/speed.c中修改或添加部分代码,如下:
#gedit board/samsung/my2440/my2440.c //设置主频和USB时钟频率参数与start.S中的一致
#define FCLK_SPEED 2 //设置默认等于2,即下面红色代码部分有效
#if FCLK_SPEED==0 /* Fout = 203MHz, Fin = 12MHz for Audio */
#define M_Mdiv 0xC3
#define M_Pdiv 0x4
#define M_Sdiv 0x1
#elif FCLK_SPEED==1 /* Fout = 202.8MHz */
#define M_Mdiv 0xA1
#define M_Pdiv 0x3
#define M_Sdiv 0x1
#elif FCLK_SPEED==2 /* Fout = 405MHz */
#define M_Mdiv 0x7F //这三个值根据S3C2440芯片手册“PLL VALUE SELECTION TABLE”部分进行设置
#define M_Pdiv 0x2
#define M_Sdiv 0x1
#endif
#define USB_CLOCK 2 //设置默认等于2,即下面红色代码部分有效
#if USB_CLOCK==0
#define U_M_Mdiv 0xA1
#define U_M_Pdiv 0x3
#define U_M_Sdiv 0x1
#elif USB_CLOCK==1
#define U_M_Mdiv 0x48
#define U_M_Pdiv 0x3
#define U_M_Sdiv 0x2
#elif USB_CLOCK==2 /* Fout = 48MHz */
#define U_M_Mdiv 0x38 //这三个值根据S3C2440芯片手册“PLL VALUE SELECTION TABLE”部分进行设置
#define U_M_Pdiv 0x2
#define U_M_Sdiv 0x2
#endif
#gedit cpu/arm920t/s3c24x0/speed.c //根据设置的分频系数FCLK:HCLK:PCLK = 1:4:8
- U-Boot的编译与移植到QT-S3C44B0X开发板上(03-08)
- 基于S3C2410A的嵌入式系统的U-Boot移植(01-24)
- 从NAND闪存中启动U-BOOT的设计(05-16)
- 嵌入式Linux开发环境的搭建之:U-Boot移植(08-13)
- U-BOOT移植的经验之谈(11-29)
- mini2440开发板 u-boot 移植(11-27)