全局描述符表

news2025/1/17 3:09:22

文章目录

  • 段描述符
  • 全局描述符表GDT
  • 段选择子
  • 进入保护模式步骤

在开始介绍全局描述符之前,先了解一下段描述符。

段描述符

内存段是一片内存区域,访问内存就要提供段基址(段基址属性)以及段界限属性(约束段大小)。

段描述符是位于GDT( Global Descriptor Table, GDT )或LDT( Local Descriptor Table, GDT )中8字节大小的表项,用来描述内存段的属性。给处理器提供一个段的位置、界限、访问特权级等信息。具体格式如下图所示。

在这里插入图片描述

段描述符格式(人为划分高低位)

保护模式下地址总线宽度是 32 位,段基址需要用 32 位地址来表示。

段描述符属性介绍

  • 低32位 :第 0~15 位用来存储段的段界限前 0~15 位。段界限表示段边界的扩展最值,即最大扩展到多少或最小扩展到多少。
    实际段界限 = ( 描述符中段界限 + 1 ) ∗ 粒度 − 1 实际段界限=(描述符中段界限+1)∗粒度−1 实际段界限=(描述符中段界限+1)粒度1其中,G表示段界限粒度,0表示粒度为1byte,1表示粒度为4KB。
  • 低32位 :第 16~31 位用来存储段基址 0~15 位。
  • 高32位 :第 0~7 位是段基址的 16~23 位。
  • 高32位 :第 8~11 位是 type 字段,共 4 位,用来指定本描述符的类型。type 字段和 S 字段配合使用。
  • 高32位 :第 12 位是 S 字段。S为 0 时表示系统段,S 为 1 时表示数据段。【解释】凡是硬件运行要用到的东西都可称之为系统,凡是软件(代码,数据,栈)需要的东西都称为数据。
  • 高32位 :第 13~14 位是 DPL(Descriptor Privilege Level) 字段,即描述符特权级。2位能表示 4 种特权级,数字越小,特权级越大。
  • 高32位 : 第 15 位是 P (Present) 字段,即段是否存在。如果段存在于内存中,P 为 1,否则 P 为 0。
  • 高32位 : 第 16~19 位是段界限的第 16~19 位。
  • 高32位 :第 20 位为 AVL 字段,
  • 高32位 :第 21 位为 L 字段,用来设置是否是 64 位代码段。L 为 1 表示 64 位代码段,否则表示 32位代码段。
  • 高32位 :第 22 位是 D/B 字段,用来指示有效地址(段内偏移地址)及操作数的大小。
  • 高32位 :第 23 位是 G 字段,Granularity,粒度,用来指定段界限的单位大小。
  • 高32位 :第 24~31 位是段基址的第 24~31 位。

全局描述符表GDT

全局描述符表( Global Descriptor Table, GDT )是保护模式下内存段的登记表全局描述符表 GDT 相当于是描述符的数组,数组中的每个元素都是 8 字节的描述符。可以用选择子(马上会讲到)中提供的下标在 GDT 中索引描述符。

段描述符与内存段的关系图
在这里插入图片描述

全局描述符表存放在内存中,需要用专门的寄存器(GDTR,GDT Register)指向它(GDT )后,CPU 才知道它的位置。

【补充】

GDTR 是个 48 位的寄存器,专门用来存储 GDT 的内存地址及大小。

GDTR 中48 位内存数据划分为两部分,其中前 16 位是 GDT 以字节为单位的界限值,所以这 16 位相当于GDT 的字节大小减 1。后 32 位是 GDT 的起始地址。由于 GDT 的大小是 16 位二进制,其表示的范围是 2的16次方等于65536字节。每个描述符大小是8字节,故,GDT中最多可容纳的描述符数量是65536/8=8192个,即 GDT 中可容纳 8192 个段或门。

在这里插入图片描述

段选择子

选择子(16位)的作用主要是确定段描述符,达到确定描述符的目的。

在这里插入图片描述
参数解释

  • RPL:请求特权级别
  • TI(Table Indicator)
    ●TI=0:查GDT表
    ●TI=1:查LDT表
  • INDEX(描述符索引值):此值用来在 GDT 中索引描述符

✳保护模式下访问内存地址实例

前提:选择子为 0x8,将其加载到 ds 寄存器后,访问 ds:0x9 的内存地址。

过程:分析选择子 0x8 ,其中 低 2 位是RPL,其值为 00。第 3 位是 TI,其值 0,表示是在 GDT 中索引段描述符。高 13 位 0x1 在 GDT 中的第 1 个段描述符(GDT 中第 0 个段描述符不可用)。这样,用 第 1 个段描述符中的 3 个段基址部分与段内偏移地址 0x9 相加所得的和 X 作为访存地址

进入保护模式步骤

准备进入保护模式的3个步骤:

  1. 打开A20
  2. 加载gdt
  3. 将cr0的pe位置1

【补充1】 打开A20地址线

打开 A20Gate只需要将端口 0x92 的第 1 位置 1即可

in al,0x92
or al,0000_0010B
out 0x92,al

【补充2】 CR0 寄存器的 PE 位

PE 为 0 表示在实模式下运行,PE 为 1 表示在保护模式下运行。

mov eax, cr0   ;将 cr0 写入 eax。
or eax, 0x00000001 ;通过或运算 or 指令将 eax 的第 0 位置 1。
mov cr0, eax  ;将 eax 写回 cr0,这样 cr0 的 PE 位便置为 1

参考资料

  • 《操作系统真象还原》

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/145041.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

美团前端一面必会react面试题

state 和 props 触发更新的生命周期分别有什么区别? state 更新流程: 这个过程当中涉及的函数: shouldComponentUpdate: 当组件的 state 或 props 发生改变时,都会首先触发这个生命周期函数。它会接收两个参数:nextP…

分布式存储综述与方案选型

文章目录引言基本诉求存储选型考虑的要素分布式存储的野蛮生长史主要开源选型GFS(Google File System)HDFS (Hadoop Distributed File System)miniocephTFSSwiftfastDFSGridFSMooseFSGlusterFSMogileFS一些国产的xFS阿里腾讯百度京东网易字节跳动美团滴滴结论数据库选型分布式存…

Java基础之《netty(21)—WebSocket长连接开发》

一、实例要求 1、http协议是无状态的,浏览器和服务器间的请求响应一次,下一次会重新创建连接 2、要求:实现基于webSocket的长连接的全双工的交互 3、改变http协议多次请求的约束,实现长连接了,服务器可以发送消息给浏…

Go第 10 章 :面向对象编程(上)

Go第 10 章 :面向对象编程(上) 10.1 结构体 10.1.1 看一个问题 10.1.2 使用现有技术解决 单独的定义变量解决 代码演示: 使用数组解决 代码演示: 10.1.3 现有技术解决的缺点分析 使用变量或者数组来解决养猫的问题,不利于数…

AI与艺术——图像生成网络经典算法

生成模型是一种训练模型进行无监督学习的模型,即,给模型一组数据,希望从数据中学习到信息后的模型能够生成一组和训练集尽可能相近的数据。图像生成(Image generation,IG)则是指从现有数据集生成新的图像的…

代码块和执行顺序

