标签:保护模式 CPL 检查 MOV 描述符 AX 权限 RPL
1.CPU的分级
2.如何查看程序处于几环?
CPL:当前特权级
CS和SS中存储的段选择子后两位
3.DPL:描述符的特权级别:
举例说明:MOV DS,AX
如果AX指向的段DPL = 0但当前程序的CPL =3 这行指令是不会成功执行的
4.RPL 请求特权级别
RPL是针对段选择子而言的,每个段的选择子都有自己的RPL
举例说明:
MOV AX,0008 与 MOV AX,000B //段选择子
MOV DS,AX MOV DS,AX //段描述符
指向是同一个段描述符。但RPL是不一样的。
5.数据段的权限检查
参考代码如下:
当程序处于0环,也就是CPL = 0
MOV AX,000B //1011 RPL = 3
MOV DS,AX //AX指向的段描述符的DPL = 0
数据段的权限检查:(满足条件指令才能执行成功)
CPL<=DPL 并且RPL<=DPL (数值上的比较)
注意:代码段和系统段描述符检查方式是不一样的!
6.总结:
CPL CPU当前的权限级别
DPL 如果你想访问我,你应该具备什么样的权限
RPL 用什么权限去访问一个段
为啥要有RPL?
我们本来可以用”读写“权限打开一个文件,但为了避免出错,我们只用”只读“的权限去打开!
标签:保护模式,CPL,检查,MOV,描述符,AX,权限,RPL 来源: https://www.cnblogs.com/hanhandaren/p/11200941.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。