u-boot移植心得

来源:互联网 发布:windows phonesdk 编辑:程序博客网 时间:2024/05/17 09:01
几经艰辛,终于基本完成了u-boot在s3c44b0的移植工作,在些记录一下在移植过程中所碰到的困难和解决方法(一些心得),作为日后参考之用,也希望能够帮到其它有需要的人^_^。
1.来由:
在我搞完ucos后(本来我是想学uclinux的,不过在对系统一无所知的情况下,还是先学一下ucos比较实际^_^,从中也可以对系统有个清晰的概念),我意识到要搞系统的话一个功能强大的bootloader是必不可少的,而我的板上自带的是armboot(其实我个人觉得应用在ARM上的话armboot已经足够了,毕竟u-boot也是从armboot中发展过来的,纯属个人意见),如果我的板上自带光盘有已经移植好的armboot源代码供我参考的话,我想我也不会花这么多时间去搞u-boot,可恨的是我的光盘上只有armboot.bin这个二进制文件,而没有源文件,没办法,我下定主意自己搞一个,考虑了一番后我选择了u-boot,毕竟参考资料相对比较多,再我学完u-boot后再回头看armboot,简直是一个炉里出的饼,这是后话。
    2.准备:
          说是容易,做起来却挺难。因为编译u-boot要在linux环境下,而不能在我们平时所熟悉的ads下那么直观。首先要建立好交叉编译环境,这个交叉编译环境可以自己来做,不过完全没必要,而且难度也挺大,一般是下载人家编译好的工具。我刚开始在这里就郁闷了很久,现在会了以后觉得原来就是这么简单,在些我把方法说清楚,希望不会再有人为这个问题郁闷了^_^:
1)在网上下载一个u-boot源代码,我用的是1.1.2版本的,最新的应该是1.1.4的吧,其实差不多,那就像我那样下载一个1.1.2版本的吧。把源文件解压,这个应该不用说了吧,学过linux的人应该会,不会的话我想你继续做下去也困难,那就先装个linux用下吧(我用的是RedHat的,哦对了,编译程序是需要gcc编译器的,所以安装方式一定要选择工作站哦^_^)。好了,解压后你发现在u-boot.1.1.2目录下有Makefile这个文件吧?让我们看看它里面的内容,最简单的方法就是vi Makefile了。我们要看的是它选择的是哪一个交叉编译器。可以看到这一项:
ifeq ($(ARCH),arm)
CROSS_COMPILE = arm-linux-
看到吧,也就是说这里所用的交叉编译器是arm-linux-gcc了,(u-boot默认是用这个的,也有用arm-elf-gcc的,网上有个工具包arm-elf-tools-20030314.sh,我试过用它来编译,没有问题,顺便提一下,arm-elf-gcc是用来编译uClinux内核的工具来的)那你就下载一个arm-linux-的交叉编译器吧,我是在网上下载cross-2.95.3.tar.bz2这个文件,然后解压得到2.95.3版本的交叉编译工具的,具体设置如下(参考网上资料):

2)在宿主机上建立arm-linux-gcc交叉编译环境
在RedHat Linux系统下以root用户登录,
将cross-2.95.3.tar.bz2文件复制到/目录下,
安装:
# tar jxvf cross-2.95.3.tar.bz2
这个命令会在你的/usr/local/arm/2.95.3目录下安装 arm-linux-gcc 交叉编译程序,
然后在PATH变量中添加一项:/usr/local/arm/2.95.3/bin.
[root@localhost root]# export ATH=/usr/local/arm/2.95.3/bin:$PATH

把PATH=/usr/local/arm/2.95.3/bin:$PATH添加到/ETC/bash_profile文件中
或者
在/etc/bashrc文件中添加一项:
export PATH=/usr/local/arm/2.95.3/bin:$PATH
测试:
把终端关闭,重新打开后执行如下命令:
# arm-linux-gcc –v
好了,建立好交叉编译环境后可以试着编译u-boot了

