体系结构19_降低Cache失效率的方法

2023-10-19 01:20

本文主要是介绍体系结构19_降低Cache失效率的方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.三种失效(3C)

(1)强制性失效(Compulsory miss)

     当第一次访问一个块时,该块不在Cache中,需从下一级存储器中调入Cache,这就是强制性失效

    (冷启动失效,首次访问失效)

(2)容量失效(Capacity miss)

    如果程序执行时所需的块不能全部调入Cache中,则当某些块被替换后,若又重新被访问,就会发生失效。这种失效称为容量失效。

(3)冲突失效(Conflict miss)

  在组相联或直接映像Cache中,若太多的块映像到同一组(块)中,则会出现该组中某个块被别的块替换(即使别的组或块有空闲位置),然后又被重新访问的情况。这就是发生了冲突失效。

        (碰撞失效,干扰失效

 

2.三种失效所占的比例

 可以看出:

  (1)相联度越高,冲突失效就越少

  (2)强制性失效不受Cache容量的影响,但容量失效却随着容量的增加而减少;请执行失效和容量失效不受相联度的影响。

  (3)表中的数据符合2:1的Cache经验规则,即大小为N的直接映像Cache的失效率约等于大小为N/2的两路组相联Cache的失效率

3.减少三种失效的方法

  强制性失效:增加块大小,预取(本身很少)

  容量失效:增加容量  (防止出现抖动现象)

  冲突失效:提高相联度  (理想情况:全相联)

4.许多降低失效率的方法会增加命中时间或失效开销

增加Cache块大小

1.失效率与块大小的关系

(1)对于给定的Cache容量,当块大小增加失效率开始时下降,后来反而上升。

(2)Cache容量越大,失效率达到最低的块大小就越大

2.增加块大小会增加失效开销

例1: 假定存储系统在延迟40个时钟周期后,每两个时钟周期能送出16个字节。即:经过42个时钟周期,它可提供16个字节;经过44个时钟周期,可提供32个字节;依次类推。试问:对于表5-6中列出的各种容量的Cache,在块大小分别为多少时,平均访存时间最小?假设命中时间为一个时钟周期

解:

     解题过程

      1KB、4KB、16KB Cache:块大小=32字节

       64KB、256KB Cache:块大小=64字节

提高相联度

1. 采用相联度超过8的方法实际意义不大

2. 2:1 Cache经验规则

     容量为N的直接映像Cache

                              约等于容量为N/2的两组相联Cache

3.提高相联度是以增加命中时间为代价

    例如:

            TTL或ECL板级Cache,两路组相联:(板级Cache:以前的CPU中不包含Cache,他俩放在一个板子上)

            增加10%

            定制的CMOS Cache,两路组相联:(Cache做在了CPU里)

            增加2%

Victim Cache

1.基本思想

  在Cache和它从下一级存储器调数据的通路之间设置一个全相联的小Cache,用于存放被替换出去的块(称为Victim),以备重用。

工作过程:

2.作用

 对于减小冲突失效很有效,特别是对于小容量的直接映象数据Cache,作用尤其明显。例如,项数为4的Victim Cache:使4KBCache的冲突失效减少。  20%~90%(跟程序有关)

伪相联Cache

取直接映象及组相联两者的优点:

   命中时间少,失效率低

缺点: 多种命中时间会使CPU流水线的设计复杂化

(1)基本思想及工作原理

   在逻辑上把直接映象Cache的空间上下平分为两个区。对于任何一次访问,伪相联Cache先按直接映象Cache的方式去处理。若命中,则其访问过程与直接映象Cache的情况一样。若不命中,则再到另一区相应的位置去查找。若找到,则发生了伪命中,否则就只好访问下一级存储器。

(2)快速命中与慢速命中

   要保证绝大多数命中都是快速命中

 

 

 

 

这篇关于体系结构19_降低Cache失效率的方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

在Linux中改变echo输出颜色的实现方法

《在Linux中改变echo输出颜色的实现方法》在Linux系统的命令行环境下,为了使输出信息更加清晰、突出,便于用户快速识别和区分不同类型的信息,常常需要改变echo命令的输出颜色,所以本文给大家介... 目python录在linux中改变echo输出颜色的方法技术背景实现步骤使用ANSI转义码使用tpu

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin