DAMQ(动态分配共享多队列)实现过程总结
来源:互联网 发布:三星s8预装软件 编辑:程序博客网 时间:2024/04/29 05:14
DAMQ:动态分配共享多队列,此实现方法一般在ASIC设计中使用,但也可以在FPGA的设计中使用,主要应用于系统有多个通道传送数据需要存储,而在实际使用时有部分通道会无数据传输,如果对每个通道都分配存储空间,则当部分通道无数据需要存储时,造成系统存储空间的浪费,而使用DAMQ方式共享总的存储空间,则可以存储所有通道传输的数据,存储的空间采用共享的方式使用系统的总存储空间,在部分通道没有数据需要存储时,可以把系统的存储空间分配到有数据传输的通道,更优的利用系统的总存储空间。
DAMQ实现过程中使用到以下几个模块: (1)共享数据缓存模块 (2)地址缓存模块 (3) 空闲地址缓存模块 (4)头尾地址管理模块 (5)预取数据缓存模块
(1)共享数据缓存模块:此模块为系统的总存储空间,各个通道传输的数据都存储到此存储空间中。
(2)地址缓存模块:此模块中存储的都是地址信息,这些地址信息是各个通道数据存储在共享数据缓存模块的位置,无论哪个通道有数据写入共享数据缓存模块,则同时把地址信息写入地址缓存模块中。
(3)空闲地址缓存模块:此模块存储的也是地址信息,这些地址信息是共享数据缓存模块中还没有使用的地址;在读数据时,从共享数据缓存模块读出一个数据,则同时把读地址写入空闲地址缓存模块;
(4)头尾地址管理模块:此模块用来管理共享数据缓存模块、地址缓存模块和空闲地址缓存模块;根据地址缓存模块存储的地址,从共享数据缓存模块中读出数据;同时把此读地址存储到空闲地址缓存模块中,并同时从地址缓存模块中取出下个数据的存储地址;
(5)预取数据缓存模块:此模块在读写操作时用来分别管理各个通道的读写请求,尤其在读操作时,会预先从共享缓存里读出数据放在总线上,这样在读请求有效时,则数据总线上的为有效数据;
DAMQ实现过程的功能框图如下所示:
- DAMQ(动态分配共享多队列)实现过程总结
- 共享内存队列的实现
- 在严蔚敏《数据结构(C语言版)》中,不能用动态分配的一维数组来实现循环队列
- DLL共享数据段,实现多进程数据共享总结
- DLL共享数据段,实现多进程数据共享总结
- 动态分配内存空间过程
- 队列实现总结:
- CUDA 共享内存的动态分配
- 利用共享内存实现消息队列
- PHP共享内存实现的消息队列
- 共享内存+信号量+消息队列实现IPC
- 共享内存无锁队列的实现
- C++队列之动态分配数组
- linux下的多进程通信(IPC)原理及实现方案(管道、队列、信号量、共享内存)
- 【C语言总结】动态分配
- 二维数组动态分配总结
- 动态分配的栈实现
- 【操作系统】动态分配的实现
- go slice与函数
- php100教程资料96~112讲
- Android UI(Layouts)-RelativeLayout详解
- SQL按天进行分组查询最大值和最小值
- hash模块 hashlib 和hmac
- DAMQ(动态分配共享多队列)实现过程总结
- Linux查看网络端口对应的程序
- Android Bitmap图像色彩质量
- TensorFlow 从入门到精通(五):使用 TensorFlow 实现 RNN
- STM32F103VC串口做输入打印到终端
- Java EE的十三个技术规范
- 偏差,方差,训练误差,测试误差的区别
- 英语学习思维导图
- 枚举(enum)的简单用法