https://mp.weixin.qq.com/s/UggNsNOeEMP-GhzlLiT-qQ

 
简单介绍Edges的实现。
 
 
1. TLEdge
 
包含client和manager两端的边,继承TLEdgeParameters类:
 
1) isAligned
 
判断访问的地址和访问大小是否对齐:
a. 如果最大访问大小为1个字节,则访问是对齐的;
b. 生成掩码(lgSize=2, maxLgSize=4, mask=0b1100)与地址相与,计算是否为0;
 
2) mask
 
根据访问的地址和大小生成访问的掩码:
 
3) isRequest
 
判断channel x是否在执行请求:
 
因为Grant/GrantData需要GrantAck响应,所以也是请求:
8.3.5: A Grant message is both a response and a request message...
 
4) isResponse
 
channel x是否在传输响应:
 
5) hasData
 
判断消息是否包含数据:
首先通过staticHasData检查是否能在构建期(软件代码执行)得到答案,如果不能则生成硬件逻辑在硬件中进行判断。
 
staticHasData根据client/manager的能力特点,看能否获得恒定的答案:
 
6) opcode
 
获取channel中的opcode部分:
 
可以看到这里使用的是TLDataChannel,而不是TLChannel:
a/b/c为TLAddrChannel,因为他们包含address这一项;
a/b/c/d为TLDataChannel,因为他们包含data这一项;
e既没有address也没有data,只是TLChannel;
 
7) param
8) size
9) data
10) corrupt
corrupt信号对应着规范中的valid。
 
11) mask
 
这里使用的为TLAddrChannel,只有a/b/c:
其中:a/b的mask外面提供,c的mask需要自己算;
 
full_mask都是自己算:
 
12) address
13) source
14) addr_hi/addr_lo
 
根据manager支持的位宽,把地址分成高低两部分:
a. 低的部分为按照manager.beatBytes对齐的部分。比如beatBytes=4, 则低2位为低的部分;
b. 其余的高位为高的部分;
 
15) numBeats
 
计算把数据传完需要多少个时钟周期,即burst包含多少个beat:
a. manager.maxTransfer <= manager.beatBytes:如果最大传输大小,小于数据总线位宽,则一定能在一个时钟周期(beat)内传完;
b. 否则,需要看数据大小是否大于位宽:size <= UInt(cutoff);
c. 若small为真,则右移cutoff后decode为0,需要一个beat;
d. 若small为假,则small为0,需要的beat数取决于decode;
e. UIntToOH(size, maxLgSize+1)=2^size;
f. 需要的beat数为:2^size / 2^cutoff;
g. hasData为假,则没有数据,需要一个beat;
 
16) first/last
 
2. TLEdgeOut
 
定义client到manager的输出边(EO),我为client,对端为manager。
 
1) Transfers
 
Cache Permission相关消息。
 
a. AcquireBlock
 
生成支持AcquireBlock的硬件连接:
 
b. AcquirePerm
 
 
c. Release
 
Release:
 
ReleaseData:
 
不会出错的ReleaseData:
 
d. ProbeAck
 
直接传入参数的ProbeAck:
 
通过b:Probe生成c:ProbeAck:
 
ProbeAckData同理;
 
e. GrantAck
 
 
2) Access
 
生成访问消息硬件连接。
 
a. Get
 
 
b. Put
考虑因素:
- PutFull/PutPartial;
- corrupt是否固定;
- mask是传入,还是自己生成;
 
c. Arithmetic
 
简单数学运算消息:
 
d. Logical
 
简单逻辑运算消息:
 
e. AccessAck
 
TLEdgeOut从client连向manager:
- client发起的Access消息从channel a传递,对应的AccessAck从b传回;
- client发出的AccessAck消息从channel c传递,作为manager通过channel b传来的Access消息的回应;
 
f. Hint
 
client通过channel a发送Hint消息:
 
g. HintAck
 
client通过channel c返回HintAck消息,以响应manager通过channel b发出的Hint请求消息:
 
3. TLEdgeIn
 
定义manager到client的输入边(EI),我为manager,对端为client。
 
1) Transfers
 
定义manager发出的与Cache Permission相关的消息。
 
a. Probe
 
从channel b发出:
 
b. Grant
 
Grant和GrantData通过channel d回复:
 
c. ReleaseAck
 
 
2) Access
 
定义访问消息。
 
a. Get
 
manager通过channel b发起请求:
 
b. Put
c. Arithmetic
d. Logical
 
同上。
 
e. AccessAck
 
manager通过channel d回复client通过channel a发来的访问请求:
 
f. Hint
 
manager通过channel b发起请求:
 
g. HintAck
 
manager通过channel d回复client通过channel a发来的Hint请求:
 

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

  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 - first

    https://mp.weixin.qq.com/s/0nzkV4K1osNEQzrtITYxmw   介绍Edges中first/last/done的实现.   ​​   1. firstlastH ...

  4. Rocket - tilelink - AsyncCrossing

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

  5. Rocket - tilelink - mask

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

  6. Rocket - tilelink - Parameters

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

  7. Rocket - tilelink - Bundles

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

  8. Rocket - tilelink - TLBusWrapper.to

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

  9. Rocket - tilelink - BusWrapper

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

随机推荐

  1. Spring 学习 之 再探publish-event机制

    之前的文章链接:https://blog.csdn.net/qq_41907991/article/details/88544777 我们要知道的是,Spring的publish-event使用的是监 ...

  2. EChart将timeline图标设置为加号

    一 要实现的效果 二 官方文档 看一下官方文档上,替换symbol的描述: timeline.symbol string [ default: 'emptyCircle' ] timeline标记的图 ...

  3. 【Spark】SparkStreaming与flume进行整合

    文章目录 注意事项 SparkStreaming从flume中poll数据 步骤 一.开发flume配置文件 二.启动flume 三.开发sparkStreaming代码 1.创建maven工程,导入 ...

  4. 【Django+Element UI】使用一个接口文件,搞定分页获取数据,模糊查询后分页获取数据

    1:序列化获取数据的接口设计 1:分页获取序列化数据 2:是个能传参数的接口 class Society(APIView): def post(self, request): keywords = s ...

  5. Redis安装启动(linux系统)

    Redis简介 redis是以kv存储的nosql非关系型数据库 sql支持事务性,nosql不支持 Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间 ...

  6. day06:三级菜单练习0218

    #1:省份数列:data = { "北京":{ "昌平":{ "沙河":["oldboy","电信" ...

  7. Crystal | 水晶方法的七大特征,你了解吗?

    本文摘自敏捷开发 20世纪90年代末,Alistair Cockburn提出水晶方法论. 自2001年的敏捷宣言提出以来,以极限编程为首的一系列敏捷方法逐渐走入大众视野,其中就包括水晶方法(Cryst ...

  8. 关于mysql的metadata lock

    昨天晚上上线,却发现一个ddl语句长时间没有生效 查processlist, 发现包括ddl语句在内的众多查询提示 “Waiting for table metadata lock” 唯一没有该提示的 ...

  9. mysql全方位知识大盘点

    一.mysql都有哪些存储引擎?各自的特点是什么? 引擎 事务 锁 主键 索引 外键 数据结构 适用场景 InnoDB 支持 行锁.表锁 必须有主键,没有设置会自动创建 主键索引和数据在一起,其他索引 ...

  10. 苏浪浪 201771010120 第四周 Java基本程序设计总结

    第四章   对象与类 学习目标 掌握类与对象的基础概念,理解类与对象的关系: 掌握对象与对象变量的关系: 掌握预定义类的基本使用方法,熟悉Math类.String类.math类.Scanner类.Lo ...