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