DAMQ(动态分配共享多队列)实现过程总结

DAMQ:动态分配共享多队列,此实现方法一般在ASIC设计中使用,但也可以在FPGA的设计中使用,主要应用于系统有多个通道传送数据需要存储,而在实际使用时有部分通道会无数据传输,如果对每个通道都分配存储空间,则当部分通道无数据需要存储时,造成系统存储空间的浪费,而使用DAMQ方式共享总的存储空间,则可以存储所有通道传输的数据,存储的空间采用共享的方式使用系统的总存储空间,在部分通道没有数据需要存储时,可以把系统的存储空间分配到有数据传输的通道,更优的利用系统的总存储空间。

         DAMQ实现过程中使用到以下几个模块: (1)共享数据缓存模块 (2)地址缓存模块 (3) 空闲地址缓存模块 (4)头尾地址管理模块 (5)预取数据缓存模块

         (1)共享数据缓存模块:此模块为系统的总存储空间,各个通道传输的数据都存储到此存储空间中。

         (2)地址缓存模块:此模块中存储的都是地址信息,这些地址信息是各个通道数据存储在共享数据缓存模块的位置,无论哪个通道有数据写入共享数据缓存模块,则同时把地址信息写入地址缓存模块中。

         (3)空闲地址缓存模块:此模块存储的也是地址信息,这些地址信息是共享数据缓存模块中还没有使用的地址;在读数据时,从共享数据缓存模块读出一个数据,则同时把读地址写入空闲地址缓存模块;

         (4)头尾地址管理模块:此模块用来管理共享数据缓存模块、地址缓存模块和空闲地址缓存模块;根据地址缓存模块存储的地址,从共享数据缓存模块中读出数据;同时把此读地址存储到空闲地址缓存模块中,并同时从地址缓存模块中取出下个数据的存储地址;

         (5)预取数据缓存模块:此模块在读写操作时用来分别管理各个通道的读写请求,尤其在读操作时,会预先从共享缓存里读出数据放在总线上,这样在读请求有效时,则数据总线上的为有效数据;

DAMQ实现过程的功能框图如下所示:





  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值