这里提几个注意点:
1.不可用winRAR解压u-boot-1.1.2.tar.bz2或u-boot-1.1.2.tar.gz这种文件(就个可能新手会犯,一般熟悉linux命令的人应该都不会这样做吧,在此还是要提一下)
2.可能下载的文件有一些中间文件会阻碍编译的运行,所以在编译前最好来个彻底清除,在u-boot.1.1.2目录下运行命令:make distclean (其实这个命令在Makefile文件下就有)我当时为这个问题郁闷了很久,希望你们不会像我这样^_^);
3,有些人为了方便想在cygwin下编译,但是经常在网上看到在这个虚拟平台下编译有很多的问题,要配置的东西也多,而且好像我用过那个vi没有linux环境下的好用,所以最好还是不要用这个软件了吧,如果你真的离不开windows的话可以像我这样装个虚拟机,在虚拟机下再装linux的系统,具体参考这个网站):http://fedora.linuxsir.org/doc/vmware/
3)好了,现在开始测试你的交叉编译器搞好没有。在u-boot.1.1.2目录下执行如下命令:
1)Make distclean (再次强调)
2)Make B2_config(随便再个现成的试试^_^)
3)Make (没错的话应该会生成u-boot.bin文件,发生错误的话也不怕,只要细心看一下哪里错就行了,gcc碰到错误后会退出编译,所以可以一个个错误来改,一般的问题都是没找到编译器(可能你没装或者装的不对,例如人家用的是arm-linux-而你装的是arm-elf-,如果你装了的话看看你的环境变量设好了没有,前面有讲,如果不关编译器的事的话那就再看看,一般是文件的后缀不对,有些文件后缀是大写的,例如start.S但是如果你的是start.s小写的话那当然找不到(解决方法很,把它改成大写就行了)。细心看吧,不用怕,它都有注明路径,很容易可以找到的))
如果以上步骤都无误的话那么恭喜你,你的交叉编译环境可以用来编译你的u-boot源代码了,可以开始以下阶段。
3.移植:
说时迟那时快,现在开始移植工作(以下是我一步步重新做一遍,力求说得详细点,感谢我吧^_^)
我以B2板子的程序做为模板来做.
#cd u-boot-1.1.2
#cd board
#cp -R dave myboard (这是我取的板子名字,可以换上你的,但是后面的也要跟着来换哦^_^)
#cd myboard
#mv B2 myboards3c44b0 (自己取个板子名)
#cd myboards3c44b0
# mv B2.c myboards3c44b0.c
修改myboards3c44b0里面的Makefile, 把B2改成myboards3c44b0,编译时如果报的其它类似找不到B2的错误也是把相应的B2改成myboards3c44b0来处理。

1)其中的myboards3c44b0.c文件是板的初始化代码,看一下就知道,根据你的板上自带的44binit.s来修改吧。memsetup.S文件主要是存储器的初始化设置,其实也是44binit.s里面的一部分。
2)其实board这里要修改的不多,先跳过flash部分吧,我们来看一下cpu设置部分吧。
u-boot-1.1.2里面已经加入了对s3c44b0的支持,让我们来看一下cpu/s3c44b0里面的部分吧。
看到start.S这个文件了吗?要修改的其实并不多,按照你的板设置一下中断跳转矢量就行了,或者上网查一下吧,应该很容易看明的。其中cpu.c这个文件简直不用修改,再来看一下serial.c这个文件吧,改一下波特率的设置就行,就是你用多少M的CPU频率的话对应的波特率参数设置问题,其实B2已经做得不错的了,很多子程序都不用自己写的了^_^,在我的板上是这样设置的,参考一下吧:
#if CONFIG_S3C44B0_CLOCK_SPEED==66 ,把所有的这些66改成60,原因,我的实验板上用的频率是60(44B0最高频率为64M)。然后其它分频系数,寄存器初始化设置,可以参考一下44blib.c,在这里我给出我的设置出来吧,可以参考一下。

case 115200:
#if CONFIG_S3C44B0_CLOCK_SPEED==60
divisor = 32;

UFCON0 = 0x0;
ULCON0 = 0x03;
UCON0 = 0x245;
UBRDIV0 = divisor;

我在这方面算术不好,所以都是参考人家的。

3)好,再加上个头文件:
cd u-boot-1.1.2/include/configs
cp B2.h myboards3c44b0.h
这个头文件其实要改的地方还挺多的,我等下再说怎样修改。先回到u-boot.1.1.2目录,

4)在Makefile里面加上这部分,不会的话就模仿B2来写吧^_^
在B2的这部分文件
B2_config:unconfig
@./mkconfig $(@:_config=) arm s3c44b0 B2 dave
后面加上这部分:
myboards3c44b0_config:unconfig
@./mkconfig $(@:_config=) arm s3c44b0 myboard3c44b0 myboard

切记在@./mkconfig $(@:_config=) arm s3c44b0 myboard3c44b0 myboard前面的是Tab来的,万万不能用空格代替,因为它是靠这个来识别命令的!
   
