您的位置:首页 > 编程语言

UBoot启动代码第一阶段流程

2013-09-11 09:30 281 查看
http://blog.csdn.net/xautfengzi/article/details/7470134

前段时间了看了UBoot的源码,放了一段时间之后忘得差不多了。现做一些注释,方便以后温习。

第一阶段代码主要位于start.S中,其流程如下:

1.设置中断向量表。

2.设置CPU为管理员模式。

3.禁狗。

4.关中断。

5.设置系统时钟。

6.跳至cpu_init_crit。(注意bl指令,bl指令是相对跳转,绝对跳转用mov lr,pc。由于此阶段代码是位置无关代码,所以在跳至的细节部分要仔细理解)


6.1.使缓存无效。




6.2.禁用MMU和缓存。




6.3.跳转至lowlevel_init设置内存时钟。




该函数具体分析可参考这里:/article/2973787.html



7.初始化NAND控制器。

8.设置堆栈、FP指针、ro、r1、r2这三个寄存器,作为实参。

9.跳转至nand_read_II中将UBoot拷贝至SDRAM中。

10.将刚才拷贝至SDRAM中的前4k内容与steppingStone里面的内容做比较。

11.设置SP指针,清空bss段。

12.跳至start_armboot,即第二阶段。

第一阶段结束时,内存中的分布如下图所示:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: