CPU特权环ring

2 篇文章 0 订阅

可能你凭借直觉就知道应用程序的功能受到了Intel x86计算机的某种限制,有些特定的任务只有操作系统的代码才可以完成,但是你知道这到底是怎么一回事吗?在这篇文章里,我们会接触到x86的特权级(privilege level),看看操作系统和CPU是怎么一起合谋来限制用户模式的应用程序的。特权级总共有4个,编号从0(最高特权)到3(最低特权)。有3种主要的资源受到保护:内存,I/O端口以及执行特殊机器指令的能力。在任一时刻,x86 CPU都是在一个特定的特权级下运行的,从而决定了代码可以做什么,不可以做什么。这些特权级经常被描述为保护环(protection ring),最内的环对应于最高特权。即使是最新的x86内核也只用到其中的2个特权级:0和3。

 x86的保护环

x86的保护环

 

在诸多机器指令中,只有大约15条指令被CPU限制只能在ring 0执行(其余那么多指令的操作数都受到一定的限制)。这些指令如果被用户模式的程序所使用,就会颠覆保护机制或引起混乱,所以它们被保留给内核使用。如果企图在ring 0以外运行这些指令,就会导致一个一般保护错(general-protection exception),就像一个程序使用了非法的内存地址一样。类似的,对内存和I/O端口的访问也受特权级的限制
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Ring0、Ring1、Ring2和Ring3是指x86架构特权级别,也被称为特权特权层。这些特权级别用于控制操作系统和应用程序对计算机硬件和资源的访问权限。 在x86架构,系统的所有指令和操作都被分为特权指令和非特权指令。特权指令需要在更高的特权级别下执行,而非特权指令可以在较低的特权级别下执行。 以下是对每个特权级别的简要说明: 1. Ring0(内核模式):也称为内核模式或特权级0,它具有最高的特权级别。在Ring0,操作系统内核运行,并且可以直接访问和控制计算机的所有硬件资源,如内存、CPU和设备等。只有在Ring0才能执行一些敏感的操作和特权指令。 2. Ring1(驱动程序模式):也称为驱动程序模式或特权级1,它具有比Ring0低的特权级别。在Ring1,驱动程序可以运行,并且可以执行一些受限制的操作,如对硬件设备的直接访问。Ring1通常用于操作系统的设备驱动程序。 3. Ring2(自定义模式):也称为自定义模式或特权级2,它具有比Ring1低的特权级别。在Ring2,可以执行一些较为受限制的操作,但通常不被广泛使用。 4. Ring3(用户模式):也称为用户模式或特权级3,它具有最低的特权级别。在Ring3,运行着用户应用程序,如浏览器、办公软件等。在这个特权级别下,应用程序只能访问受限的资源,并且无法直接访问硬件资源。 特权级别的设计使得操作系统可以有效地控制和保护系统资源,防止恶意应用程序或用户对系统进行未授权的访问和操作。通过限制应用程序的特权级别,可以增强系统的安全性和稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值