《操作系统》OS学习(二):启动、中断、异常

Bootloader:加载OS。操作系统一开始是放在DISK(硬盘)中,并不是放在内存中。

BIOS:基本I/O处理系统。存放在ROMRead-Only Memory)只读存储中

 

BIOS(Basic Input/Output System)基本输入输出系统。

首先我们需要知道,计算机加电之后,是从什么地方读取的第一条指令,从磁盘的什么地方读取的我的操作系统的内容,也就是计算机启动的过程是怎样的。

计算机加电后,首先是CPU的初始化过程,将各寄存器初始化,此时系统处于实模式下。我们要知道计算机内存分为两种,RAM(Random Access Memory)随机访问存储和ROM(Read-Only Memory)只读存储。其中RAM掉电内容会丢失(也就是我平时所理解的内存条内的内容比如),ROM掉电不会丢失内容。因此系统初始化代码就存储在ROM中。由于CPU初始化完成后处于实模式,寻址空间为20位也就是1M,因此系统初始化代码也就是BIOS启动固件是存储在1M之下,如下图。还需要知道的是,CPU初始化完后CS代码段寄存器与IP指令指针寄存器决定了第一条要执行的代码在ROM中的位置,而BIOS能提供的功能也列在下图之中:

  1. 基本输入输出的程序(从磁盘读数据、从键盘读输入、显示器上显示输出等);
  2. 系统设置信息(从硬盘启动还是从网络启动还是从U盘启动等);
  3. 开机后自检程序(检查内存显卡是否正常);
  4. 系统自启动程序(启动操作系统)等。

BIOS会根据设置执行启动程序,从磁盘把加载程序和操作系统内容加载到系统。首先BIOS将磁盘读引导扇区加载进指定位置0x7c00,引导扇区大小限制为512byte。此时跳转到CS:IP = 0000:7c00执行引导扇区的程序段,通过引导扇区的程序段跳转到读取操作系统的加载程序。加载程序主要有两个功能:

  1. 将操作系统的代码和数据从硬盘加载到内容中;
  2. 将控制权转移给操作系统,也就是CS:IP跳转到操作系统代码段,执行操作系统的功能。

那么问题来了,既然能读磁盘内容,为什么不直接将操作系统内核映像读取到内存空间而要先读取引导扇区的加载程序呢?这是因为不同的操作系统有不同的文件系统,也就需要不同的启动方式。而加载程序限制为512字节,无法覆盖所有类型的系统,因此首先将磁盘引导扇区内的程序加载进来,引导扇区内的程序可以识别并加载不同类型的系统内核到内存中(亦或是不同的系统有着不同的引导扇区,加载进来之后就知道是什么类型的系统了,至少学到现在还不知道,后续可能会有详细介绍吧)。此时控制权转移给操作系统内核。

除此之外BIOS还可以使用一些简单地系统调用,比如说:1. INT 10h:字符显示;2. INT 13h:磁盘扇区读写;3. INT 15h:检测内存大小;4. INT 16h:键盘输入。这些系统调用都只是最简单的系统调用,并且只能在实模式下访问。当进入操作系统并且操作系统是保护模式,那么这些功能就不能用了。

系统启动流程

上一节讲解系统调用的过程中粗略的讲了一下系统启动的流程,然而实际上系统地启动流程远没有那么简单,本节就稍微详细地讲解一下。但是实际上即使是这一节也无法十分详细讲解,只是让我们对系统启动的过程有一个整体的认识而已。

首先是BIOS读取加载程序的过程:系统加电后,CPU初始化,然后BIOS初始化硬件,然后查询主引导记录读取主引导扇区代码,这是由于现代计算机内通常不止有一个分区,不同分区内可能有不同的操作系统,而我们需要知道我们要启动的操作系统在哪个分区内(称为活动分区),这就是通过读取主引导记录实现的。知道活动分区之后将活动分区引导扇区内的代码读取到内存并执行,引导扇区内的代码读取文件系统的加载程序。这才是较为完整的读取加载程序的过程。

那么再详细一点讲,计算机上电后,首先是CPU初始化:CPU上电后,通过CS、IP两个寄存器知道从0XFFFF0地址读取第一条指令,这条指令是跳转指令,跳转到BIOS程序段。为什么是0XFFFF0呢,这是因为CPU上电后会初始化CS:IP = 0xf000:fff0。并且CPU初始化后处于实模式,也就是16位系统,20位寻址空间,是通过将CS左移4位与IP相加得到最终的地址因此指令指针PC = 16*CS+IP。20位寻址空间自然意味着最大寻址空间为2^20byte,即1M。

