一种基于指针迭代的ipv6报文硬件解析方法

文档序号:7803390阅读:191来源:国知局
一种基于指针迭代的ipv6报文硬件解析方法
【专利摘要】本发明公开了一种基于指针迭代的IPV6报文硬件解析方法,主要包括如下步骤:将输入报文转换为64bit宽的数据,从报文头开始,对报文进行周期计数;根据IPV6基本头的外层信息,解析出IPV6基本头的位置以及基本头中的下个首部所在位置,并存入指针;用报文所在的处理周期以及在周期内的偏移与指针值进行比较,提取出基本头的下个首部类型并判定是否是IPV6扩展头,如否,则扩展头解析结束;如是,则根据首部类型值以及指针值来提取第一个扩展头中的头长度、下个首部类型信息,下个扩展头的位置等信息,并分别存入类型寄存器与位置指针;用类型寄存器与位置指针对下一层报文进行迭代处理,将新计算出的值覆盖旧值,直至扩展头解析结束。本发明的特点是:使用硬件资源少;能够对任意扩展头组合的IPV6报文的解析;能够实现IPv6报文的实时解析。
【专利说明】一种基于指针迭代的IPV6报文硬件解析方法
【技术领域】
[0001]本发明涉及计算机网络技术中的一种报文解析方法,特别是涉及一种基于指针迭代的IPv6报文硬件解析方法。
【背景技术】
[0002]近年来,IPv6网络有了很大的发展和应用,尤其是基于各种隧道协议的Ipv6网络层出不穷。丰富多样的报文类型对与网络设备的报文解析能力与报文分类带来了很大的压力。
[0003]因为各层协议种类丰富,协议间的嵌套变化多端,使得使用硬件对各种报文进行实时解析困难重重。目前通常的做法是,用硬件完成基础的功能较为简单的协议解析,随后通过控制通道或数据通道交由上层的协议处理软件进行进一步处理。这种做法的好处是处理比较灵活,可重构性强,但在数据流量巨大的情况下采用上述方法会使系统处理能力与实时性受到很大限制。因此,现在亟需一种能够通过硬件实时完成更多的协议解析的方法。

【发明内容】

[0004]本发明的目的是:提供一种基于指针迭代的能够实时对IPv6报文解析的方法。
[0005]本发明的技术方案是:
一种基于指针迭代的IPV6报文硬件解析方法,其特征在于,所述方法包括如下步骤:
A、将输入报文转换为64bit宽的数据,从报文头开始,对报文进行周期计数;
B、根据IPV6基本头的外层信息,解析出IPV6基本头的位置以及基本头中的下个首部所在位置,并存入指针;
C、用报文所在的计数周期以及在周期内的偏移与指针值进行比较,提取出基本头的下个首部类型并判定是否是IPV6扩展头,如否,则扩展头解析结束;如是,则根据首部类型值以及指针值来提取第一个扩展头中的头长度、下个首部类型信息,下个扩展头的位置等信息,并分别存入类型寄存器与位置指针;用类型寄存器与位置指针对下一层报文进行迭代处理,将新计算出的值覆盖旧值,直至扩展头解析结束。
[0006]进一步地,所述步骤B的具体过程为:根据IPV6基本头的外层信息,解析出IPV6基本头的位置以及基本头中的下个首部所在位置,用寄存器basehead_pointer作为指针存储基本头的位置,用寄存器first_ext_headtype_pointer作为指针存储基本头中下个首部所在位置,计算并生成指针first_ext_headloc_pointer作为基本头的下个首部所在位置。
[0007]进一步地,所述步骤C的具体过程为:用报文所在的周期以及在周期内的偏移与寄存器first_ext_headtype_pointer进行匹配,提取出基本头的下个首部类型并存入寄存器first_ext_headtype,根据寄存器first_ext_headtype存储的值来判定是否是IPV6扩展头,如否,则扩展头解析结束;如是,根据first_ext_headloc_pointer来提取第一个扩展头中的头长度和下个扩展头的首部类型的信息,累加计算下个扩展头的位置与类型,并分别存人?旨针 next_ext_headloc_pointer 与寄存器 next_ext_headtype ;用宇旨针 next_ext_headloc_pointer与寄存器next_ext_headtype对下一层报文进行处理,用新计算出的值覆盖旧值,接着对下层报文进行迭代处理,直至扩展头解析结束。
[0008]进一步地,所述迭代处理的过程为:解析出首层扩展头的位置与类型,并将首层扩展头的位置存入指针first_ext_headtype_pointer,将其类型存入寄存器first_ext_headtype ;根据首层扩展头的位置与类型,解析出第二层扩展头的位置及其类型,并存入指针next_ext_headloc_pointer与寄存器next_ext_headtype ;依次类推,根据第η层扩展头的位置与类型,解析出第η+1层的扩展头位置及其类型,并同样存入指针next_ext_headloc_pointer 与寄存器 next_ext_headtype,进行替换;直至 next_ext_headtype 指不下一层为非IPV6扩展头,则完成迭代过程。
[0009]本发明的有益效果是:
O灵活,系统可以支持任意IPv6扩展头的任意组合,无需增加新的组件,不会降低系统的处理能力与实时性;
2)实时,系统支持对Ipv6数据的实时解析,解析过程仅有微秒级的逻辑处理延时。
[0010]
【专利附图】

