聊聊x86计算机启动发生的事?

这篇具有很好参考价值的文章主要介绍了聊聊x86计算机启动发生的事?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

大家好,我是呼噜噜,最近在看linux早期内核0.12的源码,突然想到一个困扰自己好久的问题:当我们按下电源键,计算机发生了什么?神秘地址0x7C00究竟是什么?操作系统又是如何被加载到硬件中的?带着这些问题,继续往下阅读本文。

x86计算机启动过程,主要分为这几个阶段:BIOS自检,引导设备的选择,主引导记录,加载操作系统

BIOS自检

当电源自检通过后,主板会通电,开始读取ROM里面的BIOS程序,进行BIOS自检BIOS(Basic Input Output System,基本输入输出系统),它负责管理和控制计算机硬件设备,本质上是一组"程序代码"。

BIOS作为计算机开机之后,CPU要进行处理的第一个“可执行程序”,也就是第一个“开机启动项”。其程序代码事先被刷入集成在主板的ROM芯片中,主要保存着系统设置程序、基本输入输出程序、开机上电自检程序和系统启动自举程序等

ROM: 只读存储器,不需要供电也可保持数据不丢失。这点特性和内存有着鲜明的对比

现在一般用Flash闪存来代替ROM,由于ROM写入后就不能修改,改用Flash闪存后,既方便又能用专用程序即可修改其中代码

当BIOS启动后,会开始BIOS自检,会依次执行以下操作:

  1. 主要是对计算机的硬件设备进行检测,然后初始化,包括处理器、内存、硬盘、显卡、声卡等
  2. 对计算机内存进行检测,检查硬盘和其他存储设备是否正常
  3. BIOS还会检查计算机的其他设备,包括键盘、鼠标、显示器、声卡等
  4. 显示系统信息:BIOS会在屏幕上显示系统信息,包括计算机型号、处理器型号、内存大小、硬盘容量等

聊聊x86计算机启动发生的事?

作者:小牛呼噜噜 ,首发于公众号「小牛呼噜噜」

期间如果检测到设备或者硬件运行不正常,主板会发出不同的蜂鸣声(具体查看bios手册区分)来作为警告,同时启动会中止。同时我们不用担心检测时间过长,往往我们还没感觉的时候,计算机的BIOS自检就已经完成了。

引导设备选择

当BIOS完成硬件自检后,需要进行引导设备的选择,主要是确定计算机从哪个设备启动,通常是硬盘或可移动设备。这一步也是我们常说的BIOS下的启动顺序,计算机需要知道下一个阶段要启动的程序具体放在了哪一个设备上。

用户可以自行去选择从哪个设备启动计算机,比如光盘或USB驱动器,进而调节启动设备的优先级。

BIOS操作界面,有一项就是"设定启动顺序",我们一般使用U盘装系统就得在这一步设置为U盘启动。

聊聊x86计算机启动发生的事?

主引导记录

当BIOS按照我们设定好的启动顺序,BIOS则根据这个顺序将计算机的控制权交给排在第一位的存储设备。主要目的是将硬盘中操作系统的核心代码加载到计算机的内存中并执行它。通俗点讲,主引导程序它个头比较小,操作系统个头大,它的任务就是去加载一个个头大的程序,也就是操作系统。

那怎样将操作系统的核心代码加载到计算机的内存中并执行?我们只需将从第一位设备中读取设备的MBR,并且将程序放在0x7c000的内存地址位中即可

MBR是什么?

MBR是存储设备中的第一个扇区,也就是磁盘最前面的512字节(Byte),称为“主引导记录”(Master boot record,简称为MBR)

我们这就不得不提机械硬盘的构造了,常见的机械硬盘的组成部分:

聊聊x86计算机启动发生的事?
我们就不一一介绍了,我们直接讲其存储数据的原理。机械硬盘存储数据的时候,是将数据存储在其内部的盘面上。一块硬盘中一般会有多个盘片。

盘片的表面涂有磁性物质,这些磁性物质用来记录二进制数据。因为正反两面都可涂上磁性物质,故一个盘片可能会有两个盘面。

每个盘面都会有对应的磁头,所有磁头"共进共退",因为会有一个磁臂固定它们。
聊聊x86计算机启动发生的事?

每个盘面划分成了一圈一圈的磁道,最外圈是0磁盘。然后每个磁盘又划分为了一个个小块,小块叫做扇区扇区大小固定,是512个字节

扇区大小为啥固定512字节?这是1956年由industry trade organization, International Disk Drive Equipment和Materials Association三家机构确定的行业标准, 大家都默认会遵守的标准,久而久之,如果改变的话,兼容各种情况的代价非常大。

我们现在更常用的固态硬盘的原理是和机械硬盘是截然不同的,大家感兴趣地可以自行去了解。上面科普了许多磁盘的知识,下面让我们回到MBR上。

由于BIOS很小,功能有限,为了完成加载操作系统的功能,就诞生了MBR

MBR在** 0 盘 0 道0扇区上(最外层磁盘的最外围磁道的第一个扇区),也就是该储存设备的第一个扇区(大小512个字节)存放了用于启动操作系统的引导程序代码,其实这串代码就是告诉计算机去哪一个地址去找操作系统**。

