循环优先级(Round Robin)仲裁器。
 
参考链接:
 
RRArbiter是一个仲裁器,只是使用RR的逻辑实现优先级。grant是优先级逻辑的结果,所以实现RRArbiter与严格优先级Arbiter的区别在于(仅在于)grant的生成逻辑不同。
 
1. RR优先级的两个层次
 
RR优先级的含义,包括两个层次:
 
a. 基于次序的优先级
 
小号输入口的优先级高于大号输入口;
 
b. 最高优先级是循环的
 
与严格优先级不同的是,RR逻辑中,最高优先级并不总是0,而是根据上一次选择的输入口而变化的。上一次选择的输入口的下一个输入口具有最高的优先级。
 
最高优先级并不是逐个向后轮换的,而是根据上一次选择的输入口可能产生跳变。因为最高优先级的输入口不一定被选择,也并不代表次优先级不能被选择。
 
2. 上一次轮到的输入口
 
要实现RR逻辑,需要记录上一次轮到的输入口,序号记为:lastGrant。
那么判断输入口是否轮过的逻辑为:i > lastGrant,为真则未轮过,为假则已轮过。
 
3. 忽略已经轮过的输入口
 
输入口的状态首先通过valid信号表达。判断某个输入口是否考虑的逻辑为:
(i > lastGrant) && io.in(i).valid;
 
4. 表达基于次序的优先级
 
基于次序的优先级的逻辑与Arbiter一样,如下(设Arbiter 输入口个数n = 4):
 
 
5. 引入未轮过的输入口
 
因为循环优先级的存在,输入口0并不总是最高优先级,其优先级还要低于未轮过的输入口,所以需要引入依赖未轮过的输入口。如下:
 
 
这里选择把所有的接口都加上,那些已经轮过的输入口i > lastGrant为假,自动忽略其valid。未轮过的输入口i > lastGrant为真,则会依赖其valid信号。
 
6. 不适用于未轮过的输入口
 
不过这种方法,不适用于未轮过的输入口。
假设lastGrant = 1, 那序号为2的输入口也依赖于其自身的valid,也依赖于序号为3的valid。这是不合理的。
 
所以这个逻辑只适用于已轮过的输入口。
 
7. 分而治之
 
此时需要使用分治策略,为已轮过的和未轮过的输入口提供不同的逻辑。而两种接口的分野就在于i > lastGrant。
 
8. 未轮过的输入口使用的逻辑
 
未轮过的输入口的优先级只依赖于前一个未轮过的输入口,如果是第一个未轮过的输入口,则其优先级最高,不依赖于任何其他输入口。
 
把所有输入口都当做未轮过输入口,考虑基于次序的优先级,逻辑如下:
 
若lastGrant = 1:
a. in(0)/in(1)为已轮过的输入口,使用已轮过输入口的逻辑;
b. in(2)为第一个未轮过输入口,其优先级最高,不依赖于其他输入口的valid(直接为true);
c. in(3)为第二个未轮过输入口,依赖于in(2).valid,而不依赖于in(0)/in(1);
 
9. 总结
 
总结下来,如果接口已轮过,则使用如下逻辑确定是否授权:
 
如果接口未轮过,则使用如下逻辑确定授权:
 
综合起来,如下:
 
10. RRArbiter类
 
RRArbiter类为LockingRRArbiter类的子类。
 
11. LockingRRArbiter类
 
这个类中实现RR的逻辑。
 
 
a. lastGrant
 
lastGrant记录上一次选择的输入口。
 
b. grantMask
 
为每一个输入口生成一个:i > lastGrant 逻辑。
 
c. validMask
 
根据是否轮过,决定是否考虑该输入口的valid信号。为每个输入口生成一段 (i > lastGrant) && in(i).valid逻辑。
 
d. ctrl
 
1) 依次取出validMask中的元素:(0 until n).map(i => validMask(i))
2) 依次取出所有的valid信号:io.in.map(_.valid)
3) 把两个list连接起来:listA ++ listB
 
 
4) 使用ArbiterCtrl连接每个元素,结果如下:
 
 
e. grant
 
grant(i) = ctrl(i) && grantMask(i) || ctrl(n + i)
 
如下:
 
f. choice
 
choice决定chosen, chosen决定io.out.valid和io.out.bits:
 
choice的逻辑如下:
 
如果还记得上一篇对循环when的解释:时间上后面执行的when先行判断,前面执行的when逐次为eslewhen/otherwise。
 
这里validMask的循环在后面执行,那么validMask的判断就在前面,validMask为假才会继续判断后面的valid信号。
 
这样就为未轮过的输入口提供了优先级。倒着来从大号到小号,是为了遵从基于次序的优先级。
 
值得注意的有两点:
1) 第一个循环从n-2到0,那n-1呢?
 
很简单,n-1已经作为默认值了。
 
2) 第二个循环从n-1到1,那0呢?
 
因为0 > lastGrant始终为false,所以validMask(0)始终为false。总是第一个进行结果已知的判断,干脆直接省略。
 
