1、高速缓存
1.1 定义
用来存放当前最活跃的程序和数据。
特点:容量在几千字节到几兆之间,速度比主存快5~·10倍左右。快速半导体组成。
1.2 高速缓存的组成
一般位于CPU和主存之间。主要包括管理模块、由相联存储器构成的存储表、小容量的高速存储器。
1.3 高速缓存的地址映像方法
主存地址转换成Cache存储器的地址,这种地址转换叫做地址映像。地址映像主要有三种方式:
1、直接映像:主存的块和Cache块的关系是固定的。主存地址中主存区号和Cache存储的存储号相同表示命中。优点:地址变换简单;缺点:但灵活性差。
2、全联映像
允许主存的任一块调用Cache存储器的任何一个块空间。
优点:主存的物理块调入Cache的位置不受限制,比较灵活;缺点:无法从主存块号直接获得Cache对应的块号,变换复杂,速度较慢。
3、组相联映像
就是 将Cache中的块再分成组。组相联映像中组采用直接映像,块采用全相联映像方式。
1.4 高速缓存的替换算法、
替换算法目的是为了让Cache获得最高的命中率。
随机替换算法:利用随机数发生器产生一个要替换的块号,将该块替换出去。
先进先出算法:将最先进入的块替换出去。
近期最少使用算法:近期最少使用的块替换出去。
优化替换算法:先执行一次程序统计Cache替换的情况,第二次根据第一次的分析情况用最合理的方式进行替换。
1.5 Cache的性能分析
Cache的命中率是性能的一个重要指标。Cache的设计目标就是在成本允许的情况下达到较高的命中率、使存储系统拥有最短的访问时间。
在指令流水线中,Cache失效将会影响指令的流水。降低失效率是提升Cache性能的重要措施。降低失效率的主要方法可以选择合理的块容量、提高Cache容量、提升Cache的相联程度。
Cache容量越大命中率将会越高。要合理提升Cache的容量。因为容量大了成本将会增加、访问时间也会增加。
1.6 什么是多级Cache
Cache分为一级(L1 Cache)、二级(L2 Cache)。CPU访问先找L1,不命中找L2.。直到都命不中,则访问主存。CPU内通常为二级Cache结构。
2、虚拟存储器
理论上可以把主存存储器看作由多个字节构成的存储空间,每个字节有一个存储编号,主存单元的该地址称为物理地址。当需要访问主存的数据时,由CPU给出要访问的数据所在的存储单元地址,然后由主存的读写控制部件定位对应的存储单元,对其进行读写操作来完成访问动作。
虚拟存储器实际是一种逻辑存储器。实际上是对物理存储设备进行逻辑化处理,并将统一的逻辑视图呈现给使用者。