第二讲 操作系统启动 & 中断、异常 和 系统调用

从计算机原理角度看,最基本的就三部分: CPU、I/0(DISK磁/硬盘)设备、内存。 操作系统一开始,并没有放在内存里供CPU去执行。它其实是放在DISK里, 由BIOS提供支持。

启动

DISK: 存放OS

  • DISK上,还存在Bootloader,用于加载OS,将OS从硬盘加载到内存中

BIOS: 基本I/0处理系统。它会检查所安装的RAM数量, 键盘和其他基本设备是否已安装并正常响应。然后,加载相应的软件进行执行。

BIOS自己占用部分内存。然后开始完成初始化检查。初始化检查完成后, 接下来, 它会把Bootloader从硬盘上放到内存中。这是BIOS要完成的最基本功能。

BIOS如何把Bootloader放到内存中的呢?

Bootloader一般放在硬盘上第一个主引导扇区。这样的话,硬盘就很容易找到了。然后, 把Bootloader加载到内存中去。 一般来说,硬盘的第一个扇区占512字节。

接下来, Bootloader会将更复杂的系统软件--操作系统从硬盘中加载到内存

然后, BootloaderCPU的控制权交给操作系统,也就是跳转到操作系统的起始地址

中断、异常 和 系统调用

异步: 当一个事件产生的时候,应用程序并不知道什么时候会产生。

同步: 执行一个指令时, 一定会产生。

系统调用可以是异步同步的。

  • 正常情况下, 当应用程序向系统调用发出请求后, 应用程序一直处于等待状态。操作系统响应请求,并把结果返回给应用程序。这个过程中, 返回是个同步过程。
  • 当应用程序向系统调用发出请求后, 应用程序立即去做其他事情。操作系统响应请求,并把结果异步返回给应用程序。这个过程中, 返回是个异步过程。

系统调用来说, 它发出的请求点是同步的。它的返回过程返回点有可能是同步的,也可能是异步的

中断和异常的处理机制

操作系统里有系统调用/异常/中断向量表

因此,应用程序完全不用感知到中断的产生。

系统调用

系统调用来源于应用程序,需要操作系统提供服务,这些服务需要操作系统来执行,这个过程就需要一个接口:系统调用接口

程序访问主要是通过高层次的API接口,而不是直接进行系统调用。

用户态:操作系统运行中,级别特别低,不能访问特权指令

内核态:操作系统运行中,级别很高,可以执行任何一条指令,包括特权指令

用户态和内核态的区别

系统调用:触发CPU从用户态到内核态的特权级转换,切换程序和内核的堆栈,需要一定的开销

函数调用只是在一个栈空间完成参数的传递以及返回。

当执行系统调用时,它带来的开销会比函数调用要大很多,当然这个开销是有回报的(安全、可靠,且是必须要付出的代价)。

参考资料

从OS角度看计算机系统

启动 & 中断、异常 和 系统调用

相关推荐
燃于AC之乐8 小时前
【Linux系统编程】进程调度解析:优先级与O(1)调度算法
linux·操作系统·进程调度·进程优先级·调度算法
_OP_CHEN20 小时前
【Linux系统编程】(二十)揭秘 Linux 文件描述符:从底层原理到实战应用,一篇吃透 fd 本质!
linux·后端·操作系统·c/c++·重定向·文件描述符·linux文件
凉、介1 天前
ARM 架构中的内存屏障
arm开发·笔记·学习·架构·操作系统·嵌入式
Trouvaille ~1 天前
【Linux】进程信号(一):信号的快速认识与五种产生方式
linux·运维·网络·c++·操作系统·信号处理·中断
mifengxing2 天前
操作系统(一)
大数据·数据库·操作系统
Trouvaille ~2 天前
【Linux】进程间通信(三):共享内存深度剖析与System V IPC机制
linux·c++·操作系统·管道·进程间通信·信号量·system v
_OP_CHEN2 天前
【Linux系统编程】(十九)深入 Linux 文件与文件 IO:从底层原理到实战操作,一文吃透!
linux·运维·操作系统·系统文件·系统调用·c/c++·文件i/o
c++逐梦人3 天前
进程控制(2)进程程序替换
linux·操作系统·进程
柏木乃一3 天前
ext2文件系统(2)inode,datablock映射,路径解析与缓存,分区挂载,软硬连接
linux·服务器·c++·缓存·操作系统
lcreek4 天前
Linux信号机制详解:阻塞信号集与未决信号集
linux·操作系统·系统编程