https://mp.weixin.qq.com/s/0ob-Fq-ZOoj-_S7pTJu6rQ

 
介绍TLArbiter的实现,主要关注如何实现burst的多个beat的输出。
 
 
1. beatsIn/sourcesIn
 
对输入参数进行简单处理。输入参数为:
 
sources为不定参数:
二元组第一个元素为所需时钟周期即心跳(beat)的个数,第二个元素为输入的DecoupledIO。
 
2. beatsLeft
 
剩余的beat数:
 
3. idle
 
如果剩余的beat数为0,则Arbiter空闲(idle):
 
4. latch
 
是否可以把beat数目的初始值存入beatsLeft中:
 
使用方式:
 
5. valids/readys
 
a. 获取sources的valid信号;
b. 根据policy生成ready信号,以决定哪一个source可以输出;
 
6. winner
 
标志着每一个source是否可以输出:
 
winner为真需要满足两个条件:
a. valid为真:需要输出;
b. ready为真:允许输出;
 
7. initBeats
 
计算beatsLeft的初始值:
a. 根据是否是winner输出每一个source的beats值;
b. 取出仲裁胜出者需要的beats值;
c. 根据latch的值,选择把初始值存入beatsLeft,还是在输出时减一;
d. 只有在输出时beatsLeft才减一:beatsLeft - sink.fire();
 
8. state
 
记录sources的状态:
 
如果idle为真,则把仲裁结果winner在下一个时钟周期存入state中;否则state保持不变。
 
9. allowed
 
是否允许source输出:
 
如果idle为真,则是否允许输出由仲裁结果readys决定;否则当前burst的beats还没有传输完毕,是否允许由state决定,即只允许当前正在传输的source进行输出。
 
10. sink.valid
 
 
如果idle为真,则由valids决定;否则由正在进行传输的source的valid决定。
 
11. sink.bits
 
似乎有点问题,muxState可能为全0,而Mux1H要求muxState中有且只有一个1。这里不深入讨论。
 

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

  1. Rocket - tilelink - RegisterRouter

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

  2. Rocket - tilelink - toBools

    https://mp.weixin.qq.com/s/UGMH8EoaVcFkkQW-l4HLWg   分析toBools在Intellij中显示为红色的问题.   ​​   1. 问题   在TLA ...

  3. Rocket - tilelink - Nodes

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

  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. CSS设置table样式

    \(\color{purple}{表格是个很重要的东西,让我们来美化一下吧!}\) table{ width:290px;height:300px; border:1px solid black;/* ...

  2. spring表达式语言

    使用文本表达式 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http: ...

  3. 【Scala】isInstanceOf 与 classOf的对比,代码+注解简洁明了

    class Animal { } class Cat extends Animal { } object Cat { def main(args: Array[String]): Unit = { / ...

  4. android实现计时器

    新建布局文件activity_main.xml <?xml version="1.0" encoding="utf-8"?> <LinearL ...

  5. [hdu5418 Victor and World]floyd + 状压DP 或 SPFA

    题意:给n个点,m条边,每次只能沿边走,花费为边权值,求从1出发经过所有其它点≥1次最后回到1的最小花费. 思路: 状压DP.先用Floyd得到任意两点间的最短距离,转移时沿两个点的最短路转移.此时的 ...

  6. Windows10系统优化(批处理)

    经历过XP.Win7.Vista.Win8之后,Win10有了很大的改变,虽然Win10刚出时,非常糟糕,甚至很长一段时间被认为没有Win7,但是随着Win10的不断优化不断更新,已经慢慢的变得更好了 ...

  7. linux --开机自动挂载硬盘【转】

    转:http://c.biancheng.net/view/900.html 了解了 mount 命令之后,读者可能会问,系统如何在开机时自动挂载硬盘,它又是怎么知道哪些分区是需要挂载的呢? 很简单, ...

  8. docker push的时候提示requested access to the resource is denied

    参考:http://blog.csdn.net/baidu_19473529/article/details/70156144 上面的信息显示是拒接访问,因为tag的名字斜线前面部分a10309076 ...

  9. ql的python学习之路-day3

    字典操作 特性: 1.无序的 2.key是唯一的 , ,,], ,,], ,,], }, ,,], 'bbb' : ['a', 'b', 'c'], }}

  10. React:Conditional Rendering(条件渲染)

    就像JS中常常会根据条件(比如if/else.switch)返回不同的值,React中也可以根据组件的状态或其他参考条件返回不同的React Element. 比如根据用户是否登陆渲染对应的UI面板. ...