Linux内核的引导过程


总体上来讲:

BIOS->MBR->GRUB(LILO)->内核->用户空间

1. 系统上电时,cpu会将pc指针赋值为一个特定的地址0xffff0, 并且执行该地址处的指令。在pc中,该地址位于BIOS中。

2. BIOS按照CMOS中设定的启动顺序来搜索处于活动状态的,可以引导的设备。如果是硬盘,则读取MBR(512)个字节到RAM中,并将控制权交给这段程序。

3. 主引导加载程序查找并加载次引导加载程序。它在分区表中查找活动分区,当找到一个活动分区时,扫描其他分区,以确保它们不是活动的。当这个过程完成之后,将这个活动分区的引导记录读入RAM并执行它。

4. 次引导加载程序加载Linux内核和可选的初始RAMdisk, 并将控制权交给Linux内核。

5. 运行被加载的内核,并启动用户空间应用程序。

内核启动到用户空间的流程如下:

start() :                                                                      /arch/i386/boot/head.S     基本的硬件设置

startup_32():                                                            /arch/i386/boot/compress/head.S 初始化页表,启动内层分页机制。

          decompress_kernel():                                     /arch/i386/boot/compress/misc.c

startup_32();

start_kernel():                                                          /init/main.c  初始化中断,进一步设置内存

cpu_idle():                                                                /init/main.c

相关内容