计算机一次取数过程分析

计算机一次取数过程分析

1 取址过程

CPU由运算器和控制器组成,其中控制器中的程序计数器(PC)保存的是下一条指令的虚拟地址,经过内存管理单元(MMU),将虚拟地址转换为物理地址,之后交给主存地址寄存器(MAR),从主存中取出这条指令,通过主存数据寄存器(MDR)交给指令寄存器(IR),IR再将其转化成控制信号。

在这里插入图片描述

2 间址过程

一条指令由 <操作码,寻址方式,地址码> 几部分组成,寻址方式共有以下十种

  • 隐含寻址
  • 立即寻址
  • 直接寻址
  • 间接寻址
  • 寄存器寻址
  • 寄存器间接寻址
  • 相对寻址
  • 基址寻址
  • 变址寻址
  • 堆栈寻址

根据有效地址(EA)或立即数所处的位置,可以分为以下三类

在寄存器:隐含寻址、寄存器寻址

在立即数:立即寻址

在主存:直接寻址、间接寻址、寄存器间接寻址、相对寻址、基址寻址、变址寻址、堆栈寻址

而无论哪种方式得到的有效地址(EA)同样也是虚拟地址


接下来要解决以下两个问题

问题一:虚拟地址如何转为物理地址?

问题二:如何访问该物理地址?


3 虚拟地址转为物理地址

3.1 单级页表系统

在分页管理的操作系统中,将主存分为一个个页框,操作系统会建立页表这种数据结构,负责虚拟页号和主存页框号的映射。

在这里插入图片描述

虚拟地址由 <页号,页内偏移量> 两部分组成,根据页号去查询页表,然后将页表中的页框号和页内偏移量组成物理地址。

例如页表部分内容如下,虚拟地址为00123366H,按字节编址,虚拟地址格式为<页号12位,页内偏移量20位>

在这里插入图片描述

在这里插入图片描述

根据虚拟地址中的001H,找到1号页表项,其页框号为521H,拼接上页内偏移量后即可得到物理地址52123366H。

但是如果想要查询页表,也要知道页表的起始地址,页表的地址保存在进程控制块(PCB)中,当CPU调度该进程时,会将PCB中的页表起始地址放入页表基址寄存器中,页表起始地址为物理地址

同时,为了解决页表项过多导致一个页框中放不下的问题,引入了多级页表。为了减少访存次数引入了快表(TLB)。

3.2 二级页表系统

在使用多级页表的32位操作系统中(以二级页表为例),虚拟地址被分成了 <页目录号,页号,页内偏移量> 三部分,例如在下图虚拟地址格式下虚拟地址为10801008H,页目录项和页表项长度均为4字节,按字节编址。

在这里插入图片描述

在这里插入图片描述

10801008H,其页目录号是66,页号是1,因此根据页目录号为66找到页目录项,其中的页框号是00301H,找到对应的页表所在页框,然后拼接上页号找到页号页表项对应的物理地址00301004H(这里因为一个页目录项是4B),页表中的页框号是98521H,拼接上页内偏移量,最终的物理地址为98521008H。

3.3 二级页表系统+快表

快表的实现基于相联存储器,是一种静态随机存取存储器(SRAM),使用的存储元是双稳态触发器,存取速度快。

在使用TLB的系统中,虚拟地址向物理地址的转换一般先查询快表(或者快表慢表一起查询),如果快表命中,可以直接获得页框号,再和页内偏移量组合,得到物理地址。

快表的映射方式有两种,为全相联映射和组相联映射,至于为什么不使用直接映射,在讨论完全相联映射和组相联映射后再讨论。

全相联映射

使用全相联映射的TLB中

TLB的格式为 <标记位,有效位,页框号>

此处的标记位即虚拟页号,若虚拟地址格式为 <页目录号(10位),页号(10位),页内偏移量(12位)>

TLB的标记位是虚拟地址中的页目录号+页号组成的虚拟页号

在这里插入图片描述

因为TLB是使用硬件电路实现的,全部TLB标记可以并行对比。

例如虚拟地址为10801008H,TLB使用全相联映射,虚拟地址格式为<页目录号(10位),页号(10位),页内偏移量(12位)>,TLB部分内容如下图所示

在这里插入图片描述

查询TLB表,10801H与虚拟页号一致,且有效位为1,因此可以直接得到页框号00001H,与页内偏移量008H拼接得到物理地址为00001008H,若未命中则回到上文中的查询二级页表的过程,且更新快表。

组相联映射

使用组相联映射的TLB格式如为 <标记位,有效位,页框号>,虚拟地址格式为 <标记位,组号,页内偏移量>,标记位+组号就是虚拟页号,同页目录号+页表号

