五、Pentium 微处理器保护模式存储管理,《微机系统》第一版,赵宏伟

news2025/1/20 0:50:27

一、分段存储管理

Pentium支持分段存储管理、分页存储管理和段页式存储管理。

1.1 分段存储管理的基本思想

一个程序由多个模块组成。

每一个模块都是一个特定功能的独立的程序段。

段式管理:把主存按段分配的存储管理方式。

程序模块→段→段描述符→段描述符表一段描述符表寄存器

1.2 分段存储管理工作过程

每一个程序段都会有一个段描述符

在这里插入图片描述

1.3 虚拟地址和虚拟地址空间

Pentium 微处理机在保护模式下的存储器管理单元使用48位的存储器指针。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

高16位为段选择符,其中INDEX字段是索引字段,即可以从 2 13 2^{13} 213个段描述符的段描述符表中选出一个段描述符

TI为段描述符表选择字段,来说明是GDT还是LDT(即全局描述符表还是局部描述符表)

RPL则是请求特权级字段。

因此,Pentium 的实际寻址范围是46位(去掉了特权级字段)

1.4 虚实地址转换

转换过程:

段选择符 -> 段描述符表 -> 段描述符 -> 段基址 -> 偏移量 -> 物理地址

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

1.5 段描述符

段描述符:用于描述段的基本信息。

由8个字节组成。

段描述符保存段的属性、段的大小、段在存储器中的位置以及控制和状态信息。

分类如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

1.5.1 程序段描述符

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

基地址:32位,规定一个段在4GB物理地址空间中的起始位置

段界限:20位,决定了段的长度,该字段的值的单位出“G”位决定。

“G”位称作粒度位,用来确定段界限所使用的长度单位

  • G = 0时,单位为一个字节

  • G = 1时,单位为4KB

分类S:区分是系统段描述符还是非系统段述符。

  • 当S=0时,是系统段描述符
  • 当S=1时,是非系统段描述符。

段存在位P:该段是否在内存中。

  • 当P=1时,表示该段在内存中。
  • 当P=0时,表示该段不在内存中。

系统可用位AVL:表示系统软件是否可用本段。

  • 当AVL=1时,表示系统软件可用本段。
  • 当AVL=0时,表示系统软件不能用本段。

特权级DPL:定义段的特权级。

  • 2位,有4个特权级:00、01、10、11,称作0级、1级、2级、3级。0级的特权最高,1级次之,3级的特权最低。
  • 用这个字段定义的特权级去控制对这个段的访问。

D位/B位:32/16大小选择。D/B=1,选32位;D/B=0,选16位。

  • 在代码段描述符中,指示操作数长度和有效地址长度,D位。
  • 在堆栈段描述符中,指示ESP或SP,B位。
  • 在数据段描述符中,指示操作数长度。B位

类型TYPE:在不同的段描述符中有不同的格式。

数据段或堆栈段描述符中的类型TYPE字段

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

E可执行位:当E=0时,是数据段或堆栈段。

ED扩展方向位:当ED=0时,向上扩展(地址增加方向),通常用于数据段。

当ED=1时,向下扩展(地址减小方向),通常用于堆栈段。

W可写位:当W=0时,不允许写入。当w=1时,允许写入

A访问位:当A=0时,该段尚未被访问。当A=1时,该段已被访问

代码段描述符中的类型TYPE字段

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

E可执行位:当E=1时,是代码段。

C一致性位:一致性检查就是采用特权级进行控制。C-0,表示非一致性代码段,此时忽视段描述符的特权值。C=1,表示一致性代码段,需要进行特权级检查。

R可读位:当R=0时,不允许读。当R=1时,允许读。

A访问位:当A=0时,该段尚未被访问;当A=1时,该段已被访问

1.5.2 系统段描述符

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

1.6 门描述符

一种关卡,用来控制从一段程序到另一段程序或从一个任务到另一个任务的转移。

门描述符:用于控制转入目标代码段的入口点。

门描述符包括调用门、任务门、中断门和陷阱门

调用门用于改变特权级别。

任务门用于任务切换。

中断门和陷阱门用于确定中断服务程序

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

段选择符:16位,指出段描述符位置,索引值。

任务门送TR,其他门则送CS。

类型TYPE:确定门的分类:调用门、任务门、中断门和陷阱门。

类型TYPE字段的规则与系统段描述符中的类型TYPE字段的格式完全相同。

P字段:表示描述符内容是否有效。

当P=0时,表示描述符内容无效。

当P=1时,表示描述符内容有效。

1.7 全局描述符表及寄存器

全局描述符表GDT:保存系统使用、各任务共享的段描述符,只有一个

全局描述符表寄存器GDTR:指定了GDT的起始地址

