当前位置:首页 > 单片机 > 单片机
[导读]U-Boot移植:系统:Ubuntu 12.04开发板:JZ2440虚拟机:VM10.04U-Boot:U-BOOT-1.1.6步骤:1、解压U-BOOT-1.1.6tar jxvf U-BOOT-1.1.6.tar.bz22、同时支持S3C2410和S3C2440:(1)、新建一个开发板的相应目录和文件在

U-Boot移植:
系统:Ubuntu 12.04
开发板:JZ2440
虚拟机:VM10.04
U-Boot:U-BOOT-1.1.6
步骤:
1、解压U-BOOT-1.1.6
tar jxvf U-BOOT-1.1.6.tar.bz2
2、同时支持S3C2410和S3C2440:
(1)、新建一个开发板的相应目录和文件
在board目录下将smdk2410复制为100ask24x0,并将board/100ask24x0/smdk2410.c改名为100ask24x0.c,再将include/configs/smdk2410.h复制为100ask24x0.h
修改两个Makefile:
1)、在顶层Makefile中增加如个两行:
100ask24x0_config :unconfig
@$(MKCONFIG) $(@:_config=) arm arm920t 100ask24x0 NULL s3c24x0
2)、在board/100ask24x0/Makefile中修改如下:
COBJS:= smdk2410.o flash.o
改为
COBJS:= 100ask24x0.o flash.o
3、修改SDRAM的配置
SDRAM的初始化在U-Boot的第一阶段完成,在board/100ask24x0/lowlevel_init.S中,由于开发板的HCLK都为100mhz,需该REFCNT寄存器的值。修改如下:
#define REFCNT0x1113
改为
#define REFCNT0x4f4
4、增加对S3C2440的支持
2440的时钟计算公式、NAND操作和2410不太一样。

对于2440开发板,将FCLK设为400MHz,分频比为FCLK:HCLK:PCLK=1:4:8。


首先修改board/100ask24x0/100ask24x0.c中的board_init函数:

#define S3C2440_MPLL_400MHZ((0x5c<<12)|(0x02<<4)|(0x01))

#define S3C2440_UPLL_48MHZ((0x38<<12)|(0x02<<4)|(0x02))

#define S3C2440_CLKDIV0x05

#define S3C2410_MPLL_200MHZ((0x5c<<12)|(0x04<<4)|(0x00))

#define S3C2410_UPLL_48MHZ((0x28<<12)|(0x01<<4)|(0x02))

#define S3C2410_CLKDIV0x03


int board_init (void)

{

S3C24X0_CLOCK_POWER * const clk_power = S3C24X0_GetBase_CLOCK_POWER();

S3C24X0_GPIO * const gpio = S3C24X0_GetBase_GPIO();

gpio->GPACON = 0x007FFFFF;

gpio->GPBCON = 0x00044555;

gpio->GPBUP = 0x000007FF;

gpio->GPCCON = 0xAAAAAAAA;

gpio->GPCUP = 0x0000FFFF;

gpio->GPDCON = 0xAAAAAAAA;

gpio->GPDUP = 0x0000FFFF;

gpio->GPECON = 0xAAAAAAAA;

gpio->GPEUP = 0x0000FFFF;

gpio->GPFCON = 0x000055AA;

gpio->GPFUP = 0x000000FF;

gpio->GPGCON = 0xFF95FFBA;

gpio->GPGUP = 0x0000FFFF;

gpio->GPHCON = 0x002AFAAA;

gpio->GPHUP = 0x000007FF;

if ((gpio->GSTATUS1 == 0x32410000) || (gpio->GSTATUS1 == 0x32410002))

{

clk_power->CLKDIVN = S3C2410_CLKDIV;

__asm__("mrcp15, 0, r1, c1, c0, 0n"

"orrr1, r1, #0xc0000000n"

"mcrp15, 0, r1, c1, c0, 0n"

:::"r1"

);

clk_power->LOCKTIME = 0xFFFFFF;

clk_power->MPLLCON = S3C2410_MPLL_200MHZ;

delay (4000);

clk_power->UPLLCON = S3C2410_UPLL_48MHZ;

delay (8000);

gd->bd->bi_arch_number = MACH_TYPE_SMDK2410;

}

else

{

clk_power->CLKDIVN = S3C2440_CLKDIV;

__asm__("mrcp15, 0, r1, c1, c0, 0n"

"orrr1, r1, #0xc0000000n"

"mcrp15, 0, r1, c1, c0, 0n"

:::"r1"

);

clk_power->LOCKTIME = 0xFFFFFF;

clk_power->MPLLCON = S3C2440_MPLL_400MHZ;

delay (4000);

clk_power->UPLLCON = S3C2440_UPLL_48MHZ;

delay (8000);

gd->bd->bi_arch_number = MACH_TYPE_S3C2440;

}

gd->bd->bi_boot_params = 0x30000100;

icache_enable();

dcache_enable();

return 0;

}

5、修改系统时钟
在U-Boot的第二阶段,设置串口波特率时需要获得系统时钟,lib_arm/board.c中,start_armboot函数调用serial_init函数初始化时会调用get_PCLK函数。
在cpu/arm920t/s3c24x0/speed.c中修改:
首先,在程序开头增加一行DECLARE_GLOBAL_DATA_PTR;,这样才可以使用gd变量。
S3C2410和S3C2440的MPLL,UPLL计算公式不一样,所以修改get_PLLCLK:

static ulong get_PLLCLK(int pllreg)

{

S3C24X0_CLOCK_POWER * const clk_power = S3C24X0_GetBase_CLOCK_POWER();

ulong r, m, p, s;

if (pllreg == MPLL)

r = clk_power->MPLLCON;

else if (pllreg == UPLL)

r = clk_power->UPLLCON;

else

hang();

m = ((r & 0xFF000) >> 12) + 8;

p = ((r & 0x003F0) >> 4) + 2;

s = r & 0x3;

if (gd->bd->bi_arch_number == MACH_TYPE_SMDK2410)

return((CONFIG_SYS_CLK_FREQ * m) / (p << s));

else

return((CONFIG_SYS_CLK_FREQ * m * 2) / (p << s));

}

由于分频系数的设置方法也不一样,get_HCLK,get_PCLK也做如下修改:


#define S3C2440_CLKDIVN_PDIVN(1<<0)

#define S3C2440_CLKDIVN_HDIVN_MASK(3<<1)

#define S3C2440_CLKDIVN_HDIVN_1(0<<1)

#define S3C2440_CLKDIVN_HDIVN_2(1<<1)

#define S3C2440_CLKDIVN_HDIVN_4_8(2<<1)

#define S3C2440_CLKDIVN_HDIVN_3_6(3<<1)

#define S3C2440_CLKDIVN_UCLK(1<<3)

#define S3C2440_CAMDIVN_CAMCLK_MASK(0xf<<0)

#define S3C2440_CAMDIVN_CAMCLK_SEL(1<<4)

#define S3C2440_CAMDIVN_HCLK3_HALF(1<<8)

#define S3C2440_CAMDIVN_HCLK4_HALF(1<<9)

#define S3C2440_CAMDIVN_DVSEN(1<<12)

ulong get_HCLK(void)

{

S3C24X0_CLOCK_POWER * const clk_power = S3C24X0_GetBase_CLOCK_POWER();

unsigned long clkdiv;

unsigned long camdiv;

int hdiv = 1;

if (gd-

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