- 1、本文档共4页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)