chi trans简介--stash trans

stash flow

The Stash transactions are:

• WriteUniquePtlStash

• WriteUniqueFullStash

• StashOnceUnique

• StashOnceShared

• StashOnceSepUnique

• StashOnceSepShared

  1. 对于home node来讲,允许ignore任何的stash request,并且不做任何的stash snoop;
  2. 被snoop的node, 允许忽略stash request, 同时不发出data pull请求来完成trans;
  3.  StashOnceSepUnique and StashOnceSepShared既可以由分开的stashDone resp, 或者combined CompStashDone resp;

StashOnceUnique, StashOnceSepUnique

  • 往一个snoopable的地址空间,发送的请求,用来将对应地址的cacheline,pass to targeted cache, 同时让对应的targeted cache存储该cacheline;
    • 这里通过Node ID和LPID来指定,需要缓存cacheline的request Node;
    • 如果valid target没有指定,则对应的cacheline可以由request completer缓存;
    • 从target Request Node发出的Data Pull, 当作ReadNotSharedDirty处理;
  • 初始状态:

       

  • 最终状态

          

  • 对应的snp请求

    

  • 状态转换如下:

    

StashOnceShared, StashOnceSepShared

  • Request to a Snoopable address region to attempt to move the addressed cache line to a targeted cache.
    • 这里通过Node ID和LPID来指定,需要缓存cacheline的request Node;
    • 如果valid target没有指定,则对应的cacheline可以由request completer缓存;
    • 从target Request Node发出的Data Pull, 当作ReadNotSharedDirty处理;
  • 初始状态:

       

  • 最终状态:

      

  • 对应的snp命令:

     

  • 状态转换关系:

    

  • 对应的流程图:

WriteUniquePtlStash,WriteUniqueFullStash

  • 往snoopable的地址空间写数据;
  • 当requester处的状态为invalid时,最多写入一个cacheline的数据到下一级cache或者memory;
  • 同样,此命令也会携带对应的stash target node来获取对应的cacheline;
  • 初始状态:

        

  • 对应的snp请求

      

  • 状态转换如下所示:

       

  • 对应的snoop请求:

      

  • 可能的请求flow如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值