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

 
简单介绍TileLink相关的参数实现(具体问题暂时不展开,后续用到时再做分析)。
 
 
1. TLManagerParameters
 
定义TileLink Manager节点的参数,Manager节点为Sink节点。
 
1) 参数列表
 
a. address:支持的地址集合;
b. resources:包含的资源;
c. regionType:区域类型;
d. executable:是否可执行;
e. nodePath:使用本参数的节点的路径;
f. 能力标志:supportsXXX, mayDenyXXX等;
g. fifoId:是否支持FIFO,以及FIFO的编号;
 
2) 限制条件
 
 
a. 支持的地址集合不能为空;
b. 支持的地址集合不能包含无限个地址;
c. 任意两个地址集合不能重叠;
d. 支持PutFull操作的大小不能小于PutPartial;
e. 支持PutFull操作的大小不能小于Arithmetic;
f. 支持PutFull操作的大小不能小于Logical;
g. 支持Get操作的大小不能小于Arithmetic;
h. 支持Get操作的大小不能小于Logical;
i. 支持Acquire Branch操作的大小不能小于Acquire Trunk;
 
3) name
 
TLManagerParameters是下游(Sink)节点的参数,其传递方向是从下游向上游(Upward)传递。nodePath中记录了参数传递过程中经历的节点:
 
name表示最后一个节点的名称。如果没有,则使用默认值“disconnected”。
 
4) maxTransfer
 
各个操作支持的最大的传输大小:
 
5) maxAddress
 
节点支持的最大的地址:
 
6) minAlignment
 
节点支持的最小对齐:
 
要求最小对齐不小于最大传输大小:
 
7) toResource
 
生成地址空间资源类型的描述:
 
8) findTreeViolation/isTree
 
查找是否存在破坏规则的节点:
 
2. TLManagerPortParameters
 
一个Manager Port包含多个Manager:
 
1) 参数列表
 
a. managers: 包含的Managers;
b. beatBytes:单个时钟(心跳、beat)可以传递的数据宽度(字节数);
c. endSinkId:最后一个下游节点的编号;
d. minLatency:最小延迟;
 
2) 限制条件
 
其中:beatBytes需要是2的幂;
 
3) requireFifo
 
所有的manager节点必须都定义fifoId,并且都相同。
 
4) 能力
 
 
5) 软件查找:def find(address: BigInt)
 
在软件执行期使用的查找功能:
返回包含第一个包含address的manager。
 
6) 硬件查找
 
生成一个硬件查找逻辑:
 
a. findSafe(UInt)
 
逐个生成查找逻辑。
 
b. findFast(UInt)
 
快速查找:
- 使用AddressDecoder生成需要比对的位的掩码:val routingMask = AddressDecoder(managers.map(_.address));
- 忽略不需要比对的位:_.address.map(_.widen(~routingMask))
- 把扩展后生成的新地址去重:.distinct.
- 再检查是否包含address:.map(_.contains(address)).reduce(_ || _)
 
剩余的find不再介绍。
 
7) 能力
 
使用safe和fast两种方式实现的是否支持能力判断方法:
 
8) findTreeViolation/isTree
 
检查所有manager是否都符合规则:
 
3. TLClientParameters
 
TileLink的Client端为上游(Source),定义其参数:
 
1) 参数列表
 
a. name: 名称;
b. sourceId:源端编号;
c. nodePath:本参数向下游传递过程中经过的节点序列;
d. requireFifo:是否需要使用FIFO;
e. visibility:可见性,可以看到哪些地址;
f. 能力集合:supportsXXX;
 
2) 限制条件
 
其中:
a. 可见的地址集合不能重合;
 
3) maxTransfer
 
 
4. TLClientPortParameters
 
 
1) 限制条件
 
其中:
a. 所有client的IdRange不能重合;
 
2) 参数处理
 
 
3) 能力判断
 
a. 全部支持
 
 
b. 某个支持
 
 
c. 硬件判断逻辑
 
 
4) 查找
 
a. 软件查找
 
 
b. 硬件查找逻辑
 
 
5) requireFifo
 
生成硬件判断逻辑:
 
 
5. TLBundleParameters
 
 
1) 参数列表
 
a. addressBits:地址占用的比特数;
b. dataBits:数据占用的比特数;
c. sourceBits:source编号占用的比特数;
d. sinkBits:sink编号占用的比特数;
e. size:操作大小占用的比特数;
 
2) 合并
 
取各参数的最大值:
 
3) 通过两端的参数生成
 
a. addressBits:支持的地址集合在manager中定义;
b. dataBits:使用manager.beatBytes;
c. sourceBits:source编号由client决定;
d. sinkBits:sink编号由manager决定;
e. size:由client/manager共同决定;
 
6. TLEdgeParameters
 
Edge的参数包含:
a. client的参数;
b. manager的参数;
c. 其他配置参数: parameters;
 
可以通过client和manager参数生成bundle参数:
 
7. Async相关参数
 
使用AsyncQueueParams表示异步相关的参数:
 
8. Rational相关参数
 
另一种异步实现。
 
9. ManagerUnification
 
Manager参数合并。
 
1) 定义一个包含各个参数的Key:
 
 
2) key: 从manager参数转化为Key的方法:
 
 
3) 把所有manager根据key映射到哈希映射中:
 
a. 若没有manager对应key的映射(key => manager),则添加新的映射;
b. 若已有映射,则把当前manager与已有的manager合并;
 
4) 返回新的manager:
 
能力一致的manager合并后的manager列表:
 

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

  1. Rocket - config - Parameters

    https://mp.weixin.qq.com/s/uLEr9gAFaMDIXa8S9xJVTw   介绍配置类Parameters及其伴生对象的实现.   参考链接: https://docs.q ...

  2. Rocket - interrupts - Parameters

    https://mp.weixin.qq.com/s/eD1_hG0n8W2Wodk25N5KnA 简单介绍interrupts相关的Parameters. 1. IntRange 定义一个中断号区间 ...

  3. Rocket - tilelink - RegisterRouter

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

  4. Rocket - tilelink - Nodes

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

  5. Rocket - tilelink - fastProperty

    https://mp.weixin.qq.com/s/9nikweQUGG5FO3Z8t6feaw 介绍Parameters中定义的fastProperty的实现.(使用最近的新版本,差别不大)   ...

  6. Rocket - tilelink - AsyncCrossing

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

  7. Rocket - tilelink - mask

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

  8. Rocket - tilelink - Bundles

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

  9. Rocket - tilelink - TLBusWrapper.to

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

随机推荐

  1. C. Coffee Break 贪心 思维 有点难 有意思

    C. Coffee Break 这个贪心之前好像写过,还是感觉挺难的,有点不会写. 这个题目大意是:给你一个数列n个元素,然后给你一天的时间,给你一个间隔时间d, 问你最少要用多少天可以把这个数列的所 ...

  2. M - 昂贵的聘礼 最短路 dij

    http://poj.org/problem?id=1062 这个题目有一点点特别,因为数据很小也可以用Floyd跑,但是个人比较钟爱dij. 这个dij是怎么走的呢,首先就是普通的建图,然后就是带上 ...

  3. React Native超简单完整示例-tabs、页面导航、热更新、用户行为分析

    初学React Native,如果没有人指引,会发现好多东西无从下手,但当有人指引后,会发现其实很简单.这也是本人写这篇博客的主要原因,希望能帮到初学者. 本文不会介绍如何搭建开发环境,如果你还没有搭 ...

  4. JVM 运行时数据区(二)

    @ 目录 运行时数据区 共享区 堆区 方法区 隔离区 虚拟机栈 栈帧 本地方法栈 程序计数器 运行时数据区 JVM 运行时数据区主要分为5块 方法区 JDK1.8以后叫做元数据区(Metaspace) ...

  5. stanfordcorenlp安装教程&问题汇总(importerror-no-module-named-psutil、OSError: stanford-chinese-corenlp-yyyy-MM-dd-models.jar not exists.)&简单使用教程

    stanfordcorenlp安装教程&简单使用教程 编译环境:python 3.6 .win10 64位.jdk1.8及以上 1.stanfordcorenlp安装依赖环境 下载安装JDK ...

  6. 在IntelliJ IDEA中创建和运行java/scala/spark程序

    本文将分两部分来介绍如何在IntelliJ IDEA中运行Java/Scala/Spark程序: 基本概念介绍 在IntelliJ IDEA中创建和运行java/scala/spark程序 基本概念介 ...

  7. centos6 升级gcc 无法识别的命令行选项“-std=gnu++1y”的解决办法

    npm install 提示: 1.下载源文件,并安装: wget http://people.centos.org/tru/devtools-2/devtools-2.repo mv devtool ...

  8. Docker & Kubenetes 系列四:集群,扩容,升级,回滚

    本篇将会讲解应用部署到Kubenetes集群,集群副本集查看,集群自愈能力演示,集群扩容,滚动升级,以及回滚. 本篇是Docker&Kubenetes系列的第四篇,在前面的篇幅中,我们向Kub ...

  9. IDEA插件记录

    IDEA个性化设置 1. 开发工具 Free MyBatis plugin 作用:可以快速的在mybatis 的mapper 文件和xml文件中快速切换 Lombok 作用:为POJO类添加@Data ...

  10. 爬虫之图片懒加载技术、selenium工具与PhantomJS无头浏览器

    图片懒加载技术 selenium爬虫简单使用 2.1 selenium简介 2.2 selenium安装 2.3 selenium简单使用 2.3.1 selenium使用案例 2.3.2 selen ...