计算机组成原理学习笔记————Cache主存地址映射

2023-10-13 03:10

本文主要是介绍计算机组成原理学习笔记————Cache主存地址映射,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Cache——主存地址映射

由主存地址映射到Cache地址称为地址映射。映射方式很多,有直接映射,全相联映射、组相联映射。 映射就是指将主存地址中的某一块儿加载到Cache地址中,并指定某一块。

直接映射

主存当中任意一个块只能映射到Cache中某一个指定的块。如图:
在这里插入图片描述
图中每个主存块只与一个缓存块相对应,映射关系为**i = j mod C 或 i = j mod 2^c ** i为缓存块号,j为主存块号,C为缓存块数。映射结果表明每个缓存块对应若干个主存块。

具体实现过程

  1. 根据Cache存储体大小,将主存分成若干个与Cache存储体大小相同的区。如图中Cache有2c-1个块,则主存被分为若干个含有2c-1个块的区。每个区中的块的编号与Cache中的编号相同,并且一一对应。因此,Cache中的一个块对应了主存中的若干个块的位置,主存中的块要存储到Cache中时只能根据这样的对应关系存储到Cache中唯一的一块中。
  2. 对于CPU给出的地址,可以分为三部分,分别是:区号、块号、块内偏移地址。区号就是上图中的t位主存子块标记 块号就是c位Cache字块地址,块内偏移地址就是b位字块内地址。
  3. Cache存储体中的t位标记存储了主存储体中对应的区号。对CPU给出的地址,可以根据块号在Cache中直接找到对应的块,然后再通过比较器比较地址给出的区号是否与Cache存储体中标记的区号一致,一致则说明CPU给出的地址已经保存到了Cache中,可直接获取地址中的指令或数据,若不一致,说明地址还未保存到Cache中,则需访问主存。

计算机组成原理(第2版)唐朔飞 中的解释:
在这里插入图片描述

缺点

不够灵活,每个主存块只能固定的对应某个缓存块,即使缓存内还空着许多位置也不能占用,使缓存的存储空间得不到充分的利用。此外,如果程序恰好要重复访问对应同一缓存位置的不同主存块,就要不停的进行替换,而且降低命中率。

对映射关系式i = j mod C的解释

映射关系为**i = j mod C 或 i = j mod 2^c ** i为缓存块号,j为主存块号,C为缓存块数。中文描述就是 缓存中块地址=主存块地址 mod Cache中的块数
一个块数为8的Cache,取模运算之后得到的就是主存块地址中的第三位。例如存储器地址11101被映射到Cache中的101位置,如下图:
在这里插入图片描述
从图中可以看出一个CPU给出的地址的地位是用来检索到Cache中的位置,那如何判断该位置的数据是否为CPU所请求的字呢? 因此有了标记,即直接映射图中的高t为主存块标记。以上图中的映射关系为例,存储器地址11101的低三位用来映射到Cache,那么高两位就用来作为标记。
在这里插入图片描述

对有效位的解释

当一个处理器启动时,Cache中没有数据,则标记域中的值没有意义。甚至在执行一些指令后,Cache中的一些块依然为空,则这些块中的标记应该被忽略。因此增加了有效位,用来识别Cache存储块中的数据是否有效,因为有时Cache中的数据是无效的。 如果该位没有置1,则不能使用该块中的内容。
在这里插入图片描述

地址划分

对于CPU给出的每个可能地址,在Cache中如何进行查找,地址的地位用来找到Cache中与该地址匹配的唯一项。如下图:将一个地址划分为
**标记域:**用来与Cache中标记域的值进行比较。

Cache索引: 用来选择块。
在这里插入图片描述
对这个cache,地址的低位用来选择由数据字和标记组成的一个cache项。这个cache中有1 024个字,即4KiB。假设使用32位的地址。cache 中的标记与地址高位相比较,判断cache中的项是否符合请求的地址。由于cache有210 (1024) 个字,块大小为1个字,因此,索引cache需要10位,剩下的32- 10-2= 20位用来和标记相比较。如果标记和地址的高20位相等,并且有效位开启,那么请求在cache中命中,相应的字被提供给处理器。否则,发生缺失。
在这里插入图片描述

全相联映射

全相联映射允许主存中每一个字块映射到Cache中任何一块位置。如下图。
在这里插入图片描述
如图,主存储器中的块可能映射到Cache中的任意一个位置。所以当CPU放访问主存时,需将给出地址中的主存字块标记与Cache存储器中的全部标记进行比较,如果有相等的标记,则命中,否则未命中,需进行替换。

优点

方式灵活,命中率更高,缩小了块冲突率。 逻辑电路多,成本高。

缺点

与直接映射相比,主存字块标记的位数变成了t+c位,进行比较的比较器位数增加。需和Cache中全部标记进行比较才能判断所访问地址内容是否已经在Cache中。

组相联映射

组相联映射是直接映射和全相联映射的一种折中方式。
在这里插入图片描述
首先将Cache分成若干个块,再对块进行分组,假设分成r个组,组内块的数量不固定。 然后对主存进行分区,区数与Cache中的组数相同,即r组。主存中每个区的块可以存储到Cache对应组中的任意一块。所以,主存中某个块所在的区号直接决定了它能够映射到Cache中的哪个组。

优点

一个块能映射的位置有多个,与直接映射的一一对应关系相比,更不容易冲突。 在判断主存中某一个块是否已在Cache中,只需根据地址所在的区号找到Cache中对应的组,再根据组内块的标记比较区号是否对应。不需要和每一个Cache进行比较。与全相联映射相比,比较次数更少。

Cache缺失处理

Cache缺失:由于数据不在Cache中而导致被请求的数据不能满足。
缺失就是未命中,Cache中没有CPU要访问的地址。
Cache缺失处理主要有两部分组成:处理器控制单元,以及一个进行初始化主存访问和重新填充Cache的独立控制器。

Cache缺失处理步骤:

  1. 把程序计数器(PC)的原始值(当前PC-4)送到存储器中。
  2. 通知主存执行- -次读操作,并等待主存访问完成。
  3. 写cache项,将从主存取回的数据写人cache中存放数据的部分,并将地址的高位(从ALU中得到)写人标记域,设置有效位。
  4. 重启指令执行第-一步,重新取指,这次该指令在cache中。数据访问时对cache 的控制基本相同:发生缺失时,处理器发生阻塞,直到从存储器中取回数据后才响应。.

这篇关于计算机组成原理学习笔记————Cache主存地址映射的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/200373

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识