计算机系统的启动是一个复杂的过程,启动过程大致可以分为以下几个阶段:

+------计算机系统启动流程----------------------------- --------------------+
|+-----------------+ +------------------+ +----------------+|
|| | | | | ||
|| 管理控制单元上电 |----->| cpu上电 |---->| BIOS引导 ||
|| | | | | ||
|+------------------+ +-------------------+ +-------+---------+|
| | |
| +-------<-------------------------<--------------+ |
| | |
| | |
|+---------+-------+ +------------------+ +----------------+|
|| | | | | ||
|| 加载OS内核 |----->| 系统软硬件初始化 |---->| 启动init进程 ||
|| | | | | ||
|+------------------+ +-------------------+ +-----------------+|
+-----------------------------------------------------------------------+

其中最开始的2个阶段是属于机械物理过程,最后2个阶段主要是按照一定的顺序来执行软件程序,这几个阶段都较为直观简单,中间的2个阶段从BIOS开始到系统执行内核启动函数start_kernel()结束。

  那么先来说说bios,计算机基本输入输出系统,通俗点讲是保存在ROM的一组程序,计算机系统上电后cpu执行的第一个程序就是bios程序,这里有一个问题:

在系统上电的一瞬间,内存、cpu相关的一些寄存器都是空白的,bios程序是如何开始执行的呢?

  从系统体系的角度看,既然bios不能由软件来触发执行,那么只能由硬件逻辑来实现。Intel 80x86 系列的cpu分为实模式和保护模式,实际上是,在cpu上电的一瞬间即进入实模式运行,同时硬件逻辑将cpu的cs寄存器和ip寄存器设置为:0xFFFF-0x0000,计算机体系将bios程序的入口写死在这个地址上,同时cpu在实模式下的地址即为绝对地址,cpu根据cs+ip找到了bios程序的入口的物理地址,load第一条bios指令到cpu开始执行。bios程序主要干两件事情:硬件检测和配置、加载os 的内核。注意bios程序是不会直接去加载os 内核的,那么:

bios程序为什么不直接加载os 内核, os内核是由谁来加载的呢?

  从硬件设计的角度考虑,如果将内核加载的细节固化在硬件中,那么内核的设计和安装必须严格遵循这一套硬件逻辑,这无疑很大程度上限制了软件的灵活性,另外将内核加载细节固化在bios中,也增加了bios程序的复杂度。因此在bios和内核之间,增加了bootloader软件模块,内核的加载由内核对应的bootloader实现,bios不直接加载内核,bios启动bootloader程序,由bootloader程序来加载内核,对于linux 内核,其bootloader程序就是我们熟知的grub。那么:

bios如果找到bootloader,bios找到bootloader加载到内存后,在执行bootloader前要做哪些初始化?

  接下来以linux os为依据,其他类型的os过程类似,linux kernel的bootloader为所熟知的grub程序(0.93 version),grub 一般会随 linux os一起安装。grub的引导分成了几个阶段:stage1、stage1.5、stage2,软件层面上对应于几个独立的软件模块,stage1的代码文件,是源码目录下stage1/stage1.S,汇编后便成了一个512字节的img,被写在硬盘的0面0道1扇区,作为硬盘的主引导扇区,主引导扇区=主引导记录 MBR+磁盘分区表 DPT。Stage1作为grub引导的开始,并且Stage1被放在磁盘的固定位置0面0道1扇区,因此在硬件逻辑实现上bios例程启动grub引导的过程是:bios通过raw read读0面0道1扇区的512字节到内存,至此bios引导结束,控制权交给grub 并开始grub 引导。

grub的引导流程?

  grub(.93version)的大致引导过程:stage1--->start--->stage1.5--->stage2--->OS kernel。

  

待续~~~~

参考资料:

1、http://www.linuxsir.org/bbs/thread170348.html?pageon=2

2、