48位=32位基地址+16位界限

GDT保存的描述符类型:除中断门、陷阱门外的各类描述符。

GDT寻址可归纳为

1.段选择符 * 8 + GDTR基址 = 段描述符地址

2.段描述符内容(包括基址) → 相应段cache

3.cache中段基址 + 虚地址偏移量 = 物理地址

由GDTR确定GDT存储位置和界限

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

1.8 局部描述符表及寄存器

  • 局部描述符表LDT:保存某任务使用的段描述符,每个任务一个。
  • LDTR:指出LDT的基址
    • 16位选择符 + (32位基址 + 20位界限 + 12位属性)
  • LDTR的段选择符确定LDT描述符在GDT中的位置
  • 如果LDTR中装入了段选择符,处理器自动地将相应的LDT描述符从全局描述符表GDT中读出来,并装入LDTR中的cache部分,其中包括LDT基址,从而为当前任务创建一个LDT

1.9 中断描述符表及寄存器

  • 中断描述符表IDT:保存门描述符,整个系统一个,包括中断门、陷阱门、任务门(通常没有调用门)
  • 门提供了一种将程序控制转移到中断服务程序入口的手段。每个门8个字节,包含服务程序的属性和起始地址。
  • 中断描述符表寄存器IDTR
    • 48位 = 32位基地址 + 16位界限
    • IDT按字节计算大小,IDT最大可达64KB(但是Pentium微处理机只能够支持256个中断和异常,最多占用2KB)。
  • 中断描述符表IDT中存放的描述符类型均是门描述符。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

1.10 任务状态段及寄存器

  • 任务状态段TSS:保存现有任务的机器状态(指处理器的工作环境,比如各个寄存器的状态)及其任务间的关联信息。
  • 没有数据和代码,每个任务一个。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  • (1)返回链BACK LINK:是一个段选择符,把前一个任务的TSS描述符的段选择符(即原来TR中的16位可见部分)转入新任务TSS中,供任务返回时使用。

    • 比如我们平时从QQ切换到vscode,又从vscode切换回QQ,其实就是BACK LINK保存了QQ的段选择符
  • (2)由返回指令IRET将其装入TR寄存器,从而回到前一个TSS

  • 寄存器保存区域,用于保存通用寄存器、段寄存器、指令指针和标志寄存器。

  • 每当任务切换时,处理器当前所有寄存器的内容都被保存在TSS的这些单元中,然后又将新任务TSS所对应的单元内容装入所有的寄存器。

1.11 段选择符及寄存器

在实模式下,段寄存器的16位值是基地址。

在保护模式下,每一个段寄存器由两部分组成

可见部分 不可见部分(高速缓存)
16位 64位

段选择符

选择符分为3个字段:

INDEX TI RPL
索引字段 描述符表选择字段 请求特权级字段
13位 1位 2位

  • 索引值乘以8就是相对于GDT或LDT首址的偏移量,这个偏移量再加上描述符表的基地址(来自全局描述符表寄存器GDTR,或者局部描述符表寄存器就是段描述符在LDTR)描述符表中的地址。

  • 当TI=0时,选择的是全局描述符表GDT。

  • 当TI=1时,选择的是局部描述符表LDT。

  • 有4个特权级,00、01、10、11,称作0级、1级、2级、3级

  • 0级的特权最高,1级次之,3级的特权最低。

段选择符装入段寄存器的操作

装入段寄存器的指令有2类

**直接的装段寄存器指令:**例如MOV DS,AX等。

**隐含的装段寄存器指令:**例如CALL FAR SUB1,JMP FAR AA6等。

二、保护模式下的访问操作与保护机制

2.1 保护机制的分类

1.任务间存储空间的保护

任务间的保护是通过每一个任务所专用的LDT描述符实现的。根据LDT描述符,每个任务都有它特定的虚拟空间,因而避免各任务之间的干扰,起到隔离、保护的作用。

2.段属性和界限的保护

当段寄存器进行加载时,需要进行段存在性检查以及段限检查

在段描述符中给出了20位的段界限值,每当产生一个逻辑地址时,都要比较偏移量和段限值。一旦偏移地址大于段限值,CPU就终止执行命令,并发出越限异常。由此限制每个程序段只在自己的程序、数据段内运行,不相互干扰。

最后,还要对该段的读写权限进行检查

3.特权级与特权级保护

特权级与特权保护是为了支持多用户多任务操作系统,使系统程序和用户的任务程序之间、各任务程序之间五不干扰而采取的保护措施。

3种形式的特权管理:

(1)当前特权级CPL

  • CPL是当前正在执行的代码段所具有的访问特权级
  • 每一项任务都是在其代码段描述符所确定的特权级中运行。当前特权级就是任务执行时所处的特权级。例如,一个正在运行的任务的CPL,就是其描述符中访问权限字节的DPL。当前特权级的值一般就是代码段描述符中的DPL。

