实验
- 在gdb中设置断点start_kernel
- 执行到断点rest_init
- 执行到kernel_init
- 执行到run_it_process,启动用户态1号进程
- 执行完毕,系统成功启动
关于start_kernel执行的分析
- strat_kernel是内核的基础,不管哪个模块都要调用start_kernel才能执行。所以不管分析内核的哪一部分都会涉及到start_kenel。
- 在start_kenel中,init_task即手工创建的PCB, 0号进程即最终的idle进程。
- trap_init涉及中断模块。
- 最后调用了rest_init,rest_init是涉及调用其他函数,rest_init里面的run_init调用0号进程。rest_init从start_kernel启动后会一直存在,0号进程创建了1号进程kernel_init, 还创建了一些服务。
- 这样系统就启动起来了。
总结
Linux系统启动过程包含start_kernel之前和之后,之前全部是做初始化的汇编指令,之后开始C代码的操作系统初始化,最后执行第一个用户态进程init。0号进程启动后,原执行序列调用cpu_idle() 等待调度。0号进程创建好之后,创建了1号进程kernel_init。