[发明专利]一种数据分段卸载发送方法有效
申请号: | 201710396537.8 | 申请日: | 2017-05-31 |
公开(公告)号: | CN107257329B | 公开(公告)日: | 2019-10-01 |
发明(设计)人: | 杨惠;李韬;吕高锋;孙志刚;赵国鸿;毛席龙;全巍;张彦龙;范鹏冉 | 申请(专利权)人: | 中国人民解放军国防科学技术大学 |
主分类号: | H04L29/06 | 分类号: | H04L29/06 |
代理公司: | 湖南省国防科技工业局专利中心 43102 | 代理人: | 冯青 |
地址: | 410073 *** | 国省代码: | 湖南;43 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | 本发明涉及一种数据分段卸载发送方法。本方法是一种软硬件协同的、分组I/O开销低、硬件实现复杂度低的大块数据分段卸载发送方法。将一部分硬件的功能卸载到软件实现,即采用驱动切分大报文及更新报文头字段,省去了硬件分段计算处理开销,大大降低硬件设计复杂度;另外,本发明支持低开销分组I/O,大大降低软硬件协同代价,同时相较于支持轻量级分组I/O的网卡,省去了分段报文到专用软件缓冲区的一次拷贝,仅将切分后内容更新的报文头部分拷贝到软件缓冲区,大大提高性能,实现了数据分段卸载的高效发送。 | ||
搜索关键词: | 一种 数据 分段 卸载 发送 方法 | ||
【主权项】:
1.一种数据分段卸载发送方法,将一部分硬件的功能卸载到软件实现,即采用驱动切分大报文及更新报文头字段,省去了硬件分段计算处理开销,降低硬件设计复杂度,其特征在于,包括以下步骤:步骤401:获取SKB,socket buffer是linux网络代码中的数据结构,线性缓冲区和页缓冲区数目,解析报文头,对于TCP报文,确认报文分段数目,以及是否需要进行报文分片,报文长度大于1514字节;步骤402:对于需要分片的报文,根据需要分片的数目,将报文头拷贝至多个专用软件缓冲区,完成每个分片报文头内容的更新,无需分片则跳过此步骤;步骤403:根据报文分段,为每个分段完成DMA映射;步骤404:为每个分片的每个报文分段,包括专用缓冲区、线性缓冲区、页缓冲区分别获取一个发送描述符,填充相关字段,构造描述符链表,在获取描述符时需获得锁,确保不会有多个进程获得同一个描述符;步骤405:将SKB缓存到SKB缓冲区环,并更新发送描述符缓冲区环的write_p指针;步骤406:构造一个发送描述符控制块,通知硬件有新的报文需要发送;步骤407:硬件根据发送描述符控制块的内容DMA读发送描述符链,获取所有分片中每个报文分段所在位置;步骤408:根据描述符中指示报文分段地址,DMA读取所有分片的每个分段报文内容,将属于同一个分片的多个报文分段拼装成一个分片报文;步骤409:网卡硬件计算TCP校验和和CRC,完成报文发送后,向发送描述符进行回写,通知软件报文发送完成;步骤410:驱动处理中断或软中断,检查发送描述符的回写状态,若发送完成则将SKB从SKB缓冲区环出队,完成SKB的释放,并更新发送描述符缓冲区环的read_p指针。
下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国人民解放军国防科学技术大学,未经中国人民解放军国防科学技术大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/patent/201710396537.8/,转载请声明来源钻瓜专利网。
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置