这是一个很有趣的地方。尽管0 > lastGrant始终为假,也就是说in(0)始终被当做已轮过的输入口,但却并未影响其基于次序的优先级和基于RR的优先级。为什么呢?
 
因为在设计已轮过和未轮过输入口的授权逻辑时,已经考虑到了这一点。
 

Chisel3 - util - RRArbiter的更多相关文章

  1. Chisel3 - util - OneHot

    https://mp.weixin.qq.com/s/Jsy8P3m9W2EYKwneGVekiw   独热码相关的电路生成器.   参考链接: https://github.com/freechip ...

  2. Chisel3 - util - MixedVec

    https://mp.weixin.qq.com/s/mO648yx4_ZRedXSWX4Gj2g   可以容纳不同类型的变量的向量.   参考链接: https://github.com/freec ...

  3. Chisel3 - util - Mux

    https://mp.weixin.qq.com/s/TK1mHqvDpG9fbLJyNxJp-Q   Mux相关电路生成器.   参考链接: https://github.com/freechips ...

  4. Chisel3 - util - Lookup

    https://mp.weixin.qq.com/s/g85Si6n37D9PYfR5hEoRQQ     实现一个查找逻辑.   参考链接: https://github.com/freechips ...

  5. Chisel3 - util - Valid

    https://mp.weixin.qq.com/s/L5eAwv--WzZdr-CfW2-XNA   Chisel提供的Valid接口.如果valid为置1,则表明输出的bits有效:反之,则输出无 ...

  6. Chisel3 - util - Math vs. CircuitMath

    https://mp.weixin.qq.com/s/8lC8vQnBdKW9C39H0QFFkA     对数相关的辅助方法,Math通过软件方法实现,CircuitMath通过硬件方法实现.   ...

  7. Chisel3 - util - LFSR16

    https://mp.weixin.qq.com/s/DSdb4tmRwDTOki7mbyuu9A     实现16位线性反馈移位寄存器.可用于生成简单的伪随机数.     ​​     ​​   参 ...

  8. Chisel3 - util - Bitwise

    https://mp.weixin.qq.com/s/MQzX1Ned35ztz0vusPdkdQ   比特相关的操作.   参考链接: https://github.com/freechipspro ...

  9. Chisel3 - util - BitPat

    https://mp.weixin.qq.com/s/80Q8j-OSMtgh5a92pI-MZA   使用value和mask来描述一个比特模式,即:value = bits & mask. ...

随机推荐

  1. SpringCloudGateWay学习 之 从函数式编程到lambda

    文章目录 前言: 函数式编程: 什么是函数式编程: 函数式编程的特点 lambda表达式: 核心: 函数接口: 方法引用: 类型推断: 变量引用: 级联表达式跟柯里化: 前言: 这一系列的文章主要是为 ...

  2. Numpy-np.random.normal()正态分布

    X ~ :随机变量X的取值和其对应的概率值P(X = ) 满足正态分布(高斯函数) 很多随机现象可以用正态分布描述或者近似描述 某些概率分布可以用正态分布近似计算 正态分布(又称高斯分布)的概率密度函 ...

  3. clang8.0及以上编译rocks问题

    升级了MacOS 10.15 Beta版,结果编译 CockroachDB 遇到了问题. [ %] Building CXX object CMakeFiles/rocksdb.dir/db/buil ...

  4. [poj 1743] Musical Theme 后缀数组 or hash

    Musical Theme 题意 给出n个1-88组成的音符,让找出一个最长的连续子序列,满足以下条件: 长度大于5 不重叠的出现两次(这里的出现可以经过变调,即这个序列的每个数字全都加上一个整数x) ...

  5. [hdu1532]最大流

    裸最大流,求最大流一般步骤如下: (1)所有正向边权初始化为容量,反向边权初始化为0 (2)找增广路 (3)找到则进入(4),否则得到最大流并退出 (4) 增广路上所有边减去最小边权,相应的方向边加上 ...

  6. 两个有序数组 A1 A2 的合并

    /** * 问题6.有序数组 A1 A2 的合并 */ @Test public void orderArrayMerge() { // 两个有序数组 A1 A2 的合并 int[] A1 = {1, ...

  7. python-经典类和新式类区别

    经典类和新式类区别 Eg: class A(object):    def x(self):        print('A')class B(A):    def x(self):        p ...

  8. Centos7 下代理配置

    对于提供服务的服务器来说,一般都配置在内网环境中,而在内网下公司处于安全的考虑,一般不开放外网的访问权限.这时如果想要访问外网,一般需要配置公司提供的代理服务器再进行使用.下面介绍几种配置代理的方法: ...

  9. js中的小案例(一)

    效果图: html代码: <div id="date"> <p> <span id="prev">上一月</span& ...

  10. java 面向对象面试题,问答题,构造方法,抽象类,继承,多态,接口,异常总结;

    一,构造方法的特点 面向对象的思想是如何在java展现的呢? 就是通过类和对象 类是一组相关的属性和行为的集合.是一个抽象的概念. 对象是该类事物的具体表现形式.具体存在的个体. 一.抽象类的抽象方法 ...