接下来是BIOS初始化:硬件自检(ROM等);检测内存(RAM)、显卡等关键部件是否存在,存在的话工作状态是否正常;查找并执行显卡等接口卡的BIOS(显卡等拥有自己的BIOS固件),对设备进行初始化;之后执行系统BIOS进行系统检测,主要是为了检测计算机有哪些即插即用设备,比如硬盘、光驱或者U盘;检查完之后更新CMOS中的扩展系统配置数据(ESCD)告知有哪些即插即用设备;之后就可以按照指定的启动顺序从软盘、硬盘或者光驱启动操作系统。

BIOS初始化完了,自然是要读取主引导记录。主引导记录(MBR)的格式如下图:启动代码限制为446字节以内,用于检查分区表的正确性、寻找活动分区并将活动分区引导程序加载到内存;还有64字节用于存储硬盘分区表,描述分区状态和位置,最多表示4个分区,每个分区16字节;还有一个MBR结束标志字(0x55AA),占2字节,只有有这个结束字才认为这条MBR是合法的MBR并执行启动代码。

当主引导记录读完并正确执行启动代码后,活动分区引导扇区的内容就被读入内存,分区引导扇区格式如下图:首先是跳转指令,这条跳转指令是与平台相关的,CPU不同则跳转指令不同,跳转至启动代码处;文件卷头结构则记录文件系统描述信息;结束标志也是0X55AA;启动代码则负责跳转到加载程序,加载程序不存储在引导扇区,而是存储在磁盘中,只要在启动代码中记录加载程序的位置即可。

活动分区引导扇区将加载程序读入内存之后,加载程序的执行状态如下图:加载程序并不是直接读取操作系统内核,而是从文件系统中读取启动配置信息;依据配置信息(不同的内核有不同的配置信息),确定启动的内核或启动参数(比如是安全模式启动还是正常模式启动);最后根据配置加载指定内核并转到内核执行,此时将控制权转移给了操作系统内核。

值的一提的是,以上所说为较早版本的系统启动流程,随着技术的发展,出现了UEFI(Unified Extensible Firmware Interface)统一可扩展固件接口,这是BIOS的接任者。里面有一些新的标准,比如MBR只能存储4个分区的方式逐渐被淘汰,现在出现了GPT(Globally Unique Identifier Partition Table)进行替代;UEFI可以选择启用哪些固件等。

中断、异常与系统调用

这一节讲解中断、异常与系统调用,这三者也可以总称为中断处理机制。首先我们需要知道这三个机制的背景:1. 计算机运行过程中,内核是被完全信任的第三方;2. 只有内核可以执行特权指令;3. 内核需要方便地为应用程序提供服务。

那么我们为什么需要这三个机制呢?也就是说这三个机制实现了什么功能呢?

中断是为了处理外设IO的,比如当我有一个新的键盘和鼠标接入了计算机,或者我们在键盘上敲了键盘,此时即使计算机正在进行其他任务也需要对此作出快速响应,这就是中断要做的事情;

当我程序运行中出现了异常,比如某个在分母上的变量运行过程中变为了0,也就是出现了除以0这种操作,这是不合法的,又比如说程序访问一块内存区,而这个内存区是不允许这个程序访问的,在运行到这一行程序之前我们无法预测这一异常,因此我们需要对这种异常有一种处理机制;

系统调用则是为上层的应用程序提供了各种接口,方便应用程序使用系统提供的服务,而又规避安全风险问题,即应用程序只使用提供给他的服务,而不会胡乱修改内核。

中断、异常与系统调用的结构图如下图:当有外部设备接入或者有输入,则告知内核(插入中断向量表),内核通过设备驱动与外部设备交互;当应用程序执行过程中出现异常,也插入中断向量表,内核要么将异常解决掉,要么终止程序,并将程序占用的资源返还;应用程序可以直接或者通过函数库间接地使用系统调用接口,插入中断向量表,中断向量表通过查询系统调用表提供系统调用实现,并将结果返还。因此可以说内核与外界打交道的接口主要就是中断、异常与系统调用。

从上图也可以看到中断、异常与系统调用的区别如下图:系统调用是应用程序主动向操作系统发出的服务请求;异常是非法指令或其他原因导致当前指令执行失败(如内存出错)后的处理请求;中断则是来自硬件设备的处理请求。

下图是三者比较:

这三者也即中断处理机制具体实现过程是怎样的呢?实现过程可以分为硬件和软件两部分。首先是硬件部分:在CPU初始化过程中会设置中断使能标志,即在CPU做好准备工作之后才会开始接受中断请求,在此之前是不会有反应的;此外需要根据内部或外部事件设置中断标志,记录出现了一次中断;依据中断向量表中的内容知道中断源是什么,并调用相应中断服务例程。以上为硬件部分工作内容,接下来的内容是软件部分:1. 现场保存(编译器);2. 中断服务处理(服务例程);3. 清除中断标记(服务例程);4. 现场恢复(编译器)。

那么如果一个中断出现的时候又出现新的中断会怎样呢(此处中断指中断处理机制即包含中断、异常、系统调用三者)?其中,硬件终端服务例程可以被打断,比如不同硬件中断源同时出现,此时可以按照优先级依次处理,而出现了非常重要的中断比如电源出现问题时,则可以临时禁止接收中断请求,而被接收了的中断请求会保持到CPU对中断做出响应。异常服务例程也是可以被打断的,比如异常执行中可能出现硬件中断,例如处理异常时进行磁盘IO,此时磁盘出现了硬件中断,则会打盹异常服务例程去进行硬件中断处理。异常服务例程也是可以嵌套的,比如处理异常时又出现了缺页异常,此时则会产生嵌套。

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

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

相关文章

常用css属性集(持续更新…)

禁止换行,超出部分显示…:a. 代码:.hide_word{ max-width: 100px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; } b. 效果: 本文转自 bilinyee博客,原文链接: http://blog.51cto.co…

parallels网络初始化失败_33 个神经网络「炼丹」技巧

自然语言处理Andrej Karpathy 是深度学习计算机视觉领域、与领域的研究员。博士期间师从李飞飞。在读博期间,两次在谷歌实习,研究在 Youtube 视频上的大规模特征学习,2015 年在 DeepMind 实习,研究深度强化学习。毕业后&#xff0…

《操作系统》OS学习(三):系统调用

例子 首先看一个标准C库的例子:当我们程序中使用了C库中的printf()函数,实际在底层是在内核态中调用了write()函数。图中右侧则是将程序代码与C库都算到应用程序中,内核提供了一个系统调用接口。 从这个例子我们可以得到以下几点&#xff1a…

JavaScript服务器端开发技术(对象属性的枚举与查询)

既然对象是属性的集合,那么检测与枚举集合中的属性就是一项重要任务。对此,我们来分别看一下ES3和ES5提供的解决方案。 1) ES3枚举方案 示例代码: var contacts{ ID:[0,1,2,3,4,5], names:["Zero","One","Two&q…

treelistview 所有节点失去焦点_垃圾询盘过滤,焦点科技的 Milvus 实践

文章作者:黎阳,焦点科技软件开发工程师李成龙,Zilliz 数据工程师Milvus (https://milvus.io/) 向量搜索引擎开源半年以来,全球已经有数百家企业或组织用户。焦点科技是一家以 B2B 外贸交易为主营业务的科技公司,也是 M…

《操作系统》OS学习(四):计算机体系结构、内存层次和地址生成

计算机除了计算能力之外还有存储能力,存储能力即计算机拥有一系列的存储介质,我们可以在存储介质上存储我们的代码和数据。计算机体系结构中约定了哪些地方可以用来存储数据:CPU内的寄存器、内存和外存。不同的存储介质,容量、速度…

GCC中SIMD指令的应用方法

X86架构上的多媒体应用开发,如果能够使用SIMD指令进行优化, 性能将大大提高。目前,IA-32的SIMD指令包括MMX,SSE,SSE2等几级。 在GCC的开发环境中,有几种使用SIMD指令的方式,本文逐一介绍。X86的…

使用angular4和asp.net core 2 web api做个练习项目(二), 这部分都是angular

上一篇: http://www.cnblogs.com/cgzl/p/7755801.html 完成client.service.ts: import { Injectable } from angular/core; import { Http, Headers } from angular/http; import { Observable } from rxjs/Observable; import { ErrorHandler } from angular/core; import rxj…

leelen可视对讲怎么接线_楼宇对讲系统怎么布线 楼宇对讲系统布线方式【介绍】...

随着智能小区规模不断增加,楼宇可视对讲系统应用越来越广泛,因而视频信号的传输方式与布线设计显得越来越重要。视频信号与数据和音频信号不同,可行的一种传输方式为视频信号基带传输,下面小编就简要介绍一下这种传输方式和布线方…

路由汇总实例

5.2.2.2 路由汇总策略 之前提到过,在网络管理员计划好子网选择并进行预期地路由汇总时,手动路由汇总工作能取得最佳效果。例如,之前的例子设定好了一个考虑周全的计划,管理员只使用远离Yosemite路由器并以10.2开头的子网。这个规定…

《操作系统》OS学习(五):连续内存分配 内存碎片、动态分配、碎片整理、伙伴系统

内存碎片 在没有其他方式辅助的情况下,我们分配给一个进程的内存是连续的。在分配时候我们需要有动态分配与碎片处理。如何理解呢?就是每个进程需要一块内存,我们要选取合适的位置的内存分配给它。当有的进程先结束了内存还给操作系统&#…

世界之窗浏览器删除文本框信息_文本框——Excel里的便利贴

工作表里面的单元格应该是足够我们来记录数据和信息了。但是文本框这个功能在工作表中还是存在,可以理解为便利贴功能。插入文本框1.点击“插入”选项卡。2.然后点击“文本框”。3.在下拉菜单里面,有两种可供选择:横排文本框和垂直文本框。在…

RHEL 5服务篇—常用网络配置命令

常用网络配置命令 在“Linux系统管理”的文章中,大家已经学习了Linux系统的基本管理命令和技巧,为了进一步学习Linux网络服务打下了良好的基础。所以我作者以后将陆续推出Linux网络服务的相关文章。希望大家能给与我大大的支持。 今天我们就来学习一下…

清华大学《操作系统》(六):非连续内存分配 段式、页式、段页式存储管理

背景 连续内存分配给内存分配带来了很多不便,可能所有空闲片区大小都无法满足需求大小,这个分配就会失败。基于这种现状,就有了非连续内存分配的需求。非连续分配成功的几率更高,但也面对更多的问题,比如分配时是不是…

C语言第三次博客作业---单层循环结构

一、PTA实验作业。 题目1 1.实验代码 int n,i; double height1,height2;//1为输入身高&#xff0c;2为输出身高。 char sex; //1<height1<3; //N<1; scanf("%d",&n); while(n--){getchar();scanf("%c%lf",&sex,&height1);switch(sex)…

清华大学《操作系统》(七):虚拟存储、覆盖、交换

接下来几节都是对虚拟存储的讲解。虚拟存储是非连续存储管理的扩展。通过将内存中的数据暂存到外存的方式&#xff0c;为进程提供更大的内存空间。虚拟存储出现的主要原因是因为程序规模的增长速度远远大于存储器容量的增长速度&#xff0c;导致内存空间不够用。其实针对内存空…

遵义大数据中心项目工程概况_市委书记张新文到曹州云都大数据中心等项目现场调研建设情况...

4月25日&#xff0c;市委书记张新文到曹县调研重点项目建设情况&#xff0c;研究推进措施。市委常委、秘书长任仲义参加活动。张新文首先来到曹州云都大数据中心项目建设现场&#xff0c;查看项目推进情况。曹州云都大数据中心&#xff0c;是涵盖云计算区、研发办公区、公寓生活…

linux 可执行文件的分析(gcc GUN BUILEIN)

1、GCC The History of GCC 1984年&#xff0c;Richard Stallman发起了自由软件运动&#xff0c;GNU (Gnus Not Unix)项目应运而生&#xff0c;3年后&#xff0c;最初版的GCC横空出世&#xff0c;成为第一款可移植、可优化、支持ANSI C的开源C编译器。GCC最初的全名是GNU C Com…

Cassandra 的数据存储结构——本质是SortedMapRowKey, SortedMapColumnKey, ColumnValue

Cassandra 的数据存储结构 Cassandra 的数据模型是基于列族&#xff08;Column Family&#xff09;的四维或五维模型。它借鉴了 Amazon 的 Dynamo 和 Googles BigTable 的数据结构和功能特点&#xff0c;采用 Memtable 和 SSTable 的方式进行存储。在 Cassandra 写入数据之前&a…

清华大学《操作系统》(八):置换算法

功能&#xff1a;置换算法是指当出现缺页异常时&#xff0c;需要调入新页面而内存已满时&#xff0c;置换算法选择被置换的物理页面。 设计目标&#xff1a; 尽可能减少页面的调入调出次数&#xff1b;把未来不再访问或短期内不访问的页面调出。 页面锁定&#xff1a; 了解具…