Author:宵伯特
原创作品转载请注明出处
《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
实验内容:
-
使用实验楼的虚拟机打开shell
cd LinuxKernel qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img
启动效果如下:
下一步,修改启动参数,进入调试模式
使用gdb跟踪调试内核
qemu -kernel linux-3.18.6/arch/x86/boot/bzImage -initrd rootfs.img -s -S
打开另外一个shell,进入gdb调试窗口
gdb
(gdb)file linux-3.18.6/vmlinux
(gdb)target remote:1234
(gdb)break start_kernel
调试窗口:
在 start_kernel()
处设置了断点,于是在内核运行的过程中,停止在了start_kernel()
处。
经过多次的设置断点,和查看源码,发现在内核的启动时,在start_kernel()
函数中,初始化了大量的内核组件和硬件设备状态,例如在start_kernel()
函数中有如下函数:
boot_cpu_init();
trap_init();
mm_init();
sched_init();
rest_init();
等,也就说明了start_kernel()
主要起到环境启动初始化的作用。
在rest_init()
中有发现有
kernel_thread(kernel_init, NULL, CLONE_FS);
init_idle_bootup_task(current);
schedule_preempt_disabled();
其中, kernel_thread(kernel_init, NULL, CLONE_FS);
启动了一号进程,从而启动了kernel_init()
,从而进入了内核进程的启动运行状态。
在init_idle_bootup_task(current);
中初始化了idle进程的状态,通过schedule_preempt_disabled();
函数:
void __sched schedule_preempt_disabled(void)
{
sched_preempt_enable_no_resched();
schedule();
preempt_disable();
}
通过执行schedule();
使得idle进程启动。。。
总结:
这节课看代码看得眼花。。。。