您的位置:首页 > 运维架构 > Linux

Linux内核的引导过程

2011-05-22 07:47 309 查看
总体上来讲:

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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: