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