CN115277407A - 网口配置处理方法、装置、电子设备和存储介质 - Google Patents
网口配置处理方法、装置、电子设备和存储介质 Download PDFInfo
- Publication number
- CN115277407A CN115277407A CN202210880237.8A CN202210880237A CN115277407A CN 115277407 A CN115277407 A CN 115277407A CN 202210880237 A CN202210880237 A CN 202210880237A CN 115277407 A CN115277407 A CN 115277407A
- Authority
- CN
- China
- Prior art keywords
- pcie
- channel
- pcie channel
- queue
- network port
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000003672 processing method Methods 0.000 title claims abstract description 13
- 238000000034 method Methods 0.000 claims abstract description 22
- 238000012545 processing Methods 0.000 claims description 20
- 238000004590 computer program Methods 0.000 claims description 6
- 238000004891 communication Methods 0.000 description 6
- 238000010586 diagram Methods 0.000 description 6
- 230000009471 action Effects 0.000 description 4
- 230000006870 function Effects 0.000 description 4
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 238000011161 development Methods 0.000 description 3
- 238000001514 detection method Methods 0.000 description 2
- 230000006872 improvement Effects 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 230000008569 process Effects 0.000 description 2
- 238000013461 design Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000026676 system process Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
- H04L41/0803—Configuration setting
- H04L41/0813—Configuration setting characterised by the conditions triggering a change of settings
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/40—Bus structure
- G06F13/4063—Device-to-bus coupling
- G06F13/4068—Electrical coupling
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/42—Bus transfer protocol, e.g. handshake; Synchronisation
- G06F13/4282—Bus transfer protocol, e.g. handshake; Synchronisation on a serial bus, e.g. I2C bus, SPI bus
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Hardware Design (AREA)
- Information Transfer Systems (AREA)
- Computer And Data Communications (AREA)
Abstract
本申请提供一种网口配置处理方法、装置、电子设备和存储介质,其中,网口配置处理方法包括:扫描用于将网口接收的目标报文传输至CPU的FPGA卡;初始化FPGA卡与CPU之间的PC I e通道,其中,对FPGA卡的第一个PC I e通道执行向上注册及初始化第一个PC I e通道对应的网口,和将从PC I e通道对应的网口保存在自定义变量中;当检测到上层应用模扫描到第一个PC I e通道注册的网口时,基于从PC I e通道的接收队列挂在第一个PC I e通道下;初始化从PC I e通道的接收队列信息和第一个PC I e通道的接收队列信息;初始化FPGA卡等步骤。本申请能够克服网口的硬件带宽瓶颈,进而提高网口的带宽,从而提高网口的性能。
Description
技术领域
本申请涉及数据处理领域,具体而言,涉及一种网口配置处理方法、装置、电子设备和存储介质。
背景技术
随着当前应用丰富多样及移动终端的普及,对网络安全及通信设备的性能要求越来越高,性能的高低直接影响设备的稳定性和功能的完善性,DPDK作为一种数据平面开发工具集,以其设计优势有效提升网络数据包的处理性能而被广泛应用到各种网络设备开发中,但传统PCIe网卡普遍使用单网口通过单PCIe物理通道跟CPU连接的设计方式,当网口速率较低时还能满足,但当网口速率比较高时,一个网口跟CPU之间只有一个PCIe通道的物理带宽将成为网口性能提升的瓶颈。
发明内容
本申请实施例的目的在于提供一种网口配置处理方法、装置、电子设备和存储介质,用以克服网口的硬件带宽瓶颈,进而提高网口的带宽,从而提高网口的性能。
第一方面,本发明提供一种网口配置处理方法,所述方法包括:
扫描用于将网口接收的目标报文传输至CPU的FPGA卡;
初始化所述FPGA卡与所述CPU之间的PCIe通道,其中,对所述FPGA卡的第一个所述PCIe通道执行向上注册及初始化第一个所述PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个所述PCIe通道注册的网口;
当检测到所述上层应用模扫描到第一个所述PCIe通道注册的网口时,基于所述从PCIe通道的接收队列挂在第一个所述PCIe通道下,以扩展第一个所述PCIe通道的接收队列;
初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文;
初始化所述FPGA卡,其中,对从PCIe通道对应的FPGA phy模块进行复位解复位。
在本申请第一方面中,通过扫描用于将网口接收的目标报文传输至CPU的FPGA卡,进而能够初始化所述FPGA卡与所述CPU之间的PCIe通道,其中,对所述FPGA卡的第一个所述PCIe通道执行向上注册及初始化第一个所述PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个所述PCIe通道注册的网口,另一方面,当检测到所述上层应用模扫描到第一个所述PCIe通道注册的网口时,通过基于所述从PCIe通道的接收队列挂在第一个所述PCIe通道下,能够扩展第一个所述PCIe通道的接收队列,进而通过初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,能够使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,最后,通过初始化所述FPGA卡,能够对从PCIe通道对应的FPGA phy模块进行复位解复位。
与现有技术相比,现有技术是一个网口仅通过一个PCIe通道将其接收到报文发送给CPU,因此其带宽受限,然而本申请能够利用两个或两个以上的个PCIe通道将网口接收到报文发送给CPU,从而能够提高网口的带宽,从而提高网口的性能。
在本申请第一方面中,作为一种可选的实施方式,所述初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,包括:
基于rx_queue_setup指令或rx_init指令初始化所述第一个所述PCIe通道的接收队列信息;
基于rx_queue_setup指令或rx_init指令初始化所述从PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
在本可选的实施方式中,基于rx_queue_setup指令或rx_init指令能够初始化所述第一个所述PCIe通道的接收队列信息,并且基于rx_queue_setup指令或rx_init指令能够初始化所述从PCIe通道的接收队列信息,进而通过接收队列信息的初始化,能够使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
在本申请第一方面中,作为一种可选的实施方式,所述基于rx_queue_setup指令或rx_init指令初始化所述从PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,包括:
将与所述从PCIe通道的接收队列操作相关的硬件信息保存在所述从PCIe通道的接收队列信息中;
将与所述从PCIe通道的接收队列操作无相关的软件信息配置为与第一个所述PCIe通道的软件信息相同并保存在所述从PCIe通道的接收队列信息中,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
在本可选的实施方式中,通过将与所述从PCIe通道的接收队列操作相关的硬件信息保存在所述从PCIe通道的接收队列信息中,和将与所述从PCIe通道的接收队列操作无相关的软件信息配置为与第一个所述PCIe通道的软件信息相同并保存在所述从PCIe通道的接收队列信息中,能够使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
在可选的实施方式中,所述基于rx_queue_setup指令或rx_init指令初始化所述从PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,还包括:
获取所述自定义变量的空间地址,将所述自定义变量的空间地址保存在所述从PCIe通道的接收队列信息中。
第二方面,本发明提供一种网口配置处理装置,所述装置包括:
扫描模块,用于扫描用于将网口接收的目标报文传输至CPU的FPGA卡;
第一初始化模块,用于初始化所述FPGA卡与所述CPU之间的PCIe通道,其中,对所述FPGA卡的第一个所述PCIe通道执行向上注册及初始化第一个所述PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个所述PCIe通道注册的网口;
扩展模块,用于当检测到所述上层应用模扫描到第一个所述PCIe通道注册的网口时,基于所述从PCIe通道的接收队列挂在第一个所述PCIe通道下,以扩展第一个所述PCIe通道的接收队列;
第二初始化模块,用于初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文;
第三初始化模块,用于初始化所述FPGA卡,其中,对从PCIe通道对应的FPGA phy模块进行复位解复位。
在本申请第一方面中,通过扫描用于将网口接收的目标报文传输至CPU的FPGA卡,进而能够初始化所述FPGA卡与所述CPU之间的PCIe通道,其中,对所述FPGA卡的第一个所述PCIe通道执行向上注册及初始化第一个所述PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个所述PCIe通道注册的网口,另一方面,当检测到所述上层应用模扫描到第一个所述PCIe通道注册的网口时,通过基于所述从PCIe通道的接收队列挂在第一个所述PCIe通道下,能够扩展第一个所述PCIe通道的接收队列,进而通过初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,能够使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,最后,通过初始化所述FPGA卡,能够对从PCIe通道对应的FPGA phy模块进行复位解复位。
与现有技术相比,现有技术是一个网口仅通过一个PCIe通道将其接收到报文发送给CPU,因此其带宽受限,然而本申请能够利用两个或两个以上的个PCIe通道将网口接收到报文发送给CPU,从而能够提高网口的带宽。
在本申请第二方面中,作为一种可选的实施方式,所述第二初始化模块,包括:
第一初始化子模块,用于基于rx_queue_setup指令或rx_init指令初始化所述第一个所述PCIe通道的接收队列信息;
第二初始化子模块,用于基于rx_queue_setup指令或rx_init指令初始化所述从PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
在本可选的实施方式中,基于rx_queue_setup指令或rx_init指令能够初始化所述第一个所述PCIe通道的接收队列信息,并且基于rx_queue_setup指令或rx_init指令能够初始化所述从PCIe通道的接收队列信息,进而通过接收队列信息的初始化,能够使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
在本申请第二方面中,作为一种可选的实施方式,所述第二初始化子模块,包括:
第一保存模块,用于将与所述从PCIe通道的接收队列操作相关的硬件信息保存在所述从PCIe通道的接收队列信息中;
第二保存模块,用于将与所述从PCIe通道的接收队列操作无相关的软件信息配置为与第一个所述PCIe通道的软件信息相同并保存在所述从PCIe通道的接收队列信息中,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
在本可选的实施方式中,通过将与所述从PCIe通道的接收队列操作相关的硬件信息保存在所述从PCIe通道的接收队列信息中,和将与所述从PCIe通道的接收队列操作无相关的软件信息配置为与第一个所述PCIe通道的软件信息相同并保存在所述从PCIe通道的接收队列信息中,能够使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
在本申请第二方面中,作为一种可选的实施方式,所述第二初始化子模块,还包括:
第三保存模块,用于获取所述自定义变量的空间地址,将所述自定义变量的空间地址保存在所述从PCIe通道的接收队列信息中。
第三方面,本发明提供一种电子设备,包括:
处理器;以及
存储器,配置用于存储机器可读指令,所述指令在由所述处理器执行时,执行如前述实施方式任一项所述的网口配置处理方法。
本申请第三方面的电子设备通过执行网口配置处理方法,能够扫描用于将网口接收的目标报文传输至CPU的FPGA卡,进而能够初始化所述FPGA卡与所述CPU之间的PCIe通道,其中,对所述FPGA卡的第一个所述PCIe通道执行向上注册及初始化第一个所述PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个所述PCIe通道注册的网口,另一方面,当检测到所述上层应用模扫描到第一个所述PCIe通道注册的网口时,通过基于所述从PCIe通道的接收队列挂在第一个所述PCIe通道下,能够扩展第一个所述PCIe通道的接收队列,进而通过初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,能够使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,最后,通过初始化所述FPGA卡,能够对从PCIe通道对应的FPGA phy模块进行复位解复位。
与现有技术相比,现有技术是一个网口仅通过一个PCIe通道将其接收到报文发送给CPU,因此其带宽受限,然而本申请能够利用两个或两个以上的个PCIe通道将网口接收到报文发送给CPU,从而能够提高网口的带宽。
第四方面,本发明提供一种存储介质,所述存储介质存储有计算机程序,所述计算机程序被处理器执行如前述实施方式任一项所述的网口配置处理方法。
本申请第四方面的存储介质通过执行网口配置处理方法,能够扫描用于将网口接收的目标报文传输至CPU的FPGA卡,进而能够初始化所述FPGA卡与所述CPU之间的PCIe通道,其中,对所述FPGA卡的第一个所述PCIe通道执行向上注册及初始化第一个所述PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个所述PCIe通道注册的网口,另一方面,当检测到所述上层应用模扫描到第一个所述PCIe通道注册的网口时,通过基于所述从PCIe通道的接收队列挂在第一个所述PCIe通道下,能够扩展第一个所述PCIe通道的接收队列,进而通过初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,能够使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,最后,通过初始化所述FPGA卡,能够对从PCIe通道对应的FPGA phy模块进行复位解复位。
与现有技术相比,现有技术是一个网口仅通过一个PCIe通道将其接收到报文发送给CPU,因此其带宽受限,然而本申请能够利用两个或两个以上的个PCIe通道将网口接收到报文发送给CPU,从而能够提高网口的带宽。
附图说明
为了更清楚地说明本申请实施例的技术方案,下面将对本申请实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本申请的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1是本申请实施例公开的一种网口配置处理方法的流程示意图;
图2是本申请实施例公开的一种网口报文通过多PCIe上送物理框架图
图3是本申请实施例公开的一种网口配置处理装置的结构示意图;
图4是本申请实施例公开的一种电子设备的结构示意图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行描述。
实施例一
请参阅图1,图1是本申请实施例公开的一种网口配置处理方法的流程示意图,如图1所示,本申请实施例的方法包括以下步骤:
101、扫描用于将网口接收的目标报文传输至CPU的FPGA卡;
102、初始化FPGA卡与CPU之间的PCIe通道,其中,对FPGA卡的第一个PCIe通道执行向上注册及初始化第一个PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个PCIe通道注册的网口;
103、当检测到上层应用模扫描到第一个PCIe通道注册的网口时,基于从PCIe通道的接收队列挂在第一个PCIe通道下,以扩展第一个PCIe通道的接收队列;
104、初始化从PCIe通道的接收队列信息和第一个PCIe通道的接收队列信息,以使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文;
105、初始化FPGA卡,其中,对从PCIe通道对应的FPGA phy模块进行复位解复位。
在本申请实施例中,CPU(central processing uni)是指中央处理器,例如,CPU可以AMD系列的中央处理器。
在本申请实施例中,网口是指网络接口,例如,网口可以是网卡上的接口硬件,其中,外部计算机向本地计算机发送的报文,经过网卡上的接口硬件可被网卡传输至本地计算机的CPU,使得本地计算机的CPU对该报文进行处理。
在本申请实施例中,FPGA(Field Programmable Gate Array)是指现场可编程逻辑门阵列,进一步地,FPGA卡是指通过FPGA芯片实现标准网卡收发包功能并定制特定功能的卡,在本申请实施例中,FPGA卡可充当网卡。
在本申请实施例中,PCIe是指一种高速串行计算机扩展总线标准,而PCIe通道是指采用高速串行计算机扩展总线标准进行通信的通信通道。
在本申请实施例中,针对步骤101,如图2所示,图2是本申请实施例公开的一种网口报文通过多PCIe上送物理框架图。如图2所示,网口通过FPGA与CPU之间的PCIe1通道和PCIe2通道,可将报文传输至CPU。
在本申请实施例中,针对步骤101,扫描用于将网口接收的目标报文传输至CPU的FPGA卡的一种具体方式是:
基于DPDK(Data Plane Development Kit,数据面软件开发套件),扫描用于将网口接收的目标报文传输至CPU的FPGA卡。
在本申请实施例中,针对步骤102,为了能够初始化FPGA卡与CPU之间的PCIe通道,本申请实施例的方法还包括以下步骤:
扫描FPGA卡的FPGA卡与CPU之间的PCIe通道,其中,每扫描到一个PCIe通道执行步骤102;初始化FPGA卡与CPU之间的PCIe通道操作。
在本申请实施例中,FPGA卡与CPU之间的PCIe通道至少包括2个PCIe通道,例如,可以是2个,也可以是3个,进一步地,多个PCIe通道可依次被扫描到,其中,最先扫描到的PCIe通道为第一个PCIe通道,而在第一个PCIe通道之后扫描得到的PCIe通道为从PCIe通道。
在本申请实施例中,针对步骤102,对FPGA卡的第一个PCIe通道执行向上注册是指将第一个PCIe通道注册到上层应用模块,用于告知上层应用模块第一个PCIe通道与哪个网口关联,其中,由于从PCIe通道对应的网口保存在自定义变量中,而没有注册到上层应用模块,因此上层应用模扫描注册的网口时只能扫描到第一个PCIe通道注册的网口,实现多个PCIe只出一个网口的目的。
在本申请实施例中,针对步骤102,对FPGA卡的第一个PCIe通道执行向上注册的一种具体方式为;
基于DPDK对FPGA卡的第一个PCIe通道执行向上注册。
在本申请实施例中,初始化第一个PCIe通道对应的网口的一种具体方式为:
基于DPDK对初始化第一个PCIe通道对应的网口。
在本申请实施例中,针对步骤103,当检测到上层应用模扫描到第一个PCIe通道注册的网口时,通过调用DPDK统一的获取网口硬件信息接口dev_infos_get,进而能够在获取网口硬件信息接口dev_infos_get中对接收队列数量做特殊处理,即基于从PCIe通道的接收队列挂在第一个PCIe通道下,以扩展第一个PCIe通道的接收队列。
在本申请实施例中,针对步骤103,由于只有第一个PCIe通道向上注册了网口,所以为了使得从PCIe通道的接收队列能够用于传输数据,从PCIe通道对应的接收队列也要挂在注册的这个网口上,即扩展第一个PCIe通道的接收队列。例如,假设第一个PCIe通道对应有16个接收队列,从PCIe通道有16个接收队列,通过将从PCIe通道的接收队列挂在第一个PCIe通道下,从而第一个PCIe通道的接收队列经扩展后,总接收队列为16*2,其中,如果从PCIe通道的数量为3,则总接收队列为16*3,以此类推。
在本申请实施例中,通过扫描用于将网口接收的目标报文传输至CPU的FPGA卡,进而能够初始化FPGA卡与CPU之间的PCIe通道,其中,对FPGA卡的第一个PCIe通道执行向上注册及初始化第一个PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个PCIe通道注册的网口,另一方面,当检测到上层应用模扫描到第一个PCIe通道注册的网口时,通过基于从PCIe通道的接收队列挂在第一个PCIe通道下,能够扩展第一个PCIe通道的接收队列,进而通过初始化从PCIe通道的接收队列信息和第一个PCIe通道的接收队列信息,能够使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文,最后,通过初始化FPGA卡,能够对从PCIe通道对应的FPGA phy模块进行复位解复位。
与现有技术相比,现有技术是一个网口仅通过一个PCIe通道将其接收到报文发送给CPU,因此其带宽受限,然而本申请能够利用两个或两个以上的个PCIe通道将网口接收到报文发送给CPU,从而能够提高网口的带宽。
在本申请实施例中,作为一种可选的实施方式,步骤104:初始化从PCIe通道的接收队列信息和第一个PCIe通道的接收队列信息,以使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文,包括:
基于rx_queue_setup指令或rx_init指令初始化第一个PCIe通道的接收队列信息;
基于rx_queue_setup指令或rx_init指令初始化从PCIe通道的接收队列信息,以使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文。
在本可续的实施方式中,rx_queue_setup指令或rx_init指令为DPDK提供的指令,其详细介绍请参阅现有技术。
在本可选的实施方式中,基于rx_queue_setup指令或rx_init指令能够初始化第一个PCIe通道的接收队列信息,并且基于rx_queue_setup指令或rx_init指令能够初始化从PCIe通道的接收队列信息,进而通过接收队列信息的初始化,能够使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文。
在本申请实施例中,作为一种可选的实施方式,基于rx_queue_setup指令或rx_init指令初始化从PCIe通道的接收队列信息,以使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文,包括:
将与从PCIe通道的接收队列操作相关的硬件信息保存在从PCIe通道的接收队列信息中;
将与从PCIe通道的接收队列操作无相关的软件信息配置为与第一个PCIe通道的软件信息相同并保存在从PCIe通道的接收队列信息中,以使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文。
在本可续的实施方式中,与从PCIe通道的接收队列操作相关的硬件信息包括队列描述符基址、队列描述符索引。
在本可续的实施方式中,与从PCIe通道的接收队列操作无相关的软件信息可以是网口Id(port_id)。
在本可选的实施方式中,作为一个示例,按一个PCIe通道有16个接收队列算,如果FPGA卡跟CPU之间有两个PCIe通道,第一个PCIe通道注册的网口对应的接收队列数量应该为16*2=32,其中前16个接收队列为第一个PCIe通道上的接收队列,之后的16个接收队列为第二个PCIe通道(从PCIe通道)的队列,因此跟PCIe通道相关的硬件信息,比如队列描述符基址、队列描述符索引等,前16个接收队列rxq的接收队列信息保存的都是第一个PCIe通道对应的寄存器地址,之后的16个接收队列rxq的接收队列信息保存的都是第二个PCIe通道对应的寄存器地址;而前16个接收队列rxq的接收队列信息中的软件相关信息和后16个接收队列rxq的接收队列信息中的软件相关信息一样,这样当系统在处理后16个接收队列rxq从第二个PCIe通道收到的报文时,才能把报文当做第一个PCIe通道注册的网口收到的报文上送给上层处理。
由此可见,通过将与从PCIe通道的接收队列操作相关的硬件信息保存在从PCIe通道的接收队列信息中,和将与从PCIe通道的接收队列操作无相关的软件信息配置为与第一个PCIe通道的软件信息相同并保存在从PCIe通道的接收队列信息中,能够使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文。
在可选的实施方式中,基于rx_queue_setup指令或rx_init指令初始化从PCIe通道的接收队列信息,以使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文,还包括以下子步骤:
获取自定义变量的空间地址,将自定义变量的空间地址保存在从PCIe通道的接收队列信息中。
在本申请实施例中,针对步骤105:由于从PCIe通道由于没有向上层注册网口,所以上层无法通过对其网口执行up操作,本申请实施例通过对从PCIe通道的FPGA phy模块进行复位解复位操作,能够起到up操作类似的作用。
本实例基于全自主国产化应用检测产品,阐述使用本发明提出的一种多个PCIe上送的一个网口报文的软件处理方法,有效扩展网卡接口硬件带宽瓶颈,而实现接口性能的提升。
下面描述结合本申请实施例的网口配置处理方法的网口上传报文的过程,具体地:
1.系统启动,默认配置参数为31核收包,绑定收包核到宿主机的2~32核,4G大页内存,设置dpdk_init为True(以DPDK方式收包),物理网卡的收包队列,默认设置32个。
2.通过物理网卡,将用户的流量导入到具体产品的上层应用模块。
3.报文到达网卡,网卡的DMA模块通过提前设置的RSS,将报文HASH到物理网卡的32个队列上。
4.DPDK通过在物理网卡的32个队列上进行收包,并根据配置的安全服务链的规则进行流表匹配。
5.流表匹配动作成功之后,报文将会转发到PCIe通道的接收队列,系统针对该FPGA卡支持配置一系列的安全流量分配规则,默认使用五元组分配方式,其中,规则支持得选项有,三元组;五元组;基于该配置,可以将流量负载均衡到不同的PCIe通道上。
6.报文在分流到不同的PCIe上之后,经过本申请实施例所述的方法就可以把FPGA卡接口上的报文收到软件,然后上送到上层应用模块进行不同的协议处理,最终,以网口采用PCIe 2.0为例,其只有一个PCIe通道,其物理带宽最大只有4.0Gb/s,如果有两个PCIe通道,物理带宽最大可以达到4.0Gb/s*2=8.0Gb/s。
需要说明的是,本申请实施例的方法可应用在防火墙、入侵检测等产品中。
实施例二
请参阅图3,图3是本申请实施例公开的一种网口配置处理装置的结构示意图,如图3所示,本申请实施例的装置包括以下功能模块:
扫描模块201,用于扫描用于将网口接收的目标报文传输至CPU的FPGA卡;
第一初始化模块202,用于初始化FPGA卡与CPU之间的PCIe通道,其中,对FPGA卡的第一个PCIe通道执行向上注册及初始化第一个PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个PCIe通道注册的网口;
扩展模块203,用于当检测到上层应用模扫描到第一个PCIe通道注册的网口时,基于从PCIe通道的接收队列挂在第一个PCIe通道下,以扩展第一个PCIe通道的接收队列;
第二初始化模块204,用于初始化从PCIe通道的接收队列信息和第一个PCIe通道的接收队列信息,以使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文;
第三初始化模块205,用于初始化FPGA卡,其中,对从PCIe通道对应的FPGA phy模块进行复位解复位。
在本申请实施例中,通过扫描用于将网口接收的目标报文传输至CPU的FPGA卡,进而能够初始化FPGA卡与CPU之间的PCIe通道,其中,对FPGA卡的第一个PCIe通道执行向上注册及初始化第一个PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个PCIe通道注册的网口,另一方面,当检测到上层应用模扫描到第一个PCIe通道注册的网口时,通过基于从PCIe通道的接收队列挂在第一个PCIe通道下,能够扩展第一个PCIe通道的接收队列,进而通过初始化从PCIe通道的接收队列信息和第一个PCIe通道的接收队列信息,能够使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文,最后,通过初始化FPGA卡,能够对从PCIe通道对应的FPGA phy模块进行复位解复位。
与现有技术相比,现有技术是一个网口仅通过一个PCIe通道将其接收到报文发送给CPU,因此其带宽受限,然而本申请能够利用两个或两个以上的个PCIe通道将网口接收到报文发送给CPU,从而能够提高网口的带宽。
在本申请实施例中,作为一种可选的实施方式,第二初始化模块,包括:
第一初始化子模块,用于基于rx_queue_setup指令或rx_init指令初始化第一个PCIe通道的接收队列信息;
第二初始化子模块,用于基于rx_queue_setup指令或rx_init指令初始化从PCIe通道的接收队列信息,以使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文。
在本可选的实施方式中,基于rx_queue_setup指令或rx_init指令能够初始化第一个PCIe通道的接收队列信息,并且基于rx_queue_setup指令或rx_init指令能够初始化从PCIe通道的接收队列信息,进而通过接收队列信息的初始化,能够使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文。
在本申请实施例中,作为一种可选的实施方式,第二初始化子模块,包括:
第一保存模块,用于将与从PCIe通道的接收队列操作相关的硬件信息保存在从PCIe通道的接收队列信息中;
第二保存模块,用于将与从PCIe通道的接收队列操作无相关的软件信息配置为与第一个PCIe通道的软件信息相同并保存在从PCIe通道的接收队列信息中,以使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文。
在本可选的实施方式中,通过将与从PCIe通道的接收队列操作相关的硬件信息保存在从PCIe通道的接收队列信息中,和将与从PCIe通道的接收队列操作无相关的软件信息配置为与第一个PCIe通道的软件信息相同并保存在从PCIe通道的接收队列信息中,能够使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文。
在本申请实施例中,作为一种可选的实施方式,第二初始化子模块,还包括:
第三保存模块,用于获取自定义变量的空间地址,将自定义变量的空间地址保存在从PCIe通道的接收队列信息中。
实施例三
请参阅图4,图4是本申请实施例公开的一种电子设备的结构示意图,如图4所示,本申请实施例的电子设备包括:
处理器301;以及
存储器302,配置用于存储机器可读指令,指令在由处理器301执行时,执行如前述实施方式任一项的网口配置处理方法。
本申请实施例的电子设备通过执行网口配置处理方法,能够扫描用于将网口接收的目标报文传输至CPU的FPGA卡,进而能够初始化FPGA卡与CPU之间的PCIe通道,其中,对FPGA卡的第一个PCIe通道执行向上注册及初始化第一个PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个PCIe通道注册的网口,另一方面,当检测到上层应用模扫描到第一个PCIe通道注册的网口时,通过基于从PCIe通道的接收队列挂在第一个PCIe通道下,能够扩展第一个PCIe通道的接收队列,进而通过初始化从PCIe通道的接收队列信息和第一个PCIe通道的接收队列信息,能够使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文,最后,通过初始化FPGA卡,能够对从PCIe通道对应的FPGA phy模块进行复位解复位。
与现有技术相比,现有技术是一个网口仅通过一个PCIe通道将其接收到报文发送给CPU,因此其带宽受限,然而本申请实施例能够利用两个或两个以上的个PCIe通道将网口接收到报文发送给CPU,从而能够提高网口的带宽。
实施例四
本申请实施例提供一种存储介质,存储介质存储有计算机程序,计算机程序被处理器执行如前述实施方式任一项的网口配置处理方法。
本申请实施例的存储介质通过执行网口配置处理方法,能够扫描用于将网口接收的目标报文传输至CPU的FPGA卡,进而能够初始化FPGA卡与CPU之间的PCIe通道,其中,对FPGA卡的第一个PCIe通道执行向上注册及初始化第一个PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个PCIe通道注册的网口,另一方面,当检测到上层应用模扫描到第一个PCIe通道注册的网口时,通过基于从PCIe通道的接收队列挂在第一个PCIe通道下,能够扩展第一个PCIe通道的接收队列,进而通过初始化从PCIe通道的接收队列信息和第一个PCIe通道的接收队列信息,能够使得经从PCIe通道的接收队列上传的报文,和经第一个PCIe通道的接收队列上传的报文被识别为第一个PCIe通道注册的网口上传的报文,最后,通过初始化FPGA卡,能够对从PCIe通道对应的FPGA phy模块进行复位解复位。
与现有技术相比,现有技术是一个网口仅通过一个PCIe通道将其接收到报文发送给CPU,因此其带宽受限,然而本申请实施例能够利用两个或两个以上的个PCIe通道将网口接收到报文发送给CPU,从而能够提高网口的带宽。
在本申请所提供的实施例中,应该理解到,所揭露装置和方法,可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,又例如,多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些通信接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
另外,作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
再者,在本申请各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
需要说明的是,功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本申请各个实施例方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(Read-Only Memory,ROM)随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。
以上仅为本申请的实施例而已,并不用于限制本申请的保护范围,对于本领域的技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。
Claims (10)
1.一种网口配置处理方法,其特征在于,所述方法包括:
扫描用于将网口接收的目标报文传输至CPU的FPGA卡;
初始化所述FPGA卡与所述CPU之间的PCIe通道,其中,对所述FPGA卡的第一个所述PCIe通道执行向上注册及初始化第一个所述PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个所述PCIe通道注册的网口;
当检测到所述上层应用模扫描到第一个所述PCIe通道注册的网口时,基于所述从PCIe通道的接收队列挂在第一个所述PCIe通道下,以扩展第一个所述PCIe通道的接收队列;
初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文;
初始化所述FPGA卡,其中,对从PCIe通道对应的FPGA phy模块进行复位解复位。
2.如权利要求1所述的方法,其特征在于,所述初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,包括:
基于rx_queue_setup指令或rx_init指令初始化所述第一个所述PCIe通道的接收队列信息;
基于rx_queue_setup指令或rx_init指令初始化所述从PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
3.如权利要求2所述的方法,其特征在于,所述基于rx_queue_setup指令或rx_init指令初始化所述从PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,包括:
将与所述从PCIe通道的接收队列操作相关的硬件信息保存在所述从PCIe通道的接收队列信息中;
将与所述从PCIe通道的接收队列操作无相关的软件信息配置为与第一个所述PCIe通道的软件信息相同并保存在所述从PCIe通道的接收队列信息中,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
4.如权利要求3所述的方法,其特征在于,所述基于rx_queue_setup指令或rx_init指令初始化所述从PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文,还包括:
获取所述自定义变量的空间地址,将所述自定义变量的空间地址保存在所述从PCIe通道的接收队列信息中。
5.一种网口配置处理装置,其特征在于,所述装置包括:
扫描模块,用于扫描用于将网口接收的目标报文传输至CPU的FPGA卡;
第一初始化模块,用于初始化所述FPGA卡与所述CPU之间的PCIe通道,其中,对所述FPGA卡的第一个所述PCIe通道执行向上注册及初始化第一个所述PCIe通道对应的网口,和将从PCIe通道对应的网口保存在自定义变量中,以使得上层应用模扫描注册的网口时只能扫描到第一个所述PCIe通道注册的网口;
扩展模块,用于当检测到所述上层应用模扫描到第一个所述PCIe通道注册的网口时,基于所述从PCIe通道的接收队列挂在第一个所述PCIe通道下,以扩展第一个所述PCIe通道的接收队列;
第二初始化模块,用于初始化所述从PCIe通道的接收队列信息和第一个所述PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文;
第三初始化模块,用于初始化所述FPGA卡,其中,对从PCIe通道对应的FPGA phy模块进行复位解复位。
6.如权利要求1所述的装置,其特征在于,所述第二初始化模块,包括:
第一初始化子模块,用于基于rx_queue_setup指令或rx_init指令初始化所述第一个所述PCIe通道的接收队列信息;
第二初始化子模块,用于基于rx_queue_setup指令或rx_init指令初始化所述从PCIe通道的接收队列信息,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
7.如权利要求6所述的方法,其特征在于,所述第二初始化子模块,包括:
第一保存模块,用于将与所述从PCIe通道的接收队列操作相关的硬件信息保存在所述从PCIe通道的接收队列信息中;
第二保存模块,用于将与所述从PCIe通道的接收队列操作无相关的软件信息配置为与第一个所述PCIe通道的软件信息相同并保存在所述从PCIe通道的接收队列信息中,以使得经所述从PCIe通道的接收队列上传的报文,和经第一个所述PCIe通道的接收队列上传的报文被识别为第一个所述PCIe通道注册的网口上传的报文。
8.如权利要求7所述的装置,其特征在于,所述第二初始化子模块,还包括:
第三保存模块,用于获取所述自定义变量的空间地址,将所述自定义变量的空间地址保存在所述从PCIe通道的接收队列信息中。
9.一种电子设备,其特征在于,包括:
处理器;以及
存储器,配置用于存储机器可读指令,所述指令在由所述处理器执行时,执行如权利要求1-4任一项所述的网口配置处理方法。
10.一种存储介质,其特征在于,所述存储介质存储有计算机程序,所述计算机程序被处理器执行如权利要求1-4任一项所述的网口配置处理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210880237.8A CN115277407B (zh) | 2022-07-25 | 2022-07-25 | 网口配置处理方法、装置、电子设备和存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210880237.8A CN115277407B (zh) | 2022-07-25 | 2022-07-25 | 网口配置处理方法、装置、电子设备和存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN115277407A true CN115277407A (zh) | 2022-11-01 |
CN115277407B CN115277407B (zh) | 2024-01-23 |
Family
ID=83768264
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210880237.8A Active CN115277407B (zh) | 2022-07-25 | 2022-07-25 | 网口配置处理方法、装置、电子设备和存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115277407B (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115412502A (zh) * | 2022-11-02 | 2022-11-29 | 之江实验室 | 一种网络端口扩展和报文快速均衡处理方法 |
CN116028426A (zh) * | 2023-03-28 | 2023-04-28 | 无锡沐创集成电路设计有限公司 | 一种多PCIe通路网卡及上送报文的单网口网卡驱动方法 |
CN116795605A (zh) * | 2023-08-23 | 2023-09-22 | 珠海星云智联科技有限公司 | 一种外围器件互联扩展设备异常自动恢复系统以及方法 |
Citations (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101609442A (zh) * | 2009-06-17 | 2009-12-23 | 成都市华为赛门铁克科技有限公司 | 一种接口自适应的方法及其装置、系统 |
CN102739490A (zh) * | 2012-06-26 | 2012-10-17 | 国电南瑞科技股份有限公司 | 一种基于PCIe总线的多路同步以太网扩展系统 |
CN102929818A (zh) * | 2012-10-23 | 2013-02-13 | 华为技术有限公司 | PCIe接口的传输报文数据方法、桥接模块、读取模块和系统 |
US20140195711A1 (en) * | 2013-01-04 | 2014-07-10 | American Megatrends, Inc. | Pci express channel implementation in intelligent platform management interface stack |
US20150143016A1 (en) * | 2013-11-18 | 2015-05-21 | Futurewei Technologies, Inc. | Method and apparatus for delivering msi-x interrupts through non-transparent bridges to computing resources in pci-express clusters |
CN105068953A (zh) * | 2014-05-07 | 2015-11-18 | Hgst荷兰公司 | 用于对等高速外围组件互联存储传输的系统和方法 |
CN105721357A (zh) * | 2016-01-13 | 2016-06-29 | 华为技术有限公司 | 交换设备、外围部件互连高速系统及其初始化方法 |
CN108234264A (zh) * | 2017-12-29 | 2018-06-29 | 杭州迪普科技股份有限公司 | 一种基于PCIe信号接口扩展的数据包转发方法及装置 |
CN108924008A (zh) * | 2018-07-10 | 2018-11-30 | 郑州云海信息技术有限公司 | 一种双控制器数据通信方法、装置、设备及可读存储介质 |
US10540185B1 (en) * | 2019-01-11 | 2020-01-21 | Liqid Inc. | Software deployment in disaggregated computing platforms |
CN110943941A (zh) * | 2019-12-06 | 2020-03-31 | 北京天融信网络安全技术有限公司 | 一种报文接收方法、发送方法、网卡及电子设备 |
US10628342B1 (en) * | 2018-12-20 | 2020-04-21 | Dell Products, L.P. | System and method for accelerating performance of non-volatile memory RAID stacks |
CN112181887A (zh) * | 2019-07-05 | 2021-01-05 | 迈普通信技术股份有限公司 | 数据传输方法及装置 |
CN112437028A (zh) * | 2020-12-10 | 2021-03-02 | 福州创实讯联信息技术有限公司 | 一种嵌入式系统扩展多个网口的方法及系统 |
CN113141281A (zh) * | 2021-04-23 | 2021-07-20 | 山东英信计算机技术有限公司 | 一种fpga加速器、网络参数测量系统、方法及介质 |
CN113468090A (zh) * | 2020-03-30 | 2021-10-01 | 浙江宇视科技有限公司 | 一种PCle通信方法、装置、电子设备及可读存储介质 |
CN114416630A (zh) * | 2021-12-24 | 2022-04-29 | 深圳市广和通无线通信软件有限公司 | 基于pcie的通信方法、装置、计算机设备和可读存储介质 |
-
2022
- 2022-07-25 CN CN202210880237.8A patent/CN115277407B/zh active Active
Patent Citations (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101609442A (zh) * | 2009-06-17 | 2009-12-23 | 成都市华为赛门铁克科技有限公司 | 一种接口自适应的方法及其装置、系统 |
CN102739490A (zh) * | 2012-06-26 | 2012-10-17 | 国电南瑞科技股份有限公司 | 一种基于PCIe总线的多路同步以太网扩展系统 |
CN102929818A (zh) * | 2012-10-23 | 2013-02-13 | 华为技术有限公司 | PCIe接口的传输报文数据方法、桥接模块、读取模块和系统 |
US20140195711A1 (en) * | 2013-01-04 | 2014-07-10 | American Megatrends, Inc. | Pci express channel implementation in intelligent platform management interface stack |
US20150143016A1 (en) * | 2013-11-18 | 2015-05-21 | Futurewei Technologies, Inc. | Method and apparatus for delivering msi-x interrupts through non-transparent bridges to computing resources in pci-express clusters |
CN105068953A (zh) * | 2014-05-07 | 2015-11-18 | Hgst荷兰公司 | 用于对等高速外围组件互联存储传输的系统和方法 |
CN105721357A (zh) * | 2016-01-13 | 2016-06-29 | 华为技术有限公司 | 交换设备、外围部件互连高速系统及其初始化方法 |
CN108234264A (zh) * | 2017-12-29 | 2018-06-29 | 杭州迪普科技股份有限公司 | 一种基于PCIe信号接口扩展的数据包转发方法及装置 |
CN108924008A (zh) * | 2018-07-10 | 2018-11-30 | 郑州云海信息技术有限公司 | 一种双控制器数据通信方法、装置、设备及可读存储介质 |
US10628342B1 (en) * | 2018-12-20 | 2020-04-21 | Dell Products, L.P. | System and method for accelerating performance of non-volatile memory RAID stacks |
US10540185B1 (en) * | 2019-01-11 | 2020-01-21 | Liqid Inc. | Software deployment in disaggregated computing platforms |
CN112181887A (zh) * | 2019-07-05 | 2021-01-05 | 迈普通信技术股份有限公司 | 数据传输方法及装置 |
CN110943941A (zh) * | 2019-12-06 | 2020-03-31 | 北京天融信网络安全技术有限公司 | 一种报文接收方法、发送方法、网卡及电子设备 |
CN113468090A (zh) * | 2020-03-30 | 2021-10-01 | 浙江宇视科技有限公司 | 一种PCle通信方法、装置、电子设备及可读存储介质 |
CN112437028A (zh) * | 2020-12-10 | 2021-03-02 | 福州创实讯联信息技术有限公司 | 一种嵌入式系统扩展多个网口的方法及系统 |
CN113141281A (zh) * | 2021-04-23 | 2021-07-20 | 山东英信计算机技术有限公司 | 一种fpga加速器、网络参数测量系统、方法及介质 |
CN114416630A (zh) * | 2021-12-24 | 2022-04-29 | 深圳市广和通无线通信软件有限公司 | 基于pcie的通信方法、装置、计算机设备和可读存储介质 |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115412502A (zh) * | 2022-11-02 | 2022-11-29 | 之江实验室 | 一种网络端口扩展和报文快速均衡处理方法 |
CN116028426A (zh) * | 2023-03-28 | 2023-04-28 | 无锡沐创集成电路设计有限公司 | 一种多PCIe通路网卡及上送报文的单网口网卡驱动方法 |
CN116028426B (zh) * | 2023-03-28 | 2023-08-15 | 无锡沐创集成电路设计有限公司 | 一种多PCIe通路网卡及上送报文的单网口网卡驱动方法 |
CN116795605A (zh) * | 2023-08-23 | 2023-09-22 | 珠海星云智联科技有限公司 | 一种外围器件互联扩展设备异常自动恢复系统以及方法 |
CN116795605B (zh) * | 2023-08-23 | 2023-12-12 | 珠海星云智联科技有限公司 | 一种外围器件互联扩展设备异常自动恢复系统以及方法 |
Also Published As
Publication number | Publication date |
---|---|
CN115277407B (zh) | 2024-01-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN115277407A (zh) | 网口配置处理方法、装置、电子设备和存储介质 | |
CN105376107B (zh) | 终端测试方法和代理服务器 | |
JP2019091494A (ja) | エミュレートされたエンドポイントコンフィグレーション | |
EP3116189A1 (en) | Service link selection control method and device | |
US8711817B2 (en) | Low cost mesh network capability | |
CN105721535A (zh) | 对服务功能链中的服务功能的并行处理 | |
EP3490304B1 (en) | Method for identifying access point and hotspot, and related products | |
CN103957593A (zh) | 无线网络接入方法、装置和系统 | |
CN104349319A (zh) | 一种用于配置多设备的方法、设备和系统 | |
CN204117142U (zh) | 提供主机即时切换分享通用串行总线电子设备的电子装置 | |
CN115422106A (zh) | 一种中断请求的处理方法和装置 | |
CN113986969A (zh) | 数据处理方法、装置、电子设备和存储介质 | |
CN100586124C (zh) | 根据send机制来保证用于处理数据分组的通信设备的安全 | |
CN112134826A (zh) | 一种通信方法以及相关设备 | |
KR102280343B1 (ko) | 복수의 이더넷 포트를 가지는 사물인터넷 디바이스 | |
CN109639555B (zh) | 链路层报文生成方法、链路层报文生成装置及终端设备 | |
WO2018057165A1 (en) | Technologies for dynamically transitioning network traffic host buffer queues | |
CN115277641B (zh) | 地址共享方法及装置、电子设备、存储介质 | |
CN115022424B (zh) | 水电lcu控制器网卡虚拟控制方法、系统、设备及其介质 | |
CN112437035A (zh) | 分布式拒绝服务攻击防护方法及相关设备 | |
CN115278395A (zh) | 一种网络交换设备、数据流处理控制方法及相关设备 | |
CN113014610B (zh) | 一种远程访问方法、装置及系统 | |
CN114237928A (zh) | 容器间通信方法及装置、电子设备、计算机可读存储介质 | |
CN110493818B (zh) | 无线保真模块的检测方法、装置、存储介质及电子装置 | |
CN102497652A (zh) | 一种码分多址r-p接口大流量数据负载均衡方法及装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |