【技术实现步骤摘要】
本专利技术涉及网络数据处理领域,具体涉及一种多个应用共享一个缓冲区的报文接 收方法。
技术介绍
在网络数据分析系统中,往往在一个硬件平台上运行多个应用,也就是说对设备 接收到的同一个网络报文中的数据,需要多个应用软件进行接收和处理。目前常用的一种方案是采取数据拷贝的方法,把每一个网络报文数据复制两份, 分别交给两个应用,每个应用处理自己的数据拷贝;另一种方案是采用二次分发的方法,每 个应用建立自己的报文指针队列,设备每收到一个报文,就把报文的指针分发到每个应用 的接收队列中。但是在高速网络上,采取数据拷贝的方法会带来大量的cpu数据拷贝和内存访问 开销,采用二次分发的方法,需要每个应用建立自己的报文指针队列,需要使用同步机制进 行复杂的队列管理。两种方案都会使系统的整体性能降低。
技术实现思路
本专利技术的目的是提供,避免多应用 接收报文的内存拷贝和二次分发。,包括硬件网卡、驱动软件、接口库 软件,方法如下A、硬件网卡的PCI控制器向主机注册PCI空间,定义接收报文相关的寄存器地址; PCI空间寄存器有报文缓冲区地址、长度、软件从缓冲区读报文的读指针、硬件向缓冲区 ...
【技术保护点】
一种多个应用共享一个缓冲区的报文接收方法,其特征在于:包括硬件网卡、驱动软件、接口库软件,方法如下: A、硬件网卡的PCI控制器向主机注册PCI空间,定义接收报文相关的寄存器地址;PCI空间寄存器有:报文缓冲区地址、长度、软件从缓冲区读报文的读指针、硬件向缓冲区写报文的写指针,其中读指针有多个,每个应用有自己的读指针; B、驱动软件申请连续的物理内存,作为接收报文的缓冲区,并把缓冲区的物理地址和长度写入PCI空间的对应寄存器,并设置硬件的写指针和所有应用软件的读指针为初始值0; C、硬件网卡每次从网络接收到一个报文后,把报文传输到软件的报文缓冲区中,并根据报文长度,修 ...
【技术特征摘要】
1. 一种多个应用共享一个缓冲区的报文接收方法,其特征在于包括硬件网卡、驱动 软件、接口库软件,方法如下A、硬件网卡的PCI控制器向主机注册PCI空间,定义接收报文相关的寄存器地址;PCI 空间寄存器有报文缓冲区地址、长度、软件从缓冲区读报文的读指针、硬件向缓冲区写报 文的写指针,其中读指针有多个,每个应用有自己的读指针;B、驱动软件申请连续的物理内存,作为接收报文的缓冲区,并把缓冲区的物理地址和 长度写入PCI空间的对应寄存器,并设置硬件的写指针和所有应用软件的读指针为初始值 0 ;C、硬件网卡每次从网络接收到一个报文后,把报文传输到软...
【专利技术属性】
技术研发人员:刘朝辉,刘兴奎,窦晓光,李锋伟,刘灿,
申请(专利权)人:天津曙光计算机产业有限公司,
类型:发明
国别省市:12[中国|天津]
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。