1、什么是代码块 使用{}定义的一段代码我们称之为代码块 一般分为: 1. 普通代码块 2. 实例代码块 3. 静态代码块 2、普通代码块 定义在方法中的代码块,可以用于限定局部变量的生命周期。 public class Main{public static void main(String[] args) {{…

【分享】百度更喜欢自媒体站,9种方法让你轻松玩转微博营销

微博营销是指通过微博平台为商家、个人等创造价值而执行的一种营销方式。 以下九种方式,你一定要学习一下,视频最后,有干货。 1、注重价值的传递 企业博客经营者首先要改变观念——企业微博的“索取”与“给予”之分,企业微博是…

2023你冲不冲,冲冲冲冲~~

前言:\textcolor{Green}{前言:}前言: 💞2022已经成为历史,趁着还没有遗忘来看看我这一年发生了什么事。 在这一年中有很多的收获也有一些遗憾,但是这不会让我停下来,未来的2023又会发生什么&…

ArcGIS 中的 7 种主要地理处理工具

地理处理工具可以提高人们的工作效率,并且这些工具可以批量应用于编辑,例如应用于所有功能或所有选定功能。本文将和大家一起探讨 7 个 ArcGIS 中的地理处理工具。 地理处理的用途 模型中的地理处理工具可解决许多空间完整性的问题,应用地理…

分布式缓存系统 Ignite、Hazelcast、Ehcache

一、Apache IgniteApache Ignite是一个以内存为中心的分布式数据库、缓存和处理平台,支持事务、分析以及流式负载,可以在PB级数据上享有内存级的性能。如果禁用原生持久化,Ignite就是一个分布式缓存,它实现了JCache规范&#xff0…

深入解析Linux虚拟化KVM-Qemu分析之中断虚拟化

说明: KVM版本:5.9.1QEMU版本:5.0.0工具:Source Insight 3.5, Visio 1. 概述 本文会将ARM GICv2中断虚拟化的总体框架和流程讲清楚,这个曾经困扰我好几天的问题在被捋清的那一刻,让我有点每有…

JsonUtility读写json简单应用

使用Unity提供的JsonUtility 简单封装了一个将数据以json格式存储到本地,方便数据读写的案例;一共三个脚本:MyJsonRW : 提供SaveJsonData和LoadWithJson,实现数据与json的转换和读写;TestData : 测试数据类,列举了部分常用的简单数据类型(不过有坑,后面会说);MyJsonExample : 例…

新诤信张强—兔年展望|2023-2025:看风的必不撒种、望云的必不收割

新诤信知识产权服务股份有限公司 首席技术官 张强 “看风的必不撒种、望云的必不收割”出自古老的犹太智慧书《传道书》,意思是,如果要等刮风才撒种,快要下雨才收割,一切就都来不及了。元宇宙的发展布局,也是这个道理…

基础算法[四]之图的那些事儿

文章目录前言图的表示邻接矩阵邻接表结构存储遍历路径搜索多源最短路问题问题描述Floyd实现模板单源最短路径问题Dijkstra算法朴素版本堆优化邻接表python实现Bellman-Ford 算法实现SPFA 算法实现python 版本判断负环小结最小生成树Prim算法Kruskra算法实现python版本二分图二分…

网络资源归档标准WARC介绍

WARC---Web ARChive 01 ● WARC格式概述 ● WARC(Web ARChive)格式是网络资源存档中使用的常见文件格式,全称为Web Archive File Format,由互联网保存联盟(International Internet Preservation Consortium&#xff0…

2023年1月6日星期五-PPP/BPP相关学习

独立均匀分布matlab的rand指令可以帮助我们生成[0,1]的均匀分布的数据,这样,如果我们想要[a,b]的分布数据,只需要a+(b-a)*rand就可以了。 [a,b] 均值,标准差 均值

Git 常用基本命令

文章目录基本命令仓库相关命令提交相关命令分支相关命令tag 相关命令撤销相关命令IDEA Git 相关操作仓库相关操作提交相关操作提交代码步骤分支相关操作tag 相关操作撤销相关操作参考资料本文主要介绍 Git 常用的基本命令。基本命令 仓库相关命令 创建新仓库 git init克隆项…

C#,图像二值化(15)——全局阈值的一维最大熵(1D maxent)算法及源程序

1、最大熵(maxent) 最大熵(maxent)方法植根于信息理论,并已成功应用于许多领域,包括物理学和自然语言处理。它创建了一个模型,该模型最好地解释了可用数据,但有一个约束&#xff0c…

甘特图中的依赖关系是什么?

依赖关系是甘特图应用中常见的概念。甘特图依赖关系也称为任务依赖关系,它是指项目任务之间的关系,需要按特定顺序执行一个或多个任务才能完成某项任务,依赖于完成前一任务的任务是后继任务,而其依赖的任务是前导任务。依赖关系一…

字典特征提取、文本特征提取、jieba分词处理、tf-idf文本特征提取概念及代码实现

一、特征提取 特征提取:将任意数据(如文本或图像)转换为可用于机器学习的数字特征,特征值化是为了计算机更好的去理解数据 特征提取api:sklearn.feature_extraction 特征提取分类 字典特征提取(特征离散化)文本特征…