一、跟踪分析内核的启动过程实验 :
1.启动Menuos:
qemu仿真kernel:
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img

2.调试跟踪:
-S 开始处冻结CPU,方便调试
-s 使用tcp端口1234来进行通讯,将进程信息传过去(在后面的调试中会用到)。若不想使用1234端口,可以使用-gdb tcp:xxxx来取代-s选项

启动gdb,把内核加载进来,建立连接:
file linux-3.18.6/vmlinux
target remote:1234
在 start_kernel 处设置断点,继续执行,停在断点处:

在 rest_init 处设置断点,继续执行,停在断点处:


本文详细跟踪分析了Linux内核的启动过程,从qemu仿真kernel开始,通过gdb调试,深入start_kernel、init_task、rest_init等关键函数。重点解析了init_task作为0号进程的角色,以及kernel_thread如何创建内核线程。文章还总结了调度器的模块化结构和红黑树的数据结构,并讨论了进程调度与加锁机制的重要性。
最低0.47元/天 解锁文章
1226

被折叠的 条评论
为什么被折叠?