主引导记录由三个部分组成:

  1. 占446个字节:** 主引导程序(也叫Boot Loader),如果启动管理器grub是直接写进mbr硬盘的主引导记录中的,计算机BIOS 在启动时,按照预定的方式,将MBR内的代码加载至内存指定位置**, 然后跳转至那里,mbr的代码就开始运行了。
  2. 占64个字节:记录分区表,由于硬盘可以分区,每个区可以安装不同的操作系统,所以主引导记录必须知道将控制权转交给哪个区。
  3. 占2个字节:主引导记录的签名(0x55和0xAA),如果这512字节的最后两个字节是0x55和0xAA,表明这个设备可以用于启动;如果不是,表明设备不能用于启动,控制权于是被转交给"启动顺序"中的下一个设备。如果到最后还是没找到符合条件的,直接报出一个无启动区的error。

聊聊x86计算机启动发生的事?

额外补充一下,分区表的概念:分区表的长度只有64个字节,里面又分成四项,每项16个字节。所以,一个硬盘最多只能分四个一级分区,又叫做"主分区"。

每个主分区的16个字节,由6个部分组成:

  • 第1个字节:如果为0x80,就表示该主分区是激活分区,控制权要转交给这个分区。四个主分区里面只能有一个是激活的。
  • 第2-4个字节:主分区第一个扇区的物理位置(柱面、磁头、扇区号等等)。
  • 第5个字节:主分区类型。
  • 第6-8个字节:主分区最后一个扇区的物理位置。
  • 第9-12字节:该主分区第一个扇区的逻辑地址。
  • 第13-16字节:主分区的扇区总数,决定了这个主分区的长度,一个主分区的扇区总数最多不超过2的32次方。。

当主引导程序将硬盘的第一个扇区中读取到的 操作系统引导程序代码(512 个字节的内容),加载(原封不动地复制)到计算机内存0x7c00这个位置。这个过程需要依靠硬盘控制器和指令集来完成。

那看到这里大家一定有一个疑惑?计算机为啥要把操作系统代码加载到内存地址0x7c00处,其他地址不行吗?

0x7c000是什么神秘的地址?

0x7C00这个地址,它不属于Intel x86平台规范的,你翻遍Intel x86的手册,也找不到它的定义。它其实是历史遗留原因,第一次出现于IBM PC 5150电脑,IBM PC 5150是x86(32位)IBM PC/AT系列的老祖宗,其使用了intel 8088芯片,后人一直沿用这个地址以保持兼容。

那这个地址是怎么得出来的呢?IBM PC 5150电脑的操作系统是86-DOS,它最少需要32KB的内存,要知道那个时候内存是非常宝贵的,能省就省,勤俭持家嘛。

32KB=32 * 1024 B = 32768 B = 0x8000 B, 由于内存地址是从0x0000开始的,32位末地址是0x8000 -1=0x7FFF
所以32KB的内存地址是0x0000~0x7FFF

现在又知主引导记录需要512字节,其本身引导程序的堆栈/数据区域也至少需要512 字节

0x7FFF -512 -512 + 1=0x7C00,这样就得出0x7C00这个地址了。

计算机启动会后,内存布局如下:

+——————— 0×0
| Interrupts vectors(中断向量表)
+——————— 0×400
| BIOS data area(BIOS的数据区域)
+——————— 0×5??
| OS load area(操作系统加载区域)
+——————— 0x7C00
| Boot sector(引导区域)
+——————— 0x7E00
| Boot data/stack(引导数据/堆栈)
+——————— 0x7FFF
| (not used) 
+——————— (…)

当操作系统启动后,主引导记录也就完成使命了,其所在的内存地址0x7C00之后的所有内存,皆可被操作系统重新利用,突出一个节约内存的理念。
聊聊x86计算机启动发生的事?

加载操作系统

操作系统的加载是计算机启动过程中的最后一步,控制权将被转交给操作系统,主要工作是操作系统的所有模块加载到内存中,完成操作系统的初始化,最终实现**

我们这里以Linux为例,首先会去加载boot目录下的内核启动文件,成功加载内核后,然后去启动init进程(pid进程号为1),最后去加载操作系统的各个模块,比如网络、IO设备、窗口等,使得操作系统能够正常运行。

这块就不细讲了,如果去深扒linux的源代码,远远不是一篇文章能讲完的。后面笔者会尝试去更新linux0.12的相关文章,敬请期待

直到计算机中出现我们所熟悉,输入用户名密码登录的界面
聊聊x86计算机启动发生的事?


参考资料:
《Linux内核完全注释5.0》
https://www.minitool.com/lib/power-on-self-test.html
https://www.ruanyifeng.com/blog/2015/09/0x7c00.html
https://www.glamenv-septzen.net/en/view/6


作者:小牛呼噜噜 ,首发于公众号「小牛呼噜噜」

感谢阅读,原创不易,如果有收获的话,就点个免费的[]or[转发],你的支持会激励我输出更高质量的文章,感谢!