例如二路组相联的TLB,其中共有32行,分成16组(用4位二进制表示),若虚拟地址为10801008H,虚拟地址格式为<标记位(16位),组号(4位),页内偏移量(12位)>,则查找1号分组,标记位为1080H

在这里插入图片描述

第一组标记位为1080H命中,其有效位为1,直接得到页框号为00002H,拼接上页内偏移量得到物理地址为00002008H,若未命中则回到上文中的查询二级页表的过程,且更新快表。

直接映射

TLB一项的大小很小,而且直接映射冲突率高,为了实现高命中率和低冲突率,因此TLB不使用直接映射。

而cache按照块大小,将主存一块数据(主存的一块和内存管理的一页没有关系,通常一页的大小比一块的大小要更大)读入cache行中,冲突率相比TLB会小一些,在部分场景下可以接受这种冲突的成本。

4.访问物理地址

得到物理地址后,会先访问cache,如果cache未命中访问主存,并将该物理地址所在块调入cache中(或者同时访问cache和主存)。

cache和TLB都是基于SRAM的相联存储器,不同的是cache的映射方式有三种,分别是直接映射,全相联映射,组相联映射。

在这里插入图片描述

直接映射

物理地址格式为 <Tag,行号,块内地址>

cache行内格式为 <Tag,有效位,脏位等其他数据,块数据>

全相联映射

物理地址为 <Tag,块内地址>

cache行内格式为 <Tag,有效位,脏位等其他数据,块数据>

组相联映射

物理地址格式为 <Tag,组号,块内地址>

cache行内格式为 <Tag,有效位,脏位等其他数据,块数据>

因为和TLB的过程没有太大区别,此处不再详细讨论。

不过值得注意的是,当TLB和cache未命中要更新TLB和cache时候需要使用置换算法,置换算法此处也不再讨论。

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

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

相关文章

从equals思考对“正念”的认知

正念 很多人聊正念&#xff0c;每个人有自己的解说&#xff0c;我听到最符合逻辑的一个说法&#xff1a;正念就是对抗惯性。 如果尝试过打坐或者冥想&#xff0c;就有一个说法叫正观&#xff0c;什么意义呢&#xff1f;就是说感受自己的呼吸&#xff0c;自己的心跳&#xff0c…

信息安全管理与评估2025山东卷

需要其他赛题解析的可联系博主

【leetcode】02.07. 链表相交

链表相交 题目代码1. 计算两个链表的长度2. 双指针 题目 02.07. 链表相交 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点&#xff0c;返回 null 。 图示两个链表在节点 c1 开始相交&#xff1a; 代码 …

可视化与动画:构建沉浸式Vue应用的进阶实践

在现代Web应用中&#xff0c;高性能可视化和流畅动画已成为提升用户体验的核心要素。本节将深入探索Vue生态中的可视化与动画技术&#xff0c;分享专业级解决方案与最佳实践。 一、 Canvas高性能渲染体系 01、Konva.js流程图引擎深度优化 <template><div class"…

⼤模型驱动的DeepInsight Copilot在蚂蚁的技术实践

本文整理自潘兰天&#xff08;蚂蚁数据智能团队数据分析平台技术专家)在DA数智大会2025上海站的演讲实录。 本文围绕AI技术在数据分析领域的应用及DeepInsight Copilot产品展开。DeepInsight是一款蚂蚁长期深耕数据分析领域的BI产品&#xff0c;本文首先介绍了DeepInsight Copi…

Express教程【003】:Express获取查询参数

文章目录 3、获取URL中携带的查询参数3.1 参数形式&#xff1a;查询字符串3.2 参数形式&#xff1a;动态参数3.3 参数形式&#xff1a;Json数据 3、获取URL中携带的查询参数 3.1 参数形式&#xff1a;查询字符串 1️⃣通过req.query对象&#xff0c;可以访问到客户端通过查询…

在CentOS7上使用tree查看目录树

文章目录 1. 利用yum安装tree2. 利用rpm安装tree2.1 下载tree的rpm包2.2 上传到云主机2.3 安装tree软件 3. 使用tree查看目录树4. 实战小结 1. 利用yum安装tree 执行命令&#xff1a;yum -y install tree CentOS7停止更新&#xff0c;即使更新镜像源&#xff0c;也无法正常安装…

大规模JSON反序列化性能优化实战:Jackson vs FastJSON深度对比与定制化改造

背景&#xff1a;500KB JSON处理的性能挑战 在当今互联网复杂业务场景中&#xff0c;处理500KB以上的JSON数据已成为常态。 常规反序列化方案在CPU占用&#xff08;超30%&#xff09;和内存峰值&#xff08;超原始数据3-5倍&#xff09;方面表现堪忧。 本文通过Jackson与Fas…