5)好,现在可以在u-boot-1.1.2目录下执行如下命令:
Make distclean(还是用这个吧,比较彻底)
Make myboards3c44b0_config
Make
看看有没有错,有错的话按着提示来改,如果没错的话应该就能生成u-boot.bin这个文件,现在还不能用哦,因为这几是B2的一个仿制品而已(注:在我的机上到这一步可没有报错哦,你一步步按着来做的话应该也不会有什么错误吧^_^)。


6)好,现在继续修改u-boot-1.1.2/include/configs/myboards3c44b0.h这个文件。
#define CONFIG_INIT_CRITICAL1         这个在cpu/s3c44b0/start.S里面用到,如果你的u-boot程序不是在sdram中调试而是固化到flash中运行的话,这个必不可少。
找到 #define CONFIG_B2          1        把B2改成myboards3c44b0吧(不然就不会编译你的板了)
找到 #define CONFIG_S3C44B0_CLOCK_SPEED   75   你的44b0x应该没有75M吧 我的是改成60的
找到Size of malloc() pool这部分设置,改成这样吧,反正我是照着人家来做的,你自己研究下吧^_^。

#define CFG_MONITOR_LEN(256 * 1024)/* Reserve 256 kB for Monitor*/
#define CFG_ENV_SIZE   (64*1024)/* 1024 bytes may be used for env vars*/
#define CFG_MALLOC_LEN(CFG_ENV_SIZE + 128*1024 )
#define CFG_GBL_DATA_SIZE128/* size in bytes reserved for initial data */
#define CFG_ENV_IS_IN_FLASH  1  这个必不可少,如果你想把你的参数保存到flash的话(有些板是保存到EEPRAM中去的,但是s3c44b0的话还是保存到flash吧)
#define CFG_ENV_ADDR(PHYS_FLASH_1+0x40000)  这个就是你的参数保存在flash里的起始地址了
#define CFG_ENV_OFFSET0x40000      这个我后来看它源程序发现如果你上一步没有设置它的起始地址的话就会用它来作默认地址的了
#define CONFIG_AUTO_COMPLETE

其它地方没有深究哦,有些好像不要也行,你就试试吧。

找到Hardware drivers部分,这应该是网络芯片设置吧,参考一下这个吧(要看芯片的):
#define CONFIG_DRIVER_RTL8019        这个就要看你的板上用的是什么网卡了(这个是台湾出的,有10M)
#define RTL8019_BASE0x06000000   这个是网卡相就寄存器的起始地址
以下部分我试过不要也行,你试下吧
#define RTL8019_BUS320
#define CONFIG_SMC_USE_16_BIT
#undef  CONFIG_SHOW_ACTIVITY
#define CONFIG_NET_RETRY_COUNT10   应该是重试的次数吧

#define CONFIG_BAUDRATE115200  设置波特率

#define CONFIG_COMMANDS( CONFIG_CMD_DFL | /
CFG_CMD_DATE | /
CFG_CMD_ELF| /
CFG_CMD_NET    | /
CFG_CMD_EEPROM| /
CFG_CMD_I2C| /
CFG_CMD_FAT | /
CFG_CMD_JFFS2)
把CFG_CMD_EEPROM改成CFG_CMD_FLASH吧,虽然不改也是可以的,具体没考究。

以下是板上env参数设置,看一下吧,其实我觉得了解一下就行的了,只是一些初始设置值,以后可以用命令setenv  saveenv来修改的。
#define CONFIG_BOOTDELAY3                这个就是运行bootcmd之前的等待时间
#define CONFIG_BOOTARGS  "devfs=mount root=ramfs console=ttyS0,115200" 引导uClinux的时候传递的参数,不会就先不用管它也行。
#define CONFIG_ETHADDR00:50:c2:1e:af:fb    网卡的物理地址MAC
#define CONFIG_NETMASK  255.255.255.0       掩码地址,设置过ip的人都应该知道吧
#define CONFIG_IPADDR   192.168.0.30          这是你板上网卡8019的ip地址
#define CONFIG_SERVERIP192.168.0.10       这是你宿主机的ip地址,以后用tftp下载的时候用到,一定要跟你的宿主机一致才行。
#define CONFIG_BOOTFILE"u-boot.bin"        这个就是你要下载文件的默认名字
#define CONFIG_BOOTCOMMAND"bootm 0x50000"   这是bootdelay后运行的命令

