您的位置:首页 > 运维架构 > Linux

《linux内核与分析》第三周

2016-03-13 13:23 459 查看
20135130王川东

实验:构造一个简单的Linux系统的MenuOS

命令:qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img、

命令含义:kernel启动一个内核,其后为内核位置。

initrd指定一个根文件系统。

使用gdb调试和跟踪:

 重新配置和编译Linux使之携带调试信息

命令:qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S

注:-S freeze CPU at startup (use ’c’ to start execution) CPU初始化之前冻结
-s shorthand for -gdb tcp::1234 在端口1234上创建gdb server (不想使用1234端口,则可以使用-gdb tcp:xxxx来取代-s选项)

另开一个shell窗口:

  (gdb)file linux-3.18.6/vmlinux # 在gdb界面中targe remote之前加载符号表

  (gdb)target remote:1234 # 建立gdb和gdbserver之间的连接,按c 让qemu上的Linux继续运行

  (gdb)break start_kernel # 断点的设置可以在target remote之前,也可以在之后

start_kernel函数中有全局变量init_task,即手工创建的PCB,0号进程即最终的idle进程。0号进程一直存在。当系统没有进程需要执行时就调度idle进程。

rest_init()中的run_init_process是linux中的一号进程,第一个用户态进程。
实验过程:

进入LinuxKernel,输入指令:



得到结果:



重新配置和编译Linux使之携带调试信息;输入命令:qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -S -s

此时QEMU为Stopped状态:



另开窗口,输入指令:

linux-3.18.6/vmlinux # 在gdb界面中targe remote之前加载符号表

target remote:1234 # 建立gdb和gdbserver之间的连接,按c 让qemu上的Linux继续运行

break start_kernel # 设置断点:



输入C,回车,QEMU开始执行:



输入list,可看到程序执行到此:



同样的方法,设置rest_init断点“



内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: