计算机从加电到系统(Linux)启动完成

0x0 背景



在我参加的面试和我面试别人、或者参加别人对别人的面试的事后经常遇到的一个问题就是:请从计算机加电开始描述一下计算机启动到操作系统正式启动起来的全过程。这是一个考验对计算机体系结构和基本知识了解程度的问题。今天也就特别针对这个问题做一个回答,答案是基于80x86结构Linux 2.6及更高版本内核的为基准操作系统为例来回答的。

0x1 从加电到BIOS启动



STEP 1 加电引导寄存器置位


这一过程指的是,计算机加电后,一个特殊电路会在CPU对应的一阵针脚产生一个逻辑电平,这个电平的值从针脚进入CPU后,会引发将寄存器(cs、eip等等)设置成特定值。

STEP 2 引导BIOS启动


这一过程指的是系统从物理地址0xfffffff0处加载一段程序到只读内存(ROM-> Read Only Memory),这个程序在80x86体系架构中一般称为BIOS。

相关知识学习


  • MS-DOS的很多系统调用依赖BIOS
  • Linux进入保护模式后不再依赖BIOS,BIOS只能以实模式运行。
实模式的寻址是20位总线寻址,支持的寻址空间为2^20,也就是1MB,保护模式目前在x86结构下,支持4GB寻址;
实际区别主要是EIP中的虚地址到实地址转化的区别:
实模式是seg(eip地址)*16+offset(4为偏移量);
保护模式实EIP的16位地址代表页面位置,一个页在操作系统中都学习过是4KB,1M*4K = 4G,我相信很多人就此理解了为啥页的大小要设计成4K;

0x2 BIOS引导操作系统镜像的加载



STEP 1 检查硬件


没啥可说的,一般可认为是开机加电自检,这个阶段会显示一些信息,包括BIOS版本这一类的信息。

STEP 2 初始化硬件


主要是避免IRQ先与I/O冲突,本阶段最后会显示所有PCI(总线--内部硬件通信线路)设备信息。

STEP 3 搜索操作系统


从软盘、网络、磁盘、CD-ROM的主引导扇区上搜索。找到后加载注意到扇区的内容到0x00007c00的位置(RAM中),跳转到这个地址,开始执行这段代码,这段程序叫做bootloader。

由于大小限制,linux的启动程序GRUB(GRand Unified BootLoader)或者是LILO(LInux LOader)被分为两部分。
第一部分就是加载到0x00007c00的这一段,他会把自己移动到0x00096a00的位置,建立实模式栈(0x00098000~0x000969ff)
第一部分吧第二部分加载到0x00096c00开始的位置中。
以上的位置都是在RAM中。
第二部分搜索磁盘上的OS景象,,把对应的扇区拷贝到RAM中执行:
1、首先把内核景象的第一个512B的部分从0x00090000处装入RAM中;
2、把setup()函数代码段装入0x00090200位置(RAM);
3、加载其他内核部分从高(0x00100000)或低(0x00010000)两个位置任选其一加载到RAM中,分别称为大映像内核和小映像内核;
4、跳转到setup函数执行;

0x3 setup函数引导内核



这个过程主要是检查和初始化硬件、虽然BIOS完成了相似的大部分工作,但是因为不依赖与BIOS,所以,还是重新初始化了硬件方面的事情;重要的过程有:

1、移动低装载小映像内核的位置到0x00001000去,如果是高装载则不移动;
2、建立IDT(临时中断描述符表)和GDT(临时全局描述符表);
3、如果需要,重置浮点单元(FPU);
4、重新编写可编程终端控制器(PIC),屏蔽除IRQ2外的所有终端;
5、设置cr0寄存器到PE位,设置PG位为0,切换到保护模式,暂未启用分页;
6、跳转到startup_32()函数;

0x4 内核建立阶段



STEP 1 startup_32()函数


主要做的事情如下:

1、初始化段寄存器和一个临时堆栈,并清零eflags寄存器所有为;
2、用0填充_edata 和_end符号标识的内核未初始化数据区;
3、调用decompress_kernel函数解压内核映像;
【低装载的情况解压内容放在0x00100000位置开始的RAM中,高装载的放在这后面的一个临时缓冲区内,解压后的内核就被移动到0x00100000位置】
4、跳转到0x00100000位置开始执行,新的执行点事arch/i386/kernerlhead.s中的另一个startup_32函数。

STEP 2 再战startup_32()函数


这个函数就是init进程(也是pid=0的0号进程)主要做了一下工作:

1、段寄存器初始化为最终值,内核的bss段填写为0;
2、初始化临时内核页表,初始化pg0,使得线性地址一律映射到统一的物理地址上;
3、cr3寄存器保存了页全局目录,并设置cr0的pg位启用分页;
4、清零eflags,使用setup_idt函数用空的终端处理程序填充IDT;
5、从bios获取的数据(系统参数和传递给os的参数)放入页框1;
6、识别处理器、用GDT和IDT填充gdtr和idtr寄存器;
7、跳转到start_kernel函数

0x5 内核完善阶段start_kernel函数



这一阶段最终完善了内核的初始化的后续工作,启动了程序调度、内存管理等操作系统的功能,其中就涉及到了著名的函数sched_init函数,至此,系统完全启动成功。

转载于:https://www.cnblogs.com/KevinGeorge/p/10166647.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/412552.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《少有人走的路——心智成熟的旅程》读书笔记

大家好,我是烤鸭: 《少有人走的路——心智成熟的旅程》,读书笔记。 第一部分 自律 规避问题和逃避痛苦的趋向,是人类心理疾病的根源。(正视自己是最重要的) 自律可以消除人的痛苦:延迟满足、承担责任、尊重事实…

[css] 说下line-height三种赋值方式有何区别?

[css] 说下line-height三种赋值方式有何区别? line-height 可以有带单位及不带单位的写法(感觉其实是两种)。div{line-height: 24px;line-height: 1.5;line-height: 1.5em;line-height: 150%; }对于应用在单个元素上,这几种写法的…

MySQL数据库select语句的使用方法

select语句可 以用回车分隔$sql"select * from article where id1"和 $sql"select * from article where id1" 都可以得到正确的结果,但有时分开写或许能 更明了一点,特别是当sql语句比较长时。批量查询数据可以用in 来实现 $sql&…

PMP 错题记录

PMP 错题记录 大家好,我是烤鸭: 这次的PMP错题集本来想考前发,临时能看看,还是耽搁了,补发一下吧,不知道以后用不用的上,据说改版了,可能也用不上了。 变更题错题记录 9、一项…

[css] 让网页的字体变得清晰,变细用CSS怎么做?

[css] 让网页的字体变得清晰,变细用CSS怎么做? 全家桶:-webkit-font-smoothing: antialiased -moz-osx-font-smoothing: grayscale text-shadow: 1px 1px 1px 1px rgba(0,0,0,0.005) text-rendering: optimizeLegibility个人简介 我是歌谣&…

skywalking oap-server 域名配置

大家好,我是烤鸭: ​ ​ ​ ​ 由于skywalking 的 -Dskywalking.collector.backend_service 的后端服务过多,想通过配置域名的方式简化上报端agent配置,也更灵活。 报错了,先看代码 报错信息: org.apac…

[css] 描述下你所了解的图片格式及使用场景

[css] 描述下你所了解的图片格式及使用场景 通常网页在显示的图片(图形)的时候,有以下几种格式:GIF、PNG、JPG、SVG,还有个比较新的WebP格式。▍GIF优点:GIF是动态的;支持无损耗压缩和透明度。…

【P1063】 能量项链

之前一直在luogu博客上 2018年12月25日17:15:52 copy到博客园 P1063 能量项链 简单的区间dp 通过解决小区间来影响大区间 环形问题 存储的时候存两边 变成 2*N 个元素 code: for(int i1;i<n;i) {cin>>e[i];e[in]e[i]; }s[i][j] ------- i到j的最大能量 k --------…

nginx 配置 http/2(h2) 和 http 在同一端口的问题

nginx 配置 http/2(h2) 和 http 在同一端口的问题 大家好&#xff0c;我是烤鸭&#xff1a; ​ 这个完全是个采坑记录了。 场景说明 由于这边有个需求想加个支持 grpc 方式转发的域名。 正常的二级域名都是映射到80端口&#xff0c;所以也没想太多&#xff0c;按照这个…

[css] 请描述css的权重计算规则

[css] 请描述css的权重计算规则 权重值计算 选择器 案例 权重值 !important !important Infinity 内联样式 style"…" 1000 ID #id 100 class .class 10 属性 [type‘text’] 10 伪类 :hover 10 标签 p 1 伪元素 ::first-line 1 相邻选择器、子代选择器、通配符 * &…

不同操作系统打开文件浏览器(资源管理器)的方式

windows      start . 或 explorer .Mac        open .Linux(ubuntu) nautilus .Linux KDE4 dolphin . 详细说明 转载于:https://www.cnblogs.com/mengff/p/10175767.html

FutureTask isDone 返回 false

大家好&#xff0c;我是烤鸭&#xff1a; ​ 今天看一下 FutureTask源码。好吧&#xff0c;其实遇到问题了&#xff0c;哪里不会点哪里。 伪代码 package src.executor;import org.springframework.scheduling.annotation.AsyncResult; import org.springframework.sche…

为什么MySQL数据库要用B+树存储索引

A&#xff1a;为什么MySQL数据库要用B树存储索引&#xff1f; Hash的查找速度为O(1)&#xff0c;而树的查找速度为O(log2n)&#xff0c;为什么不用Hash作为数据库的存储索引呢&#xff1f; 树的话&#xff0c;无非就是前中后序遍历、二叉树、二叉搜索树、平衡二叉树&#xff0c…

[css] rgba()和opacity这两个的透明效果有什么区别呢?

[css] rgba()和opacity这两个的透明效果有什么区别呢&#xff1f; 1.opacity 是属性&#xff0c;rgba()是函数&#xff0c;计算之后是个属性值&#xff1b; 2.opacity 作用于元素和元素的内容&#xff0c;内容会继承元素的透明度&#xff0c;取值0-1&#xff1b; 3.rgba() 一般…

lettuce 配置域名 dns 切换

大家好&#xff0c;我是烤鸭&#xff1a; 如果你也有类似的困扰&#xff0c;运维告诉你&#xff0c;redis连接配置域名&#xff0c;这样出问题了&#xff0c;直接改dns地址就行&#xff0c;不需要重启服务。。。梦想是美好的&#xff0c;现实是残酷的。如果你使用的是 let…

[css] 怎样修改chrome记住密码后自动填充表单的黄色背景?

[css] 怎样修改chrome记住密码后自动填充表单的黄色背景&#xff1f; input:-webkit-autofill { -webkit-box-shadow: 0 0 3px 100px #eee inset; //改变填充背景色 }个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢…

[css] 说说你对z-index的理解

[css] 说说你对z-index的理解 层叠 就是Z轴的方向的位置&#xff0c;值越大离屏幕前的你越近&#xff0c;反之亦然。可以为负数个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通…

zuul 1.x 和gateway性能对比

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享下 zuul和gateway 网关压测。 环境&#xff1a; windows 10 jdk 8 压测工具&#xff1a; wrk jmeter 数据对比 场景是仅单独转发&#xff0c;接口 Thread.sleep(50) jmeter 12 线程&#xff0c;30s zuul&#xf…

[css] 在页面中的应该使用奇数还是偶数的字体?为什么呢?

[css] 在页面中的应该使用奇数还是偶数的字体&#xff1f;为什么呢&#xff1f; 常用偶数号字体,但奇数号字体也没关系,例如 知乎正文使用15px字体,豆瓣电影使用13px字体UI设计师导出的设计稿一般都是偶数号字体偶数字号容易和页面其他标签的其他属性形成比例关系Windows 自带的…

redisson 大量ping操作,导致 tps过高

大家好&#xff0c;我是烤鸭&#xff1a; 这个问题有点奇怪&#xff0c;新服务上线&#xff0c;redis tps居高不下&#xff0c;还都是ping命令。 环境&#xff1a; 服务 &#xff1a; 280台&#xff0c;redis集群&#xff1a;12主24从 问题 由于服务刚上线&#xff0c;还没…