Linux内核分析之跟踪内核启动过程

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
    

启动效果如下:
Linux内核分析之跟踪内核启动过程_第1张图片

下一步,修改启动参数,进入调试模式
使用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 

调试窗口:
Linux内核分析之跟踪内核启动过程_第2张图片
start_kernel()处设置了断点,于是在内核运行的过程中,停止在了start_kernel()处。
Linux内核分析之跟踪内核启动过程_第3张图片

经过多次的设置断点,和查看源码,发现在内核的启动时,在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进程启动。。。

总结:
这节课看代码看得眼花。。。。

你可能感兴趣的:(Linux内核分析之跟踪内核启动过程)