总体上来讲: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.cstartup_32();start_kernel(): /init/main.c 初始化中断,进一步设置内存cpu_idle(): /init/main.cLinux监听子线程的函数Ubuntu下查看Printk的输出相关资讯 Linux内核
- IT人员必须了解的六项Linux内核变 (今 12:05)
- Linux 内核更新:3.10.98、3.14.62 (02月26日)
- Linux:让手机运行主线内核 (11/26/2015 22:16:17)
| - Linux内核自防护项目 (05月24日)
- Linux 内核架构的理解 (12/09/2015 09:01:01)
- Linux内核被指缺乏安全性 (11/07/2015 08:28:47)
|
本文评论 查看全部评论 (0)