Miscellaneous configurable options部分,参考一下吧:
#defineCFG_LONGHELP/* undef to save memory*/
#defineCFG_PROMPT"s3c44b0=>"   这是进入命令模式下的提示符,改个帅一点的吧
#defineCFG_CBSIZE256/* Console I/O Buffer Size*/
#defineCFG_PBSIZE (CFG_CBSIZE+sizeof(CFG_PROMPT)+16) /* Print Buffer Size */
#defineCFG_MAXARGS 100/* max number of command args*/
#define CFG_BARGSIZECFG_CBSIZE/* Boot Argument Buffer Size*/

#define CFG_MEMTEST_START    0x0C400000/* memtest works on*/
#define CFG_MEMTEST_END0x0C800000/* 4 ... 8 MB in DRAM*/
#undef  CFG_CLKS_IN_HZ/* everything, incl board info, in Hz */
#defineCFG_LOAD_ADDR0x0c008000默认的下载地址
#defineCFG_HZ1000/* 1 kHz */
#define CFG_BAUDRATE_TABLE  { 9600, 19200, 38400, 57600, 115200 } 可供选择的波特率


Physical Memory Map部分,比较重要,修改你的sdram和flash的地址和容量。
#define CONFIG_NR_DRAM_BANKS1   我们只占用了一个Bank用来映射sdram
#define PHYS_SDRAM_10x0c000000     sdram的起始地址
#define PHYS_SDRAM_1_SIZE0x00800000     sdram的容量(8M)
#define PHYS_FLASH_10x00000000     flash的起始地址
#define PHYS_FLASH_SIZEflash的容量(2M)
#define CFG_FLASH_BASEPHYS_FLASH_1   定义多个名字而已,其它地方会用到


FLASH organization部分,看注释应该知道了吧,参考一下:
#define CFG_FLASH_ERASE_TOUT4120000/* Timeout for Flash Erase (in ms)*/
#define CFG_FLASH_WRITE_TOUT4000/* Timeout for Flash Write (in ms)*/


按着来一步步的做应该不难,这里提一下vi程序的用法,其实在google一搜就找到了,不过为了方便大家,还是说一声吧,
在命令模式下:
按/ xxx再回车即可搜索到你所需要的内容(xxx),再按n搜索下一个,按shift+n搜索上一个
按:xxx即可跟到你想要的行
按:set nu显示行号
其它查书都可以找到就不说了。

做到这个时候,你可以再编译一下,看有没有错,这一步我就没有帮你们做了,不过我觉得应该不会有问题吧,下载到ram中运行,看看效果。


7)终于到了flash的设置部分了,这完全是我个人悟出来的,网上资料好像讲得不是先清楚。
 首先介绍一下flash的识别吧,每块flash都有一个id,前部分用来说明生产厂家,后部分用来说明它的容量,类型,位数等。它们的定义是在u-boot-1.1.2/include/flash.h中,就以我的ssts9vf1601为例:
#define SST_MANUFACT0x00BF00BF  这是生产厂家id
#define SST_ID_xF16010x234B234B  这是它的型号,容量,位数等id
#define FLASH_SST160A0x0046       这个我还说不清楚,有个要注意的问题是像sst160是不能用奇地址的,我做的过程中是把SST160A改成SST1601的,懒得帮它创一个
好了,相信你已经找到你的板上所用的flash对应的id号了吧?现在就来谈谈怎么改。
先进入u-boot-1.1.2/board/myboards3c44b0/common/flash.c
它里面已经帮SST160A设置好了,我的做法是把SST公司的160A都改成1601,是不是很简单,当然你也可以帮1601再写一分,但是我是个懒人,所以我就样做了^_^

到这里还有个问题没提到的,就是如果你重新用setenv saveenv 设置了参数,但是复位后会发现怎么没有保存到的(不信你试试看)。其实我是故意留到这里讲的,应该它不会报错,可以说是比较隐秘的问题,所以我故意放到这里来说,以引起你的重视。
解决方法:vi u-boot-1.1.2/board/myboard/common/flash.c
找到这个函数:write_buff
里面有这句话:#ifdef CONFIG_B2
要把B2改了,因为我们的板不叫B2,那叫什么呢?原来是在这里定义的:u-boot-1.1.2/include/configs/myboards3c44b0.h
里面有这句话:#define CONFIG_HFRK 你不喜欢HFRK这个名字也行,可以改成别的名字,只不过相应地前面的B2也要改成这个名字而已。


