内存保护
正在执行的任务是不能随意访问的,操作系统必须保护挂起任务的内存空间不受正在运行任务的非法更改。
IO端口访问
在单任务系统中,任务可以随意的访问IO端口,但在多任务系统中,由于任务切换,可能会产生许多问题。在任务访问IO端口时(使用io指令),CPU将陷入到操作系统例程,有操作系统代为访问IO设备。未授权的调用
由于操作系统负责维护系统的完整性,对控制寄存器,内存页表的访问应该只由操作系统来执行,这需要通过授权来实现。在x86体系中,有以下四个特权等级:
- Level 0:最高优先级,通常赋予内核。
- Level 1:通常赋予提供服务和驱动的系统服务。
- Level 2:通常赋予设备驱动程序。
- Level 3:赋予普通应用程序。
屏蔽中断
在多任务系统下,单个任务发起屏蔽中断指令(cli),这种情况下是不可能真正的关闭CPU中断的。当任务执行cli时,cpu陷入操作系统例程,系统将标识该任务不接受中断。