分析uboot是如何启动内核的

分析uboot是如何启动内核的

ID:37716319

大小:25.45 KB

页数:12页

时间:2019-05-29

分析uboot是如何启动内核的_第1页
分析uboot是如何启动内核的_第2页
分析uboot是如何启动内核的_第3页
分析uboot是如何启动内核的_第4页
分析uboot是如何启动内核的_第5页
资源描述:

《分析uboot是如何启动内核的》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、分析uboot是如何启动内核的 (2011-12-2719:16:30)转载▼标签: 鏉傝皥1.uboot启动内核的代码缩减如下:s=getenv("bootcmd");debug("###main_loop:bootcmd="%s"",s?s:"");if(bootdelay>=0&&s&&!abortboot(bootdelay)){        run_command(s,0);}2.假设bootcmd=nandread.jffs20x30007FC0kernel;

2、bootm0x30007FC0<1>nandread.jffs20x30007FC0kernelnandread.jffs20x30007FC0kernel;从nand读出内核:从哪里读?   从kernel分区        放到哪里去?-0x30007FC0下面讲解什么是分区:就是将nand划分为几个区域,一般如下:bootloader-》params-》kernel-》root这些分区的划分是在/include/configs/mini2440.h中写死的:#defineMTDPARTS_DEFA

3、ULT"mtdparts=nandflash0:250k@0(bootloader),"           "128k(params),"           "5m(kernel),"           "-(root)"注:@0表示从0地址开始,250k的bootloader分区可能对某些uboot不够用,这里只是举例而已。将上面的信息换算成十六进制:#    name             大小        在nand上的起始地址    0    bootloader     0x0

4、0040000        0x000000001    params        0x00020000              0x00040000        2    kernel        0x00200000        0x000600003    root        0xfda00000        0x00260000那么上面的nandread.jffs20x30007FC0kernel就等价于:nandread.jffs20x30007FC00x000600000x

5、00200000注:这里的read.jffs2并不是指定要什么特定的格式,而是用read.jffs2不需要块/页对齐,所以这个kernel的分区大小可以随意定。<2>bootm0x30007FC0关键函数do_bootm()flash上存的内核:uImageuImage=头部+真正的内核头部的定义如下:typedefstructimage_header{    uint32_t    ih_magic;        uint32_t    ih_hcrc;        uint32_t    ih_

6、time;        uint32_t    ih_size;        uint32_t    ih_load;        uint32_t    ih_ep;            uint32_t    ih_dcrc;        uint8_t        ih_os;            uint8_t        ih_arch;        uint8_t        ih_type;        uint8_t        ih_comp;        u

7、int8_t        ih_name[IH_NMLEN];    }image_header_t;我们需要关心的是:    uint32_t    ih_load;        uint32_t    ih_ep;        ih_load是加载地址,即内核运行是应该位于的地方  ih_ep是入口地址,即内核的入口地址这与uboot是类似的,uboot的加载地址是TEXT_BASE=0x33F80000;入口地址是start.S中的_start。其实我们把内核中nand读出来的时候是可以放在

8、内核的任何地方的,如0x31000000,0x32000000等等,只要它不破坏uboot所占用的内存空间就可以了,如下图:从0x33F4DF74-0x30000000都是可以用的。那么为什么既然设定好了加载地址和入口地址内核还能随意放呢?那是因为uImage有一个头部!头部里有加载地址和入口地址,当我们用bootmxxx的时候,do_bootm这个函数会先去读uImage的头部以获取该uImage的加载地址和入口地址,当发现该uImage

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。