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. MOD3干扰

    1.MOD3干扰的定义 MOD3干扰也称模3干扰,是LTE网络内干扰的一种形式,要了解这种干扰的产生原理,就要从小区PCI入手. PCI全称PhysicalCellIdentifier,即物理小区标识 ...

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

    实验十一   集合 实验时间 2018-11-8 1.实验目的与要求 (1) 掌握Vetor.Stack.Hashtable三个类的用途及常用API: (2) 了解java集合框架体系组成: (3)  ...

  3. Programmatically add an application to Windows Firewall

    Programmatically add an application to Windows Firewall 回答1   Not sure if this is the best way, but ...

  4. README.md编写

    一.标题写法: 第一种方法: 1.在文本下面加上 等于号 = ,那么上方的文本就变成了大标题.等于号的个数无限制,但一定要大于0个哦.. 2.在文本下面加上 下划线 - ,那么上方的文本就变成了中标题 ...

  5. 深入理解JS中的对象(一)

    目录 一切皆是对象吗? 对象 原型与原型链 构造函数 参考 1.一切皆是对象吗? 首先,"在 JavaScript 中,一切皆是对象"这种表述是不完全正确的. JavaScript ...

  6. react-grid-layout实现拖拽,网格布局

    借鉴地址:https://www.jianshu.com/p/b48858eee3a7 安装 react-grid-layout npm install react-grid-layout impor ...

  7. interface和abstract 的区别和相同点

    在Java语言中,abstract class和interface是支持抽象类定义的两种机制. 不能创建abstract类的实例,然而可以创建一个变量,其类型是一个抽象类,并让它指向具体子类的一个实例 ...

  8. 3.6 Go String型

    1. Go String型 Unicode是一种字符集,code point UTF8是unicode的存储实现,转换为字节序列的规则 go的rune类型 可以取出字符串里的unicode 字符串是一 ...

  9. 情人节闷在家里做画( 安卓统计图MPAndroidChart开发 )

    有些时候觉得一个人挺好的,可以更自由安排自己的时间: 有些时候觉得有个人挺好的,很多事情一个人做起来太没意思了,纵使心中澎湃,倾听的独有自己. 废话少说,直接上图 MPAndroidChart是啥 一 ...

  10. 【蓝桥杯C/C++组】备赛基础篇之差分算法

    一.个人理解 前面学习了前缀和算法,对于访问任意区间的速度是比较快的,但如果我们要修改某个区间的数呢,对于前缀和算法来说这还是有点棘手. 所以我们来学学新的算法:差分算法! 前缀和数组储存的是前n个数 ...