linux bootargs参数解析.doc

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
linux bootargs参数解析

【原创】Linux启动bootargs参数分析 Written by leeming 这几天刚好在看linux c语言启动,现在就顺便把内核在启动时解析bootargs这一块单独拎出来讲解下,内核对于bootargs的解析分为几块: setup_arch(command_line); 综述:在这个函数中,系统会获得bootargs参数,并对其做简单的初步分析。并将bootargs的参数保存在command_line这个地址中。 详解: 先获得bootargs的地址,uboot传进来的参数是放地方的 //一般默认为0置//boot_params 如果为0则表示bootloader没有传参数 if (mdesc-boot_params) tags = phys_to_virt(mdesc-boot_params); 是通过标签ATAG来辨别的, uboot中有相应的标签字,将相应的uboot参数放置到相应的全局变量中。 if (tags-hdr.tag == ATAG_CORE) { //已经被fixup函数修改,则将atag中的mem段置为none if (meminfo.nr_banks != 0) squash_mem_tags(tags); //继续把atag的参数传递结束, 通过参数的类型(比如ATAG_CMDLINE,ATAG_MEM诸如此类的参数)将bootargs参数全部分析完毕。 parse_tags(tags); { extern struct tagtable __tagtable_begin, __tagtable_end; struct tagtable *t; //我们的参数是放在__tagtable_begin到__tagtable_end区间内,各个类型的通过__tagtable的宏定义在编译的时候就将其定位在这个区间,我们的每一个参数只需要和每个宏比较,并调用其对用的parse函数。 //对于我们一般的bootargs,只传递了ATAG_CMDLINE,而在其对应的parse函数就是把传递进来的cmdline存放到default_command_line中。 for (t = __tagtable_begin; t __tagtable_end; t++) if (tag-hdr.tag == t-tag) { t-parse(tag); break; } return t __tagtable_end; } } 将cmdline存放至saved_command_line中 //在setup_arch函数刚开始就定义了char *from= default_command_line,因此通过下面这个函数实现把cmdline存放至saved_command_line中。 memcpy(saved_command_line, from, COMMAND_LINE_SIZE); 对cmdline做简单的 分析,主要是mem和initrd的 这里的处理和B步比较类似,通过对cmdline中的一个个参数和__early_begin到__early_end间的参数进行比较。从而得到匹配的参数,然后调用其相应的parse函数进行处理,同时将剩余部分存放到setup_arch(command_line)传进来的字符串指针command_line中。。这部分先对cmdline进行分析是因为接下来就需要对页表进行建立,所以必须知道内存mem和initrd文件系统的信息,所以这部分属于early,parse的参数很少。其余的参数解析都留至后面的参数分析中。 parse_early_param(); 综述:第二次分析cmdline,不过在这里分析的是系统能够辨别的一些早期参数(这个函数甚至可以去掉),而且在分析的时候并不是以setup_arch(command_line)传出来的command_line为基础,而是以最原生态的saved_command_line为基础的。 详解: parse_args(early options, tmp_cmdline, NULL, 0, do_early_param); { args = next_arg(args, param, val);//一个个参数分离 ret = parse_one(param, val, params, num, unknown(就是do_early_param));//解析参数 由于传进去的num为0,因此对于每一个参数param和值value,直接调用do_early_param解析。 } // do_early_param

文档评论(0)

xcs88858 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档