一致性代码段和非一致性代码段【转】

转载 2016年08月30日 19:17:14

一致代码段是内核开辟出来的供应用程序访问的段,但是不允许用户程序写入数据。

  1. CPL(Current Priviliege Level):它代表了当前代码段的特权等级,由CS和SS的第0位和第1位表示。当程序转移到不同的特权等级的代码时处理器将改变CPL。在遇到一致代 码段时,一致代码可以被相同或者更低特权等级(用户程序)的代码访问。当处理器访问一个与CPL特权等级不同的一致代码段时,CPL不会被改变。
  2. DPL(Descriptor Priviliege Level):表示段或者门的特权等级。它存储在段或者门描述符的DPL字段中。当当前代码段试图访问一个段或者门时,DPL将会和CPL以及RPL作比 较,根据段或者门类型的不同,DPL将会被区别对待: 数据段:DPL规定了可以访问此段的最低特权等级。 非一致代码段(不使用调用门的情况下):DPL规定了访问此段的特权级。 调用门:与数据段一致。 一致代码段和通过调用门访问的非一致代码段:DPL规定了访问此段的最高特权等级。 TSS:与数据段一致。
  3. RPL(Requested Priviliege Level):RPL是通过选择子的第0位和第1位来表示的。处理器通过检查RPL和CPL来确认一个访问请求是否合法。即使提出请求的段有足够的特权级,如果RPL不够也是不行的。也就是说,如果RPL的数字比CPL大,那么RPL将会起决定作用,反之亦然。 

似乎下面的解释更直观一些:

  • 对于一致代码段:也就是共享的段.

    1. 特权级高的程序不允许访问特权级低的数据:核心态不允许调用用户态的数据.
    2. 特权级低的程序可以访问到特权级高的数据.但是特权级不会改变:用户态还是用户态.
  • 对于普通代码段.也就是非一致代码段:
    1. 只允许同级间访问.
    2. 绝对禁止不同级访问:核心态不用用户态.用户态也不使用核心态.

一致与非一致性代码段

之所以出现这个定义是因为系统要安全:内核要和用户程序分开..内核一定要安全.不能被用户程序干涉. 但是有时候用户程序也需要读取内核的某些数据,怎么办呢? 于是os将内核程序开辟一些可以供用用户程序...
  • xphh
  • xphh
  • 2011年08月31日 20:39
  • 172

一致性/非一致性代码段的总结

关于一致性代码段和非一致性代码段的由来:http://wenda.tianya.cn/wenda/thread?tid=0cc76471fd94f119   代码段分为一致代码段和非一致代码段,这...

一致性代码段和非一致性代码段

一致代码段&非一致代码段     之所以出现这个定义是因为系统要安全:内核要和用户程序分开.内核一定要安全.不能被用户程序干涉.但是有时候用户程序也需要读取内核的某些数据,怎么办呢?     于是...

一致性代码段和非一致性代码段

一致代码段: 非一致代码段. 之所以出现这个定义是因为系统要安全:内核要和用户程序分开..内核一定要安全.不能被用户程序干涉. 但是有时候用户程序也需要读取内核的某些数据,怎么办呢? 于是...

一致性代码段和非一致性代码段

“一致”的意思是这样的,当转移的目标是一个特权级更高(PDL   比如当前程序的特权级(CPL)是3,有一个描述符的特权级(DPL)是0,现在向该描述符转移: 若该描述符是一致代码段,...

CPL DPL RPL的区别 &&一致性代码段和非一致性代码段

概述:在谈论保护模式编程的时候,一直会有这样的困惑:为什么除了CPL和DPL还有RPL?什么时候高特权级不能访问低特权级?什么时候低特权级不能访问高特权级?一致性代码和非一致性代码有什么区别?等等这些...

《一个操作系统的实现》读书笔记--第三章---不同特权级代码段之间的跳转

1、特权级 2、一致代码段和非一致代码段 3、DPL、RPL、CPL分别代表的含义,存储在什么位置,以及它们之间的关系 4、不同特权级数据段之间的访问规则 5、不同特权级代码段之间的转移 6、代码段之...
  • zgh1988
  • zgh1988
  • 2012年02月15日 23:26
  • 4480

精悍的Python代码段-转

1 文件处理 readlines() 和 writelines()方法可以讲列表元素依次写到文件中; file类本身没有提供复制方法,可以使用read()和write()方法模拟实现文件的拷贝,也...
  • zwqjoy1
  • zwqjoy1
  • 2017年12月01日 17:46
  • 22

(第三章 10)“代码段间跳转” 和 “访问数据段”

下面说明代码段和数据段的访问: 一、代码段间跳转 1、普通(直接)跳转: JMP Selector:0 或 CALL Selector:0 1)一致代码段(JMP&CALL) ...
  • bfboys
  • bfboys
  • 2016年09月01日 16:17
  • 213

进程的虚拟地址空间,堆栈、堆、数据段、代码段(转)

进程的虚拟地址空间,堆栈、堆、数据段、代码段 上图是进程的虚拟地址空间示意图。 堆栈段:   1. 为函数内部的局部变量提供存储空间。   2. 进行函数调用时,存储“过程活动记录”。...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一致性代码段和非一致性代码段【转】
举报原因:
原因补充:

(最多只允许输入30个字)