(2)描述符特权级DPL

DPL是段被访问的特权级,保存在该段的段描述符的特权级DPL位。

(3)请求特权级RPL

RPL是新装入段寄存器的段选择符的特权级,存放在段选择符的最低两位

特权管理规定:特权级为P的段中存储的数据,只能由特权级高于或等于P的段中运行的程序使用;特权级为P的代码段/过程,只能由在低于或等于P的特权级下执行的任务调用。

为记忆方便,特权级规则可以不严格地归纳为

  • 高特权级可以访问低(等于)特权级的数据;
  • 低特权级可以调用高(等于)特权级的程序。

2.2 数据段访问

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.3 分页存储管理

分页是虚拟存储器多任务操作系统另一种存储器管理方法。**段的长度是可变的,而页的长度是固定的,**比如每页4KB。

分页:将程序分成若干个大小相同的页,各页与程序的逻辑结构没有直接的关系。

Pentium微处理器采用二级页表方法对页面进行管理,第1级页表称作页目录,页目录中的页目录项指明第2级页表中各页表的基址。

页目录基地址寄存器CR3保存页目录的基地址,该基地址起始于任意4KB的边界。

页目录:由页目录项组成,页目录项包含下一级页表的基址和有关页表的信息。Pentium微处理器中,页目录最多包含1024个页目录项,每个页目录项为4个字节,所以,页目录白身占用一个4KB的页面(存储页)

页表:由页表项组成,页表项包含页面(存储页)的基和有关页面的信息。Pentium微处理器中,页表最多包含1024个页表项,每个页表项为4个字节,所以,页表自身也占用一个4KB的页面(存储页)。

2.4 段页式存储管理寻址过程

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

地址寄存器CR3**:保存页目录的基地址,该基地址起始于任意4KB的边界。

页目录:由页目录项组成,页目录项包含下一级页表的基址和有关页表的信息。Pentium微处理器中,页目录最多包含1024个页目录项,每个页目录项为4个字节,所以,页目录白身占用一个4KB的页面(存储页)

页表:由页表项组成,页表项包含页面(存储页)的基和有关页面的信息。Pentium微处理器中,页表最多包含1024个页表项,每个页表项为4个字节,所以,页表自身也占用一个4KB的页面(存储页)。

2.4 段页式存储管理寻址过程

[外链图片转存中…(img-kSzrAPLh-1719744231622)]

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

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

相关文章

基于Java校园短期闲置资源置换平台设计和实现(源码+LW+调试文档+讲解等)

💗博主介绍:✌全网粉丝10W,CSDN作者、博客专家、全栈领域优质创作者,博客之星、平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌💗 🌟文末获取源码数据库🌟 感兴趣的可以先收藏起来,…

1.搭建篇——帝可得后台管理系统

目录 前言项目搭建一、搭建后端项目1.初始化项目Maven构建 2.MySQL相关导入sql配置信息 3. Redis相关启动配置信息 4.项目运行 二、 搭建前端项目1.初始化项目2.安装依赖3.项目运行 三、问题 前言 提示:本篇讲解 帝可得后台管理系统 项目搭建 项目搭建 一、搭建后…

【多媒体】Java实现MP4视频播放器【JavaFX】【音视频播放】

在Java中播放视频可以使用多种方案,最常见的是通过Swing组件JFrame和JLabel来嵌入JMF(Java Media Framework)或Xuggler。不过,JMF已经不再被推荐使用,而Xuggler是基于DirectX的,不适用于跨平台。而且上述方案都需要使用第三方库。…

CleanShot X - 超好用苹果电脑截图录屏工具

Mac 自带的截图工具十分鸡肋,不仅功能少,无法长截图外,也不支持 GIF 制作,很难满足日常做图需求。 CleanShot X 是一款 Mac 平台近乎无可挑剔的专业截图录屏工具 ,能完美代替 Mac 自带截图。它提供超过 50 项功能&…

SpringBoot使用redis 笔记(视频摘抄 哔哩哔哩博主(感谢!):遇见狂神)

springboot集成redis步骤 1.创建springboot项目 2.配置连接 3.测试 创建springboot项目 创建以一个Maven项目 创建之后查看pom.xml配置文件,可以看到 pom文件里面导入了 data-redis 的依赖,那我们就可以在知道,springboot集成redis操作…

VBA代码解决方案第十五讲:如何对单元格区域进行高亮显示

《VBA代码解决方案》(版权10028096)这套教程是我最早推出的教程,目前已经是第三版修订了。这套教程定位于入门后的提高,在学习这套教程过程中,侧重点是要理解及掌握我的“积木编程”思想。要灵活运用教程中的实例像搭积木一样把自己喜欢的代码…

