首页 > 代码库 > Linux嵌入式驱动学习之路⑥u-boot启动内核
Linux嵌入式驱动学习之路⑥u-boot启动内核
内核启动是需要必要的启动参数。不能开机自动完全从0开始启动,需要uboot帮助内核实现重定位并提供参数。
首先,uboo会从Kernel分区中读取bootcmd环境变量,根据环境变量可自动启动。
分区:
每个硬盘上都有一个分区表。由于Flash中没有分区表,所以Flash的分区只能在源代码中定义,故无法更改。
mtdparts=nandflash0:256k@0(bootloader),128k(params),2m(kernel),-(root)
注:@0 表示从0开始。
在启动之前,先从NandFlash中读出内核,放到内存中。而uImage = 头部+真正的内核。
头(64字节):
ih_load:加载地址,即内核运行是应该位于的地方。
ih_ep: 入口地址,即内核的入口地址。
这和uboot很相似。uboot的加载地址是TEXT_BASE,入口地址是start.S中的_start。
bootm完成的工作:
1.读取头部
2. 根据头部信息移动内核
2. 启动内核。
在启动的时候,uboot需要告诉内核一些启动参数。即设置参数。
跳转到内核的第一条代码。
启动内核时,用头部的入口地址作为函数指针(thekernel),来启动。
setup_start_tag()
setup_memory_tag()
setup_commandline_tag()
setup_end_tag()
sd
Linux嵌入式驱动学习之路⑥u-boot启动内核
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。