https://mp.weixin.qq.com/s/6McbqOKM4fu4J5vdpZvxKw

 
简单介绍异步队列(AsyncQueue)的实现。
 
0. 异步队列
 
异步队列的两端分属不同的时钟域,拥有各自的复位逻辑。
异步队列用于存值的一端为上游端(source),用于取值的一端为下游端(sink)。
 
1. AsyncQueueParams
 
异步队列的参数,包含如下几项:
a. depth
 
队列深度,表示队列可以存储几个元素;
 
b. sync
 
表示流水线的级数。
 
c. safe
 
使用valid来标识ridx和widx是否合法;是否要把一端的reset同步到另一端。
 
d. narrow
 
标识数据同步通道的宽度。如果数据同步通道为窄,则每次只同步一个数据。否则,为所有数据提供同步通道。
 
2. AsyncBundleSafety
 
 
safe相关要在队列两端同步的信号(这里略去不做详细介绍):
 
个人认为更名为AsyncSafetyBundle更好,因为本质上是一个Bundle,Safety是修饰词,前置为宜。如白马和马白不是同一个意思。
 
3. AsyncBundle
 
要在队列两端同步的数据,包括:
a. 待读取元素的索引号:ridx;
b. 待写入元素的索引号:widx;
c. 数据:mem;
d. 数据索引号:index;
e. safe相关的bundle(valid和reset);
 
c和d重构如下:
如果数据同步通道为窄通道,则mem这个Vec只包含1个元素,而index则是当前数据通道中元素的索引号。
如果数据同步通道为宽通道,则mem这个Vec包含depth个元素,每一个元素都有自己的同步通道,就不需要index来指示元素索引号了,所以此时index为None。
 
PS. option是一个隐式方法,定义如下:
 
4. GrayCounter
 
格雷码计数器。
 
5. AsyncValidSync
 
用于支持AsyncBundleSafety,这里不做具体介绍。
 
6. AsyncQueueSource
 
异步队列的上游端。上游端写数据。
 
1) io
 
a. enq:输入;
b. async:用于数据同步的端口;
 
2) 实现
 
a. enq
 
当对方valid,而我方ready,亦即io.enq.fire()时,把io.enq.bits存入mem中。
 
注意,此index为新定义的index,非io.async.index:
 
b. mem
 
也要注意区分mem和io.async.mem。
 
mem的定义为:
存储的元素个数为队列深度params.depth。
 
根据数据同步通道的宽窄,来决定同步一个,还是全部同步:
 
c. widx
 
source端为写端,widx是一个格雷码计数器,会被同步到sink端:
 
d. ridx
 
读取的元素索引号。sink端为读端。ridx从sink端同步而来。
 
e. ready
 
队列不满,则可以ready。
可以看到io.enq.ready也取决于sink_ready。在不考虑safe的情况下,sink_ready一直为true。
 
7. AsyncQueueSink
 
与AsyncQueueSource对应,这里略去。
 
8. FromAsyncBundle
 
x是一个AsyncBundle,构造一个sink端与之连接。从AsyncBundle到DecoupledIO,即From AsyncBundle to DecoupledIO。
 
9. ToAsyncBundle
 
x是一个ReadyValidIO,构造一个source端与之连接。从ReadyValidIO到AsyncBundle,即To AsyncBundle from ReadyValidIO。
 
10. AsyncQueue
 
创建异步队列的两端,并把它们相连。
 
CrossingIO定义如下:

