保护模式总结(二)——任务和特权级

2024-06-19 03:38

本文主要是介绍保护模式总结(二)——任务和特权级,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       32位保护模式相对实模式来说,除了内存保护,还多了一大功能,那就是多任务。今天总结的内容就从多任务入手。

       程序本质上是指令和数据,任务是程序为了完成某个特定的工作而执行的一个副本。

       这是抽象的描述,任务在计算机中具体是由什么描述的呢?下面引入LDT和TSS的概念。

       LDT:局部描述符表Local Descriptor Table。

       TSS:任务状态段Task State Segment。

先看图:

                       

       下面来具体介绍一下。任务和任务之间需要实施隔离,以免发生冲突。于是每个任务都会有自己的全局空间和局部空间。全局空间是所有任务共有的,含有操作系统的软件和库程序,以及可以调用的系统服务和数据;私有空间则是每个任务格子的数据和代码。全局空间用全局描述符表GDT来指定,局部空间由每个任务私有的局部描述符表LDT来指定。同GDT有GDTR来指定位置一样,LDT和TSS分别有LDTR和TR。不同的是,后二者指定的是当前任务的信息。

       LDT和TSS分别能提供一个任务的什么信息呢?LDT中存的描述符,可以描述一个任务的私有空间的段的各种信息。TSS存放一个任务的现场信息,用于任务切换。LDT中的描述符属于连续存储,而TSS之间是链表的形式。

       再来说说TCB。TCB:任务控制块Task Control Block。这是内核为每个任务开设的一块内存区域,里面包括了一个任务几乎所有的信息。具体结构看图,它也是以链表形式存储。

            

       现在暂停一下关于任务的内容,来看看特权级保护的内容。特权级保护的内容我第一次看的时候感觉真挺复杂,但是毋庸置疑的是这部分内容很重要,所以建议多花时间去消化理解。

       特权级Prrivilege Level,是存在于描述符以及其选择子总的一个数值,当这些描述符或者选择子所指向的对象要进行某种操作,或者被别的对象访问时,该数值用于控制它们所能进行的操作,或者限制它们的可访问性。注意理解上面这句定义,它的作用是双向的,当一个任务的一个代码段要访问另外一个代码段或者是数据段时,它会对其进行限制,反过来,如果是那个被访问的段,它会对其进行保护。Intel处理器可识别四个特权级别:

                        

       那么特权级究竟是怎么工作的呢?接下来引入DPL,CPL,RPL。

       DPL:Descriptor Privilege Level 描述符特权级。

       CPL:Current Privilege Level 当前特权级。

       RPL:Requested Privilege Level请求特权级。

       DPL是每个段的固有属性。每定义一个段的时候,在它的段描述付里都会有DPL,这是上一篇总结里讲的内容。

       CPL是指当前在执行的代码段的特权级。

       RPL是什么稍后再说。

       这几个特权级如何一起工作完成保护的功能?

       首先设想,有一个很重要的系统段A,我们当然不希望其他的应用随便访问它。假设有个代码段C。那么如何保护A不被C侵入呢?此时CPL(数值)>DPL,所以只需规定,在访问的时候,CPL≤DPL才能访问就行了。

       但是这样有点一刀切呀,如果我要用系统例程怎么办?这时有两个办法,一是调用依从段,二是调用门。此处着重介绍调用门。其实调用门的原理很简单。一个段到底什么特权级我们怎么知道?通过段描述符。假设有一个系统段B,此刻我们希望C访问B。可B的DPL比C的小,访问不了怎么办?这个时候我们想办法“伪造”一个B的描述符,把它的特权级改得特小,小到让C能访问为止。当我们想让C访问B时,就调用这个“伪造”的描述符就可以了。这个“伪造”的描述符就是“调用门”。

                    

       那么调用的时候,具体用什么指令呢?一是 jmp far,而是call far。二者区别是什么呢?首先后者可以返回,前者不行。另外,用call far后,CPL会改变,而用jmp far后CPL不会变化。

       好的,现在该讲RPL了。接着上面的假设讲。我们不希望C访问A,但允许C访问B。那么就会存在这种风险,当A访问B以后,用call far,把CPL变成和A一样了,那么C就可以用这种方法间接访问A。这也是绝对不允许发生的情况。如果我们有办法知道在C访问B之前是什么特权级就可以防止这种情况的发生,RPL就是记录这个特权级的。

        基本的特权级别检查规则总结:

各种情况下要满足的规则

1. 将控制直接转移到非依从的代码段

CPL=目标代码段描述符的DPL

RPL=目标代码段描述符的DPL

2.将控制直接转移到依从的代码段

CPL≥目标代码段描述符的DPL

RPL≥目标代码段描述符的DPL

3.高特权级的程序访问低特权级的数据段

CPL≤目标代码段描述符的DPL

RPL≤目标代码段描述符的DPL

4.修改栈段时

CPL=目标代码段描述符的DPL

RPL=目标代码段描述符的DPL



调用门的规则:

CPL≤调用门描述符的DPL

RPL≤调用门描述符的DPL

CPL≥目标代码段描述符的DPL(若是JMP FAR且目标代码是非依从的, CPL=。。。的DPL)




这篇关于保护模式总结(二)——任务和特权级的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1073900

相关文章

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

在Golang中实现定时任务的几种高效方法

《在Golang中实现定时任务的几种高效方法》本文将详细介绍在Golang中实现定时任务的几种高效方法,包括time包中的Ticker和Timer、第三方库cron的使用,以及基于channel和go... 目录背景介绍目的和范围预期读者文档结构概述术语表核心概念与联系故事引入核心概念解释核心概念之间的关系

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li