华为交换机S12708常用命令

以下是华为S12708交换机&#xff08;高端园区/数据中心核心交换机&#xff09;的常用运维命令&#xff0c;涵盖基础配置、状态查看、故障排查等场景&#xff1a; 一、基础配置命令 1. 系统管理 system-view # 进入系统视图 sysname S12708-Core # 设置设备名称 clock timez…

通过海康萤石API控制家里相机的云台及抓图

通过海康萤石API控制家里相机的云台及抓图 一、背景二、环境准备2.1 注册开发者账号2.2 安装依赖库2.3 创建`.`env`文件三、代码片段解释3.1 加载并使用环境变量3.2 发送HTTP请求的封装函数3.3 获取AccessToken3.4 分页查询设备列表3.5 抓拍图片3.6 开始云台控制3.7 控制云台并…

XCUITest 是什么

XCUITest&#xff08;全称 Xcode UI Test&#xff09;是苹果官方提供的 iOS/macOS UI 自动化测试框架&#xff0c;集成在 Xcode 开发工具中&#xff0c;专门用于测试 Swift/Objective-C 开发的应用程序。 1. XCUITest 的核心特点 ✅ 官方支持&#xff1a;苹果原生框架&#xf…

mapbox高阶,PMTiles介绍,MBTiles、PMTiles对比,加载PMTiles文件

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️Fill面图层样式1.4 ☘️PMTiles介绍1.5…

5.0以上版本antv/g6使用心得

1. 画布只重新渲染数据 graph.render graph.drawgraph,fitview()graph.fitCenter()setData塞入新的数据 const updateGraph (data) > {if (!graph) {console.warn("Graph is not initialized");return;}graph.clear();graph.setData(data);graph.render(); };…

4.5V~100V, 3.8A 峰值电流限, 非同步, 降压转换器,LA1823完美替换MP9487方案

一&#xff1a;综述 LA1823 是一款易用的非同步&#xff0c;降压转换器。 该模块集成了 500mΩ 低导通阻抗的高侧 MOSFET。LA1823 使用 COT 控制技术。此种控制方式有利于快速动态响应,同时简化了反馈环路的设计。LA1823 可以提供最大 2A 的持续负载电流。LA1823有150kHz/240kH…

如何定位并优化慢 SQL?

如何定位并优化慢 SQL? 一、慢 SQL 的定义与影响 1.1 什么是慢 SQL? 慢 SQL是指执行时间超过预期阈值的SQL语句,通常由以下特征: 执行时间超过慢查询阈值(如MySQL默认10秒)消耗大量CPU/IO资源导致连接堆积或系统负载升高关键结论:慢SQL是数据库性能瓶颈的主要诱因,可…

提升WSL中Ubuntu编译速度的完整指南

在 WSL&#xff08;Windows Subsystem for Linux&#xff09;中使用 make 编译项目时&#xff0c;如果发现编译速度非常慢&#xff0c;通常是由以下几个原因导致的。以下是一些常见的排查和优化方法&#xff1a; &#x1f50d; 一、常见原因及解决方案 ✅ 1. 文件系统性能问题…

77. 组合【 力扣(LeetCode) 】

文章目录 零、原题链接一、题目描述二、测试用例三、解题思路四、参考代码 零、原题链接 77. 组合 一、题目描述 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 二、测试用例 示例 1&#xff1a; 输入&…

C++中指针与引用的区别详解:从原理到实战

C中指针与引用的区别详解&#xff1a;从原理到实战 1. 引言&#xff1a;指针与引用的重要性 在C编程中&#xff0c;指针和引用是两个极其重要的概念&#xff0c;也是许多初学者容易混淆的地方。作为C的核心特性&#xff0c;它们直接操作内存地址&#xff0c;提供了对内存的直…

WebFuture:网站部分图片突然无法显示的原因

问题描述&#xff1a; 主站群迁移到linux系统后&#xff0c;原先部署在windows下的子站群节点部分图片无法显示。 原因分析&#xff1a; 检查无法显示的图片的路径&#xff0c;发现调用的是原先主站的图片。主站重新部署到linux系统后&#xff0c;图片路径会区分大小写所以统…

uniapp使用Canvas生成电子名片

uniapp使用Canvas生成电子名片 工作中有生成电子名片的一个需求&#xff0c;刚刚好弄了发一下分享分享 文章目录 uniapp使用Canvas生成电子名片前言一、上代码&#xff1f;总结 前言 先看效果 一、上代码&#xff1f; 不对不对应该是上才艺&#xff0c;哈哈哈 <template…