Rocket - util - AsyncQueue的更多相关文章

  1. Rocket - util - Annotations

    https://mp.weixin.qq.com/s/7C8ZmPpwAqFqyKjL9K40Fg   介绍util中定义的注解(Annotations).   ​​   1. Annotation ...

  2. Rocket - util - Timer

    https://mp.weixin.qq.com/s/Z4JJhZ_jL1lqF1nf_orq9A   简单介绍Timer的实现.   ​​   1. 基本功能   实现定时器的功能.   2. Ti ...

  3. Rocket - util - Replacement

    https://mp.weixin.qq.com/s/zCP7wPuxgQ-r94Tr6BV5iw   简单介绍Replacement的实现.   ​​   1. 基本介绍   用于实现Cache替换 ...

  4. Rocket - util - ReduceOthers

    https://mp.weixin.qq.com/s/gbR5fuDbE_nUFVxw-p4rsA   简单介绍ReduceOthers的实现.   ​​   1. 基本介绍   输入一组Bool元素 ...

  5. Rocket - util - Repeater

    https://mp.weixin.qq.com/s/xyEq3DgYuf2QuNjssv8pkA   简单介绍Repeater的实现.   ​​   1. 基本功能   A Repeater pas ...

  6. Rocket - util - PrefixSum

    https://mp.weixin.qq.com/s/G2vLP-ncoJzSOgxGGEJkfA   简单介绍PrefixSum的实现.   ​​   1. 基本介绍   ​​ 把一个序列从前向后逐 ...

  7. Rocket - util - MultiWidthFifo

    https://mp.weixin.qq.com/s/CUnrpyQN5LRBR5bxC5u86A   简单介绍MultiWidthFifo的实现.   ​​   1. 基本介绍   实现一个输入宽度 ...

  8. Rocket - util - MaskGen

    https://mp.weixin.qq.com/s/_aJqf1cFJDK5RVRBhxTWOw   介绍MaskGen的实现.   ​​   1. 基本介绍   给定总线宽度beatBytes,根 ...

  9. Rocket - util - Misc

    https://mp.weixin.qq.com/s/kf4FvAFye_bRdT49Yow7Hg   简单介绍Misc中各个辅助方法的用途和实现.   ​​   1. ParameterizedBu ...

随机推荐

  1. Face The Right Way 开关(POJ3276)

    描述: \( N 头牛排成了一列.每头牛或者向前或者向后.为了让所有的牛都面向前方,农夫约翰买了 一台自动转向的机器. 这个机器在购买时就必须设定一个数值 K,机器每操作一次恰好使 K 头连续的牛转向 ...

  2. 基于3D NAND层差异的固态盘请求调度算法研究立项 报告

    Abstract SSD(Solid State Drive),因其超高的读写性能,以及价格的走低趋势逐渐占据市场,为人们带来更好的用户体验,也为企业级的高并行业务需要提供了一定支持,近几年来SSD的 ...

  3. AntDesignPro的权限控制和动态路由

    最近看了AntDesignPro关于权限控制的官方文档以及自己框架里权限控制的实现,总结一下. 先贴一下官网上关于权限控制的图有利于理解 步骤如下: 判断是否有 AccessToken 如果没有则跳转 ...

  4. 单片机之静态局部变量static

    HL-1慧静电子 上程序: main.c #include <reg52.h>#include "Timer.h" /********P1口低有效*********** ...

  5. [hdu4631 Sad Love Story]最近点对,枚举

    题意:S是平面内点的集合,初始为空,每次向集合里面加入一个点P(x,y),询问S内最近点对的距离的平方和 思路:设当前集合的答案为D,则找到集合里面横坐标在(x-√D,x+√D)内的数,用它们来更新答 ...

  6. Linux --如何新增一块硬盘并自动挂载

    1. 虚拟机添加硬盘 2.  分区 fdisk /dev/sdb 3. 格式化 mkfs -t ext4 /dev/sdb1 将刚刚创建的盘格式化成 ext4格式 4. 挂载 先创建一个目录,/hom ...

  7. Lvs 调度算法

    lvs scheduler:仅根据IP和端口进行调度 静态方法:仅根据算法本身进行调度,不考虑当前服务器实际负载情况:保证起点公平 RR:round robin, 轮调,轮询,轮叫: 调度器通过&qu ...

  8. 【比较】遗传算法GA和遗传编程GP有什么不同?

    遗传算法GA 本质上有一个固定的长度,这意味着所产生的功能有限的复杂性 通常会产生无效状态,因此需要以非破坏性方式处理这些状态 通常依赖于运算符优先级(例如,在我们的例子中,乘法发生在减法之前),这可 ...

  9. Mysql之Linux中mariadb主从复制

    master主机mysql安装配置 1.下载mariadb(Centos7开始mysql的名字) (1)其它方式(不推荐):rpm安装/软件源安装 (2)yum安装(推荐): ①centos官方的yu ...

  10. Hyperledger Fabric Node SDK和应用开发

    Hyperledger Fabric 提供了多种语言的SDK版本,其中提出比较早.比较稳定而全面的是Node.js版本的SDK. 前面提到的fabric示例(如first-network和e2e-cl ...