x86计算机的启动初期流程 Linux 启动流程

x86计算机的启动初期流程

CPU:

step1,加点开机,cpu自己初始化

step2,cpu 从物理地址 0xFFFFFFF0h 取指令执行;此处存放BIOS代码,这些代码可以是由主板自动从 EEPROM中拷贝至此内存地址处;即下面将执行的 POST 代码

BIOS:

step3,POST:加电自检(Power-On Self-Test, POST):计算机通电后,BIOS会执行自检程序,检查硬件是否正常工作。

step4,测试成功 则继续下面的步骤,否则显示出错信息;

step5,加载 BIOS 的中断向量到物理内存的最低1024字节单元中去;

step6,执行 INT 19h 软中断调用,根据 CMOS 的设置,顺序地从引导盘搜寻引导扇区(以55AA为标志该盘为引导盘),找到第一个引导盘的引导扇区后,继续下一步;

补充:MBR 主引导记录在磁盘的0磁头0柱面1号扇区,BIOS的代码会锁定这个位置查看。

MBR 由三部分构成:

(1)446字节的引导记录,负责检查硬盘分区表、寻找可引导分区、将可引导的活动分区记录DBR装入内存,它位于硬盘的每一分区的第一个扇区;

(2)硬盘分区表16x4=64,每份16字节的4份硬盘分区表,其中记录了每个分区的类型,分区size,和分区开始与结束的位置等;

(3)magic Number 55AAH ,占2个字节,是MBR结束标志

MBR 总共占 446 + 64 + 2 = 512 bytes

step7,执行 INT 13h 软中断调用,从引导扇区取 MBR 值DBR转存到内存00007C00处,并跳转到该处开始执行,即将控制权交给引导扇区的引导程序。

上述3~7步由BIOS完成,开源的BIOS可参考复古8088PC的 8088_bios 和 快跑的 Coreboot:

GitHub - skiselev/8088_bios: BIOS for Intel 8088 based computers

GitHub - coreboot/coreboot: Mirror of https://review.coreboot.org/coreboot.git. We don't handle Pull Requests.

Loader:

step8,执行引导程序:引导扇区中包含引导程序(Boot Loader),比如 grub2,该程序负责加载操作系统的核心部分到内存中,例如 vmlinux,并启动操作系统的运行。

上述由引导程序完成,可参考 grub2:

GNU GRUB - Obtaining GRUB

https://github.com/rhboot/grub2

GNU GRUB Manual 2.12

OS:

step9,启动操作系统:引导程序加载完操作系统核心后,控制权被转移到操作系统内核,操作系统开始初始化并启动系统服务。

Linux。。。

相关推荐
handler018 分钟前
Linux基础知识(1)
linux·服务器·c语言·开发语言·数据结构·c++
ん贤11 分钟前
手敲Linux命令
linux·运维·服务器
泽020218 分钟前
OJBalancer ----- 基于负载均衡仿leetcode的刷题界面
linux·leetcode·负载均衡
花间相见23 分钟前
【Linux进阶01】—— tmux原理与实战教程
linux·运维·服务器
Bert.Cai26 分钟前
Linux groupadd命令详解
linux·运维
路溪非溪26 分钟前
抓取手机的蓝牙HCI日志并分析
linux·arm开发·驱动开发·智能手机
有谁看见我的剑了?27 分钟前
新服务器上线优化调整
linux·运维·服务器
成为你的宁宁27 分钟前
【apt update突然报错Temporary failure resolving ‘cn.archive.ubuntu.com‘】
linux·运维·ubuntu
凤年徐32 分钟前
【Linux从入门到进阶】打包压缩、跨平台互传、内核版本、热键历史、关机与Shell原理一篇全搞定
linux·运维·服务器
i建模34 分钟前
Linux 服务器上配置 XFCE 桌面以实现远程登录
linux·运维·服务器