U-Boot提供了一个go命令,可以用来启动操作系统的内核或者其他应用程序。当U-Boot还没有实现网络功能时,常常需要调试,而每次都用JTAG把u-boot.bin烧写到Flash是一件费时费力的事情,因此调试的时候最好让U-Boot从SDRAM里启动。
如果不出差错,一般情况下,只要U-Boot跑起来了,它的loadb命令就是可用的。因此我们可以通过串口下载需要调试的u-boot.bin到SDRAM中,直接跳转到SDRAM中执行,这样就避免了反复烧写Flash。loadb命令和超级终端配合使用,可以方便的下载文件到SDRAM中。并且,u-boot.bin往往不像内核那么大,一般就100多K,用串口只需要花10多20秒就可以下载完毕;而内核比较大,1M多的内核用串口下载要好几分钟。
下面介绍一个实现U-Boot从SDRAM启动的方法。
需要注意几个地方:
1、配置头文件的修改
添加如下两行
#define CONFIG_SKIP_LOWLEVEL_INIT |
这两行使U-Boot不执行汇编代码段的cpu_init_crit 和relocate 代码段。
2、修改config.mk文件
config.mk文件中定义了一个TEXT_BASE,指定程序的入口地址。在博创的经典pxa270开发板上,我做的如下的定义:
TEXT_BASE = 0xa3f80000 |
表示U-Boot在RAM中的程序入口地址。U-Boot启动以后,在RAM中就运行在这个地址往上的空间。这样定义的U-Boot,将它烧写到Flash中。
然后,在调试用的U-Boot中做如下设定:
TEXT_BASE = 0xa3f00000 |
这样,调试用的U-Boot就运行在RAM中从0xa3f00000往上的地址,两个U-Boot空间互不干扰。
编译完调试用的U-Boot,执行如下命令:
[UP270 #]tftp 0xa3f00000 u-boot.bin |
可以看到,新的U-Boot就正确地启动了,代码空间从0xa3f00000到0xa3f1f060;BSS段从0xa3f1f060到0xa3f53e84。