https://mp.weixin.qq.com/s/JS4Pguwa6LXjPsMq6nW8HA

 
简单介绍FIFOFixer的实现。
 
 
1. 基本介绍
 
按照一定的策略把某一部分manager的fifoId摊平转换为一个fifoId,并为这个fifoId实现同步功能。这样上游节点看到的fifoId就减少了,所需要实现的同步功能就少了,减轻了其负担。
 
2. TLFIFOFixer.Policy
 
用于筛选Manager的策略:
 
定义了如下三种:
 
3. fifoMap
 
用于根据策略重新映射各个manager的fifoId:
 
1) 按策略分成两组:
 
符合策略的叫flatManagers,不符合的叫keepManagers。
 
2) 取得两组manager的fifoId:
 
如果某fifoId在两个组中都有,那么把它当做符合策略的使用。
 
根据注释:
a. 所谓flat,就是摊平,所有的fifoId都变成0;
b. 所谓keep,就是保持,compacted的意思是压缩,即保持每一个都不一样,但是压缩成为连续的自然数;
 
3) 构建两组老fifoId到新fifoId的映射:
 
a. 摊平的那一组,所有fifoId映射后的值都是0;
b. 保持的那一组,所有fifoId映射为从1开始的连续的自然数值;
 
4) 把两组映射合在一起:
 
 
5) fixMap
 
为每一个manager分配的fifoId:
A. 符合策略的manager的新fifoId为0;
B. 不符合策略的manager有两种情况:
a. 若原fifoId = None,新fifoId=None;
b. 若原fifoId != None,新fifoId为按顺序压缩后的新fifoId;
 
6) splatMap
 
重新映射,把符合策略的fifoId压缩为从0开始的自然数:
a. 不符合策略的manager的新fifoId为None;
b. 原fifoId=None的manager,新fifoId不变,也是None;
c. 符合策略的manager的新fifoId为按顺序压缩后的从0开始的自然数;
 
7) 对比
 
 
4. diplomacy node
 
需要调整下游节点传过来的fifoId,进行fix,也就是使用fixMap生成的新fifoId:
 
5. lazy module
 
用于实现内部逻辑:
a. 因为符合策略的manager的fifoId被摊平了,所以需要为他们做同步功能;
b. 不符合策略的manager各自具有不同的fifoId,其同步由client实现;
 
1) 成对出现的输入边和输出边
 
 
2) 处理下游的managers的fifoId
 
 
3) 是否属于符合策略的fifo的请求:
 
其中:
a. edgeIn表明使用的是转换之后的fifoId,根据diplomacy node中的用法,即fixMap中的fifoId;
b. _.fifoId==Some(0)表明address所属的manager符合策略;
c. 因为上游client看到符合策略的manager的fifoId都为0,而与之对应的下游manager的fifoId不一定为0,所以需要我们为这些请求做同步处理;
d. _.fifoId!=Some(0)表明address所属的manager不符合策略;
 
4) 找出符合策略的manager:compacted
 
a. f==Some(0):表明对应的manager符合策略;
b. 不符合策略的manager对应的None被flatMap过滤掉,不会存在于compacted中;
c. 符合策略的manager中,原fifoId为None的,被fifoId=s还原为None;
d. 符合策略的manager中,原fifoId不为None的,被fifoId=s重新编排为从0开始的自然数;
e. edgeOut表明使用的是下游manager;
 
5) a_id
 
把摊平的fifoId再提起来:
根据请求访问的地址,把请求分配到不同的fifo;原来fifo相同的还分配到同一个fifo。
 
a_noDomain表示manager属于符合策略的manager中原fifoId为None的那一部分。
 
6) 记录某source的请求是否需要做同步:
 
响应消息到来时,就不再需要做同步了。
 
7) 是否需要挂住停止发送请求:
 
a. 不需要Fifo的client不作处理:c.requestFifo;
b. 该client是否包含当前source;
c. 该client下属所有的source中是否有请求排斥其他请求:flight.slice(c.sourceId.start, c.sourceId.end).reduce(_ || _)
 
该client若要求挂住,需满足如下条件:
a. 当前请求源自该client;
b. 请求的第一个beat;
c. 该client下属的source中已经存在发出但仍未响应的请求;
d. a_noDomain || id =/= a_id
 
这里分析一下d:
a. a_noDomain
 
若a_noDomain为真,则表明两个请求的fifoId至少有一个为0。请求的fifoId=0表明对应的下游manager的fifoId=None,意为接收到的请求不一定会被按顺序响应。
 
若只有一个请求的fifoId=0,那么这两个请求对应着两个下游manager,无法保证响应顺序;
若两个请求的fifoId=0,因为可能存在两个以上下游manager的fifoId为None。所以虽然两个请求的fifoId都为0,但无法保证针对的是同一个下游manager。即便是同一个下游manager,也无法保证顺序。
 
b. id =/= a_id
 
意为这一次请求的a_id与上一次记录的id不同。
同时发出两个相同fifoId的请求,由下游manager保证这两个请求的响应消息安装先后顺序返回;
同时发出两个不同fifoId的请求,其响应顺序则无从保证。
 
8) 是否存在client要求同步:
 
 
9) 根据是否需要同步连接输入边和输出边的channel a/d:
 
 
10) channel b/c/e不做处理:
 
 
6. a_notFIFO重定义
 
是否需要为请求做序列化:
 
可以看到这个名字有两个问题:
a. 词不达意;
b. 名称中含有反转,理解时需要拐一个弯;
 
可以看到,后面使用时也多用其反转义项:
 
所以这里最好重新定义,反转一下意义:
 
修改后用处如下:
 
 

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

  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. Spring官网阅读(十八)Spring中的AOP

    文章目录 什么是AOP AOP中的核心概念 切面 连接点 通知 切点 引入 目标对象 代理对象 织入 Spring中如何使用AOP 1.开启AOP 2.申明切面 3.申明切点 切点表达式 excecu ...

  2. 流媒体与实时计算,Netflix公司Druid应用实践

    Netflix(Nasdaq NFLX),也就是网飞公司,成立于1997年,是一家在线影片[租赁]提供商,主要提供Netflix超大数量的[DVD]并免费递送,总部位于美国加利福尼亚州洛斯盖图.199 ...

  3. 深度剖析西门子PLC的开放式TCP通信

    对于自控或电气工程师来说,西门子PLC是每个人都非常熟悉的一款PLC品牌:而对于上位机开发工程师来说,Socket通信或TCP/IP协议也是必须要掌握的一种通信方式.刚好手头有一款西门子的200Sma ...

  4. 数组的操作。1,JS数组去重。2,把数组中存在的某个值,全部找出来。3在JS数组指定位置插入元素。。。

    1,数组去重 let arr = [1,2,3,4,5,6,1,2,3,'a','b','a']; let temp = []; // 作为存储新数组使用 for(let i = 0; i < ...

  5. HMM-维特比算法理解与实现(python)

    HMM-前向后向算法理解与实现(python) HMM-维特比算法理解与实现(python) 解码问题 给定观测序列 \(O=O_1O_2...O_T\),模型 \(\lambda (A,B,\pi) ...

  6. Docker之镜像地址

    转载自https://www.cnblogs.com/doraman/p/9570891.html 官方docker hub 官方:https://hub.docker.com/explore/ 常用 ...

  7. virtualbox复制了以后网卡启动不了。

    还是有些坑..必须踩 virtualbox复制了以后网卡启动不了.原因是如果没选重新生成mac ,那么mac地址会和第一台 机器一模一样,出现ip 征用的情况. 第二是系统方面的原因,你要删一个文件, ...

  8. React中父子组件数据传递

    Vue.js中父子组件数据传递:Props Down ,  Events Up Angular中父子组件数据传递:Props Down,  Events  Up React中父子组件数据传递:Prop ...

  9. http://blog.itpub.net/28602568/viewspace-759789/

    varchar .varchar2.nvarchar.nvarchar2  -->存储可变的字符串 varchar .varchar2:varchar:汉字全角等字符占2字节,数字.字母均1个字 ...

  10. 201771010120 苏浪浪 面向对象程序设计(Java)第10周

      1.实验目的与要求 (1) 理解泛型概念: (2) 掌握泛型类的定义与使用: (3) 掌握泛型方法的声明与使用: (4) 掌握泛型接口的定义与实现: (5)了解泛型程序设计,理解其用途. 2.实验 ...