内核加载与linux的grub的更多相关文章

  1. Linux内核加载全流程

    无论是Linux还是Windows,在加电后的第一步都是先运行BIOS(Basic Input/Output System)程序——不知道是不是所以的电脑系统都是如此.BIOS保存在主板上的一个non ...

  2. bootm命令中地址参数,内核加载地址以及内核入口地址

    bootm命令只能用来引导经过mkimage构建了镜像头的内核镜像文件以及根文件镜像,对于没有用mkimage对内核进行处理的话,那直接把内核下载到连接脚本中指定的加载地址0x30008000再运行就 ...

  3. 基于TFTP方式加载启动Linux内核

            一.软硬件平台 1.开发板:创龙AM3359核心板,网口采用RMII形式. 2.UBOOT版本:U-Boot-2016.05,采用FDT和DM. 3.交换芯片MARVELL的88E63 ...

  4. Linux驱动之内核加载模块过程分析

    Linux内核支持动态的加载模块运行:比如insmod first_drv.ko,这样就可以将模块加载到内核所在空间供应用程序调用.现在简单描述下insmod first_drv.ko的过程 1.in ...

  5. Linux0.11内核--加载可执行二进制文件之3.exec

    最后剩下最核心的函数do_execve了,由于这里为了简单起见我不分析shell命令的情况, /* * 'do_execve()'函数执行一个新程序. */ //// execve()系统中断调用函数 ...

  6. Linux0.11内核--加载可执行二进制文件之1.copy_strings

    从现在开始就是分析最后的核心模块exec.c了,分析完这个文件后,就会和之前的所有分析形成一个环路,从创建进程.加载进程程序到进程调度.内存管理. exec.c的核心do_execve函数很长,而且用 ...

  7. 使用Windows安装的最高版本IE内核加载内嵌页(转载)

    客户端程序内嵌Webbrowser控件时,默认情况都是使用IE7兼容模式打开网页的.但是IE7有很多新的特性不支持,导致无法正常显示出来,所以需要强制使用高版本的IE内核来加载.渲染. void Ch ...

  8. 内核加载模块时提示usb_common: exports duplicate symbol of_usb_get_dr_mode

    1.分析: 既然符号重复了,那么说明有一个部分既被编译到内核中也被编译成模块了,因此在加载模块时,内核报符号重复的提示 2.解决 直接配置内核的某一部分编译成模块,例如笔者就直接将USB这一部分编译成 ...

  9. 内核加载模块时出现Unknown symbol等提示

    一.背景 1.更改了内核的配置,重新编译了内核 2.未重新编译内核模块 3.板子上只更新了内核,并未更新文件系统 二.分析 发现是在加载内核模块时出现Unknown symbol等信息,恰逢当时只更新 ...

随机推荐

  1. IHttpModule与IHttpHandler的区别整理

    IHttpModule与IHttpHandler的区别整理1.先后次序.先IHttpModule,后IHttpHandler. 注:Module要看你响应了哪个事件,一些事件是在Handler之前运行 ...

  2. CSS Sprite小图片自动合并工具

    css-sprite是将css样式中零星的小图标,小图片合并成大图显示,这样能减小服务器并发连接数,减小服务器负载和带宽使用,有很高的实用价值.这里介绍一些自动合并图片并生成样式的工具. NodeJS ...

  3. Android基础知识巩固:关于PendingIntent和广播

    平时使用广播的场合比较多,但细节的东西,看过了也没有总结,以至于某些场合有小问题,还是要把原理和属性搞清楚才能运用自如. 其实也是自己比较懒,先看别人的blog,有个概念再去官网看英文的能好理解一些. ...

  4. Android UI高级交互设计Demo

    首先:是google的新标准 Google Material design 开源项目 1.直接拿来用!十大Material Design开源项目 2.收集android上开源的酷炫的交互动画和视觉效果 ...

  5. c# session总结

    C# 中对 Session 的“(string)”.“.ToString()”与“Convert.ToString”用法笔记 在实际操作当中,我们经常会遇到将 Session 的值转为 String ...

  6. 思考----拒绝单纯copy

    工作4个多月以来感触最深的是: 做事情的时候遇到不会的可以上网查或者问别人,但是获取到的知识不能只是单纯的copy过来使用达到要求就ok, 更重要的是事后等有空了一定要仔细研究学习,使知识网络完整,这 ...

  7. mina 实例(转载)

    mina:http://mina.apache.org/ 原文:http://maosheng.iteye.com/blog/1891665 大并发量socket 通信框架MINA介绍 博客分类: J ...

  8. lua math libary

    函数名 描述 示例 结果 pi 圆周率 math.pi 3.1415926535898 abs 取绝对值 math.abs(-2012) 2012 ceil 向上取整 math.ceil(9.1) 1 ...

  9. python 程序中设置环境变量

    python 中调用系统命令有三种方法: 1.os.system('command') ,这个方法是直接调用标准C的system() 函数,仅仅在一个子终端运行系统命令,而不能获取命令执行后的返回信息 ...

  10. 富文本编辑器ckeditor继承

    新建一个web项目ckfinder,导入lib包 加入java包,编码格式UTF-8 在WebRoot下添加ckedtior以及ckfinder两个文件夹,将config.xml拷入WEB-INF中 ...