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

来源:互联网 发布:三星s8预装软件 编辑:程序博客网 时间:2024/04/29 05:14

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

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

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

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

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

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

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

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





1 0
原创粉丝点击