`
heycheng
  • 浏览: 3415 次
社区版块
存档分类
最新评论

Cache一致性协议之MESI

阅读更多

原文地址:https://blog.csdn.net/muxiqingyang/article/details/6615199

 

处理器上有一套完整的协议,来保证Cache一致性。比较经典的Cache一致性协议当属MESI协议,奔腾处理器有使用它,很多其他的处理器都是使用它的变种。

单核Cache中每个Cache line有2个标志:dirty和valid标志,它们很好的描述了Cache和Memory(内存)之间的数据关系(数据是否有效,数据是否被修改),而在多核处理器中,多个核会共享一些数据,MESI协议就包含了描述共享的状态。

         在MESI协议中,每个Cache line有4个状态,可用2个bit表示,它们分别是: 

状态

描述

M(Modified)

这行数据有效,数据被修改了,和内存中的数据不一致,数据只存在于本Cache中。

E(Exclusive)

这行数据有效,数据和内存中的数据一致,数据只存在于本Cache中。

S(Shared)

这行数据有效,数据和内存中的数据一致,数据存在于很多Cache中。

I(Invalid)

这行数据无效。

MESI状态

           M(Modified)和E(Exclusive)状态的Cache line,数据是独有的,不同点在于M状态的数据是dirty的(和内存的不一致),E状态的数据是clean的(和内存的一致)。

          S(Shared)状态的Cache line,数据和其他Core的Cache共享。只有clean的数据才能被多个Cache共享。

          I(Invalid)表示这个Cache line无效。

 

          E状态示例如下:

 

E状态

       只有Core 0访问变量x,它的Cache line状态为E(Exclusive)。

 

        S状态示例如下:

S状态

         3个Core都访问变量x,它们对应的Cache line为S(Shared)状态。

 

         M状态和I状态示例如下:

 

M状态和I状态

            Core 0修改了x的值之后,这个Cache line变成了M(Modified)状态,其他Core对应的Cache line变成了I(Invalid)状态。

 

        在MESI协议中,每个Cache的Cache控制器不仅知道自己的读写操作,而且也监听(snoop)其它Cache的读写操作。每个Cache line所处的状态根据本核和其它核的读写操作在4个状态间进行迁移。

       MESI协议状态迁移图如下:

MESI协议状态迁移图

        在上图中,Local Read表示本内核读本Cache中的值,Local Write表示本内核写本Cache中的值,Remote Read表示其它内核读其它Cache中的值,Remote Write表示其它内核写其它Cache中的值,箭头表示本Cache line状态的迁移,环形箭头表示状态不变。

        当内核需要访问的数据不在本Cache中,而其它Cache有这份数据的备份时,本Cache既可以从内存中导入数据,也可以从其它Cache中导入数据,不同的处理器会有不同的选择。MESI协议为了使自己更加通用,没有定义这些细节,只定义了状态之间的迁移,下面的描述假设本Cache从内存中导入数据。

        MESI状态之间的迁移过程如下:

当前状态

事件

行为

下一个状态

I(Invalid)

Local Read

如果其它Cache没有这份数据,本Cache从内存中取数据,Cache line状态变成E;

如果其它Cache有这份数据,且状态为M,则将数据更新到内存,本Cache再从内存中取数据,2个Cache 的Cache line状态都变成S;

如果其它Cache有这份数据,且状态为S或者E,本Cache从内存中取数据,这些Cache 的Cache line状态都变成S

E/S

Local Write

从内存中取数据,在Cache中修改,状态变成M;

如果其它Cache有这份数据,且状态为M,则要先将数据更新到内存;

如果其它Cache有这份数据,则其它Cache的Cache line状态变成I

M

Remote Read

既然是Invalid,别的核的操作与它无关

I

Remote Write

既然是Invalid,别的核的操作与它无关

I

E(Exclusive)

Local Read

从Cache中取数据,状态不变

E

Local Write

修改Cache中的数据,状态变成M

M

Remote Read

数据和其它核共用,状态变成了S

S

Remote Write

数据被修改,本Cache line不能再使用,状态变成I

I

S(Shared)

Local Read

从Cache中取数据,状态不变

S

Local Write

修改Cache中的数据,状态变成M,

其它核共享的Cache line状态变成I

M

Remote Read

状态不变

S

Remote Write

数据被修改,本Cache line不能再使用,状态变成I

I

M(Modified)

Local Read

从Cache中取数据,状态不变

M

Local Write

修改Cache中的数据,状态不变

M

Remote Read

这行数据被写到内存中,使其它核能使用到最新的数据,状态变成S

S

Remote Write

这行数据被写到内存中,使其它核能使用到最新的数据,由于其它核会修改这行数据,

状态变成I

I

MESI状态迁移

           AMD的Opteron处理器使用从MESI中演化出的MOESI协议,O(Owned)是MESI中S和M的一个合体,表示本Cache line被修改,和内存中的数据不一致,不过其它的核可以有这份数据的拷贝,状态为S。

         Intel的core i7处理器使用从MESI中演化出的MESIF协议,F(Forward)从Share中演化而来,一个Cache line如果是Forward状态,它可以把数据直接传给其它内核的Cache,而Share则不能。

 

扩展:  Java并发编程:volatile关键字解析

          Java单例模式中双重检查锁的问题

分享到:
评论

相关推荐

    多Cache一致性__目录协议模拟器使用方法1

    通过这个模拟器,学习者可以深入理解多CPU环境下的Cache一致性问题,如MESI(Modified, Exclusive, Shared, Invalidated)或MSI(Modified, Shared, Invalidated)等协议的工作原理,以及不同配置和策略对性能的影响...

    多 Cache 一致性实验介绍.docx

    在计算机体系结构中,多Cache一致性是一个核心议题,特别是在现代多处理器系统中,它确保了当多个处理器共享内存时,每个处理器的本地Cache中的数据都能保持最新和准确。这个概念的重要性在于,如果不同处理器的...

    众核处理器cache一致性研究综述.pdf

    最后,作者提出了设计具备应用程序适应性和可扩展性的Cache一致性协议的关键方向,包括动态适应工作负载变化、优化一致性协议以降低通信开销、以及利用硬件辅助机制加速一致性处理等。这些设计策略对于构建高效且...

    众核处理器cache一致性研究综述_韩立敏1

    文章首先引出背景,指出尽管众核处理器的核数不断增加,但与之相关的许多设计挑战尚未解决,其中Cache一致性便是重要的一环。众核处理器中的每个核心都带有自己的Cache,当多个核心同时访问共享内存时,如何保持数据...

    cache的一致性的相关讨论

    - **解决方案**:为了避免此类问题,系统需要采用特定的Cache一致性协议,如MESI(Modified、Exclusive、Shared、Invalid)等,来确保数据的一致性。 #### 写直达(Write-Through) **写直达策略**则规定每次写...

    ARM926EJ-S处理器中Cache一致性问题的探讨.pdf

    为解决Cache一致性问题,学术界提出了监听协议和目录协议,MESI协议就是其中之一。MESI协议通过定义状态来监控和管理缓存行的共享和独占状态,以此来维护Cache之间的一致性。然而,ARM公司没有为ARM926EJ-S处理器...

    共享存储器Cache一致性中监听协议 (Snooping protocol)的实现和优化.doc

    《共享存储器Cache一致性中监听协议 (Snooping protocol)的实现和优化》 共享存储器Cache一致性是多处理器系统中的关键问题,监听协议(Snooping protocol)作为解决此问题的一种有效方法,广泛应用于现代计算机...

    存储模型与缓存一致性协议

    - **缓存一致性(Cache Coherence)**:涉及管理多个处理器缓存中的数据一致性,以确保读写操作在系统中正确传播。 ### 缓存一致性协议 缓存一致性协议是解决多处理器系统中数据一致性问题的关键机制。当多个...

    基于共享总线的多处理器cache一致性的硬件实现.pdf

    然而,这种架构引入了一个关键问题:如何在多个处理器之间保持cache一致性。本文主要关注的是基于共享总线的多处理器cache一致性硬件实现。 共享总线的多处理器系统中,每个处理器都有自己的私有cache,它们通过...

    MESI缓存协议.docx

    MESI缓存协议是一种多处理器缓存一致性协议,用于解决多核CPU中的缓存一致性问题。该协议定义了缓存行的四种状态:Modified(M)、Exclusive(E)、Shared(S)和Invalid(I),以确保缓存中的数据是一致的。 MESI...

    cache存储器 DMA和cache一致性问题.doc

    然而,DMA操作可能与Cache产生冲突,因为DMA可能会修改内存中的数据,而这些修改可能不会立即反映在CPU的Cache中,这就导致了【cache一致性问题】。 **Cache一致性问题**是指多个处理器或者设备共享同一内存区域时...

    多核处理器及其Cache一致性机制.pdf

    多核处理器及其Cache一致性机制 多核处理器的出现和发展是计算机技术高速发展的结果,是微电子技术的巨大进步和处理器体系结构的演化...多核处理器的Cache一致性机制可以通过总线锁、目录协议和MESI协议等方式来实现。

    CacheCoherence:为基于总线的广播系统实现 MI、MSI、MESI、MOSI、MOESI 和 MOESIF 协议

    本主题将深入探讨MI、MSI、MESI、MOSI、MOESI和MOESIF这六种缓存一致性协议,并解释它们在C++编程环境中的应用。 1. **MI协议(Modified, Invalid)**:是最简单的协议,每个处理器都有自己的私有缓存。当一个...

    15418-Cache-Simulator:我的15-418缓存一致性协议模拟器的存储库

    综上所述,这个项目提供了一个用于模拟缓存一致性协议的工具,支持MSI、MESI和MOESI协议,并考虑了回写缓冲区和非原子总线事务等实际系统中的复杂情况。这样的模拟器对于理解和分析多处理器系统中的数据一致性问题...

    2005,我们“芯芯”相印——双核心CPU缓存数据一致性浅析.pdf

    MESI 协议是 Intel 的一种 Cache Coherence Protocol,它可以确保缓存数据的一致性。MESI 协议将缓存分为四种状态:Modified(已修改)、Exclusive(独占)、Shared(共享)和Invalid(无效)。当一个CPU核心需要...

    Armv8/Armv9 cache深度学习

    Armv8/Armv9 cache 深度学习 cache 是 Arm 处理器架构中的一种重要组件,它位于处理器核心和主... MESI/MOESI 是一种 cache 协议,用于维护 cache 的一致性。包括 Modified、Exclusive、Shared 和 Invalid 四种状态。

    计算机中的cache工作原理解析

    - Cache一致性是指多个Cache之间共享数据的一致性,解决多个缓存间数据同步的问题。 - 一致性协议包括MESI(修改、独占、共享、无效)协议,确保缓存中的数据状态保持同步。 5. Cache的层次结构: - CPU通常包含...

    物172_2017218007_文华_课程报告1

    【文章摘要】: 本文探讨了多核处理器中片上多核处理器一致性问题的起源和发展,总结了高速缓存一致性协议设计的关键问题,并概述了近年来关于众核处理器Cache一致性的相关研究。 【关键词】: Cache一致性协议;片上...

Global site tag (gtag.js) - Google Analytics