DAMQ(动态分配共享多队列)实现过程总结
2016-05-22 23:24
323 查看
DAMQ:动态分配共享多队列,此实现方法一般在ASIC设计中使用,但也可以在FPGA的设计中使用,主要应用于系统有多个通道传送数据需要存储,而在实际使用时有部分通道会无数据传输,如果对每个通道都分配存储空间,则当部分通道无数据需要存储时,造成系统存储空间的浪费,而使用DAMQ方式共享总的存储空间,则可以存储所有通道传输的数据,存储的空间采用共享的方式使用系统的总存储空间,在部分通道没有数据需要存储时,可以把系统的存储空间分配到有数据传输的通道,更优的利用系统的总存储空间。
DAMQ实现过程中使用到以下几个模块: (1)共享数据缓存模块 (2)地址缓存模块 (3) 空闲地址缓存模块 (4)头尾地址管理模块 (5)预取数据缓存模块
(1)共享数据缓存模块:此模块为系统的总存储空间,各个通道传输的数据都存储到此存储空间中。
(2)地址缓存模块:此模块中存储的都是地址信息,这些地址信息是各个通道数据存储在共享数据缓存模块的位置,无论哪个通道有数据写入共享数据缓存模块,则同时把地址信息写入地址缓存模块中。
(3)空闲地址缓存模块:此模块存储的也是地址信息,这些地址信息是共享数据缓存模块中还没有使用的地址;在读数据时,从共享数据缓存模块读出一个数据,则同时把读地址写入空闲地址缓存模块;
(4)头尾地址管理模块:此模块用来管理共享数据缓存模块、地址缓存模块和空闲地址缓存模块;根据地址缓存模块存储的地址,从共享数据缓存模块中读出数据;同时把此读地址存储到空闲地址缓存模块中,并同时从地址缓存模块中取出下个数据的存储地址;
(5)预取数据缓存模块:此模块在读写操作时用来分别管理各个通道的读写请求,尤其在读操作时,会预先从共享缓存里读出数据放在总线上,这样在读请求有效时,则数据总线上的为有效数据;
DAMQ实现过程的功能框图如下所示:
DAMQ实现过程中使用到以下几个模块: (1)共享数据缓存模块 (2)地址缓存模块 (3) 空闲地址缓存模块 (4)头尾地址管理模块 (5)预取数据缓存模块
(1)共享数据缓存模块:此模块为系统的总存储空间,各个通道传输的数据都存储到此存储空间中。
(2)地址缓存模块:此模块中存储的都是地址信息,这些地址信息是各个通道数据存储在共享数据缓存模块的位置,无论哪个通道有数据写入共享数据缓存模块,则同时把地址信息写入地址缓存模块中。
(3)空闲地址缓存模块:此模块存储的也是地址信息,这些地址信息是共享数据缓存模块中还没有使用的地址;在读数据时,从共享数据缓存模块读出一个数据,则同时把读地址写入空闲地址缓存模块;
(4)头尾地址管理模块:此模块用来管理共享数据缓存模块、地址缓存模块和空闲地址缓存模块;根据地址缓存模块存储的地址,从共享数据缓存模块中读出数据;同时把此读地址存储到空闲地址缓存模块中,并同时从地址缓存模块中取出下个数据的存储地址;
(5)预取数据缓存模块:此模块在读写操作时用来分别管理各个通道的读写请求,尤其在读操作时,会预先从共享缓存里读出数据放在总线上,这样在读请求有效时,则数据总线上的为有效数据;
DAMQ实现过程的功能框图如下所示:
相关文章推荐
- Java动态代理的两种实现方法
- Java EE的十三个技术规范
- Java EE的十三个技术规范
- leetcode 144. Binary Tree Preorder Traversal-前序遍历|递归|非递归
- STM32F103VC串口做输入打印到终端
- Android Bitmap图像色彩质量
- hash模块 hashlib 和hmac
- C++第六次作业
- SQL按天进行分组查询最大值和最小值
- Linux查看网络端口对应的程序
- 偏差,方差,训练误差,测试误差的区别
- Android UI(Layouts)-RelativeLayout详解
- 快速实现hbase-0.98.6-cdh5.3.10集群部署
- ROLL A BALL (Unity 3D 入门) 游戏制作指导 - 移动游戏对象
- 七个你无法忽视的Git使用技巧(转)
- ASTAR2016 ROUND2B 1005 区间交
- ssh连接速度慢解决
- mac date 和 Linux date实现从指定时间开始循环
- python中的enumerate函数
- Node.js:Express and Waterline