一种缓存管理方法、装置及现场可编程门阵列与流程

文档序号:11199131阅读:828来源:国知局
一种缓存管理方法、装置及现场可编程门阵列与流程
本发明涉及数据缓存
技术领域
,尤其涉及一种缓存管理方法、装置及现场可编程门阵列。
背景技术
:随着信息技术和网络技术的发展,缓存技术逐渐成为一个热门且不可或缺的领域,缓存技术指可以进行高速数据交换,因此缓存技术对系统的响应速度有很大的提高。然而,传统的缓存装置的存储容量通常是有限的,使得其存储的内容也较有限,因此对缓存进行管理是本领域一个热点研究问题。参照图1所示,现有技术中的缓存系统包括:数据包输入电路11、缓存接口电路12、链表管理电路13、调度电路14、数据输出电路15、数据缓存16以及链表存储器17。图1所示缓存系统的缓存管理过程为:将数据缓存16切片为多个固定大小的存储单元(例如:512b);当收到数据包时,若接收到的数据包小于或等于一个存储单元的大小(例如:256b),则该数据包占用一个独立的存储单元,而若接收到的数据包大于一个存储单元的大小(例如:2kb),则将数据包切割为多个数据分片(例如:将2kb的数据包切割为大小为:512b的四个数据分片),然后通过缓存接口电路12将多个数据分片分别存储在一个存储单元中,并通过链表管理电路13将存储多个数据分片的存储单元组成链表发送至调度电路14和链表存储器17,从而完成数据包的写入;当需从数据缓存16中读取数据包时,调度电路14根据链表存储器17中的链表信息从对应的存储单元中读取数据,同时数据缓存14回收对应的存储单元,通过数据输出电路15将读取的数据分片拼接为一个完整的数据包后输出,从而完成数据包的读取。虽然上述缓存管理系统可以使任意数量的队列的性能都十分接近,但是上述缓存系统提供的带宽极其有限。具体的,64bit带宽ddr4工作在2400mbps的速率时,物理带宽仅有153gbps,并且64bit位宽的ddr控制器64字节短包的带宽利用率非常低,仅有20%左右,其能提供的实际双向带宽仅有153*0.2=30.72gbps,单向仅约为15gbps。技术实现要素:本发明的实施例提供一种缓存管理方法、装置及现场可编程门阵列,用于提高缓存系统的带宽。为达到上述目的,本发明的实施例采用如下技术方案:第一方面,一种缓存管理方法,用于对缓存系统进行管理,所述缓存系统中包括多个数据缓存通道,任一数据缓存通道包括一数据缓存和一数据缓存控制器,且各数据缓存通道具有唯一的数据缓存通道号;所述方法包括:在收到入队报文时,根据预设分片大小和所述入队报文的长度将所述入队报文切割为至少一个数据分片;向各所述数据分片分配所述数据缓存通道号;根据向所述数据分片分配的数据缓存通道号将数据分片分发至对应的所述数据缓存通道的数据缓存控制器;在所述数据缓存控制器的控制下将所述数据分片写入对应的数据缓存;接收所述数据缓存返回的缓存地址和缓存长度,并根据向数据分片分配的数据缓存通道号以及所述数据缓存返回的缓存地址和缓存长度生成各数据分片的缓存描述符;将各数据分片的缓存描述符写入bd缓存。可选的,所述向各所述数据分片分配所述数据缓存通道号,包括:将多个所述数据缓存通道号轮转向各所述数据分片分配。可选的,所述方法还包括:上电时分别向各队列随机分配一个数据缓存通道号作各队列的当前状态的数据缓存通道号;在将多个所述数据缓存通道号轮转向各所述数据分片分配后,将所述入队报文所属的队列的当前状态的数据缓存通道号更新为轮转结束时的数据缓存通道号之后的下一个数据缓存通道号;所述将多个所述数据缓存通道号轮转向各所述数据分片分配,包括:由所述入队报文所属的队列的当前状态的数据缓存通道号开始将多个所述数据缓存通道号轮转向各所述数据分片分配。可选的,任一所述数据缓存包括多个内存库,任一所述内存库中包括:一回收区和一未使用区域;其中,所述回收区用于存放回收的缓存空间的缓存地址,所述未使用区域用于存放未使用的缓存空间的缓存地址;所述在所述数据缓存控制器的控制下将所述数据分片写入对应的数据缓存,包括:控制所述数据缓存中的多个内存库轮转向所述数据分片分配缓存地址;判断各所述数据分片的数据缓存通道号对应的数据缓存的内存库的回收区是否具有缓存地址;若是,则从回收区取出一个缓存地址向所述数据分片分配;若否,则从未使用区取出一个缓存地址向所述数据分片分配;在所述数据缓存控制器的控制下将数据分片写入向其分配的缓存地址所指示的缓存空间。可选的,所述缓存系统包括多个bd缓存通道,任一所述bd缓存通道包括一bd缓存控制器和一bd缓存;所述将各数据分片的缓存描述符写入bd缓存,包括:根据各数据分片在所述入队报文中的顺序对各数据分片的数据缓存通道号进行排序;各bd缓存通道的bd缓存控制器根据各数据分片的数据缓存通道号的顺序分别将各数据分片的缓存描述符写入对应的bd缓存。可选的,所述各bd缓存通道的bd缓存控制器根据各数据分片的数据缓存通道号的顺序分别将各数据分片的缓存描述符写入对应的bd缓存,包括:按照预设缓存大小将所述多个bd缓存分割为多个缓存块;向各所述队列分配所述缓存块、首端缓存地址和尾端缓存地址,并记录向各所述队列分配的首端缓存地址和尾端缓存地址;其中,向不同队列分配的缓存块不同,任一队列的首端缓存地址和尾端缓存地址所指示的缓存空间为向该队列分配的缓存块中的同一个缓存空间;接收到缓存描述符时,获取第一队列的首端缓存地址;所述第一队列为接收到的缓存描述符所属的数据分片所属的入队报文所属的队列;将接收到的缓存描述符写入所述第一队列的首端缓存地址所指示的缓存空间;判断第一缓存块剩余的缓存空间是否小于或等于一个缓存描述符的大小;所述第一缓存块为向第一队列分配的缓存块;若否,则将第一队列的首端缓存地址更新为所述第一缓存块中首端缓存地址后的下一个缓存地址;若是,则向所述第一队列分配第二缓存块,将所述第二缓存块的缓存块地址写入第一缓存块,将所述第一队列的首端缓存地址更新为第二缓存块中的第一个缓存地址;根据各数据分片的数据缓存通道号的顺序依次将各数据分片的缓存描述符写入所述第一队列的首端缓存地址所指示的缓存空间。可选的,所述方法还包括:在向所述第一队列分配第二缓存块时,将所述多个bd缓存中的缓存块轮转向所述第一队列分配。可选的,所述方法还包括:接收出队命令;所述出队命令用于指示将出队报文从所述数据缓存中调出,所述出队命令包括所述出队报文的队列信息;根据所述出队报文的队列信息获取第二队列;所述第二队列为所述出队报文所属的队列;获取所述第二队列的尾端缓存地址;读出所述第二队列的尾端缓存地址所指示的缓存空间中的缓存描述符;判断第三缓存块中的缓存描述符是否已经全部取出;所述第三缓存块为所述第二队列的尾端缓存地址所指示的缓存空间所述的缓存块;若否,则将所述第二队列的尾端缓存地址更新为所述第三缓存块中尾端缓存地址后的下一个缓存地址;若是,则获取第三缓存块中的缓存块地址,并将所述第二队列的尾端缓存地址更新为向所述第三缓存块中的缓存块地址所指示的缓存块中的第一个缓存地址;根据所述第二队列的入队信息获取所述出队报文的包含的数据分片的数量;判断从所述第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量是否等于所述出队报文包含的数据分片的数量;若是,将各从所述第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符分发至对应数据缓存通道的数据缓存控制器;在所述数据缓存控制器的控制下根据从所述第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符从对应的数据缓存中读取数据分片;按照已读出的各缓存描述符中的数据缓存通道号的顺序依次将各数据分片输出。可选的,所述方法还包括:记录各数据缓存的累计写入数据量和累计读取数据量;在任一数据缓存为空闲状态时,当该数据缓存的累计读取数据量为零或者累计读取数据量大于预设数据量且检测到有数据分片需要写入时,该数据缓存跳转至写入状态并将累计读取数据量清零;当该数据缓存的累计写入数据量为零且需要读取数据分片时,该数据缓存跳转至读取状态并将累计写入数据量清零;在任一数据缓存为写入状态时,判断该数据缓存的累计写入数据量是否大于预设数据量,当该数据缓存的累计写入数据量大于预设数据量,则该数据缓存跳转至空闲状态;在任一数据缓存为读取状态时,判断该数据缓存的累计读取数据量是否大于预设数据量,当该数据缓存的累计读取数据量大于预设数据量,则该数据缓存跳转至空闲状态。第二方面,提供一种缓存管理装置,用于对缓存系统进行管理,所述缓存系统中包括多个数据缓存通道,任一数据缓存通道包括一数据缓存和一数据缓存控制器,各数据缓存通道具有唯一的数据缓存通道号;所述缓存管理装置包括:入队数据切片电路,用于在收到入队报文时,根据预设分片大小和所述入队报文的长度将所述入队报文切割为至少一个数据分片;数据缓存通道号查询电路,用于向各所述数据分片分配所述数据缓存通道号;入队分发电路,用于根据向数据分片分配的数据缓存通道号将数据分片分发至对应的所述数据缓存通道的数据缓存控制器;数据缓存控制器,用于将所述数据分片写入对应的数据缓存;链表管理电路,用于接收所述数据缓存返回的缓存地址和缓存长度,以及根据向数据分片分配的数据缓存通道号以及所述数据缓存返回的缓存地址和缓存长度生成各数据分片的缓存描述符;bd缓存控制器,用于将各数据分片的缓存描述符写入bd缓存。可选的,所述缓存系统包括多个bd缓存通道,任一所述bd缓存通道包括一bd缓存控制器和一bd缓存;所述缓存管理装置还包括:分片地址重排序电路;所述分片地址重排序电路用于根据各数据分片在所述入队报文中的顺序对各数据分片的数据缓存通道号进行排序;各bd缓存通道的bd缓存控制器用于根据各数据分片的数据缓存通道号的顺序分别将各数据分片的缓存描述符写入对应的bd缓存。可选的,所述bd缓存控制器具体用于按照预设缓存大小将所述多个bd缓存分割为多个缓存块;向各所述队列分配所述缓存块,并向各队列分配首端缓存地址;其中,向不同队列分配的缓存块不同,任一队列的首端缓存地址所指示的缓存空间向该队列分配的缓存块;接收到缓存描述符时,获取第一队列的首端缓存地址;所述第一队列为接收到的缓存描述符所属的数据分片所属的入队报文所属的队列;将接收到的缓存描述符写入所述第一队列的首端缓存地址所指示的缓存空间,并将向第一队列分配的首端缓存地址记录为第一队列的尾端缓存地址;判断第一缓存块剩余的缓存空间是否小于或等于一个缓存描述符的大小;所述第一缓存块为向第一队列分配的缓存块;若否,则将第一队列的首端缓存地址更新为所述第一缓存块中首端缓存地址后的下一个缓存地址;若是,则向所述第一队列分配第二缓存块,将所述第二缓存块的缓存块地址写入第一缓存块,以及所述第一队列的首端缓存地址更新为第二缓存块中的第一个缓存地址;根据各数据分片的数据缓存通道号的顺序依次将各数据分片的缓存描述符写入所述第一队列的首端缓存地址所指示的缓存空间。可选的,所述缓存系统还包括:调度单元,所述调度单元用于记录各队列的入队信息,接收出队命令,根据所述出队报文的队列信息获取第二队列,根据所述第二队列的入队信息获取所述出队报文的包含的数据分片的数量;所述缓存管理装置还包括:出队分发电路和出队数据重组电路;所述链表管理电路还用于获取所述第二队列的尾端缓存地址并将所述第二队列的尾端缓存地址分发至所述bd缓存控制器;其中,所述出队命令用于指示将出队报文从所述数据缓存中调出,所述出队命令包括所述出队报文的队列信息;所述第二队列为所述出队报文所属的队列;所述bd缓存控制器还用于读出所述第二队列的尾端缓存地址所指示的缓存空间中缓存描述符;判断第三缓存块中的缓存描述符是否已经全部取出;若否,则将所述第二队列的尾端缓存地址更新为所述第三缓存块中尾端缓存地址后的下一个缓存地址;若是,则获取第三缓存块中的缓存块地址,并将所述第二队列的尾端缓存地址更新为向所述第三缓存块中的缓存块地址所指示的缓存块中的第一个缓存地址;所述第三缓存块为所述第二队列的尾端缓存地址所指示的缓存空间所述的缓存块;判断从所述第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量是否等于根据所述出队报文的长度信息获取所述出队报文包含的数据分片的数量;所述出队分发电路,用于判断从所述第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量是否等于根据所述出队报文的长度信息获取所述出队报文包含的数据分片的数量以及在从所述第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量等于根据所述出队报文的长度信息获取所述出队报文包含的数据分片的数量时将各从所述第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符分发至对应数据缓存通道的数据缓存控制器;所述数据缓存控制器还用于根据从所述第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符从对应的数据缓存中读取数据分片;所述出队数据重组电路,用于按照已读出的各缓存描述符中的数据缓存通道号的顺序依次将各数据分片输出。第三方面,提供一种现场可编程门阵列,包括:第二方面任一项所述的缓存管理装置。本发明的实施例提供的缓存管理方法用于对缓存系统进行管理,其中,缓存系统中包括多个数据缓存通道,任一数据缓存通道包括一数据缓存和一数据缓存控制器,在接收到入队报文且将入队报文切割问数据分片后,首先根据向数据分片分配的数据缓存通道号将数据分片分发至对应的数据缓存通道的数据缓存控制器,然后再在数据缓存控制器的控制下将数据分片写入对应的数据缓存;即各数据缓存通道中的数据缓存控制器独立控制数据缓存通道中的数据缓存的数据写入,由于本发明提供的缓存管理方法提供了多个独立的数据缓存通道,所以相比于单个数据缓存通道,本发明实施例可以提供更高的带宽,且相比将多个缓存通道中的缓存地址统一分配管理,本发明实施例可以最大化每个缓存通道的带宽利用率,所以本发明实施例提供的缓存管理方法可以提高缓存系统的带宽。附图说明为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。图1为现有技术中的缓存系统的示意性结构图;图2为本发明实施例提供的缓存管理方法的硬件框架图之一;图3为本发明实施例提供的缓存管理方法的步骤流程图之一;图4为本发明实施例提供的伪随机码生成电路的示意图;图5为本发明实施例提供的随机码生成模块的电路图;图6为本发明实施例提供的数据缓存的示意性结构图;图7为本发明实施例提供的数据缓存的状态机轮转图之一;图8为本发明实施例提供的缓存管理方法的硬件框架图之二;图9为本发明实施例提供的缓存管理方法的硬件框架图之三;图10为本发明实施例提供的缓存管理方法的步骤流程图之二;图11为本发明实施例提供的bd链表的示意性结构图;图12为本发明实施例提供的缓存管理方法的步骤流程图之三;图13为本发明实施例提供的数据缓存的状态机轮转图之二;图14为本发明实施例提供的缓存管理方法的硬件框架图之四。具体实施方式下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。以下首先对本发明实施例提供的缓存管理方法的应用场景的总体硬件框架作简要说明。参照图2所示,本发明实施例提供的缓存管理方法的应用场景的硬件包括:位于现场可编程门阵列(英文名称:fieldprogrammablegatearray,简称:fpga)内部的数据切片电路201、数据缓存通道号查询电路202、入队分发电路203、分片地址重排序电路204、链表管理电路205、多个缓存描述符(英文名称:bufferdescription,简称:bd)缓存控制器206(图2中以包括2个bd缓存控制器为例进行说明)、出队分发电路207、多个数据缓存控制器208(图2中以包括4个数据缓存控制器为例进行说明)以及出队数据重组电路209、位于fpga外部的与多个数据缓存控制器208一一对应的数据缓存210、与bd缓存控制器206一一对应的bd缓存211以及调度单元212。上述硬件框架中各个单元、模块以及电路的连接关系为:数据切片电路201连接数据缓存通道号查询电路202;数据缓存通道号查询电路202连接入队分发电路203;入队分发电路203分别与连接多个数据缓存控制器208连接且与分片地址重排序电路204连接;分片地址重排序电路204电路连接链表管理电路205;链表管理电路205分别与多个bd缓存控制器206连接且连接调度单元212;出队分发电路207分别与连接多个数据缓存控制器208连接且与调度单元212连接;出队数据重组电路209分别连接多个数据缓存控制器208;多个数据缓存控制器208还分别与一个数据缓存210连接形成一个数据缓存通道;多个bd缓存控制器206还分别与一个bd缓存211连接形成一个bd缓存通道。上述硬件框架中各个单元、模块以及电路的主要功能为:入队数据切片电路201:将输入的各个队列的报文切割为固定大小的数据分片。数据缓存通道号查询电路202:查询各队列的初始数据缓存通道号,并根据各队列的初始数据缓存通道号为各队列的数据分片分配数据缓存通道号。入队分发电路203:根据各数据分片的数据缓存通道号将各数据分片分发至各数据缓存通道上,并接收数据缓存210为数据分片分配的缓存地址以及将数据缓存210为数据分片分配的缓存地址发送至分片地址重排序电路204。分片地址重排序电路204:根据向数据分片分配的数据缓存通道号对各数据分片的缓存地址进行重排序,从而保证数据分片的缓存地址的顺序与数据分片在报文中的顺序相同。链表管理电路205:管理各个队列的首端缓存地址和尾端缓存地址;根据向数据分片分配的数据缓存通道号以及数据缓存210返回的缓存地址和缓存长度生成各数据分片的bd,根据各数据分片的bd组成bd链表;并将各个队列的入队信息提交给调度单元。bd缓存控制器206:对fpga外部存储bd的bd缓存的读写操作进行管理。出队分发电路207:将调度单元212输入的各队列的入队信息分发给对应通道的数据缓存控制器208。数据缓存控制器208:对数据缓存的读写操作进行管理以及数据分片的缓存地址的分配与回收。数据缓存210:存储各队列的数据分片。bd缓存211:储存各数据分片的bd。调度单元212:记录各队列的入队信息,按照流量管理(英文名称:trafficmanagement,简称:tm)的调度策略和配置,完成各个队列的调度出队,将调度出队信息提交给出队命令分发电路207。基于上述硬件框架,本发明的实施例提供了一种缓存管理方法,该缓存管理方法用于对缓存系统进行管理,如上图2所示,该缓存系统中包括多个数据缓存通道,任一数据缓存通道包括一数据缓存和一数据缓存控制器,且各数据缓存通道具有唯一的数据缓存通道号。具体的,参照图3所示,本发明实施例提供的缓存管理方法包括如下步骤:s31、在收到入队报文时,根据预设分片大小和入队报文的长度将入队报文切割为至少一个数据分片。其中,预设分片大小可以根据实际应用场景进行设定,本发明实施例中对预设分片具体值不做限定。示例性的,预设分片大小可以为:128b、256b、512b等。示例性的,当预设分片大小为256b、入队报文的长度为1518b时,由于1518b/256b=5余238b;因此将入队报文切割为6个数据分片,且该6个数据分片的大小依次为:256b、256b、256b、256b、256b、238b。示例性的,当预设分片大小为256b、入队报文的长度为125b时,将入队报文切割为1个数据分片,且该1个数据分片的大小为125b。s32、向各数据分片分配数据缓存通道号。可选的,上述步骤s32中向各数据分片分配数据缓存通道号具体可以通过如下方式来实现:a、上电时分别向各队列随机分配一个数据缓存通道号作各队列的当前状态的数据缓存通道号。b、从各队列的当前状态的数据缓存通道号开始将多个所述数据缓存通道号轮转向各所述数据分片分配c、在将多个所述数据缓存通道号轮转向各所述数据分片分配后,将所述入队报文所属的队列的当前状态的数据缓存通道号更新为轮转结束时的数据缓存通道号之后的下一个数据缓存通道号。上述方法中在系统上电时为每一个队列随机分配一个数据缓存通道号作为该队列的当前状态的数据缓存通道号,并由入队报文所属的队列的当前状态的数据缓存通道号开始将各数据缓存通道号轮转向各数据分片分配,所以上述方法可以避免所有队列都从同一个数据缓存通道开始存放数据分片,进而可以避免部分数据缓存通道过载,而部分数据缓存通道空闲的情况,因此上述方法可以提高数据缓存的效率。示例性的,以下以缓存系统中共包括8个数据缓存通道,且该8个数据缓存通道的数据换缓存通道号分别为0、1、2、3、4、5、6、7;队列0、队列1、队列2、队列3具有输入入队报文为例对上述实施例的原理进行说明。首先,若在上电时不向各队列随机分配当前状态的数据缓存通道号,各队列的当前状态的数据缓存通道号相同,则会出现如下状况:队列0的当前状态的数据缓存通道号被设置为0,队列0的入队报文切割为4个数据分片,将各数据缓存通道号轮转向各数据分片分配,那么向该4个数据分片的通道号分别为0、1、2、3。队列1的当前状态的数据缓存通道号被设置为0,队列1的入队报文切割为1个数据分片,将各数据缓存通道号轮转向各数据分片分配,那么向该1个数据分片的通道号分别为0。队列2的当前状态的数据缓存通道号被设置为0,队列2的入队报文切割为2个数据分片,将各数据缓存通道号轮转向各数据分片分配,那么向该2个数据分片的通道号分别为0、1。队列3的当前状态的数据缓存通道号被设置为0,队列3的入队报文切割为10个数据分片,将各数据缓存通道号轮转向各数据分片分配,那么向该10个数据分片的通道号分别为0、1、2、3、4、5、6、7、0、1。此时,如下表1所示,各数据缓存通道被使用的次数为:数据缓存通道号01234567被使用次数54221111表1在上实施例中,若在上电时为每一个队列随机分配一个数据缓存通道号作为该队列的当前状态的数据缓存通道号,则会出现如下状况:队列0的当前状态的数据缓存通道号随机化为3,队列0的入队报文切割为4个数据分片,将各数据缓存通道号轮转向各数据分片分配,那么向该4个数据分片的通道号分别为3、4、5、6。队列1的当前状态的数据缓存通道号随机化为0,队列1的入队报文切割为1个数据分片,将各数据缓存通道号轮转向各数据分片分配,那么向该1个数据分片的通道号分别为0。队列2的当前状态的数据缓存通道号随机化为7,队列2的入队报文切割为2个数据分片,将各数据缓存通道号轮转向各数据分片分配,那么向该2个数据分片的通道号分别为7、0。队列3的当前状态的数据缓存通道号随机化为4,队列3的入队报文切割为10个数据分片,将各数据缓存通道号轮转向各数据分片分配,那么向该10个数据分片的通道号分别为4、5、6、7、0、1、2、3、4、5。此时,如下表2所示,各数据缓存通道被使用的次数为:数据缓存通道号01234567被使用次数31123322表2通过对比上述表1和表2可得知,上电时为每一个队列随机分配一个数据缓存通道号作为该队列的当前状态的数据缓存通道号,并由入队报文所属的队列的当前状态的数据缓存通道号开始将各数据缓存通道号轮转向各数据分片分配,可以使各数据缓存通道的利用率均衡,进而可以避免部分数据缓存通道过载,而部分数据缓存通道空闲的情况。进一步的,本发明实施例可以通过伪随机码生成电路来为各队列分配当前状态的数据缓存通道号,且在向各队列随机分配当前状态的数据缓存通道号后可以通过静态随机存取存储器(英文名称:staticrandomaccessmemory,简称:sram)来存储各队列的当前状态的数据缓存通道号。示例性的,参照图4所示,伪随机码生成电路包括:随机码生成模块41和静态随机存取存储器42。其中,随机码生成模块41的写入使能端portnum_wr_en连接静态随机存取存储器42的写入使能端wr_en;随机码生成模块41的写入数据输出端portnum_wr_din连接静态随机存取存储器42的写入数据输入端wr_din;随机码生成模块41的写入地址输出端portnum_wr_addr与静态随机存取存储器42的写入地址输入端wr_addr。此外,静态随机存取存储器42还包括:读取使能端rd_en、读取数据输出端rd_din以及读取地址输出端ed_addr。本发明实施例还提供了一种随机码生成模块的电路图。具体的,参照图5所示,随机码生成模块的具体电路包括:4个异或逻辑运算单元411、8个触发器412(分别为a0、a1、a2、a0、a3、a4、a5、a6、a7)、1个计数器413、1个比较器414以及1个与逻辑运算单元415。其中,与逻辑运算单元415的输出端为随机码生成模块41的写入数据输出端portnum_wr_din,比较器414的输出端为随机码生成模块41的写入地址输出端portnum_wr_addr,计数器413的输出端为随机码生成模块41的写入使能端portnum_wr_en。图5所示随机码生成模块41的电路的多项表达式为:f(x)=1+x2+x3+x4+x8示例性的,假设上述伪随机码生成电路应用于数据缓存通道号为8个、队列书为64k的应用场景时,静态随机存取存储器的设计选取深度m=64k,宽度n=3(23=8),因此对静态随机存取存储器选取a0、a1、a23个触发器输出的抽头系数进行存储即可。进一步的,在上述步骤s32由入队报文所属的队列的当前状态的数据缓存通道号开始轮转将多个数据缓存通道号轮转向各数据分片分配之后,方法还包括:将入队报文所属的队列的当前状态的数据缓存通道号更新为轮转结束时的数据缓存通道号之后的下一个数据缓存通道号。示例性的,缓存系统中共包括8个数据缓存通道,且该8个数据缓存通道的数据换缓存通道号分别为0、1、2、3、4、5、6、7,向队列0的四个数据分片分配的数据缓存通道号分别为3、4、5、6,则将队列0的当前状态的数据缓存通道号更新为数据缓存通道号6后的下一个数据缓存通道号7;向队列1的一个数据分片分配的数据缓存通道号为0,则将队列1的当前状态的数据缓存通道号更新为数据缓存通道号0后的下一个数据缓存通道号1;向队列2的两个数据分片分配的数据缓存通道号分别为7、0,则将队列2的当前状态的数据缓存通道号更新为数据缓存通道号0后的下一个数据缓存通道号1;向队列3的十个数据分片分配的数据缓存通道号分别为4、5、6、7、0、1、2、3、4、5,则将队列3的当前状态的数据缓存通道号更新为数据缓存通道号5后的下一个数据缓存通道号6。s33、根据向数据分片分配的数据缓存通道号将数据分片分发至对应的数据缓存通道的数据缓存控制器。示例性的,队列4的入队报文切割为四个数据分片(数据分片0、数据分片1、数据分片2、数据分片3、),且向该四个数据分片分配的数据缓存通道号分别为:3、4、5、6,则将数据分片0分发至数据缓存通道3的数据缓存控制器208、将数据分片1分发至数据缓存通道4的数据缓存控制器208、将数据分片2分发至数据缓存通道5的数据缓存控制器208、将数据分片3分发至数据缓存通道6的数据缓存控制器208。s34、在数据缓存控制器的控制下将数据分片写入对应的数据缓存。如上,若将数据分片0分发至数据缓存通道3的数据缓存控制器208、将数据分片1分发至数据缓存通道4的数据缓存控制器208、将数据分片2分发至数据缓存通道5的数据缓存控制器208、将数据分片3分发至数据缓存通道6的数据缓存控制器208,则在数据缓存通道3的数据缓存控制器208的控制下将数据分片0写入数据缓存通道3的数据缓存210中,在数据缓存通道4的数据缓存控制器208的控制下将数据分片1写入数据缓存通道4的数据缓存210中,在数据缓存通道5的数据缓存控制器208的控制下将数据分片2写入数据缓存通道5的数据缓存210中,在数据缓存通道6的数据缓存控制器208的控制下将数据分片3写入数据缓存通道6的数据缓存210中。示例性的,数据缓存可以为第四代双倍速率同步动态随机存储器(英文名称:doubledataratesynchronousdynamicrandomaccessmemory4,简称:ddrsdram4或者ddr4)。通常,ddr4的存储空间按照固定大小划分为无数个小的存储空间。且ddr4在缓存较短的数据包时的效能很低,而且在其读写状态切换越频繁其效能越低;此外,ddr4在同一个内存库(英文名称:bank)内换行的时候效能会急剧下降,为了解决数据缓存效能低的问题,本发明进一步提供了如下几种用于实现上述步骤s34的方法。参照图6所示,任一数据缓存210包括多个内存库(图6中以一个数据缓存210中包括4个内存库,且4个内存库分别为:bank0、bank1、bank2、bank3为例进行说明),任一内存库中包括:一回收区和一未使用区域;其中,回收区用于存放回收的缓存空间的缓存地址,未使用区域用于存放未使用的缓存空间的缓存地址;上述步骤s36中在数据缓存控制器的控制下将数据分片写入对应的数据缓存,包括:控制数据缓存中的多个内存库轮转向数据分片分配缓存地址。本发明实施例中的轮转是指轮流、循环。具体的,多个内存库轮转向数据分片分配缓存地址是指,由多个内存库中的一个开始依次向数据分片分配缓存地址,当多个内存库中的最后一个内存库向数据分片分配缓存地址后,再次从多个内存库中的第一个内存库开始依次向数据分片分配缓存地址。判断各数据分片的数据缓存通道号对应的数据缓存的内存库的回收区是否具有缓存地址;若是,则从回收区取出一个缓存地址向数据分片分配;若否,则从未使用区取出一个缓存地址向数据分片分配;在数据缓存控制器的控制下将数据分片写入向其分配的缓存地址所指示的缓存空间。由于本发明实施例中数据缓存中的每个bank的缓存地址独立管理,且在向数据分片分配缓存地址时,优先从数据缓存的bank的回收区向数据分片分配缓存地址,在回收区没有缓存地址时再从未使用区域中向数据分片分配缓存地址,所以本发明实施例可以最大程度避免从bank未使用区域读取缓存地址,进而提高数据缓存的能效。例如:如上图6所示,数据缓存通道的数据缓存中包括4个bank(分别为bank0、bank1、bank2、bank3),在本次向数据分片分配缓存地址之前访问的bank为bank0、bank1、bank2,那么再次向数据分片分配缓存地址时,则向数据分片分配bank3中的缓存地址。可选的,上述方法还包括:记录各数据缓存的累计写入数据量和累计读取数据量。在任一数据缓存为空闲状态时,当该数据缓存的累计写入数据量为零或者累计写入数据量大于预设数据量且检测到有数据分片需要写入时,该数据缓存跳转至写入状态并将累计写入数据量清零;在任一数据缓存为写入状态时,判断该数据缓存的累计写入数据量是否大于预设数据量,当该数据缓存的累计写入数据量大于预设数据量,则该数据缓存跳转至空闲状态。具体的,以下参照图7所示状态机轮转图对上述实施例中数据缓存的读写状态的切换过程进行详细说明。转换过程1、在空闲(英文名称:idle)状态时,若之前没有处理过读请求(即累计读取数据量为0),检测到有数据分片需要写入时,状态机跳转至写入状态;若之前有处理过读请求,并且累计读取数据量大于或等于预设数据量(示例性的,预设数据量可以为1kb)时,检测到有数据分片需要写入时,状态机也跳转至写入状态。转换过程2、进入写入状态后,对累计读取数据量清零,并且确认在向当前数据分片分配缓存地址之前送入数据缓存的读写命令所访问的bank;若当前数据分片分配缓存地址之前送入数据缓存的读写命令所访问的bank是bank3,则跳转至bank0的写入状态(st_get_ba0),取bank0中的缓存地址分配给当前数据分片;若当前数据分片分配缓存地址之前送入数据缓存的读写命令所访问的bank是bank0,则跳转至bank1的写入状态(st_get_ba1),取bank1中的缓存地址分配给当前数据分片;若当前数据分片分配缓存地址之前送入数据缓存的读写命令所访问的bank是bank1,则跳转至bank2的写入状态(st_get_ba2),取bank2中的缓存地址分配给当前数据分片;若当前数据分片分配缓存地址之前送入数据缓存的读写命令所访问的bank是bank2,则跳转至bank3的写入状态(st_get_ba3),取bank3中的缓存地址分配给当前数据分片;向数据分片分配缓存地址后,根据向数据分片分配的缓存地址将数据分片写入缓存地址对应的缓存空间中。转换过程3、在写入状态向数据分片分配缓存地址后,根据向数据分片分配的缓存地址将数据分片写入缓存地址对应的缓存空间中,并跳转到写入状态。转换过程4、在写入状态,使累计写入数据量加上当前数据分片的长度,判断累计写入数据量是否大于或等于预设数据量,若累计写入数据量大于或等于预设数据量,则跳转到空闲状态。s35、接收数据缓存返回的缓存地址和缓存长度,并根据向数据分片分配的数据缓存通道号以及数据缓存返回的缓存地址和缓存长度生成各数据分片的缓存描述符。示例性的,数据分片的缓存描述符可以如下表3所示:数据缓存通道号缓存地址缓存长度首片指示尾片指示30x123456780x1001040x234567800x1000050x345678000x1000060x000000000x1000070x5555555a0x1000000xaaaaaaaa0x0ee01表3s36、将各数据分片的缓存描述符写入bd缓存以及存储各队列的入队信息。具体的,上述步骤s36中将各数据分片的缓存描述符写入bd缓存,具体可以通过如下步骤来实现:s361、根据各数据分片在入队报文中的顺序对各数据分片的数据缓存通道号进行排序。示例性的,参照图8所示,本发明提供的缓存管理方法的硬件框架还包括一个用于存储各数据分片的数据缓存通道号顺序的存入先入先出(英文名称:firstinputfirstoutput,简称:fifo)存储器81以及多个用于存储数据缓存返回的缓存地址的fifo存储器82,其中,fifo存储器82的数据量与数据缓存控制器208的数量相同,且fifo存储器82分别与一个数据缓存控制器208连接。在上述图8所示硬件框架下,步骤s32中向各数据分片分配数据缓存通道号时,根据各数据分片在入队报文中的顺序将向各数据分片分配的数据缓存通道号存入fifo存储器81中。例如:向入队报文的6个数据分片分配的通道号如下表4所示:数据分片号123456数据缓存通道号345670表4则,写入fifo存储器中的数据缓存通道号的顺序即为3、4、5、6、7、0。由于多个数据缓存刷新频率不同、数据分片长度不相等、读写操作交替不同步等原因,所以每个通道返回数据分片地址的时间点的顺序并不一定与各数据分片的数据缓存通道号的顺序相同。为了避免同一入队报文的多个数据分片的bd顺序混乱,如图8所示,可以先采用fifo存储器82记录各数据缓存通道返回的缓存地址,然后根据fifo存储器81中记录的各数据分片的数据缓存通道号的顺序按照将各数据缓存通道返回的换地址和缓存长度依次生成各数据分片的缓存描述符。s362、根据各数据分片的数据缓存通道号的顺序依次将各数据分片的缓存描述符写入bd缓存。具体的,可以根据fifo存储器81中记录的各数据分片的数据缓存通道号的顺序,将入队报文的数据分片的bd发送至bd缓存,最后根据接收的数据分片的bd的顺序将各数据分片的缓存描述符写入bd缓存。本发明的实施例提供的缓存管理方法用于对缓存系统进行管理,其中,缓存系统中包括多个数据缓存通道,任一数据缓存通道包括一数据缓存和一数据缓存控制器,在接收到入队报文且将入队报文切割问数据分片后,首先根据向数据分片分配的数据缓存通道号将数据分片分发至对应的数据缓存通道的数据缓存控制器,然后再在数据缓存控制器的控制下将数据分片写入对应的数据缓存;即各数据缓存通道中的数据缓存控制器独立控制数据缓存通道中的数据缓存的数据写入,由于本发明提供的缓存管理方法提供了多个独立的数据缓存通道,所以相比于单个数据缓存通道,本发明实施例可以提供更高的带宽,且相比将多个缓存通道中的缓存地址统一分配管理,本发明实施例可以最大化每个缓存通道的带宽利用率,所以本发明实施例提供的缓存管理方法可以提高缓存系统的带宽。此外,还需要说明的是,上述实施例提供的缓存管理方法中的队列数没有限制条件,因此本发明实施例可以实现任意队列数的缓存管理,即通过上述实施例提供的缓存管理方法,本发明实施例可以对缓存管理系统中的队列数进行任意扩展。进一步的,通常的bd都是以链表单通道方式进行管理的,但是随着性能要求提升,100g系统短包打流的双向bd访问会达到300mpps。而单通道缓存难以达到这个性能。虽然四倍数据倍率(英文名称:quaddatarate,简称:qdr)可以提高bd访问带宽,但qdr的成本太高,且在多队列的情况下需要大容量qdr,因此实际用于中难以承受。为了解决上述问题,本发明实施例进一步提供了一种多bd缓存通道的缓存系统,具体的,参照图9所示,图9为本发明实施例提供的缓存管理方法的硬件架构图,本发明实施例提供的缓存管理方法的硬件架构图包括:由缓存系统的数据切片电路201、数据缓存通道号查询电路202、入队分发电路203以及分片地址重排序电路204组成的入队单元92、由链表管理电路205、多个bd缓存控制器206以及多个bd缓存组成的bd缓存单元91、链表管理电路205。其中,链表管理电路205包括:初始化单元2051和片内片内缓存2052。多个bd缓存控制器206与多个bd缓存一一对应形成多个bd缓存通道(图9中以缓存系统包括两个缓存通道为例进行说明)。当本发明实施例提供的缓存管理方法应于如图9所示的缓存系统,包括多个bd缓存通道,任一所述bd缓存通道包括一缓存描述缓存控制器和一bd缓存时,上述步骤s363中根据各数据分片的数据缓存通道号的顺序依次将各数据分片的bd写入bd缓存,包括:各bd缓存通道的存描述缓存控制器根据各数据分片的数据缓存通道号的顺序分别将各数据分片的缓存描述符写入对应的bd缓存。本发明实施例提供的缓存系统可以包括多个bd缓存通道,且任一bd缓存通道中的bd缓存控制器独立管理该bd缓存通道中的bd缓存进行读写操作,由于本发明实施例中增加了bd缓存通道数量,所以本发明实施例可以增加系统的bd缓存通道的带宽,此外,由于各bd缓存通道种的bd缓存控制器独立对各bd缓存通道中的bd缓存的读写进行管理,因此可以最大化每个bd缓存通道的利用率,因此本发明实施例可以提高bd缓存的能效。具体的,参照图10所示,当缓存系统包括多个bd缓存通道时,上述步骤s363中根据各数据分片的数据缓存通道号的顺序依次将各数据分片的bd写入bd缓存可以通过如下步骤来实现:s101、按照预设缓存大小将多个bd缓存分割为多个缓存块。示例性的,预设缓存大小可以为2kb。s102、向各队列分配缓存块、首端缓存地址和尾端缓存地址,并记录向各队列分配的首端缓存地址和尾端缓存地址。其中,向不同队列分配的缓存块不同,任一队列的首端缓存地址和尾端缓存地址所指示的缓存空间为向该队列分配的缓存块中的同一个缓存空间。可选的,可以通过链表管理电路205中的片内缓存2052记录向各队列分配的首端缓存地址和尾端缓存地址。示例性的,假设bd缓存通道中的bd缓存的缓存空间为2gb,预设缓存大小为2kb,一个数据分片的bd的大小为8bt,则一个bd缓存中包括1000000个缓存块,一个缓存块中可以存放256个数据分片的bd。片内缓存2052中记录各队列的地址首端缓存地址和尾端缓存地址的缓存内容格式可以如下表5所示:缓存块地址[19:0]偏移地址[7:0]表5此外,上述步骤s102中向各队列分配缓存块、首端缓存地址和尾端缓存地址即为对片内缓存2052中各队列的缓存块地址进行设置以及对各队列的偏移地址置零。进一步的,上述步骤s102中向各队列分配缓存块,具体可以为:向各队列随机分配多个bd缓存中的缓存块。即,将各队列随机分配到多个bd缓存通道上。示例性的,假设包括:5个队列(队列0、队列1、队列2、队列3、队列4),2个bd缓存通道(bd缓存通道0、bd缓存通道1),则各队列随机分配到多个bd缓存通道上可以如下表6所示:队列bd缓存通道0010213140表6向各队列随机分配多个bd缓存中的缓存块,可以将各队列随机分配到多个bd缓存通道上,从而避免部分bd缓存通道过载,而部分bd缓存通道空闲,进而均衡多个bd缓存通道的流量,提升bd缓存的性能。s103、接收到缓存描述符时,获取第一队列的首端缓存地址。其中,第一队列为接收到的缓存描述符所属的数据分片所属的入队报文所属的队列。示例性的,若入队报文1的队列为队列1,数据分片1为由入队报文1切割形成数据分片中的一个,bd1为数据分片1的缓存描述符,则在接收到bd1时,获取队列1的首端缓存地址。s104、将接收到的缓存描述符写入第一队列的首端缓存地址所指示的缓存空间。s105、判断第一缓存块剩余的缓存空间是否小于或等于一个缓存描述符的大小。其中,第一缓存块为向第一队列分配的缓存块。具体的,若记录各队列的地址首端缓存地址和尾端缓存地址的缓存内容格式如表5所示,则步骤s105中判断一缓存块剩余的缓存空间是否小于或等于一个缓存描述符的大小,可以为:判断偏移地址+1是否等于255。在步骤s105中,若第一缓存块剩余的缓存空间大于一个缓存描述符的大小(偏移地址+1不等于255),则执行步骤s86,而若第一缓存块剩余的缓存空间小于或等于一个缓存描述符的大小(偏移地址+1等于255),则执行步骤s87。s106、将第一队列的首端缓存地址更新为第一缓存块中首端缓存地址后的下一个缓存地址。s107、向第一队列分配第二缓存块,将第二缓存块的缓存块地址写入第一缓存块,将第一队列的首端缓存地址更新为第二缓存块中的第一个缓存地址。可选的,上述步骤s107中在向第一队列分配第二缓存块时,将多个bd缓存中的缓存块轮转向第一队列分配。例如:缓存系统中包括2个bd缓存(bd缓存0、bd缓存1),且队列0的第一缓存块属于bd缓存0,则向队列0分配第二缓存块时,从bd缓存1选取缓存块作为第二缓存块向队列0分配。上述实施例中在向第一队列分配第二缓存块时,将多个bd缓存中的缓存块轮转向第一队列分配,即分配缓存块时多个bd缓存通道轮转分配;在分配缓存块时多个bd缓存通道轮转分配可以使各数据分片的bd平均的缓存在多个bd缓存通道上,从而避免部分bd缓存通道过载,而部分bd缓存通道空闲,进而均衡多个bd缓存通道的流量,提升bd缓存的能效。s108、根据各数据分片的数据缓存通道号的顺序依次将各数据分片的缓存描述符写入第一队列的首端缓存地址所指示的缓存空间。示例性的,bd缓存的bd链表可以如图11所示,包括多个数据分片的bd组成的链表,且每一个bd块的最后一个存储空间存放一个缓存块地址。此外,由于本发明实施例提供的缓存管理方法在管理数据分片的bd链表时,仅需要在链表管理电路205的片内缓存2052中存储向各队列分配的首端缓存地址和尾端缓存地址,所以可以节省存储资源,降低制造成本。以下对基于上述数据入队流程对本发明实施例提供的缓存管理方法的出队流程进行详细说明,具体的,参照图12所示上述缓存管理方法还包括:s201、接收出队命令。其中,出队命令用于指示将出队报文从数据缓存中调出,出队命令包括出队报文的队列信息。s202、根据出队报文的队列信息获取第二队列。其中,第二队列为出队报文所属的队列。即,根据出队报文的队列信息获取出队报文的队列。s203、获取第二队列的尾端缓存地址。s204、读出第二队列的尾端缓存地址所指示的缓存空间中的缓存描述符。s205、判断第三缓存块中的缓存描述符是否已经全部取出。其中,第三缓存块为第二队列的尾端缓存地址所指示的缓存空间的缓存块。在步骤s205中,若第三缓存块中的缓存描述符没有全部取出,则执行步骤s206;若第三缓存块中的缓存描述符已经全部取出,则执行步骤s207。s206、将第二队列的尾端缓存地址更新为第三缓存块中尾端缓存地址后的下一个缓存地址。s207、获取第三缓存块中的缓存块地址,并将第二队列的尾端缓存地址更新为向第三缓存块中的缓存块地址所指示的缓存块中的第一个缓存地址。其中,上述步骤s207中获取的第三缓存块中的缓存块地址即为上述实施例中步骤s207中向缓存换写入的缓存块地址。s208、根据第二队列的入队信息获取出队报文的包含的数据分片的数量。s209、判断从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量是否等于出队报文包含的数据分片的数量。例如:出队报文的大小为2kb,且出队报文的数据分片均为64字节时,需要从读取的数据分片的数量为32个。在步骤s209中,若从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量等于出队报文包含的数据分片的数量,则执行步骤s210;若从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量小于出队报文包含的数据分片的数量,则返回步骤s203中重复执行上述步骤s203-s209直到从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量等于出队报文包含的数据分片的数量。s210、将各从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符分发至对应数据缓存通道的数据缓存控制器。s211、在数据缓存控制器的控制下根据从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符从对应的数据缓存中读取数据分片。在执行上述步骤s211时,本发明实施例提供的缓存管理方法还包括:记录各数据缓存的累计写入数据量和累计读取数据量;在任一数据缓存为空闲状态时,当该数据缓存的累计写入数据量为零且需要读取数据分片时,该数据缓存跳转至读取状态并将累计写入数据量清零;在任一数据缓存为读取状态时,判断该数据缓存的累计读取数据量是否大于预设数据量,当该数据缓存的累计读取数据量大于预设数据量,则该数据缓存跳转至空闲状态。具体的,以下在图7所示状态机转换的基础上参照图13所示状态机轮转图对上述实施例中数据缓存的状态转换过程进行详细说明。转换过程5、在空闲状态时,若之前没有处理过写请求(即累计写入数据量为0),检测到需要读取数据分片时,状态机跳转至读取状态;若之前有处理过写请求,并且累计写入数据量大于或等于预设数据量时,检测到需要读取数据分片时,状态机也跳转至写入状态。转换过程6、在读取状态下,对累计写入数据量清0,根据出队bd读取数据分片。给累计读取数据量加上当前读取数据分片的长度,若当前累计读取数据量小于预设数据量,则仍旧停留在读取状态。转换过程7、在读取状态下,若当前累计读取数据量大于或等于预设数据量,则返回空闲状态下。s112、按照已读出的各缓存描述符中的数据缓存通道号的顺序依次将各数据分片输出。上述步骤s101-109为本发明实施例提供的缓存管理方法中的数据分片的bd读取流程,步骤s110-s112为根据步骤s101-109读取的数据分片的bd从数据缓存中读取数据分片并输出的过程。同样,由于多个数据缓存刷新频率不同、数据分片长度不相等、读写操作交替不同步等原因,所以每个数据缓存通道返回数据分片的时间点的顺序并不一定与出队报文中各个数据分片的相同,因此需对各数据缓存通道返回数据分片进行排序后输出。基于上述需求,本发明实施例进一步提供了一种缓存管理方法的硬件框架。具体的,参照图14所示,本发明提供的缓存管理方法的硬件框架还包括一个用于存储各数据分片的数据缓存通道号顺序的fifo存储器81以及多个用于存储数据缓存返回的缓存地址的fifo存储器82,其中,fifo存储器82的数据量与数据缓存控制器208的数量相同,且fifo存储器82分别与一个数据缓存控制器208连接。在步骤209中,若从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量等于出队报文包含的数据分片的数量,则通过fifo存储器81存储各bd的数据缓存通道号顺,在各数据缓存通道的数据缓存返回数据分片后首先存储在对应的fifo存储器82中,安然按照fifo存储器81存储的各bd的数据缓存通道号顺序对数据缓存返回数据分片进行输出。上述方法可以保证单一队列在连续读写的时候,对数据缓存的操作都是连续的,其性能可以达到最高。即使所有队列挨个发包时也可以存保证数据缓入队分别写入,出队时连续读取。使用单通道16bitddr颗粒时,连续读出的ddr使用效能在80%以上。零散写入也能接近40%.因此即使所有队列轮流发包时,本发明采用的方法也能保证ddr的带宽利用率达到50%以上。且存放bdblock是可以重复利用的,当block中的bd全部取出后,就可以回收该block以便下一次利用。本发明再一实施例提供与上述实施例提供的缓存管理方法相对应的缓存管理装置,需要说明的是,上述缓存管理方法中的解释说明均可援引至下述实施例中对本发明实施例提供的缓存管理装置进行解释说明。同样本发明实施例提供的缓存管理装置用于对缓存系统进行管理,缓存系统中包括多个数据缓存通道,任一数据缓存通道包括一数据缓存和一数据缓存控制器,且各数据缓存通道具有唯一的数据缓存通道号。具体的,该缓存管理装置包括:入队数据切片电路,用于在收到入队报文时,根据预设分片大小和入队报文的长度将入队报文切割为至少一个数据分片;数据缓存通道号查询电路,用于向各数据分片分配数据缓存通道号;入队分发电路,用于根据向数据分片分配的数据缓存通道号将数据分片分发至对应的数据缓存通道的数据缓存控制器;数据缓存控制器,用于将所述数据分片写入对应的数据缓存;链表管理电路,用于接收数据缓存返回的缓存地址和缓存长度,以及根据向数据分片分配的数据缓存通道号以及数据缓存返回的缓存地址和缓存长度生成各数据分片的缓存描述符;bd缓存控制器,用于将各数据分片的缓存描述符写入bd缓存。可选的,所述缓存系统包括多个bd缓存通道,任一所述bd缓存通道包括一bd缓存控制器和一bd缓存;所述缓存管理装置还包括:分片地址重排序电路;所述分片地址重排序电路用于根据各数据分片在所述入队报文中的顺序对各数据分片的数据缓存通道号进行排序;各bd缓存通道的bd缓存控制器用于根据各数据分片的数据缓存通道号的顺序分别将各数据分片的缓存描述符写入对应的bd缓存。可选的,bd缓存控制器具体用于按照预设缓存大小将多个bd缓存分割为多个缓存块;向各队列分配缓存块,并向各队列分配首端缓存地址;其中,向不同队列分配的缓存块不同,任一队列的首端缓存地址所指示的缓存空间向该队列分配的缓存块;接收到缓存描述符时,获取第一队列的首端缓存地址;第一队列为接收到的缓存描述符所属的数据分片所属的入队报文所属的队列;将接收到的缓存描述符写入第一队列的首端缓存地址所指示的缓存空间,并将向第一队列分配的首端缓存地址记录为第一队列的尾端缓存地址;判断第一缓存块剩余的缓存空间是否小于或等于一个缓存描述符的大小;第一缓存块为向第一队列分配的缓存块;若否,则将第一队列的首端缓存地址更新为第一缓存块中首端缓存地址后的下一个缓存地址;若是,则向第一队列分配第二缓存块,将第二缓存块的缓存块地址写入第一缓存块,将第一队列的首端缓存地址更新为第二缓存块中的第一个缓存地址;根据各数据分片的数据缓存通道号的顺序依次将各数据分片的缓存描述符写入第一队列的首端缓存地址所指示的缓存空间。可选的,缓存系统还包括:调度单元,调度单元用于记录各队列的入队信息,接收出队命令,根据出队报文的队列信息获取第二队列,根据第二队列的入队信息获取出队报文的包含的数据分片的数量;缓存管理装置还包括:出队分发电路和出队数据重组电路;链表管理电路还用于获取第二队列的尾端缓存地址并将第二队列的尾端缓存地址分发至bd缓存控制器;其中,出队命令用于指示将出队报文从数据缓存中调出,出队命令包括出队报文的队列信息;第二队列为出队报文所属的队列;bd缓存控制器还用于读出第二队列的尾端缓存地址所指示的缓存空间中缓存描述符;判断第三缓存块中的缓存描述符是否已经全部取出;若否,则将第二队列的尾端缓存地址更新为第三缓存块中尾端缓存地址后的下一个缓存地址;若是,则获取第三缓存块中的缓存块地址,并将第二队列的尾端缓存地址更新为向第三缓存块中的缓存块地址所指示的缓存块中的第一个缓存地址;第三缓存块为第二队列的尾端缓存地址所指示的缓存空间的缓存块;判断从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量是否等于根据出队报文的长度信息获取出队报文包含的数据分片的数量;出队分发电路,用于判断从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量是否等于根据出队报文的长度信息获取出队报文包含的数据分片的数量以及在从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符数量等于根据出队报文的长度信息获取出队报文包含的数据分片的数量时将各从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符分发至对应数据缓存通道的数据缓存控制器;数据缓存控制器还用于根据从第二队列的尾端缓存地址所指示的缓存空间中读取的缓存描述符从对应的数据缓存中读取数据分片;出队数据重组电路,用于按照已读出的各缓存描述符中的数据缓存通道号的顺序依次将各数据分片输出。本发明在意实施例提供一种现场可编程门阵列,包括:上述任一实施例提供的缓存管理装置。现场可编程门阵列是一种集成度很高的新型高性能可编程芯片。fpga内部电路功能是可编程的,可以通过硬件描述语言(英文名称:hardwaredescriptionlanguage,简称:hdl)和专用设计工具,在fpga内部灵活地实现极其复杂的电路功能,适用于高速、高密度的高端数字逻辑电路设计领域。当将上述实施例中的缓存管理装置实现在fpga内部实现时,占用逻辑资源少,且在不使用中央处理器等第三方控制器件的情况下,以最低的成本实现了fpga的主动升级,并且提供了单板双功能的效果。基于上述实施例提供的缓存管理方法、装置以及fpga,本发明实施例可以利用fpga丰富的输出/输出(英文名称:input/output,简称:i/o)资源和内部缓存资源,使用多各通道的数据缓存和多个通道的bd缓存,实现任意队列数的高性能缓存管理。以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本
技术领域
的技术人员在本发明揭露的技术范围内,可轻易想到的变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以权利要求的保护范围为准。当前第1页12
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1