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

 
简单介绍WidthWidget的实现。
 
 
1. 基本介绍
 
用于设定与上游节点连接的数据总线的宽度。根据上下游数据总线宽度的大小关系,在转发消息时进行组合和拆分处理。
 
类参数innerBeatBytes是指与上游节点连接的数据总线所占的字节数:
 
2. diplomacy node
 
diplomacy node用于与上下游节点连接,并协商参数。
 
TLWidthWidget的diplomacy node是一个适配器节点:
其中:
a. clientFn:用于把TLWidthWidget看到的上游节点的参数,转换为下游节点看到的TLWidthWidget的参数;这里没有变化;
b. managerFn:用于把TLWidthWidget看到的下游节点的参数,转换为上游节点看到的TLWidthWidget节点的参数;这里把beatBytes设定为innerBeatBytes,即上游节点看到TLWidthWidget节点支持的数据总线的宽度是innerBeatBytes个字节;
 
3. lazy module
 
lazy module用于实现内部逻辑。这里主要是适配上下游节点数据总线不同导致的问题,即根据上下游数据总线宽度的大小关系,在转发消息时进行组合和拆分处理。
 
 
1) 成对的输入边和输出边
 
 
2) 处理channel a/d:
 
 
3) 处理channel b/c/e:
 
如果支持Cache,则进行组合或拆分:
 
4) splice
 
根据上下游连接数据总线宽度的大小关系,分为三种情况:
a. 相等:直连即可,无需适配;
b. 上游大:需要把请求消息拆分成多个小的分片,然后通过下游连接发出去;
c. 上游小:需要把请求消息组合成一个大的消息,然后通过下游连接发出去;
 
因为beatBytes需要是2的幂,所以如果上下游数据总线的宽度不相等,那么一定是整数倍的关系。
 
A. 总线宽度与请求的size
 
数据总线的宽度代表物理能力,实际请求中数据的大小由size域决定:
a. 如果size域大于数据总线宽度,则会分成多个beat而成为burst请求;
b. 如果size域小于数据总线宽度,则数据不会把数据总线占满,而需要使用mask域标识哪些字节包含数据;
 
所以是否组合或拆分,也由size域参与决定。如果size域比上下游数据总线宽度都小,那么就不需要组合或拆分,而可以直接透传。
 
B. 上游总线宽度较大
 
a. edgeIn.manager.beatBytes表示输入边即与上游节点连接的数据总线宽度;edgeOut.manager.beatBytes则表示下游连接的数据总线宽度;
b. repeat决定了Repeater是否重复输出保存的数据,repeat由split的结果决定;
c. cated表示上游节点输入的数据,他默认从repeater中接收数据;进而被拆分成两个部分:首先,直接从in.bits.data中取低的与下游数据总线宽度相同位宽的数据,这部分数据不需要Repeater重复;其次,从repeated中取两者总线宽度差值的数据。至于数据是否有意义,则由mask域决定;
d. repeat:如果没有把所有分片向下游发送完成,则需要repeat;如果已经发送完成则不需要repeat;如果size大小小于下游连接的总线宽度,那么可以在一个时钟周期内发送完成,也不需要repeat;
 
C. 上游总线宽度较小
 
需要把上游burst请求的多个beat合并之后,向下游发送:
如果上游是一个单beat请求,则不会等下一个单beat请求进行合并,而是直接透传。
 
4. merge
 
用于把上游burst请求的多个beat合并之后,向下游发送。
 
1) 基本参数
 
其中:
a. ratio是一个整数值(可以被除尽而没有余数);
b. countBits表示需要多少个位对用来组合的分片进行计数;
 
2) 请求信息
 
其中:limit根据当前请求的size域,计算这个请求总共包含多少个可供组合的分片;如果size也大于下游数据总线的宽度,那么这里的limit就限定在下游总线宽度。
 
3) first/last
 
其中:
a. count是用于计数的寄存器;
b. first/last表示是第一个和最后一个用于组合的beat;这里last有两种情况:第一,请求size小于下游数据总线宽度,last表示该请求的最后一个beat;第二,请求size大于下游数据总线宽度,last表示下游数据总线宽度可以容纳的最后一个beat;
c. enable是一个位图,与当前beat对应的序号为真,其他位为假;
 
4) corrupt
 
用于在多个beat之间holdcorrupt信号:
 
5) in.fire()
 
