作者:王鹤楼
原创作品转载请注明出处
《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
在实验楼中使用gdb调试内核:
cd LinuxKernel/
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S
执行命令后就可能进入到MenuOS应用程序的命令行界面,此可以执执行ls, versin,quit命令
使用gdb调试内核:
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S
在另一个shell中执行
gdb
(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处
按c后内核继续执行
start_kernel函数在init/main.c中
asmlinkage void __init start_kernel(void)
{
.......
/*init_task即手工创建的PCB,0号进程就是最终的idle进程*/
set_task_stack_end_magic(&init_task);
........
/*初始化中断向量*/
trap_init();
/*内存管理模块初始化*/
mm_init();
/*调度模块初始化*/
sched_init();
....
/*其他初始化*/
rest_init()
}
最后是rest_init()
rest_init 是0号进程,并创建1号进程和其他服务进程,此进程会一直执行下去,如果有新进程则执行,在系统没有任何需要执行的进程时,调度到此进程。