五、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,一经查实,立即删除!

相关文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

QTableView与QSqlQueryModel的简单使用

测试: 这里有一个sqlite数据库 存储了10万多条数据,col1是1,col2是2. 使用QSqlQueryModel和QTableView来显示这些数据,也非常非常流畅。 QString aFile QString::fromLocal8Bit("E:/桌面/3.db");if (aFile.isEmpty())return;//打…

计算机图形学笔记----矩阵

矩阵和标量的运算 ,则 矩阵与矩阵相乘 的矩阵A,的矩阵B。两矩阵,结果为的矩阵,第一个矩阵的列数必须和第二个矩阵的行数相同,否则不能相乘 ,中的每个元素等于A的第i行所对应的矢量和B的第j列所对应的矢量进行矢量点…

云计算【第一阶段(22)】Linux的进程和计划任务管理

目录 一、查看进程 1.1、程序和进程的关系 1.2、查看进程 1.2.1、静态查看进程信息ps ​编辑 1.2.1.1、实验 1.2.2、动态查看进程信息top 1.2.2.1、实验 1.2.2.2、top 命令全屏操作界面快捷键 1.2.3、pgrep根据特定条件查询进程pid信息 1.2.4、pstree命令以树形结构列出…

Avue框架学习

Avue框架学习 我们的项目使用的框架是 Avue 在我看来这个框架最大的特点是可以基于JSON配置页面上的From,Table以及各种各样的输入框等,不需要懂前端就可以很快上手,前提是需要多查一下文档 开发环境搭建 由于我本地的环境全是用docker来搭建的,所以我依然选择用docker搭建我…

万字浅析视频搜索系统中的多模态能力建设

万字浅析视频搜索系统中的多模态能力建设 FesianXu 20240331 at Tencent WeChat search team 前言 视频搜索是天然的富媒体检索场景,视觉信息占据了视频的一大部分信息量,在视频搜索系统中引入多模态能力,对于提高整个系统的能力天花板至关重…

机器人控制系列教程之任务空间运动控制器搭建(1)

任务空间运动控制简介 任务空间运动控制—位置被指定给控制器作为末端执行器的姿态。然后,控制器驱动机器人的关节配置到使末端执行器移动到指定姿态的值。这有时被称为操作空间控制。 任务空间运动模型表示机器人在闭环任务空间位置控制下的运动,可使用…

汽车电子工程师入门系列——AUTOSAR通信服务框架(下)

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,无利益不试图说服别人,是精神上的节…

python格式文件

python小白考后复习 CSV格式文件ini格式文件我们可以读取所有节点还可以输出一个节点下所有键值对组成的元组获取节点下的键对应的值判断节点是否存在添加节点还可以添加键值还可以删除节点 XML格式文件读取若是文件格式存在的xml若是以字符串形式存在的xml获取子标签还有获取子…

【分布式计算框架 MapReduce】高级编程—搜索日志数据分析

目录 一、对于 sogou_500w_utf 数据,使用 MapReduce 编程模型完成对以下数据的分析任务 1. 统计 2011-12-30 日搜索记录,每个时间段的搜索次数 (1)运行截图 (2) 源代码 2. 统计 2011-12-30 日 3 点至 …

2024最新初级会计职称题库来啦!!!

16.根据增值税法律制度的规定,下列各项中,属于"提供加工、修理修配劳务"的是()。 A.修理小汽车 B.修缮办公楼 C.爆破 D.矿山穿孔 答案:A 解析:选项AB:修理有形动产(…