首页 > 民航

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

来源:面包芯语 时间:2023-06-30 12:20:17

2、BIOS自检

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

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

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


(资料图片仅供参考)

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

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

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

3、引导设备选择

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

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

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

4、主引导记录

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

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

MBR是什么?

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

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

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

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

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

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

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

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

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

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

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

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

0x7c00是什么神秘的地址?

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|Interruptsvectors(中断向量表)+———————0×400|BIOSdataarea(BIOS的数据区域)+———————0×5??|OSloadarea(操作系统加载区域)+———————0x7C00|Bootsector(引导区域)+———————0x7E00|Bootdata/stack(引导数据/堆栈)+———————0x7FFF|(notused)+———————(…)

4、加载操作系统

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

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

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

直到计算机中出现我们所熟悉,输入用户名密码登录的界面:


参考资料:

《Linux内核完全注释5.0》

https://www.minitool.com/lib/power-on-self-test.html

https://www.glamenv-septzen.net/en/view/6

https://www.ruanyifeng.com/blog/2015/09/0x7c00.html

本文到这里就结束啦,如果这篇对你有所帮助,还请帮忙一键三连:点赞、关注、收藏,你的支持会激励我输出更高质量的文章,感谢!

相关稿件

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

天天热点评!明阳电气在深交所挂牌上市

立足数字化营造文化新体验(人民时评)_今日要闻

新时代青年着汉服宣读成人礼宣言 我市举办“新时代好青年”成人礼大型公益活动

6月新乡好人好事榜

环球讯息:“雷霆4号”向电信诈骗发起新一轮攻势

【全球报资讯】我市知识产权保护“国考”全省第一

【全球热闻】热点问答:美国要求重返教科文组织三问

不踩踏友商,长城新车发布会就开不下去了? 全球头条

天天快看点丨又一场4-0!帕尔梅拉斯大胜取得首名晋级

天天快看:贷款五级分类不准确 华夏银行太原分行被罚65万元

郑州市区民办初中今日电脑派位 中午12点可查询结果

2023年惠城区内陆渔业船员培训班开班 51名渔民参加

惠城汝湖:开发4条精品游线路发展城郊型经济

一项创新节省55天工期,太平岭核电2号机组主设备即将引入安装-全球即时

环球今日讯!大亚湾:省级示范点狮子山公园明年6月建成开放

惠城汝湖:开发4条精品游线路发展城郊型经济

天天看热讯:防患未“燃”!中山三乡开展大型商业综合体消防应急演练

2022年我国文化产业营业收入同比增长1%

图集 | 河北迁西:发展特色民宿 助力乡村振兴

李石松会见深圳茂雄集团董事长杨连成

曲靖市“新媒体+网红+山歌+双语”普法激发普法学法新热情

全球热议:深圳“零废弃办公”主题研讨会召开 越来越多企业找到加速绿色转型方法

最高36℃+!“小太阳”来了,深圳气温“红红火火”

全球报道:深圳律师事务所联系方式(深圳律师事务所排行榜)

全球热点评!专访:中国在推动全球绿色和循环经济转型中发挥重要作用——访世界经济论坛执行董事蒋睿杰

德转:切尔西这些年出售球员的转会费排行榜单,阿扎... 世界快看点

acg游戏资源区_ACGN中的GGame游戏是属于

大沥再推出三宗“工改工”靓地_环球报资讯

南海6所高中自主招生综合评价7月1日开考