码迷,mamicode.com
首页 > 系统相关 > 详细

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

时间:2015-05-03 20:36:02      阅读:271      评论:0      收藏:0      [点我收藏+]

标签:

跟踪分析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函数的执行。

 

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

标签:

原文地址:http://www.cnblogs.com/Diky/p/4474562.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!