https://mp.weixin.qq.com/s/1vyfhZuF4RyRE5Qjj6AGWA

 
简单介绍SourceShrinker的实现。
 
 
1. 基本介绍
 
用于把上游节点的source数量压缩到指定的值(maxInFlight)。
 
2. diplomacy node
 
diplomacy node用于与上下游节点相连接,并分别向上下游传递参数信息。
 
1) client
 
压缩之后的client参数,即要展示给下游节点看的client参数:
其中:sourceId的范围限定在最大值是maxInFlight。
 
2) node
 
定义用于适配参数的clientFn和managerFn:
其中:
a. clientFn:在client的基础上,对requestFifo进行处理,确定是否需要下游节点的FIFO支持;
b. managerFn:如果maxInFlight==1,那么SourceShrinker节点只能并发处理一个请求,相当于告诉上游节点SourceShrinker只有一个fifo。
 
3. lazy module
 
lazy module用于实现SourceShrinker的内部逻辑。这里主要是在上下游节点之间对source域进行适配。
 
1) 成对的输入边和输出边
 
 
2) 不支持适配Cache节点
 
 
3) 如果maxInFlight的值大于原有sourceId的数目那么就相当于要放大,也就不存在压缩sourceId的情况,直接透传source域即可,无需适配:
 
下面介绍需要压缩sourceId的情况。
 
4) 生成一个sourceId的位图:
 
其中:
a. sourceIdMap的宽度为maxInFlight位,即每个允许的sourceId一位;
b. allocated:记录哪些sourceId已分配的位图;
c. nextFree:下一个空闲可使用的sourceId;
d. full:是否所有的sourceId都已经被分配占用;
 
5) 如果所有的sourceId都被占用,就阻止上游节点继续发送请求:
 
6) 把in.a.bits.source适配成下一个可使用的sourceId:
 
 
记录新分配的sourceId,对应的原sourceId:
 
7) 根据响应消息中的source,查找记录中对应的sourceId,并还原到in.d.bits.source:
 
其中:bypass用于处理同一个时钟周期可以返回响应消息的情况。
 
8) 更新位图信息:
 
 
 

Rocket - tilelink - SourceShrinker的更多相关文章

  1. Rocket - tilelink - RegisterRouter

    https://mp.weixin.qq.com/s/DaJhf7hEoWsEi_AjwSrOfA   简单介绍RegisterRouter的实现.   ​​   1. 基本介绍   实现挂在Tile ...

  2. Rocket - tilelink - Nodes

    https://mp.weixin.qq.com/s/KJ8pVH76rdxPOZ1vE3QlKA   简单介绍tilelink对Diplomacy Nodes的实现.   ​​   1. TLImp ...

  3. Rocket - tilelink - AsyncCrossing

    https://mp.weixin.qq.com/s/v8plWCBD8vZkxykjJe4TCg   介绍AsyncCrossing的实现,主要介绍如何实现diplomacy Node和LazyMo ...

  4. Rocket - tilelink - mask

    https://mp.weixin.qq.com/s/Gqv09RIgSSg5VKe-wb4aGg   讨论tilelink中使用MaskGen生成mask的用法.   1. tilelink中的ma ...

  5. Rocket - tilelink - Parameters

    https://mp.weixin.qq.com/s/1I6DcONr0Mg7xiX8F1C7SQ   简单介绍TileLink相关的参数实现(具体问题暂时不展开,后续用到时再做分析).   ​​   ...

  6. Rocket - tilelink - Bundles

    https://mp.weixin.qq.com/s/jrqBg2AIpQogBrpwNXjmwg   简单介绍Bundles文件中对TileLink规范(1.7.1)的定义. 参考链接:https: ...

  7. Rocket - tilelink - TLBusWrapper.to

    https://mp.weixin.qq.com/s/jSnhBzU5_ayQCg5fWAcx-g 简单介绍TLBusWrapper.to()的实现.主要介绍确定this{...}对应代码的过程. 1 ...

  8. Rocket - tilelink - BusWrapper

    https://mp.weixin.qq.com/s/03BvgTNQtD75Guco6gUGQg   简单介绍BusWrapper的实现.   1. HasTLBusParams   定义SoC的挂 ...

  9. Rocket - tilelink - Xbar

    https://mp.weixin.qq.com/s/UXFHYEQaYotWNEhshro68Q   简单介绍Xbar的实现.   ​​   1. 基本介绍   用于为Xbar的输入和输出连接生成内 ...

随机推荐

  1. B - Planning 早训 贪心

    B - Planning 这个题目我知道要贪心,也知道怎么贪,但是写不出来,感觉自己好菜. 这个题目要用优先队列维护. 题目大意是飞机延误,不同的飞机每次延误一分钟,它的代价不同,然后问,怎么安排才能 ...

  2. C. Barcode dp

    https://codeforces.com/problemset/problem/225/C 这个题目和之前一个题目很像 https://www.cnblogs.com/EchoZQN/p/1090 ...

  3. go实现SnowFlake

    package main import ( "errors" "fmt" "strconv" "sync" " ...

  4. 新创建的项目AndroidManifast报App is not indexable by Google Search;

    原错误提示:App is not indexable by Google Search; consider adding at least one Activity with an ACTION-VI ...

  5. 黑马程序员_毕向东_Java基础视频教程——赋值(随笔)

    赋值 class Test{ public static void main(String[] args) { int i = 3; // += -= *= /= %= 它们凑一块成为一个运算符 x ...

  6. Java中JVM相关面试题-整理

    1.JVM内存模型 •程序计数器:当前线程字所执行节码的行号指示器,用于记录正在执行的虚拟机字节指令地址,线程私有. •Java虚拟机栈:存放基本数据类型,对象的引用,方法出口等,线程私有. •本地方 ...

  7. mysql小白系列_08 zabbix3.2.6概念及部署

    一 zabbix功能简介 1.zabbix三大监控组件 zabbix server web gui database zabbix_server zabbix proxy agent client 2 ...

  8. 判断数组的方法/判断JS数据类型的四种方法

    参考文: 以下 3 个判断数组的方法,请分别介绍它们之间的区别和优劣Object.prototype.toString.call() . instanceof 以及 Array.isArray() h ...

  9. Null passed to a callee that requires a non-null argument

    OC中定义的方法参数默认是不为空的,如果能够为空需要手动指定__nullable ,我想这个警告是提示开发者警惕可能空参数

  10. 15-2 insert语句介绍

    create table TblClass ( tClassId ,) primary key, tClassName ) ) --向班级表中插入一条记录 --insert into 表名(列1,列2 ...