DAMQ:动态分配共享多队列,此实现方法一般在ASIC设计中使用,但也可以在FPGA的设计中使用,主要应用于系统有多个通道传送数据需要存储,而在实际使用时有部分通道会无数据传输,如果对每个通道都分配存储空间,则当部分通道无数据需要存储时,造成系统存储空间的浪费,而使用DAMQ方式共享总的存储空间,则可以存储所有通道传输的数据,存储的空间采用共享的方式使用系统的总存储空间,在部分通道没有数据需要存储时,可以把系统的存储空间分配到有数据传输的通道,更优的利用系统的总存储空间。
DAMQ实现过程中使用到以下几个模块: (1)共享数据缓存模块 (2)地址缓存模块 (3) 空闲地址缓存模块 (4)头尾地址管理模块 (5)预取数据缓存模块
(1)共享数据缓存模块:此模块为系统的总存储空间,各个通道传输的数据都存储到此存储空间中。
(2)地址缓存模块:此模块中存储的都是地址信息,这些地址信息是各个通道数据存储在共享数据缓存模块的位置,无论哪个通道有数据写入共享数据缓存模块,则同时把地址信息写入地址缓存模块中。
(3)空闲地址缓存模块:此模块存储的也是地址信息,这些地址信息是共享数据缓存模块中还没有使用的地址;在读数据时,从共享数据缓存模块读出一个数据,则同时把读地址写入空闲地址缓存模块;
(4)头尾地址管理模块:此模块用来管理共享数据缓存模块、地址缓存模块和空闲地址缓存模块;根据地址缓存模块存储的地址,从共享数据缓存模块中读出数据;同时把此读地址存储到空闲地址缓存模块中,并同时从地址缓存模块中取出下个数据的存储地址;
(5)预取数据缓存模块:此模块在读写操作时用来分别管理各个通道的读写请求,尤其在读操作时,会预先从共享缓存里读出数据放在总线上,这样在读请求有效时,则数据总线上的为有效数据;
DAMQ实现过程的功能框图如下所示: