- 21
- 0
- 约6.73万字
- 约 86页
- 2016-06-07 发布于重庆
- 举报
02-U-boot的启动过程源码分析
U-Boot的启动过程源码分析
U-Boot属于两阶段的Bootloader,第一阶段的文件为cpu/arm920t/start.S和board/smdk2410/lowlevel_init.S,前者是平台相关,后者是开发板相关。
[编辑] U-Boot第一阶段代码分析
它与15.1.2节中描述的Bootloader第一阶段所完成的功能可以一一对应:
(1)硬件设备初始化。
依次完成如下设置:将CPU的工作模式设为管理模式(svc),关闭WATCHDOG,设置FCLK、HCLK、PCLK的比例(即设置CLKDIVN寄存器),关闭MMU、CACHE。
代码都在cpu/arm920t/start.S中,注释也比较完善,读者有不明白的地方可以参考前面硬件实验的相关章节。
(2)为加载Bootloader的第二阶段代码准备RAM空间。
所谓准备RAM空间,就是初始化内存芯片,使它可用。对于S3C2410/S3C2440,通过在start.S中调用lowlevel_init函数来设置存储控制器,使得外接的SDRAM可用。代码在board/smdk2410/lowlevel_init.S中。
注意:lowlevel_init.S文件是开发板相关的,这表示如果外接的设备不一样,可以修改lowlevel_init.S文件中的相关宏。
lowlevel_init函数并不复杂,只是要注意这时的代码、数据都只保存在NOR Flash上,内存中还没有,所以读取数据时要变换地址。代码如下:
129 _TEXT_BASE:
130 .wordTEXT_BASE
131
132 .globl lowlevel_init
133 lowlevel_init:
134 /* memory control configuration */
135 /* make r0 relative the current location so that it */
136 /* reads SMRDATA out of FLASH rather than memory ! */
137 ldr r0, =SMRDATA
138 ldrr1, _TEXT_BASE
139 subr0, r0, r1
140 ldrr1, =BWSCON/* Bus Width Status Controller */
141 add r2, r0, #13*4
142 0:
143 ldr r3, [r0], #4
144 str r3, [r1], #4
145 cmp r2, r0
146 bne 0b
147
148 /* everything is fine now */
149 movpc, lr
150
151 .ltorg
152 /* the literal pools origin */
153
154 SMRDATA:/* 13个寄存器的值 */
155 .word ……
156 .word ……
第137~139行进行地址变换,因为这时候内存中还没有数据,不能使用连接程序时确定的地址来读取数据:
第137行中SMRDATA 表示这13个寄存器的值存放的开始地址(连接地址),值为0x33F8xxxx,处于内存中。
第138行获得代码段的起始地址,它就是第130行中的“TEXT_BASE”,其值在board/smdk2410/config.mk中定义:“TEXT_BASE = 0x33F80000”。
第139行将0x33F8xxxx与0x33F80000相减,这就是13个寄存器值在NOR Flash上存放的开始地址。
(3)拷贝Bootloader的第二阶段代码到 RAM 空间中。
这里将整个U-Boot的代码(包括第一、第二阶段)都复制到SDRAM中,这在cpu/arm920t/start.S中实现:
164 relocate:/* 将U-Boot复制到RAM中 */
165 adrr0, _start/* r0 = 当前代码的开始地址 */
166 ldrr1, _TEXT_BASE/* r1 = 代码段的连接地址 */
167 cmp r0, r1 /* 测试现在是在Flash中还是在RAM中 */
168 beq stack_setup/* 如果已经在RAM中(这通常是调试时,直接下载到RAM中),
* 则不需要复制
*/
169
170 ldrr2, _armboot_start/* _armboot_start在前面定义,是第一条指令的运行地址 */
171 ldrr3, _bss_start/* 在连接脚本u-boot.lds中定义,是代码段的结束地址
您可能关注的文档
- (word版,有答案)四川达州市2015年中考题.doc
- (五)招标文件确认书.doc
- (人教版)变阻器.doc
- (人教新课标)四年级品德与社会下册教案交通与我们的生活.doc
- (农璐萍)高中地理学科教学培养学生使用课文插图的研究.doc
- (四年上)第56课用颜色填充喷枪.doc
- (好题)经济生活第二课.doc
- (含答案解析)山东省淄博市2015届高三下学期3月第一次模拟考试物理试题.doc
- (新)浅谈平板支撑.doc
- (打印)金工实习报告模板.doc
- 2026年场(厂)内专用机动车辆作业考试题库200道附参考答案【预热题】.docx
- 2026年场(厂)内专用机动车辆作业考试题库200道附参考答案(巩固).docx
- 2026年场(厂)内专用机动车辆作业考试题库200道附参考答案(培优a卷).docx
- 2026年场(厂)内专用机动车辆作业考试题库200道附参考答案【模拟题】.docx
- 2026年场(厂)内专用机动车辆作业考试题库200道附参考答案(精练).docx
- 2026年场(厂)内专用机动车辆作业考试题库200道带答案(能力提升).docx
- 2026年场(厂)内专用机动车辆作业考试题库200道附参考答案【能力提升】.docx
- 2026年场(厂)内专用机动车辆作业考试题库200道附参考答案(满分必刷).docx
- 2026年场(厂)内专用机动车辆作业考试题库200道附参考答案【突破训练】.docx
- 2026年场(厂)内专用机动车辆作业考试题库200道附参考答案(培优).docx
原创力文档

文档评论(0)