【清华大学】深入理解操作系统(陈渝) 第二章
目录
- 计算机探究计算机启动过程
- 作用解析
- 结构
- 开机流程
- 中断、异常、系统调用
- 中断
- 中断流程
- 异常
- 异常处理流程
- 系统调用
- APIs
- 特点
- 跨越操作系统边界的开销
- 区别
- 为什么应用程序不能直接访问硬件?
计算机探究计算机启动过程
作用解析
Disk : 存放OS和Bootloader
BOIS : 基于I/O处理系统
Bootloader : 加载OS,将OS放入内存
结构
Disk
|___ OS
|___ Bootloader
开机流程
BIOS
开机后,寻找显卡和执行BIOS (此时, CS : IP = 0xF000 : 0xFFF0, CS/IP 两个寄存器)
将Bootloader从磁盘的引导扇区加载到0x7C00 (Bootloader一共占用512M字节的内存)
跳转到 CS : IP = 0x0000 : 0x7C00
Bootloader
将操作系统的代码和数据从硬盘加载到内存中
跳转到操作系统的起始地址
中断、异常、系统调用
中断
中断来源于外设,来自不同的硬件设备的计时器和网络的中断。
中断流程
硬件:设置中断标记(CPU初始化)
- 将内部、外部事件设置中断标记
- 中断事件的ID
软件
- 保存当前处理状态(寄存器之类的一些数据)
- 根据中断事件的ID跳转到中断服务程序,中断服务程序处理
- 清楚中断标记
异常
异常来源于不良的应用程序,非法指令或者其他坏的处理状态(如:内存出错)。
异常处理流程
保存现场
异常处理
杀死了产生异常的程序
重新执行异常指令
恢复现场
系统调用
系统调用来源于应用程序,应用程序主动向操作系统发出服务请求。程序访问主要是通过高层次的API,而不是直接调用系统调用函数。
APIs
Win32 API 用于Windows
POSIX API 用于 POSIX-based systems(包括UNIX,LINUX,Mac OS X)
Java API 用于JAVA虚拟机
特点
通常情况下,每个系统调用有对应的序号
系统调用接口根据这些序号来维护表的索引
系统调用接口调用内核态中预期的系统调用
并返回系统调用的状态和其他任何返回值
用户不需要知道系统调用是如何实现的
只需要获取API和了解操作系统将什么作为返回结果
操作系统接口的细节大部分都隐藏在API中
**用户态:**操作系统运行中,CPU处于的特权级别,不能直接执行特权指令
**内核态:**操作系统运行中,CPU处于的特权级别,可以执行任何一条指令
**系统调用:**触发CPU从用户态到内核态的转换,切换程序和内核的堆栈,需要一定的开销
跨越操作系统边界的开销
(值得的且必须的,保证了操作系统的安全性)
- 在执行时间上的开销超过程序调用
- 开销:
(1).建立中断、异常、系统调用号与对应服务例程映射关系的初始化开销
(2).建立内核堆栈
(3).验证参数
(4).内核态映射到用户态的地址空间(更新页面映射权限)
(5).内核态独立地址空间(TLB)
区别
类型 源头 处理时间 响应
中断 外设 异步 持续,对应用程序透明
异常 应用程序意向不到的行为 同步 杀死或重新执行指令
系统调用 应用程序请求系统提供服务 同步或异步 等待和持续
异步:应用程序不知道什么时候会发生中断
同步:执行到某一条指令一定会发生该事件
为什么应用程序不能直接访问硬件?
在计算机运行时,内核是被信任的第三方
只有内核可以执行特权指令
为了方便应用程序
【清华大学】深入理解操作系统(陈渝) 第二章相关推荐
- 【清华大学】操作系统 陈渝——Part6 全局页面置换算法
[清华大学]操作系统 陈渝--Part6 局部页面置换算法 6.8 局部页面替换算法的问题,工作集模型 局部页面替换算法的问题 工作集模型 6.9 全局页面置换算法 1. 工作集页置换算法 2. 可变 ...
- 【清华大学】操作系统 陈渝 Part3 ——物理内存管理 之 连续内存分配
[清华大学]操作系统 陈渝 Part3 --物理内存管理 之 连续内存分配 3.1计算机体系结构及内存分层 计算机体系机构 内存体系层次 管理内存方法 3.2地址空间 & 地址生成 地址空间定 ...
- 《深入理解分布式事务》第二章 MySQL 事务的实现原理
shua# <深入理解分布式事务>第二章 MySQL 事务的实现原理 文章目录 一.Redo Log 1.Redo Log 基本概念 2.Redo Log 基本原理 3.Redo Log ...
- 操作系统 课堂笔记 第二章 进程管理
第二章 进程管理 2.1 本章导学 基本内容: (1)进程的基本概念. (2)进程控制. (3)进程间互斥与同步. (4)进程通信. (5)进程调度. (6)进程死锁. (7)线程. 学习重点: (1 ...
- Xv6操作系统导论(第二章)
第二章 操作系统架构 操作系统的一个关键要求是同时支持多个活动.例如,使用第1章中描述的系统调用接口,一个进程可以用fork启动新进程.操作系统必须在这些进程之间分时使用计算机资源.例如,即使进程比硬 ...
- 操作系统课后答案第二章
**第二章 进程的描述与控制** 第二章 进程的描述与控制 1.什么是前驱图?为什么要引入前驱图? 答:前驱图:前驱图是一个有向,不循环图.用于描述进程之间执行的先后关系.图中每个点可以表示一个程序段 ...
- 操作系统练习题(第二章)
保留所有权利,禁止任何未经授权的转载. 注意:二次转载,即我授权A转载,B转载A并说这是从A那里转载而不是从我,这是不行的... 关于本专栏,请查阅第一篇文章前言 操作系统练习题(第一章) 本章另行参 ...
- 操作系统学习笔记 第二章:进程管理(王道考研)
本文章基于 2019 王道考研 操作系统 考试复习推荐资料:操作系统复习总结 - 百度文库 (baidu.com) 需要相关电子书的可以关注我的公众号BaretH后台回复操作系统 第一章:操作系统概述 ...
- 计算机操作系统学习笔记 第二章、进程与线程
文章目录 1 进程和线程 1.1 进程的概念和特征 1.1.1 进程的概念 1.1.2 进程的特征 1.2 进程的状态与转换 1.3 进程的组织 1.4 进程控制 1.5 进程通信 1.5.1 共享存 ...
- 计算机三种不同类型的用户账户,计算机应用基础(第2版)教学课件作者陈绥阳第二章.ppt...
文档介绍: 项目二WindowsXP用户桌面设置引言任务1:创建"教师"管理员账户任务2:设置桌面背景及添加桌面图标任务3:设置[开始]菜单和任务栏任务4:设置鼠标和键盘任务5:系 ...
最新文章
- oracle spool用法
- webpack插件机制
- java 有序列表_关于算法:在Java中为列表列表生成唯一的有序非重复组合
- aspx 判断字符串是否为decimal_python3之判断字符串是否只为数字!isdigit()、isnumeric()方法...
- linux入门与常用指令
- python3.7安装包多大_python3.7 pip 安装第三方包
- Exchange日志
- java 绑定微信号开发_Java开发中的常见危险信号
- asp html转word文档,asp生成word文档
- 升级http到https
- 周末计划-20171028
- 哈特公社,在家也能轻创业
- PMP第6版 每日工具
- C语言——三位数排序
- 技能梳理25@stm32+adxl345+电机震动+串口输出
- 分数四则运算 python
- 特征值比对代码/计算相似度代码
- pyinstaller64位windows电脑打包32位exe 5500字超详细教程
- 研磨23种大话设计模式------简单工厂模式 + 工厂方法模式 + 抽象工厂模式
- 用Halo在自己服务器搭建一个个人博客
热门文章
- 电脑间串口连接传输文件
- 华为android是什么文件夹,华为手机里的文件夹代表什么?哪些可以清除?看完秒懂!...
- php mysql后台管理模板_[开源]TP6后台管理模板
- Movidius神经计算棒初体验
- JRebel: ERROR Failed to obtain seat. Unable to connect to license server. Check
- 3D游戏编程与设计4——游戏对象与图形基础
- 压缩包文件打开密码如何破解
- gbox推荐源_GBox
- 【面试】阿里巴巴Java经典面试题整理及答案详解
- 英特尔服务器主板怎么重装系统,foxconn主板怎么重装系统