其实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。