一:操作系统的启动
- 操作系统一开始是放在硬盘上的。
- BIOS(基本IO处理系统)加电自检,检查外设。把Bootloader从磁盘中的主引导扇区加载到0×7C00
- Bootloader找到硬盘的起始扇区读入内存,加载操作系统,把操作系统加载到内存上,并跳转到操作系统的起始地址
二:操作系统的接口
- 外设:中断和IO
- 应用程序:系统调用和异常
接口 | 来源 | 处理 | 响应 |
---|---|---|---|
中断 | 外设(如硬件的计时器和网络的中断) | 异步 | 响应会持续进行(已经由操作系统快速完成) |
异常 | 不良的应用程序(出现如非法指令或其他意外的情况) | 同步 | 响应会杀死或重新执行程序 |
系统调用 | 应用程序(向操作系统提出服务请求) | 异步或同步 | 响应可能等待或持续 |
处理过程
操作系统
- 建立中断、异常、系统调用的ID与对应服务进程映射关系的表
- 建立内核堆栈,用于保护状态
- 在内核态建立独立地址空间TLB
1:中断
硬件
- 硬件设置中断标记。
- CPU获取中断标记,产生中断ID,发给操作系统
软件
- 保护当前处理状态
- 根据中断ID查到中断服务程序地址,中断服务程序开始处理。
- 处理完成后清除中断标记
- 恢复之前保存的处理状态
2: 异常
- 保护当前处理状态
- 根据异常ID查到中断服务程序地址,异常服务程序开始处理。杀死程序,或者重新执行异常指令。
- 恢复之前保存的处理状态
- 应用程序会重新执行指令
3:系统调用
程序访问主要是通过高层次的API接口而不是直接进行系统调用。
- 应用程序主动发起请求,用户态会转换到内核态,同时切换堆栈。
- 操作系统获取参数,直接执行请求。