聊聊x86计算机启动发生的事?文章来源地址https://www.toymoban.com/news/detail-820300.html

到了这里,关于聊聊x86计算机启动发生的事?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 山东大学计算机组成与设计实验七 节拍脉冲发生器时序电路

    山东大学计算机组成与设计实验七 节拍脉冲发生器时序电路实验, 山东大学计算机组成与设计实验, 山东大学计算机组成与设计实验报告, 计算机组成原理实验报告, 山东大学计算机组成原理实验报告 掌握节拍脉冲发生器的设计方法,理解节拍脉冲发生器的工作原理。 连续节

    2023年04月15日
    浏览(55)
  • 计算机组成原理32位MIPS CPU设计实验(指令译码器电路设计 、时序发生器状态机设计、时序发生器输出函数、硬布线控制器)

    这次实验是32位MIPS CPU设计实验(单总线CPU-定长指令周期-3级时序),在头歌当中一共需要我们进行六道题的测试,分别为MIPS指令译码器设计,定长指令周期(时序发生FSM设计,时序发生器输出函数设计,硬布线控制器,单总线CPU设计),硬布线控制器组合逻辑单元。其中由于

    2024年02月02日
    浏览(29)
  • 计算机启动

    按下主机上的 power 键后,第一个运行的软件是 BIOS,BIOS 全称叫 Base Input Output System,即基本输入输出系统。 (8086的1MB内存) 地址 0~0x9FFFF 处是 DRAM,顶部的 0xF0000~0xFFFFF,这 64KB 的内存是 ROM。 BIOS 本身是个程序,程序要执行,就要有个入口地址才行,此入口地址便是 0xFFFF

    2024年02月09日
    浏览(30)
  • 计算机启动过程(万字长文)

    当电源通电后,计算机系统的启动过程始于主板上的固件,通常是BIOS(基本输入/输出系统)或UEFI(统一可扩展固件接口)。基本流程如下: 1、电源通电 用户按下计算机电源按钮,电源开始供给计算机各个组件。此时,CPU并没有直接开始执行指令。 2、BIOS/UEFI 自检 : 电源

    2024年02月02日
    浏览(56)
  • 计算机启动过程uefi+gpt方式

    启动过程: 一、通电 按下开关,不用多说 二、uefi阶段 通电后,cpu第一条指令是执行uefi固件代码。 uefi固件代码固化在主板上的rom中。 (一)uefi介绍 UEFI,全称Unified Extensible Firmware Interface,即“统一的可扩展固件接口”,是适用于电脑的标准固件接口,旨在代替BIOS。 UEF

    2024年02月16日
    浏览(29)
  • 记录一次sqlserver启动不了的问题,windows不能在本地计算机启动sql server

    如果你是开机后突然启动不了的,大概率是关机的时候vpn忘了停止,然后开机后网络出现问题造成sqlserver用不了。用下面这个方法大概率可以启动吗,如果启动成功的话记得给我点个赞吧 第一步,关闭这三个sqlserver配置服务 第二步,重启电脑 第三步,从任务管理器打开服务,找到

    2024年02月03日
    浏览(35)
  • 无法启动此程序,因为计算机中丢失vcruntime140.dll”的解决方法

    扩展名“.dll”与动态链接库(dll)有关,动态链接库是包含程序使用的代码和数据的库。一旦一个程序被创建,它就与一个DLL相关联,这个DLL只有在特定程序启动时才会被触发。因此,如果此时系统找不到带有“.dll”扩展名的文件,那么就可能会导致您无法打开当前的应用

    2024年02月04日
    浏览(46)
  • 因为计算机中找不到mfc140.dll无法启动修复步骤分享

    mfc140.dll是Microsoft Foundation Class Library(微软基础类库)的一个组件,它是许多Windows应用程序(尤其是使用MFC编写的程序)所必需的动态链接库。MFC(Microsoft Foundation Classes)是一个用于简化Windows应用程序开发的C++类库,它提供了丰富的类和函数,帮助开发者更容易地创建具有

    2024年02月07日
    浏览(35)
  • 计算机中丢失msvcp140.dll无法启动此程序怎么办(修复教程)

    DLL是Dynamic Link Library的缩写,意为动态链接库。dll文件是电脑系统及软件运行的重要文件,电脑如果丢失dll文件,那么很多软件跟游戏都是无法运行的,msvcp140.dll丢失这个问题就有很多小伙伴遇到,小编今天就分享msvcp140.dll丢失的解决方法。 首先在电脑随便打开一个浏览器后

    2024年02月10日
    浏览(46)
  • 电脑出现“无法启动此程序,因为计算机中丢失MSVCR71.dll”怎么办?

    MSVCR71.dll是一个动态链接库,是Windows系统用于操作应用程序的文件。当某个应用程序需要文件中的某个函数时,将调用DLL文件。MSVCR71.dll错误通常出现于启动应用程序时,因此我们会收到“无法启动此程序,因为计算机中丢失MSVCR71.dll。尝试重新安装该程序以解决问题”的提示

    2024年02月10日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包