【Verilog基础】【计算机体系结构】深入理解Cache一致性(针对多核SoC系统)

本文探讨了多核系统中Cache一致性的重要性和维护步骤,包括'看到'和'看到之后的动作'。介绍了Snoopying-based和Directory-based两种解决方案,以及Write Update和Write Invalidate策略。在多核SoC系统中,常见的如MESI协议采用了Write Invalidate协议来确保一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

其实cache一致性的维护分为两个步骤,一个是“看到”,另一个是“看到之后动作”。可以这样形象理解“看到”和“看到之后动作”:

  • “看到”就是一些策略可以让一个CPU更改cacheline的时候,其他CPU也知道它对应的cacheline被更改了。
  • “看到之后动作”就是其他的CPU知道它对应的cacheline被更改了,它要采用的一些动作。

cache一致性解决方案:如何“看到”

目前针对cache一致性问题,有两种主要的解决方案:

  • Snoopying-based方案:采用广播的形式,也就是当一个CPU修改了cache line之后,将广播通知到总线上其他所有的CPU。

  • Directory-based方案:采用的是点对点的方式进行传播(就像打电话一样),每个总线transaction只会发给感兴趣的CPU。

cache一致性解决方案:如何采取“看到之后动作”

  • 1、其他CPU对共享变量有写操作之后立刻更新的做法,被称为Write Update,这种方法逻辑简单,但效率不高。
  • 2、更好的做法是在其他CPU对cache line有写操作之后,仅仅是把自己的cache中对应的cache line标记为(I)nvalid的状态,这种做法被称为Write Invalidate
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ReCclay

如果觉得不错,不妨请我喝杯咖啡

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值