Linux系统内核第四周作业
跟踪分析 Linux 内核的启动过程
构建一个简单的linux内核
cd ~/LinuxKernel/
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img
qemu需要创建窗口,它在纯命令行系统下无法工作,需要使用图形化界面的虚拟机。
2.跟踪调试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)”,-S选项会把CPU在初始化之前冻结
重新打开一个shell窗口
cd ~/LinuxKernel/
# 打开 GDB 调试器
$ gdb
# 在 GDB 中输入以下命令:
# 在gdb界面中targe remote之前加载符号表
(gdb)file linux-3.18.6/vmlinux
# 建立gdb和gdbserver之间的连接,按c 让qemu上的Linux继续运行
(gdb)target remote:1234
# 断点的设置可以在target remote之前,也可以在之后
(gdb)break start_kernel
可以看到内核代码运行到start_kernel()函数时停止,通过list命名查看断点附近代码
再在rest_init处设置一个断点,按c继续执行
使用list查看断点附近代码
总结:
init_task()(PID为0)在创建了init进程后,调用cpu_idle()演变成了idle进程,执行一次调度后,init进程运行。1号内核线程负责执行内核的部分初始化工作及进行系统配置,最后调用do_execve加载init程序,演变成init进程(用户态1号进程),init进程是内核启动的第一个用户态进程。kthreadd(PID为2)进程由0号进程创建,始终运行在内核空间,负责所有内核线程的调度和管理
20222801 余酋龙
2022 年 10月 09日