【清华大学】深入理解操作系统(陈渝) 第二章

计算机探究计算机启动过程

作用解析

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初始化)

  1. 将内部、外部事件设置中断标记
  2. 中断事件的ID

软件

  1. 保存当前处理状态(寄存器之类的一些数据)
  2. 根据中断事件的ID跳转到中断服务程序,中断服务程序处理
  3. 清楚中断标记

异常

异常来源于不良的应用程序,非法指令或者其他坏的处理状态(如:内存出错)。

异常处理流程

保存现场
异常处理
杀死了产生异常的程序
重新执行异常指令
恢复现场

系统调用

系统调用来源于应用程序,应用程序主动向操作系统发出服务请求。程序访问主要是通过高层次的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)

区别

类型 源头 处理时间 响应
中断 外设 异步 持续,对应用程序透明
异常 应用程序意向不到的行为 同步 杀死或重新执行指令
系统调用 应用程序请求系统提供服务 同步或异步 等待和持续
异步:应用程序不知道什么时候会发生中断

同步:执行到某一条指令一定会发生该事件

为什么应用程序不能直接访问硬件?

在计算机运行时,内核是被信任的第三方
只有内核可以执行特权指令
为了方便应用程序

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
《基于Rust语言的组件化可重用操作系统内核设计》这篇论文阐述了一种新型的操作系统内核设计思路,即基于Rust语言实现可重用的组件化操作系统内核。Rust语言是一种安全、并发、现代化的系统级编程语言,具有内存安全、数据竞争自动检测、无GC、抽象层次高等优点,非常适合在操作系统内核中使用。 论文中提出的组件化操作系统内核设计思路,将内核划分为多个可重用的组件,每个组件实现特定的功能,并提供标准的接口和抽象,方便其他组件的调用和扩展。这种设计思路可以有效地提高操作系统内核的可维护性、可移植性和安全性。 在Rust语言的支持下,该操作系统内核在实现过程中采用了多种现代化的技术,如虚拟内存管理、进程管理、任务调度、文件系统管理等,每一个组件都采用了模块化、抽象化、可编程化、可扩展化的设计理念,使得整个系统具有高度的灵活性和可定制性。 此外,该操作系统内核还采用了一些基于Rust语言的特性,如避免数据竞争、安全指针、内存安全检查等,从而大大提高了系统的安全性和稳定性。 总之,《基于Rust语言的组件化可重用操作系统内核设计》这篇论文提出了一种有前途的、现代化的操作系统内核设计思路,为未来的操作系统内核研发和实践提供了新的思路和经验借鉴。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值