【附图说明】
[0011]下面结合附图和实施例对本发明作进一步详细说明 图1为本发明的系统 步骤流程示意图;
图2为本发明实施例的数据报文格式;
【具体实施方式】
[0012]下面将结合附图,对本发明的技术方案作进一步的描述。
[0013]本发明的核心思想是:首先对到达的数据分组进行周期计数;然后利用硬件指针存储下层协议的特定位置;接着利用数据所在计数周期以及在周期内的偏移与指针的值进行比较,提取出下层协议的特定信息;最后利用指针迭代进行IPV6的扩展头解析。
[0014]如图1所示,本发明的技术方案主要包括如下步骤:
步骤101、每个时钟周期处理64bit宽的报文数据,从报文头开始,对报文进行周期计
数;
步骤102、根据IPV6基本头的外层信息,解析出IPV6基本头的位置以及基本头中的下个首部所在位置,用寄存器basehead_pointer作为指针存储基本头的位置,用寄存器first_ext_headtype_pointer作为指针存储基本头中的下个首部所在位置,计算并生成指针first_ext_headloc_pointer做为基本头的下个首部所在位置;
步骤103、用报文所在的处理周期以及在周期内的偏移与first_ext_headtype_pointer进行匹配,提取出基本头的下个首部类型并存入寄存器first_ext_headtype,根据first_ext_headtype存储的值来判定是否是IPV6扩展头,如否,则扩展头解析结束;
步骤104、根据first_ext_headloc_pointer来提取第一个扩展头中的头长度、下个首部类型信息,累加计算下个扩展头的位置与类型,并分别存入指针next_ext_headloc_pointer 与寄存器 next_ext_headtype ; 步骤 105、用指针 next_ext_headloc_pointer 与 next_ext_headtype 对下一层报文进行迭代处理,用新计算出的值覆盖旧值,直至扩展头解析结束。
[0015]下面结合具体事例,对本发明的技术方案作进一步说明。
[0016]结构如图2所示的IPV6 over ETH-1I报文,它的解析过程如下:
对64bit宽的数据报文进行同步周期计数;
进行IPv6帧头定界,根据外层为以太网帧,确定以太网协议类型位置在13、14字节,则在第2个时钟周期到达时,取出其周期内的第5、6字节即为协议类型,如果为0X86dd,则表明下层为IPv6数据,即可以确定Ipv6 base head开始于报文第15字节,其中下个首部类型位于数据的第 20 字节,置 first_ext_headtype_pointer 为 20 ;
提取基本头中的下个首部类型,在数据的第3个周期到达时,取其周期内的第2个字节,即为基本头中的下个首部类型,判断基本头中的下个首部是否为扩展头,本实施例中,下个首部为O表示其下个首部为逐跳扩展头。
[0017]提取首个扩展头的类型与指针信息,将“O”写入next_ext_headtype,同时计算出在逐跳头中指示的下个首部位置应为“55”,将“55”写入next_ext_headloc_pointer ;
提取扩展头中的头长度、下一跳类型等信息,并计算扩展头中下一跳头的位置,进行指针迭代,在数据的第7个周期到达时,取其第7个字节,即为逐跳头中指示的下一个扩展头类型,可以得出新的next_ext_headtype为43,同时取其第8个字节计算逐跳头的头长度,加上 next_ext_headloc_pointer 的值 55,即得新的 next_ext_headloc_pointer 为 63,用新的 next_ext_headtype 与 next_ext_headloc_pointer 替代旧值,完成第一次迭代。
[0018]以此类推,重复迭代,直到扩展头解析结束。
[0019]最后应当说明的是:以上实施例仅用以说明本发明的技术方案而非对其限制;尽管参照较佳实施例对本发明进行了详细的说明,所属领域的普通技术人员应当理解:依然可以对本发明的【具体实施方式】进行修改或者对部分技术特征进行等同替换;而不脱离本发明技术方案的精神,其均应涵盖在本发明请求保护的技术方案范围当中。
【权利要求】
1.一种基于指针迭代的IPV6报文硬件解析方法,其特征在于,所述方法包括如下步骤: A、将输入报文转换为64bit宽的数据,从报文头开始,对报文进行周期计数; B、根据IPV6基本头的外层信息,解析出IPV6基本头的位置以及基本头中的下个首部所在位置,并存入指针; C、用报文所在的计数周期以及在周期内的偏移与指针值进行比较,提取出基本头的下个首部类型并判定是否是IPV6扩展头,如否,则扩展头解析结束;如是,则根据首部类型值以及指针值来提取第一个扩展头中的头长度、下个首部类型信息,下个扩展头的位置等信息,并分别存入类型寄存器与位置指针;用类型寄存器与位置指针对下一层报文进行迭代处理,将新计算出的值覆盖旧值,直至扩展头解析结束。
2.根据权利要求1所述的一种基于指针迭代的IPV6报文硬件解析方法,其特征在于,所述步骤B的具体过程为:根据IPV6基本头的外层信息,解析出IPV6基本头的位置以及基本头中的下个首部所在位置,用寄存器basehead_pointer作为指针存储基本头的位置,用寄存器first_ext_headtype_pointer作为指针存储基本头中下个首部所在位置,计算并生成指针first_ext_headloc_pointer做为基本头的下个首部所在位置。
3.根据权利要求2所述的一种基于指针迭代的IPV6报文硬件解析方法,其特征在于,所述步骤C的具体过程为:用报文所在的周期以及在周期内的偏移与寄存器first_ext_headtype_pointer进行匹配,提取出基本头的下个首部类型并存入寄存器first_ext_headtype,根据寄存器first_ext_headtype存储的值来判定是否是IPV6扩展头,如否,贝丨J扩展头解析结束;如是,根据指针first_ext_headloc_pointer来提取第一个扩展头中的头长度和下个扩展头的首部类型的信息,累加计算下个扩展头的位置与类型,并分别存入指针 next_ext_headloc_pointer 与寄存器 next_ext_headtype ;用指针 next_ext_headloc_pointer与寄存器next_ext_headtype对下一层报文进行处理,用新计算出的值覆盖旧值,接着对下层报文进行迭代处理,直至扩展头解析结束。
4.根据权利要求3所述的一种基于指针迭代的IPV6报文硬件解析方法,其特征在于,所述迭代处理的过程为:解析出首层扩展头的位置与类型,并将首层扩展头的位置存入指针first_ext_headtype_pointer,将其类型存入寄存器first_ext_headtype ;根据首层扩展头的位置与类型,解析出第二层扩展头的位置及其类型,并存入指针neXt_eXt_headl0C_pointer与寄存器next_ext_headtype ;依次类推,根据第η层扩展头的位置与类型,解析出第η+1层的扩展头位置及其类型,并同样存入指针next_ext_headloc_pointer与寄存器next_ext_headtype,进行替换;直至next_ext_headtype指示下一层为非IPV6扩展头,贝丨J完成迭代过程。
【文档编号】H04L12/749GK104009923SQ201410196343
【公开日】2014年8月27日 申请日期:2014年5月12日 优先权日:2014年5月12日
【发明者】王雨, 李玉峰, 黄万伟, 卜佑军, 姜鲲鹏, 张霞, 杜飞 申请人:中国人民解放军信息工程大学
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1