跟踪分析Linux内核的启动过程

跟踪分析Linux内核的启动过程

沙雨济 20122137
原创作品转载请注明出处 + 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
 
一 、实验内容:
使用gdb跟踪调试内核从start_kernel到init进程启动。
 
二 、实验过程:(附截图)
首先进入实验楼环境,进入LinuxKernel文件夹,可以看到文件里linux-3.18.6已经编译完成,前期工作已完成。根据提示代码,我们将其启动。
代码:
  1. cd LinuxKernel/
  2. qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img
技术分享
内核启动完成,可执行文件init被执行起来。输入help,可看见三个命令。
至此,linux系统构建完毕。
技术分享
接下来我们用gdb跟踪内核运行过程,在之前代码中加入参数—S -s,再次启动内核。
代码:
  1. qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S # 关于-s和-S选项的说明:
  2. # -S freeze CPU at startup (use ’c’ to start execution)
  3. # -s shorthand for -gdb tcp::1234 若不想使用1234端口,则可以使用-gdb tcp:xxxx来取代-s选项
可见,窗口运行被冻结。
技术分享 
另外打开一个窗口,用gdb把带有符号表的内核镜像加载进来,链接gdb server,设置断点来跟踪内核。
 
技术分享 
至此,实验结束。
至于自己搭建的linux环境,由于网速限制并没有构建成功。
技术分享 
ㄒoㄒ)/~~
 
三 、实验总结:
通过本次试验,初次认识了Linux内核的代码,通过内核启动,冻结,恢复和跟踪 更加深入了对start_kernel函数的执行。

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。