Linux内核分析课程实验三:跟踪分析Linux内核的启动过程
白杰 原创作品转载请注明出处《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000
内核使用的是课程视屏中使用的linux-3.18.6
x86 CPU 上电后从0xffff0读第一条指令,CS:EIP=0xf000:fff0,这是一条跳转指令,跳转到BIOS中。BIOS完成硬件检测和初始化,然后寻找主引导记录,引导程序bootloader负责操作系统初始化,启动操作系统。
1.内核启动过程包括start-kernel()之前和之后,之前做的全部是初始化的汇编指令,完成一些最基本的初始化与环境设置工作,比如内核代码载入内存并解压缩,CPU的最基本初始化,为c代码的运行设置环境。在start_kernel()中linux将完成整个系统内核的初始化,内核初始化的最后一步是启动init进程,这是系统的0号进程,是所有进程的父进程。
2. 跟踪分析linux内核的启动过程从init/main.c中的start_kernel()函数开始。
asmlinkage __visible void __init start_kernel(void)//内核函数入口
{
......
......
/* Do the rest non-__init'ed, we're now alive */
rest_init();
}
在rest_init()
之前的代码完成一些初始化设置的工作,如trap_init()
涉及中断相关的设置;set_task_stack_end_magic(&init_task)
涉及堆栈相关的设置;mm_init()
涉及内存管理相关的设置; sched_init()
涉及进程调度相关的设置。其他的很多函数功能比较繁琐,不做讨论