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

一、分段存储管理

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.mzph.cn/web/37288.shtml

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

相关文章

【设计】在Java后端开发时使用JSONObject完全替代JAVABean(DTO,VO)是否可行?

其实这样做你是得不偿失,不过也要看什么项目,如果你的项目只在只需要实现功能,不在乎健壮性,可持续性那就完全可以。因为我现在公司老项目所有用的POJO的地方都是用JSONObject。代码可读性几乎为0。你用了可能丧失以下功能&#x…

【微服务】后台管理项目多数据源管理方案实战

目录 前言 1、使用Spring提供的AbstractRoutingDataSource 2、使用MyBatis注册多个SqlSessionFactory 3、使用dynamic-datasource框架 前言 Java后台使用MyBatis-plus 快速访问多个数 据源,这里分享三种常用的多数据源管理方案 1、使用Spring提供的AbstractRout…

【C++深度探索】继承机制详解(一)

hello hello~ ,这里是大耳朵土土垚~💖💖 ,欢迎大家点赞🥳🥳关注💥💥收藏🌹🌹🌹 💥个人主页:大耳朵土土垚的博客 &#x1…

代码托管服务:GitHub、GitLab、Gitee

目录 引言GitHub:全球最大的代码托管平台概述功能特点适用场景 GitLab:一体化的开发平台概述功能特点适用场景 Gitee(码云):中国本土化的代码托管服务概述功能特点适用场景 功能对比结论 引言 在现代软件开发中&#…

numpy - array(3)

arr1 np.array([[(1000, 1001, 1002, 1003), (1010, 1011, 1012, 1013), (1020, 1021, 1022, 1023)],[(1100, 1101, 1102, 1103), (1110, 1111, 1112, 1113), (1120, 1121, 1122, 1123)]], dtypeint) (1) 根据坐标访问元素或内容,更改访问的内容,array也会更改。“…

C++操作系列(一):MinGW环境安装与配置(无报错版)

本文选择MinGW作为安装对象。 1. 下载MinGW 进入官网:MinGW - Minimalist GNU for Windows download | SourceForge.net 点击File: 划到最下面:  Windows 64位系统下载seh结尾的安装包: 2. 安装MinGW 解压MinGW&am…

力扣第218题“天际线问题”

在本篇文章中,我们将详细解读力扣第218题“天际线问题”。通过学习本篇文章,读者将掌握如何使用扫描线算法和堆来解决这一问题,并了解相关的复杂度分析和模拟面试问答。每种方法都将配以详细的解释,以便于理解。 问题描述 力扣第…

【CSS】深入理解CSS 的steps()函数

在CSS动画中,steps()函数是一个时间函数,它主要用于animation-timing-function属性,以定义动画的步进方式。当你想要动画的某个属性(如background-position或transform: translateX())在特定的步骤之间变化时&#xff…

探索 ES6:现代 JavaScript 的新特性

随着 JavaScript 的不断演进,ECMAScript 2015(简称 ES6)作为 JavaScript 的一次重大更新,带来了许多新特性和语法改进,极大地提升了开发体验和代码质量。本文将详细介绍 ES6 的主要新特性,并展示如何在实际…

NLTK:原理与使用详解

文章目录 NLTK简介NLTK的核心功能1. 文本处理2. 词汇处理3. 语法分析4. 语义分析5. 情感分析 NLTK的使用1. 安装NLTK2. 导入NLTK库3. 下载NLTK数据集4. 文本处理示例5. 情感分析示例 总结 NLTK简介 NLTK是一个开源的Python库,用于处理和分析人类语言数据。它提供了…

扛鼎中国AI搜索,天工凭什么?

人类的创作不会没有瓶颈,但AI的热度可不会消停。 大模型之战依旧精彩,OpenAI选择在Google前一天举行发布会,两家AI企业之间的拉扯赚足了热度。 反观国内,百模大战激发了大家对于科技变革的热切期盼,而如今行业已逐渐…

【操作系统期末速成】 EP01 | 学习笔记(基于五道口一只鸭)

文章目录 一、前言🚀🚀🚀二、正文:☀️☀️☀️1.1 考点一:操作系统的概率及特征 三、总结:🍓🍓🍓 一、前言🚀🚀🚀 ☀️ 回报不在行动…

文章浮现之单细胞VDJ的柱状图

应各位老师的需求复现一篇文章的中的某个图 具体复现图5的整个思路图,这里没有原始数据,所以我使用虚拟生产的metadata进行画图 不废话直接上代码,先上python的代码的结果图 import matplotlib.pyplot as plt import numpy as np# 数据&#…

架构师篇-8、运用事件风暴进行业务领域建

如何成为优秀架构师? 需要有一定的技术积累,但是核心是懂业务。 具备一定的方法,并且有很强的业务理解能力。 技术架构师:形成技术方案,做的更多的是底层的平台,提供工具。 业务架构师:解决方…

两数之和你会,三数之和你也会吗?o_O

前言 多少人梦想开始的地方,两数之和。 但是今天要聊的不是入门第一题,也没有面试官会考这一题吧…不会真有吧? 咳咳不管有没有,今天的猪脚是它的兄弟,三数之和,作为双指针经典题目之一,也是常…

Vue3中Element Plus组件库el-eialog弹框中的input无法获取表单焦点的解决办法

以下是vue.js官网给出的示例 <script setup> import { ref, onMounted } from vue// 声明一个 ref 来存放该元素的引用 // 必须和模板里的 ref 同名 const input ref(null)onMounted(() > {input.value.focus() }) </script><template><input ref&qu…

如何在Vue3项目中使用Pinia进行状态管理

**第一步&#xff1a;安装Pinia依赖** 要在Vue3项目中使用Pinia进行状态管理&#xff0c;首先需要安装Pinia依赖。可以使用以下npm命令进行安装&#xff1a; bash npm install pinia 或者如果你使用的是yarn&#xff0c;可以使用以下命令&#xff1a; bash yarn add pinia *…

Tomcat的安装和虚拟主机和context配置

一、 安装Tomcat 注意&#xff1a;安装 tomcat 前必须先部署JDK 1. 安装JDK 方法1&#xff1a;Oracle JDK 的二进制文件安装 [rootnode5 ~]# mkdir /data [rootnode5 ~]# cd /data/ [rootnode5 data]# rz[rootnode5 data]# ls jdk-8u291-linux-x64.tar.gz [rootnode5 data]…

C++:std::function的libc++实现

std::function是个有点神奇的模板&#xff0c;无论是普通函数、函数对象、lambda表达式还是std::bind的返回值&#xff08;以上统称为可调用对象&#xff08;Callable&#xff09;&#xff09;&#xff0c;无论可调用对象的实际类型是什么&#xff0c;无论是有状态的还是无状态…

【C++】string基本用法(常用接口介绍)

文章目录 一、string介绍二、string类对象的创建&#xff08;常见构造&#xff09;三、string类对象的容量操作1.size()和length()2.capacity()3.empty()4.clear()5.reserve()6.resize() 四、string类对象的遍历与访问1.operator[ ]2.正向迭代器begin()和end()3.反向迭代器rbeg…