CPU 的 ring0,ring1,ring2,ring3

Intel的CPU将特权级别分为4个级别:RING0,RING1,RING2,RING3。Windows只使用其中的两个级别RING0和RING3,RING0只给操作系统用,RING3谁都能用。如果普通应用程序企图执行RING0指令,则Windows会显示“非法指令”错误信息。

ring0是指CPU的运行级别,ring0是最高级别,ring1次之,ring2更次之…… 拿Linux+x86来说, 操作系统(内核)的代码运行在最高运行级别ring0上,可以使用特权指令,控制中断、修改页表、访问设备等等。 应用程序的代码运行在最低运行级别上ring3上,不能做受控操作。如果要做,比如要访问磁盘,写文件,那就要通过执行系统调用(函数),执行系统调用的时候,CPU的运行级别会发生从ring3到ring0的切换,并跳转到系统调用对应的内核代码位置执行,这样内核就为你完成了设备访问,完成之后再从ring0返回ring3。这个过程也称作用户态和内核态的切换。

RING设计的初衷是将系统权限与程序分离出来,使之能够让OS更好的管理当前系统资源,也使得系统更加稳定。举个RING权限的最简单的例子:一个停止响应的应用程式,它运行在比RING0更低的指令环上,你不必大费周章的想着如何使系统回复运作,这期间,只需要启动任务管理器便能轻松终止它,因为它运行在比程式更低的RING0指令环中,拥有更高的权限,可以直接影响到RING0以上运行的程序,当然有利就有弊,RING保证了系统稳定运行的同时,也产生了一些十分麻烦的问题。比如一些OS虚拟化技术,在处理RING指令环时便遇到了麻烦,系统是运行在RING0指令环上的,但是虚拟的OS毕竟也是一个系统,也需要与系统相匹配的权限。而RING0不允许出现多个OS同时运行在上面,最早的解决办法便是使用虚拟机,把OS当成一个程序来运行。

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
xHCI(Extended Host Controller Interface)事件环(Event Ring)是用于管理和处理USB数据传输的一种机制。 xHCI是一种USB 3.0规范中定义的主机控制器接口,它是一种高速的、低延迟的接口,用于连接USB设备与计算机主机之间的通信。 事件环是xHCI中的一个重要概念,它是一种环形数据结构,用于存储和传递USB数据传输过程中产生的事件消息。xHCI控制器使用事件环来通知主机CPU各种USB相关的事件,如传输完成、错误处理等。 xHCI事件环的工作原理是这样的:当USB设备与计算机进行数据传输时,xHCI控制器会将相应的事件消息存储到事件环的特定位置。主机CPU会定时轮询事件环,获取并处理这些事件消息。 xHCI事件环有多个槽位,每个槽位对应一个事件,事件优先级由槽位的位置决定。当有新的事件发生时,控制器会在事件环中分配一个槽位,并将事件消息写入该槽位中。主机CPU会按照事件优先级顺序依次处理这些事件。 通过使用事件环,xHCI控制器能够及时通知主机CPU各类USB事件,实现了设备与主机之间的高效通信。同时,事件环也提供了一种异步处理的机制,当一个事件正在处理时,控制器仍然可以接收和处理其他事件,提高了系统的并发性。 总之,xHCI事件环是一种用于管理和处理USB数据传输中事件消息的机制,通过事件环,USB设备与主机之间可以高效地进行数据交互,提高了系统的性能和响应速度。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值