热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

《X86汇编从实模式到保护模式》14.任务和特权级保护

文章目录DPLCPL特权指令RPL-请求特权级栈段特权级转移低特权返回高特权高特权转移到低特权门DPL对于数据段来说,决定了访问它们所应当具备的最低特权级。CPL


文章目录

    • DPL
    • CPL
    • 特权指令
    • RPL - 请求特权级
    • 栈段
    • 特权级转移
      • 低特权返回高特权
      • 高特权转移到低特权


DPL


  • 对于数据段来说,决定了访问它们所应当具备的最低特权级。

    CPL <&#61; DPL

    假设 DPL 为 2&#xff0c;则只有特权级为 0、1、2 的程序才可访问它。


CPL


  • 当前处理器正在执行的代码段&#xff0c;则该代码段的特权级称为当前特权级。
  • 位置&#xff1a;选择子位于 CS 寄存器中&#xff0c;最低两位就是当前特权级的值。

特权指令


  • 指令当前特权级 CPL 为 0 时才能执行的指令&#xff0c;称为特权级指令。

RPL - 请求特权级

无论是通过 jmp / call 指令&#xff0c;并且提供目标代码段的选择子&#xff0c;转移到其它代码段。还是访问内存数据&#xff0c;通过一些寄存器&#xff0c;且提供段选择子加载到段寄存器中。
这些都可以看做是一个请求&#xff0c;请求者提供一个段选择子&#xff0c;请求访问某个代码段&#xff0c;又或者是请求访问内存数据。
在大多数时候&#xff0c;请求者都是当前程序自己&#xff0c;因此 CPL &#61; RPL&#xff0c;要判断请求者是谁&#xff0c;最简单的方法就是看谁提供的选择子。

[SECTION A] ; 书上没有这个&#xff0c;放在这只是为了方便理解jmp dword 0x0010:flush ; 由当前 A 段提供的选择子&#xff0c;向 CS 请求 0x0010
[SECTION A]mov eax, 0x0008 ; 这里并不触发 RPL&#xff0c;只是单纯把值传入 EAXmov ds, eax ; 由当前 A 段提供的选择子&#xff0c;向 DS 请求 0x0008

当然&#xff0c;也有 CPL !&#61; RPL 的情况&#xff1a;
image-20220925215435457
特权级为 3 的应用程序想要访问磁盘&#xff0c;只能通过调用特权级为 0 的例程来实现&#xff0c;但必须通过调用门&#xff0c;因为特权级间的控制转移必须通过门。假设必须传入三个参数&#xff0c;分别为 CX 中保存的数据段选择子、EBX 寄存器中保存的段内偏移&#xff0c;以及 EAX 中的逻辑扇区号。
高特权级别的程序可以访问低特权级别的数据段。 因此操作系统会使用传入的参数 CX 中的数据段选择子&#xff0c;将其代入段寄存器&#xff1a;

mov ds, cx

在执行这条执行时&#xff0c;CX 中的段选择子&#xff0c;其中 RPL 字段值为 3&#xff0c;当前特权级 CPL 变为 0&#xff0c;因为通过 call 调用门可以改变当前特权级。
而请求者并非当前程序&#xff08;即特权级为 0 的例程&#xff09;&#xff0c;而是特权级为 3 的应用程序&#xff0c;RPL !&#61; CPL。
在这里插入图片描述

如图所示&#xff0c;假设应用程序已知操作系统数据段的选择子&#xff0c;希望通过这个选择子访问操作系统的数据段。这显然不可能&#xff0c;因为操作系统中的数据段 DPL 为 0&#xff0c;而应用程序的 CPL 为3&#xff0c;处理器会拒绝该访问。
但是&#xff0c;可以借助调用门。调用门工作在目标代码段的特权级上&#xff0c;一旦处理器的执行流离开应用程序&#xff0c;通过调用门进入操作系统例程是&#xff0c;当前特权级从 3 变为 0。当某个恶意程序将一个执行操作系统的数据段的选择子通过 CX 寄存器作为参数传入调用门时&#xff0c;因为当前特权级已经从 3 变为 0&#xff0c;因此可以从磁盘读写数据。

引入请求特权级&#xff08;RPL) 的原因是处理器在遇到一条将选择子传送到寄存器的指令时&#xff0c;无法区分真正的请求者是谁。
就拿上面的图来说&#xff0c;应用程序通过调用门调用内核例程&#xff0c;并且传入 CX 内容为指向内核数据段的选择子&#xff0c;内核例程中有这么一条语句 mov ds, cx。此时虽然我们可以人为分析出来&#xff0c;请求者是应用程序&#xff0c;但处理器并不知道请求者到底是应用程序还是内核例程。
引入 RPL 并不能解决这个问题&#xff0c;这只是处理器和操作系统之间的一种协议。

每当处理器执行一个将段选择子传送到段寄存器&#xff08;DS、ES、FS、GS&#xff09;的指令时&#xff0c;会检查以下两个条件是否都满足&#xff1a;


  • 当前特权级 CPL 高于或和数据段描述符的 DPL 相同。

    CPL <&#61; 数据段描述符的 DPL

  • 请求特权级 RPL 高于或和数据段描述符的 DPL 相同。

    RPL <&#61; 数据段描述符的 DPL

若以上两个条件不能同时成立&#xff0c;则处理器就会阻止这种操作&#xff0c;并引发异常。


引入 RPL 的意图是 “确保特权代码不会代替应用程序访问一个段&#xff0c;除非应用程序自己拥有那个段的权限”。



栈段

处理器要求&#xff0c;在任何时候&#xff0c;栈段的特权级别必须和当前特权级 CPL 相同。因此&#xff0c;要对段寄存器 SS 进行修改时&#xff0c;必须进行特权级检查。

mov ss, ax ; 修改 SS

在对段寄存器 SS 进行修改时&#xff0c;要求当前特权级 CPL 和请求特权级 RPL 必须等于目标栈段描述符的 DPL。即在数值上&#xff1a;

CPL &#61; 目标栈段描述符的 DPL
RPL &#61; 目标栈段描述符的 DPL

特权级转移

一般来说&#xff0c;控制转移只允许发生在两个特权级相同的代码段之间。


低特权返回高特权

第一种方法&#xff1a;将高特权级的代码段定义为依从的。
在段描述符中&#xff0c;有个 TYPE 字段&#xff0c;其中的 C 位&#xff0c;若 C &#61; 0&#xff0c;则该代码段只可被相同的特权级所调用。若 C &#61; 1&#xff0c;则该代码段为依从的代码段。

// 若要调用某个过程&#xff0c;则需要满足&#xff1a;
CPL >&#61; 目标代码段描述符的 DPL

若要调用的目标过程的 DPL 为 1&#xff0c;则该代码段只能被特权级分别为 1、2、3 的代码段所调用。


第二种方式&#xff1a;通过调用门。


高特权转移到低特权

不允许直接从高转移到低&#xff0c;只能通过 ref 或 iret 才能实现从高特权转移到低特权级。


门的类型&#xff1a;


  • 调用门&#xff1a;用于不同特权级之间的切换。
  • 中断门 / 陷阱门&#xff1a;作为中断过程使用。
  • 任务门&#xff1a;对应单个任务&#xff0c;用来执行任务切换。

通过调用门进行转移&#xff1a;jmp far 或 call far 指令&#xff0c;将调用门描述符的选择子作为操作数进行转移。


  • jmp far&#xff1a;可以将控制通过门转移到当前特权级高的代码段&#xff0c;但不改变当前特权级。
  • call far&#xff1a;可以将控制通过门转移到当前特权级高的代码段&#xff0c;同时将当前特权级提升到目标代码段的特权级别。

推荐阅读
  • 本文详细介绍如何使用arm-eabi-gdb调试Android平台上的C/C++程序。通过具体步骤和实用技巧,帮助开发者更高效地进行调试工作。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 在Ubuntu 16.04 LTS上配置Qt Creator开发环境
    本文详细介绍了如何在Ubuntu 16.04 LTS系统中安装和配置Qt Creator,涵盖了从下载到安装的全过程,并提供了常见问题的解决方案。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 本文详细介绍了如何在Ubuntu系统中下载适用于Intel处理器的64位版本,涵盖了不同Linux发行版对64位架构的不同命名方式,并提供了具体的下载链接和步骤。 ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • PostgreSQL 10 离线安装指南
    本文详细介绍了如何在无法联网的服务器上进行 PostgreSQL 10 的离线安装,并涵盖了从下载安装包到配置远程访问的完整步骤。 ... [详细]
  • 选择适合生产环境的Docker存储驱动
    本文旨在探讨如何在生产环境中选择合适的Docker存储驱动,并详细介绍不同Linux发行版下的配置方法。通过参考官方文档和兼容性矩阵,提供实用的操作指南。 ... [详细]
  • CentOS系统安装与配置常见问题及解决方案
    本文详细介绍了在CentOS系统安装过程中遇到的常见问题及其解决方案,包括Vi编辑器的操作、图形界面的安装、网络连接故障排除等。通过本文,读者可以更好地理解和解决这些常见问题。 ... [详细]
  • Ihaveastringwithquotesaroundthepathasfollows:我在路径周围有一个带引号的字符串,如下所示:C:\ProgramFiles(x ... [详细]
  • 本文详细介绍了C语言的起源、发展及其标准化过程,涵盖了从早期的BCPL和B语言到现代C语言的演变,并探讨了其在操作系统和跨平台编程中的重要地位。 ... [详细]
  • 本文详细介绍了如何通过RPM包在Linux系统(如CentOS)上安装MySQL 5.6。涵盖了检查现有安装、下载和安装RPM包、配置MySQL以及设置远程访问和开机自启动等步骤。 ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
  • 在 Windows 10 中,F1 至 F12 键默认设置为快捷功能键。本文将介绍几种有效方法来禁用这些快捷键,并恢复其标准功能键的作用。请注意,部分笔记本电脑的快捷键可能无法完全关闭。 ... [详细]
author-avatar
姑获_626
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有