4.后记:
  本来是想刚做好的时候写的,但是后来发现有些功能实现不了,所以就停住了笔,等我搞好了以后,又急着去学习uClinux的移植,真的很忙,现在终于抽空把它写完。虽然有些地方还没说清楚(毕竟我对它的了解还不是很深,但我相信在我以后移植系统的过程中会逐步加深对它的了解),我还是希望它能成为最详尽的u-boot移植新手指导,对u-boot移植的初学者起到实质性的作用,这样就不枉我花了这么多的心思来写这个文档。

参考资料:
http://blog.21ic.com/more.asp?name=sockit&id=8509
我所认为的最有奉献精神,写得最详细的记录,在此表示我深深的敬意!





 
  发贴时间2006/04/29 10:33pm 此 IP 为代理服务器IP: 已设置保密               -* 未注册 *-
 



信息: 该用户目前不在线
威望: 未知
来自: 未知
总发贴数: 0
注册日期: 未知
  复制 引用 回复贴子回复 

  ding...



 
  发贴时间2006/04/30 08:41am 此 IP 为代理服务器IP: 已设置保密            头衔: 认证会员
 


信息: 该用户目前不在线 此人为认证用户
威望: +16
来自: 保密 
总发贴数: 214
注册日期: 2005/12/09
  消息 查看 搜索 好友 邮件 复制 引用 回复贴子回复 

  好!



 
  发贴时间2006/04/30 11:18am 此 IP 为代理服务器IP: 已设置保密               -* 未注册 *-
 



信息: 该用户目前不在线
威望: 未知
来自: 未知
总发贴数: 0
注册日期: 未知
  复制 引用 回复贴子回复 

  ding to stanler



 
  发贴时间2006/08/01 01:43pm 此 IP 为代理服务器IP: 已设置保密               -* 未注册 *-
 



信息: 该用户目前不在线
威望: 未知
来自: 未知
总发贴数: 0
注册日期: 未知
  复制 引用 回复贴子回复 

  转一个:
http://www.linuxforum.net/forum/showflat.php?Cat=&Board=embedded&Number=618767&page=0&view=collapsed&sb=5&o=0&fpart=
s3c44b0x主板启动用到的代码分析

一 首先从cpu/s3c44b0/start.S这个文件开始执行,这个文件主要作以下几点:
1 设置处理器的工作模式。
2 初始化中断向量。
3 关闭看门狗功能。
4 允许timer5的中断(时钟中断)。
5 允许IRQ中断,进制FIQ中断。
6 设置时钟控制寄存器控制CPU的主频。根据我自己的开发板进行了设置。(下面介绍了时钟主频的计算公式)。
7 调用board//lowlevel.S对存储器进行初始化。这个文件主要是根据开发板设置每个存储器的BANK。我修改了这个文件使其支持我的开发板。
8 将ROM中的U-BOOT代码拷贝到RAM中。并在RAM中设置好中断向量表。
9 设置堆栈。
10 跳到lib_arm/board.c中执行start_armboot.
二 执行lib_arm/board.c中的start_armboot,主要完成一下工作:
1 调用cpu//cpu.c中的cpu_init()来刷新所有cache,将0x00000000~0x0c000000区设为非cache区。并使用全部8K空间作为cache。总线优先级为默认优先级。
2 调用board//.c中的board_init()根据具体的开发板对PORT进行设置。我修改这个文件使其支持我的开发板。
3 调用cpu/s3c44b0/interrupts.c 中的interrupt_init()初始化Timer1定时器使其在指定时间产生中断。
4 根据include/configs/.h配置文件中(CFG_ENV_IS_IN_<*>)环境变量保存位置选项来调用common/env_*.c对应文件中的env_init()。其作用是初始化环境变量。由于我的配置文件中的选项是CFG_ENV_IS_IN_FLASH,所以我修改board//flash.c使它支持我板子的FLASH。
5 调用本文件中的init_baudrate()来设置串口的波特率,这个函数的功能是可以使用环境变量对串口波特率进行修改。
6 调用cpu/s3c44b0/serial.c文件中的serial_init()对串口进行初始化。我修改这个文件使它支持我的开发板时钟频率对应的串口波特率。(下面介绍了串口波特率的计算公式)。
7 调用common/console.c文件中的console_init_f()对控制台进行初始化。
8 调用本文件中的display_banner()显示标题信息。
9 调用board//.c文件中的dram_init()对SDRAM进行初始化,其主要作用是在全局变量gd中设置SDRAM的起始地址与大小。
10 调用本文件中的display_dram_config()显示一些配置信息。
11 调用flash_init()来初始化FLASH。如果CFG_FLASH_CFI_DRIVER在配置文件中被定义,则调用drivers/cfi_flash.c中flash_init()驱动。否则将调用自己的FALSH驱动。

 

