代码改变世界

跟踪调试Linux内核的启动过程

2016-03-10 10:20  20135128  阅读(1113)  评论(0编辑  收藏  举报

跟踪调试Linux内核的启动过程---使用gdb

 符钰婧

原创作品转载请注明出处

《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000 ”

 

本次的实验是使用gdb跟踪调试内核从start_kernel到init进程启动,并分析启动的过程。

 

1、首先是在实验楼虚拟机上进行调试跟踪的过程。

 (1) 先构造一个简单的Linux系统

 

(2) 接下来使用gdb跟踪调试内核

启动(窗口被冻结)

 

另开一个shell窗口(水平分割),然后gdb

 

先读取符号表,接着连接Linux系统并设断点(start_kernel)

 

按“c"回车,系统开始启动到start_kernel处:

 

 

“list”可看到start_kernel上下的代码

 

设断点rest_init并运行

 

“list”可看到rest_init上下的代码(可看出它是在start_kernel函数的尾部被调用)

 

还可再设断点(如kernel_init),查看运行结果

 

 

2、接下来简单分析一下start_kernel(这里只关注较重要的地方)

(1)先打开init目录下的main.c找到start_kernel:

 

510行处的init_task为全局变量,相当于一个进程的pcb,0号进程为最终的idle进程。

注:不管内核的哪一方面都会涉及到start_kernel。

(2) 搜索trap_init,找到arch/x86下的代码:

 

其中的一个硬件中断:

这里的SYSCALL_VECTOR是一个系统调用,用指令的方式来触发中断。

 

(3)之后有很多个初始化,需要注意的还有整个函数的最后一句rest init():

总结: