BOOTM浅析
来源:互联网 发布:php订单管理系统源码 编辑:程序博客网 时间:2024/05/21 07:53
原文:http://hi.baidu.com/chenenzhi/blog/item/1a6eaf54b7115a143b293588
与boom命令实现有关的源文件主要为common/cmd_bootm.c和lib_arm/armlinux.c。下面就这两个文件中的关键代码段进行分析。
common/cmd_bootm.c(前面数字为SourceInsight中显示的行号):
168if(argc < 2) {
判断运行bootm时是否指定了程序加载地址,若没有则使用默认的加载地址,load_addr在cmd_bootm.c中是这样定义的:
ulong load_addr = CFG_LOAD_ADDR;
183memmove (&header, (char *)addr,sizeof(image_header_t));
将image的header(u-boot添加的64Byte文件头)复制到header只向的内存。
185if(ntohl(hdr->ih_magic) != IH_MAGIC){
#ifdef __I386__
#endif
判断文件头中的幻数是否为IH_MAGIC,所以如果不是u-boot镜像格式,会输出提示信息”BadMagic Number”
204data =(ulong)&header;
比对u-boot image文件头的CRC32校验和。
229data = addr +sizeof(image_header_t);
比对u-boot image数据部分的校验和。
245#ifdefined(__PPC__)
#elif defined(__ARM__)
…
#else
# error Unknown CPU type
#endif
这部条件编译指令检验检验image header中的arch类型是否是否正确。
275switch (hdr->ih_type){
判断image的类型,这里只列出了KernelImage类型的代码,直接break,:)
switch (hdr->ih_comp) {
412switch (hdr->ih_os) {
#ifdef CONFIG_SILENT_CONSOLE
#endif
#ifdef DEBUG
#endif
既然内核已经解压完了,接下来就改启动Linux内核了,这里有用到了imageheader中的另一个字段ih_os:指明操作系统的类型,我只列出Linux操作系统类型的处理,可以看到它把控制权传递给了do_bootm_linux这个do_bootm_linux对于不同的ARCH有不同的实现,而ARM的实现就是在lib_arm/armlinux.c中。
armlinux.c :do_bootm_linux
83
initrd的起始地址和结束地址
85
Linux内核的入口参数,zero =0,arch为平台编号,params为传递给内核的参数在内存中的地址
89
#endif
如果在include/configs/<boardname>.h定义了CONFIG_CMDLINE_TAG则将bootargs环境变量传递给内核。所以如果发现无法向内核传递参数,应该检查一下CONFIG_CMDLINE_TAG是否定义。
93
hdr为指向imageheader的指针,hdr->ih_ep就是我们用mkimage创建image时-e选项的参数:内核的入口地址。
从98到207行为处理bootm命令传递的initrd参数。包括判断bootm是否传递了initrd参数,检验initrd的有效性(幻数,校验和等)
下面这一段代码在内核启动前,向内核传递参数(以Tag标记的形式),这段代码依赖于很多的宏定义,比如CONFIG_CMDLINE_TAG等,它们通常定义在include/configs/<boardname>.h中,所以如果要想u-boot给内核传递特定的标记,则必须定义相应的宏。传递标记是通过setup_<tagname>_tag函数完成的,具体可以参考cmd_boot.m里面的实现。
#if defined (CONFIG_SETUP_MEMORY_TAGS) ||
#ifdef CONFIG_SERIAL_TAG
#endif
#ifdef CONFIG_REVISION_TAG
#endif
#ifdef CONFIG_SETUP_MEMORY_TAGS
#endif
#ifdef CONFIG_CMDLINE_TAG
#endif
#ifdef CONFIG_INITRD_TAG
#endif
#if defined (CONFIG_VFD) || defined(CONFIG_LCD)
#endif
#endif
#ifdef CONFIG_USB_DEVICE
#endif
275 theKernel (0, bd->bi_arch_number,bd->bi_boot_params);
经过一系列的准备,终于到了启动内核的时候了,这里bd->bi_arch_number和bd->bi_boot_params在具体开发板的board_init函数里面初始化,比如对于smdk2410的board_init:
106
107
- BOOTM浅析
- u-boot bootm命令浅析
- u-boot bootm命令浅析
- bootm
- bootm
- Bootm命令
- bootm命令
- bootm命令
- bootm命令分析
- bootm内核的启动
- uboot bootargs bootcmd bootm
- bootm 与 go
- Bootm的流程分析
- uboot bootargs bootcmd bootm
- Bootm的流程分析
- uboot bootargs bootcmd bootm
- uboot bootargs bootcmd bootm
- 四十二.移植bootm命令
- 线段树(区间树)
- java.sql.SQLException: Io exception: Connection refused(DESCRIPTION=(TMP=)(VSNNUM=169869568)(ERR=125
- 如何手动配置C#开发环境。
- jsp 页面设置no-cache
- debian中开启语法高亮显示
- BOOTM浅析
- 广东佛山财政局长:政府要敢于举债-举债-政府-债务
- android网络电话源码
- NSDateFormatter setDateFormat 自定义日期/时间格式
- 一些有用的东西集合
- 解决Cent OS在Virtual PC中花屏和鼠标使用问题
- 织梦后台更改rss、sitemap生成路径
- bootargs参数意义
- 一个题目涉及到的50个Sql语句