一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

一种高密度智能网卡、FPGA及其工作方法与流程

2021-12-08 00:10:00 来源:中国专利 TAG:

一种高密度智能网卡、fpga及其工作方法
技术领域
1.本技术涉及计算机技术领域,特别涉及一种高密度智能网卡、应用于高密度智能网卡的fpga、高密度智能网卡中fpga的工作方法。


背景技术:

2.随着数据中心网络架构的发展,为解决数据中心虚拟化所带来的网络流量资源消耗的问题,智能网卡的概念应运而生。智能网卡通过将服务器上虚拟机之间的网络流量卸载到网卡上,释放了服务器中宝贵的计算资源。
3.当前主流的智能网卡架构都通过soc fpga来实现的,如图1所示,fpga对外通过一个网口提供业务通道,fpga通过一个pcie接口和上行设备互联,fpga下设置一组dram内存,fpga和soc之间通过一组接口互联,soc下设置sodimm内存。这种架构的业务部署方便,可拓展性强。但是硬件设计上需要占用大量的硬件空间,对于有限的网卡空间来说,限制了其进一步的发展。
4.因此,亟需一种高密度的智能网卡架构,释放板卡上有限的硬件空间,提高网卡的容量。


技术实现要素:

5.本技术的目的是提供一种高密度智能网卡、应用于高密度智能网卡的fpga、高密度智能网卡中fpga的工作方法,用以解决目前智能网卡外设较多所带来的硬件布局紧张的问题。其具体方案如下:
6.第一方面,本技术提供了一种高密度智能网卡,包括:fpga,网口,pcie接口,soc设备,sodimm内存;
7.其中,所述网口用于连通所述fpga和外接设备;所述pcie接口用于连通所述fpga和上行服务器设备;所述sodimm内存和所述soc设备均与所述fpga互联;所述fpga用于分别接收来自所述soc设备的内存访问请求和来自所述网口的内存访问请求,区分来自所述soc设备的内存访问请求和来自所述网口的内存访问请求,将所述来自所述soc设备的内存访问请求发送至所述sodimm内存,得到请求数据并反馈至所述soc设备。
8.可选的,所述fpga包括:内存报文交换模块,内存控制模块,slave内存模块,网络模块;
9.所述slave内存模块接收所述soc设备发出的内存访问请求,将所述内存访问请求发送至所述内存报文交换模块;所述内存报文交换模块识别来自于所述soc设备或来自于所述网络模块的内存访问请求,并将所述内存访问请求发送至所述内存控制模块;所述内存控制模块根据所述内存访问请求实现对所述sodimm内存的访问,将所述sodimm内存返回的请求数据反馈至所述内存报文交换模块,所述内存交换模块接收到所述请求数据后,通过识别报文信息将所述请求数据反馈至所述网络模块或所述slave内存模块;所述slave内存模块将所述请求数据反馈给所述soc设备。
10.可选的,所述fpga还包括:网口控制模块以及pcie模块;
11.所述网口控制模块用于连通所述网口和所述网络模块;所述pcie模块用于连通所述pcie接口和所述网络模块。
12.可选的,所述slave内存模块和soc内存控制接口互联,用于向所述soc设备提供网络界面。
13.可选的,所述soc内存控制接口为qsfp28接口。
14.第二方面,本技术提供了一种高密度智能网卡中fpga的工作方法,所述高密度智能网卡包括网口,pcie接口,soc设备,sodimm内存,其中所述网口用于连通fpga和外接设备,所述pcie接口用于连通所述fpga和上行服务器设备,该方法包括:
15.分别接收来自所述soc设备的内存访问请求和来自所述网口的内存访问请求;
16.区分来自所述soc设备的内存访问请求和来自所述网口的内存访问请求;
17.将所述来自所述soc设备的内存访问请求发送至所述sodimm内存,得到请求数据并反馈至所述soc设备。
18.可选的,所述fpga包括内存报文交换模块,slave内存模块,网络模块,所述分别接收来自所述soc设备的内存访问请求和来自所述网口的内存访问请求;区分来自所述soc设备的内存访问请求和来自所述网口的内存访问请求,包括:
19.控制所述slave内存模块接收所述soc设备发出的内存访问请求,并将所述内存访问请求发送至所述内存报文交换模块;
20.控制所述内存报文交换模块识别来自于所述soc设备或来自于所述网络模块的内存访问请求。
21.可选的,所述fpga还包括内存控制模块,将所述来自所述soc设备的内存访问请求发送至所述sodimm内存,得到请求数据并反馈至所述soc设备,包括:
22.控制所述内存报文交换模块将所述内存访问请求发送至所述内存控制模块;
23.控制所述内存控制模块根据所述内存访问请求实现对所述sodimm内存的访问,并将所述sodimm内存返回的请求数据反馈至所述内存报文交换模块;
24.接收到所述请求数据后,控制所述内存交换模块通过识别报文信息将所述请求数据反馈至网络模块或所述slave内存模块;
25.控制所述slave内存模块将所述请求数据反馈给所述soc设备。
26.可选的,还包括:
27.控制所述slave内存模块通过soc内存控制接口向所述soc设备提供网络界面。
28.第三方面,本技术提供了一种应用于高密度智能网卡的fpga,所述高密度智能网卡包括网口,pcie接口,soc设备,sodimm内存,其中,所述网口用于连通所述fpga和外接设备,所述pcie接口用于连通所述fpga和上行服务器设备,所述sodimm内存和所述soc设备均与所述fpga互联;
29.所述fpga用于分别接收来自所述soc设备的内存访问请求和来自所述网口的内存访问请求,区分来自所述soc设备的内存访问请求和来自所述网口的内存访问请求,将所述来自所述soc设备的内存访问请求发送至所述sodimm内存,得到请求数据并反馈至所述soc设备。
30.本技术所提供的一种高密度智能网卡,包括fpga,网口,pcie接口,soc设备,
sodimm内存,其中,网口用于连通fpga和外接设备,pcie接口用于连通fpga和上行服务器设备,sodimm内存和soc设备均与fpga互联。fpga用于分别接收来自soc设备的内存访问请求和来自网口的内存访问请求,区分来自soc设备的内存访问请求和来自网口的内存访问请求,将来自soc设备的内存访问请求发送至sodimm内存,得到请求数据并反馈至soc设备。可见,相比于传统的智能网卡架构,本技术将fpga的内存和soc设备的内存池化,节省了板卡上硬件的空间,简化了硬件设计,提高了硬件设计的效率。
31.此外,本技术还提供了一种应用于高密度智能网卡的fpga、高密度智能网卡中fpga的工作方法,其技术效果与上述高密度智能网卡的技术效果相对应,这里不再赘述。
附图说明
32.为了更清楚的说明本技术实施例或现有技术的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单的介绍,显而易见地,下面描述中的附图仅仅是本技术的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
33.图1为传统智能网卡架构;
34.图2为本技术提供的高密度智能网卡架构;
35.图3为本技术提供的fpga内部软件架构框图;
36.图4为本技术提供的高密度智能网卡数据处理流程;
37.图5为本技术提供的高密度智能网卡中fpga的工作方法实施例的流程图。
具体实施方式
38.为了使本技术领域的人员更好地理解本技术方案,下面结合附图和具体实施方式对本技术作进一步的详细说明。显然,所描述的实施例仅仅是本技术一部分实施例,而不是全部的实施例。基于本技术中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本技术保护的范围。
39.本技术提供了一种高密度智能网卡、应用于高密度智能网卡的fpga、高密度智能网卡中fpga的工作方法,解决因网卡上外设较多所带来的硬件布局紧张的问题,降低硬件设备的开发难度,达到提高生产效率,节约开发成本的目的。
40.下面对本技术提供的高密度智能网卡实施例一进行介绍,参见图2,实施例一包括fpga,网口,pcie接口,soc设备,sodimm内存;
41.其中,网口用于连通所述fpga和外接设备;pcie接口用于连通fpga和上行服务器设备;sodimm内存和soc设备均与fpga互联;fpga用于分别接收来自soc设备的内存访问请求和来自网口的内存访问请求,区分来自soc设备的内存访问请求和来自网口的内存访问请求,将来自所述soc设备的内存访问请求发送至sodimm内存,得到请求数据并反馈至soc设备。
42.作为一种具体的实施方式,fpga选择intel的agilex芯片实现,网口选择所用molex qsfp28网口,soc设备选择intel的xeon d系列芯片实现,sodimm内存选择micron的16gb ecc内存,pcie接口为gen4 x16接口。fpga通过qsfp28接口对外提供100g的网络界面,fpga和soc设备互联,fpga下挂micron的16gb sodimm内存来响应fpga和soc的内存资源请
求。
43.本实施例提供一种高密度智能网卡,包括fpga,网口,pcie接口,soc设备,sodimm内存,相比于传统的智能网卡架构,本实施例将fpga的内存和soc设备的内存池化,节省了板卡上硬件的空间,简化了硬件设计,提高了硬件设计的效率。
44.下面开始详细介绍本技术提供的高密度智能网卡实施例二,参见图3,实施例二中fpga包括:内存报文交换模块,内存控制模块,slave内存模块,网络模块;
45.slave内存模块接收soc设备发出的内存访问请求,将内存访问请求发送至内存报文交换模块;内存报文交换模块识别来自于soc设备或来自于网络模块的内存访问请求,并将内存访问请求发送至内存控制模块;内存控制模块根据内存访问请求实现对sodimm内存的访问,将sodimm内存返回的请求数据反馈至内存报文交换模块,内存交换模块接收到所述请求数据后,通过识别报文信息将请求数据反馈至网络模块或slave内存模块;slave内存模块将请求数据反馈给soc设备。
46.作为一种具体的实施方式,fpga还包括:网口控制模块以及pcie模块;网口控制模块用于连通网口和网络模块,pcie模块用于连通pcie接口和网络模块。
47.具体的,slave内存模块和soc内存控制接口互联,用于向soc设备提供网络界面。
48.本实施例提供了fpga内部的软件架构框图,如图3所示,包括内存报文交换模块,内存控制模块,slave内存模块,网络模块,网口控制模块以及pcie模块。内存报文交换模块会识别来自于网络模块的报文和来自于slave内存模块的报文,并将相应的处理结果分别反馈给网络模块或slave内存模块。
49.具体的,工作流程如图4所示,开始启动之后,fpga完成各个模块的初始化,之后等待soc发出一次访问内存的请求,fpga的slave内存模块收到soc发出的请求之后,将报文发送至内存报文交换模块,内存报文交换模块会识别来自于soc或来自于网络模块的报文,并将请求发送至内存控制模块,内存控制模块完成对sodimm内存的访问,将sodimm返回的数据,反馈至内存报文交换模块。内存报文交换模块接收到数据后,通过识别报文的信息,将报文反馈至网络模块或slave内存模块,最终slave内存模块将拿到的数据反馈给soc,结束整个流程。
50.可见,本实施例提供的一种高密度智能网卡,相比于传统的智能网卡架构,本实施例通过fpga中的内存报文交换模块的设计,将fpga的内存和soc的内存池化,节省了板卡上硬件的空间,简化了硬件设计,提高了硬件设计的效率,为企业带来收益。
51.本实施例的技术关键点在于,将资源池化的思想应用于智能网卡上,创新性的提出了通过fpga内部的内存报文交换模块的设计,来实现fpga和soc共用内存资源的设计,该方案在之前的硬件设计中未见提出。
52.下面对本技术实施例提供的高密度智能网卡中fpga的工作方法进行介绍,下文描述的高密度智能网卡中fpga的工作方法与上文描述的高密度智能网卡可相互对应参照。
53.本实施例提供一种高密度智能网卡中fpga的工作方法,其中高密度智能网卡包括网口,pcie接口,soc设备,sodimm内存,其中网口用于连通fpga和外接设备,pcie接口用于连通fpga和上行服务器设备,如图5所示,该方法包括:
54.s51、分别接收来自soc设备的内存访问请求和来自网口的内存访问请求;
55.s52、区分来自soc设备的内存访问请求和来自网口的内存访问请求;
56.s53、将来自soc设备的内存访问请求发送至sodimm内存,得到请求数据并反馈至soc设备。
57.在一些具体的实施例中,fpga包括内存报文交换模块,slave内存模块,网络模块,上述分别接收来自soc设备的内存访问请求和来自网口的内存访问请求;区分来自soc设备的内存访问请求和来自网口的内存访问请求,包括:
58.控制slave内存模块接收soc设备发出的内存访问请求,并将内存访问请求发送至内存报文交换模块;
59.控制内存报文交换模块识别来自于soc设备或来自于网络模块的内存访问请求。
60.在一些具体的实施例中,fpga还包括内存控制模块,上述将来自soc设备的内存访问请求发送至sodimm内存,得到请求数据并反馈至soc设备,包括:
61.控制内存报文交换模块将内存访问请求发送至内存控制模块;
62.控制内存控制模块根据内存访问请求实现对sodimm内存的访问,并将sodimm内存返回的请求数据反馈至内存报文交换模块;
63.接收到请求数据后,控制内存交换模块通过识别报文信息将请求数据反馈至网络模块或slave内存模块;
64.控制slave内存模块将请求数据反馈给soc设备。
65.在一些具体的实施例中,还包括:
66.控制slave内存模块通过soc内存控制接口向soc设备提供网络界面。
67.本实施例的高密度智能网卡中fpga的工作方法基于前述的高密度智能网卡实现,因此该方法的具体实施方式可见前文中的高密度智能网卡的实施例部分这里不再赘述。
68.此外,本技术还提供了一种应用于高密度智能网卡的fpga,高密度智能网卡包括网口,pcie接口,soc设备,sodimm内存,其中,网口用于连通fpga和外接设备,pcie接口用于连通fpga和上行服务器设备,sodimm内存和soc设备均与fpga互联;
69.fpga用于分别接收来自soc设备的内存访问请求和来自网口的内存访问请求,区分来自soc设备的内存访问请求和来自网口的内存访问请求,将来自soc设备的内存访问请求发送至sodimm内存,得到请求数据并反馈至soc设备。
70.本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其它实施例的不同之处,各个实施例之间相同或相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。
71.结合本文中所公开的实施例描述的方法或算法的步骤可以直接用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(ram)、内存、只读存储器(rom)、电可编程rom、电可擦除可编程rom、寄存器、硬盘、可移动磁盘、cd

rom、或技术领域内所公知的任意其它形式的存储介质中。
72.以上对本技术所提供的方案进行了详细介绍,本文中应用了具体个例对本技术的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本技术的方法及其核心思想;同时,对于本领域的一般技术人员,依据本技术的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本技术的限制。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献