in.fire()表明来了一个请求:
a. 把count加1;
b. 如果是最后一个beat,则把count复位;单beat请求的第一个beat也就是最后一个beat;
 
6) ready/valid
 
 
7) edgeOut.data
 
a. 如果上游节点不会发起带数据的请求,如Put/Atomic等,那么可以使用默认值0;否则
b. 需要把in.bits.data组合之后装进out.bits.data;
c. out.bits.data的组合跨越了多个beat,也就是多个时钟周期;何时发出由out.valid决定;
 
8) out.bits.mask
 
a. 如果请求包含数据,则把in.bits.mask也组合在一起成为下游的mask;
b. 如果请求不包含数据,则直接使用MaskGen生成的mask;
 
9) helper
 
完成组装多beat数据的任务:
a. odata:把idata复制多份填满下游数据总线;
b. rdata:已经缓存的数据;
c. pdata:已缓存的数据 + 最后一个beat的数据;
d. mdata:enable中只有当前beat对应的位置的位为1,表示从odata中取出响应位置的idata;其他为0的位从pdata中取值;这样就逐个beat把数据存入rdata中了;
e. 把对应beat的数据存入rdata中,last为真时不需要缓存;
 
5. split
 
与merge类似,下面主要介绍不同点。
 
1) sel
 
 
这里的sel用于从in.bits.data中定位数据的正确偏移量。
如果in.bits.data中的数据是满的,那么因为对齐的问题,sel == 0。sel | count == count,就从偏移地址0开始取in.bits.data中的数据。
 
如果in.bits.data中的数据不是满的,那么sel != 0。sel | count 可以定位到正确的偏移量,以从in.bits.data中取数据。下面是一个例子:
 
2) sourceMap
 
因为d中不包含address域,所以需要记录请求消息中的address域:
 

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

  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. 不需要爬虫也能轻松获取 unsplash 上的图片

    我经常会使用 unsplash, 这里面的图片非常清爽,我的大多数文章的图片都是在这个网上找的,虽然也有同类型网站,但是用过一段时间以后基本都放弃了,图片质量参差不齐,筛选过程太费劲. 但是 unsp ...

  2. 如何将项目上传至GitHub?

    心血来潮的一天,突然想写点什么哈哈哈哈. 那就写写如何将项目上传到GitHub(矫情,上传个项目还要写个文章) 第一步:下载Git https://git-scm.com/download/win 下 ...

  3. 王颖奇 20171010129《面向对象程序设计(java)》第十三周学习总结

      实验十三  图形界面事件处理技术 实验时间 2018-11-22 1.实验目的与要求 (1) 掌握事件处理的基本原理,理解其用途: (2) 掌握AWT事件模型的工作机制: (3) 掌握事件处理的基 ...

  4. LeetCode--LinkedList--160. Intersection of Two Linked Lists(Easy)

    160. Intersection of Two Linked Lists(Easy) 题目地址https://leetcode.com/problems/intersection-of-two-li ...

  5. 【HBase】HBase基本介绍和基础架构

    目录 基本介绍 概述 特点 HBase和Hadoop的关系 RDBMS与HBase的对比 特征 基础架构 基本介绍 概述 HBase是bigtable的开源java版本,是建立在HDFS之上,提供高可 ...

  6. 【Hadoop离线基础总结】HDFS详细介绍

    HDFS详细介绍 分布式文件系统设计思路 概述 只有一台机器时的文件查找:hello.txt /export/servers/hello.txt 如果有多台机器时的文件查找:hello.txt nod ...

  7. [hdu5439 Aggregated Counting]公式化简,预处理

    题意:按下列规则生成一组序列,令f(n)为n这个数在序列中出现的最后一个位置,求f(f(n))的值. 1. First, write down 1, 2 on a paper.2. The 2nd n ...

  8. VMware Centos7 NAT 无法上网的解决方法

    问题描述: VMware下CentOS7使用NAT上网方式无法连网 解决方案: 网络设置为DHCP自动获取IP 查看主机(不是虚拟机)的相关服务是否打开,主要是VMware DHCP 和VMware ...

  9. java 版本比较

    public class version { public static int compareVersion(String version1, String version2) throws Exc ...

  10. Linux系统如何安装qt-desinger

    前言:最近想在python3.7.3下玩下PyQt5,写UI有两种方式一种是使用手写,第二个就是使用Qt Designer工具来写,所以首先就是安装PyQt5和pyqt5-tools工具了. 一.安装 ...