实验4 图像空间滤波

1. 实验目的 ①掌握图像空间滤波的主要原理与方法; ②掌握图像边缘提取的主要原理和方法; ③了解空间滤波在图像处理和机器学习中的应用。 2. 实验内容 ①调用 Matlab / Python OpenCV中的函数,实现均值滤波、高斯滤波、中值滤波等。 ②调…

Redis基础教程(二):redis数据类型

💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快! 💝&#x1f49…

揭秘品牌推广的制胜之道:步骤、流程、方法与技巧全攻略!

品牌推广是现代营销战略中的核心环节,对于提升品牌知名度、塑造品牌形象以及扩大市场份额具有举足轻重的作用。 作为一名手工酸奶品牌的创始人,目前全国复制了100多家门店,我来为大家分享品牌推广的制胜之道,包括具体步骤、流程、…

2024《汽车出海全产业数据安全合规发展白皮书》下载

随着中国制造向中国智造目标的迈进,中国汽车正以前所未有的速度和质量,在全球市场上开疆拓土。不过,在中国汽车加快出海步伐的过程中,数据安全合规风险管理成为车企不容忽视的课题。 6月25日,在中国(上海&…

Electron运行报错

安装: npm install --save-dev electron 1:报错: electron Unable to find Electron app at 2: ReferenceError: require is not defined in ES module scope, you can use importinstead 在ES模块作用域中没有定义ReferenceErr…

MathType绝对值符号在哪里 MathType绝对值怎么输入 MathType7产品密钥激活码获取

绝对值是数学中的一个重要概念,用于描述一个数在数轴上所对应的点到原点的距离。在MathType软件中可以输入绝对值符号,那具体该怎么做呢?下面由我带大家一起来了解MathType绝对值符号在哪里,MathType绝对值怎么输入的相关内容。 一…

Android - 利用 jitpack 免费发布闭源 aar

一、简述 目前(Android/java) library 的主要发布仓库有 MavenCentral 和 jitpack,我之前也对这两种仓库的发布流程做了详细介绍: 发布至 MavenCentral: https://juejin.cn/post/6953598441817636900发布至 jitpack: https://juejin.cn/post/7040733114506674183#heading-…

高考报志愿选专业,什么叫“报的好”?

考得好不如报得好,我认为这句话有一定的道理,当然前提还是考得好,分不够说啥都白扯了...但是有很多分数好,却载在报考上的例子也不少...有些直接退学,来年重考,杯具了.... 什么叫报得好? 1、适…

mysql8.0其他数据库日志

概述 我们在讲解数据库事务时,讲过两种日志:重做日志、回滚日志。 对于线上数据库应用系统,突然遭遇数据库宕机怎么办?在这种情况下,定位宕机的原因就非常关键。可以查看数据库的错误日志。因为日志中记录了数据库运行中的诊断信息&#xff…

LeetCode-213. 打家劫舍 II【数组 动态规划】

LeetCode-213. 打家劫舍 II【数组 动态规划】 题目描述:解题思路一:分三种情况,一:不考虑头尾;二:考虑头不考虑尾;三:考虑尾不考虑头。解题思路二:优化空间解题思路三&am…

Python逻辑控制语句 之 循环语句--for循环

1.for 的介绍 for 循环 也称为是 for 遍历, 也可以做指定次数的循环遍历: 是从容器中将数据逐个取出的过程.容器: 字符串/列表/元组/字典 2.for 的语法 (1)for 循环遍历字符串 for 变量 in 字符串: 重复执⾏的代码 字符串中存在多少个字符, 代码就执行…

idea乱码问题解决

乱码问题产生的根本原因 数据的编码和解码使用的不是同一个字符集 使用了不支持某个语言文字的字符集 Tomcat控制台乱码 在tomcat10.1.7这个版本中,修改 tomcat/conf/logging.properties中,所有的UTF-8为GBK即可 sout乱码问题,设置JVM加载.class文件时使用UTF-8字符集 设置虚…

Go线程调度器

基本结构 字段gcwaiting、stopwait和stopnoted都是串行运行时任务执行前后的辅助协调手段 gcwaiting字段的值用于表示是否需要停止调度 在停止调度前,该值会被设置为1在恢复调度之前,该值会被设置为0这样做的作用是,一些调度任务在执行时只…

小程序消息定时任务(定时触发器)发送总结

文章目录 小程序消息定时任务(定时触发器)发送总结1.开发思路2.实现办法3.查看定时触发器是否正常运作4.总结 小程序消息定时任务(定时触发器)发送总结 1.开发思路 在使用小程序的时候总是会遇到消息任务发送的情况,…