移植U-BOOT过程

一 为我的QT板子建立一个模板
1 cp –r board/dave board/51EDA
2 mv board/51EDA/B2 board/51EDA/QT
3 mv board/51EDA/QT/B2.c board/51EDA/QT/QT.c
4 cp include/configs/B2.h include/configs/QT.h
5 将board/51EDA/所有文件中的B2改为QT,将include/configs/QT.h中的B2改为QT。
6 修改Makefile和MAKEALL文件,为QT添加新的选项。
7 然后开始编译,能够正确通过,说明上面为我的QT板子建立的模板正确,下面开始修改模板中的文件使其支持自己的QT板子。
8 修改cpu/s3c44b0/start.S文件,根据自己的开发板提供的石英振荡频率(Fin)来设置自己想要的时钟主频。
9 修改board/51EDA/QT/lowlevel_init.S文件,根据自己的开发板对存储器(Bank)进行初始化。
10 修改board/51EDA/QT/QT.c文件,根据自己的开发板对PORT进行初始化。
11 修改board/51EDA/QT/flash.c文件,使它支持自己的开发板。
12 修改cpu/s3c44b0/serial.c文件,使它支持自己想要的波特率。
13 修改include/configs/QT.h文件,设置里面的选项使其满足自己的要求。

 

遇到的问题:

1. 在对应自己的开发板修改了board目录下的lowlevel_init.S,QT.c文件后串口终于出东西了。但是总是出现乱码,无论设置成什么样的时波特率,都是乱码,于是认为是自己的CPU主频的串口的波特率计算错误,查看相关资料修改了cpu目录下的start.S和serial.c文件中的系统时钟和串口波特率部分后,串口终于读到正确的数据了。(下面是有关cpu时钟频率和串口波特率的计算公式)。
S3C44B0的系统时钟设置公式
一. 通过PLL输出时钟脉冲频率的计算:
a) Fpllo = (m * Fin) / (p * 2s)
b) m = (MDIV + 8), p = (PDIV + 2), s = SDIV
c) 20MHz < Fpllo < 66MHz
d) Fpllo * 2s < 170MHz (s应该尽可能的大)
e) 1MHz <= Fin/p < 2MHz (最好是Fin/p = 1MHz)
f) 如果PLL打开则:Fpllo = Fout
g) 这样计算出MDIV, PDIV, SDIV的值写入PLLCON寄存器中就可设置Fpllo的输出频率。
二. PLL的锁存时间(为输出稳定时钟频率需要的平静时间)
a) T_lock = (1 / Fin) * n > 280us. (n = LTIMECNT value)
S3C44B0的UART波特率计算公式
UBRDIVn = ( (int)(MCLK / (bps * 16) + 0.5) – 1 )
MCLK = Fout = Fpllo
Bps = 1200,9600,19200,38400,57600,115200

2. 在使用printenv与bdinfo命令读取flash中的环境变量总是出错,并且每次读出的数据都不一样,在通过调试器进行观察后发现原来是DECLARE_GLOBAL_DATA_PTR的使用问题,这是当前我使用的这个版本(u-boot-1.1.4)的一个bug,于是换了一个更新的版本(u-boot-2006-05-10-1800),这个版本已经将这个bug去处掉了。终于读出了正确的环境变量。

3. 每当我使用出现错误死机重启后都无法正常启动,只有关掉电源10-30分钟后在启动就会正常,通过调试器对程序的观察发现,在start.S文件中将程序从flash复制到RAM中时,它只复制到了bss段的开始,而并没有对bss段进行复制(bss初始化为0的静态变量区),这样到的当我运行的程序出现错误对bss段进行了写入后,而内存在断电后数据并没有马上消失,这样就导致在重启后读取值为0的静态变量时出现了错误的数据。于是我修改了程序,让它将bss段也复制到内存,这样当重启后总是会对内存的bss段进行初始化。
建议用git直接从git repository里面拿最新的u-boot
git-clone http://www.denx.de/git/u-boot.git u-boot-git

 
原创粉丝点击