分段地址路由的路由表组织方法及查找路由的方法

文档序号:7871356阅读:359来源:国知局
专利名称:分段地址路由的路由表组织方法及查找路由的方法
技术领域
本发明涉及路由表处理技术,具体涉及分段地址路由的路由表组织方法及查找路由的方法。
背景技术
网络带宽的急剧增加,对处于网络节点的路由器设备的转发速度提出了更高的要求,尤其是处于主干网络中的高端路由器,其存储的路由达到百万之上,因此要求路由查找的速度更快。
传统Radix Trie、多分支Trie树(Multibit Trie)等路由算法通过调整查找步长在存储空间和查找速度上寻求折中。但随着信息量突增,高端路由器设备对查找速度的要求远高于对内存空间存储利用率的要求,于是有人提出了基于SDRAM硬件实现的 DIR-24-8-BASIC的地址分段快速路由查找算法。该算法把32位的IPv4地址分成长度分别为24和8的两个部分,采用两级表的方式分别存储这两部分。第一级表(TBL24)用来存储所有前缀长度小于等于24的前缀,如果前缀长度小于24就对路由前缀扩展到24位,第二级表(TBLlong)存储的是长度在25-32之间的路由前缀。
该方法为所有的IP地址都建立一个对应的转发表项,进行路由查找时,仅需要根据目的IP地址进行检索,最多两次访问就可以找到对应的路由信息。查找的过程如下首先使用目的地址的高24位作为地址查找TBL24对应表项。如果其表项最高为0,表示已经得到下一跳地址;如果其表项最高位=1,得到的TBLlong的地址编号index,以index乘以 256加上待查的IP地址的低8位作为地址查找TBLlong的对应表项得到下一跳地址。
该算法的最大优点是结构简单,便于硬件实现,查找速度快。但是,由于上述算法在实现的过程中,在二级及三级地址空间分配过程中采用一次性最大值分配来实现,虽然实现简单,却造成巨大的空间浪费。
为了降低存储空间,又出现了 DIR-21-3-8和DIR-16-8-8方案,并且提出了一些压缩机制,减少存储空间,但是这些方法都不能最大限度的解决大量路由冗余信息问题,以 DIR-16-8-8为例,当第一级TBL24某个表项的最高位=1,表明第二级TBL8可能存在最长匹配,一般这个二级区域在初始化时,申请连续的256个表项的存储空间,但是这256个表项的存储空间并不是完全被有效利用,存在极大的浪费。发明内容
本发明所要解决的技术问题是解决二级及三级地址空间不能完全被有效利用、存在极大的浪费的问题。
为了解决上述技术问题,本发明所采用的技术方案是提供一种分段地址路由的路由表组织方法,包括以下步骤
根据路由前缀长度将路由分为多类,并相应地添加在路由表的多级表中,路由表的上一级表中设有记录下一级表的路由起始值和结束值的数据域max和min以及指向下一级表中相应表项的起始位置的数据域;初始化后,路由表的第一级表完全展开,下一级表则根据添加路由的前缀长度和当前路由存储空间大小进行比较,选择性的调整存储空间的大小,并利用上一级表中的max和min值间接的记录路由存储空间大小。在上述方法中,当路由前缀长度小于等于16时,添加到路由表的第一级表中;当路由前缀长度介于17-24之间时,添加到路由表的第二级表中;当路由前缀长度介于25-32之间时,添加到路由表的第三级表中。在上述方法中,添加路由包括以下步骤步骤10、根据路由前缀长度Mask_len判断是否将其添加到路由表的第一级表中,如果是则在第一级表中添加路由,否则转步骤20 ;步骤20、根据路由前缀长度Mask_len判断是否将其添加到路由表的第二级表中,如果是转步骤30,否则转步骤40 ;步骤30、判断第二级表的存储空间是否够用,如果够用则结合第一级表中的max和min计算出该路由在第二级表中的偏移起始位置,然后进行添加并更新第一级表中的指向第二级表中相应表项的起始位置的数据域,完成后转步骤50 ;否则,根据路由的IP地址的17-24位数值重新申请第二级表的相应内存,再进行添加,完成后转步骤50 ;步骤40、判断第三级表的存储空间是否够用,如果够用则结合第二级表中的max和min计算出该路由在第三级表中的偏移起始位置,然后进行添加并更新第二级表中的指向第三级表中相应表项的起始位置的数据域,完成后转步骤50 ;否则,根据路由的IP地址的25-32位数值重新申请第三级表的相应内存,再进行添加,完成后转步骤50 ;步骤50 :路由表项添加结束。在上述方法中,步骤10包括以下步骤步骤101 :判断路由前缀长度Mask_len是否大于16,如果Mask_len小于等于16,转步骤102 ;否则转步骤20进行处理;步骤102 :结合前缀长度Mask_Len计算出路由的IP地址的高16位有效数值11_base_idx,以确定该路由对应的表项在第一级表中的偏移起始位置Table[Ll_base_idx],并计算表项的作用域num_entry=2~ (16Mask_len) -1 ;步骤103 自第一级表中的偏移起始位置Table [Ll_base_idx]开始至Table [11_base_idx+num_entry]结束,对表中前缀长度Len小于Maske_len的表项进行添加,添加完成后转步骤50。上述方法中,步骤30包括以下步骤步骤301:找到第一级表中对应的表项Table [Ll_base_idx];步骤302 :结合前缀长度Mask_Len计算出路由的IP地址的17_24位有效数值new_12_first_idx,同时根据前缀长度Mask_Len计算出添加表项作用域长度num_entry=2~(24_Mask_len)-l,将 new_12_first_idx 和 num_entry+new_12_first_idx 的值分别与第一级表中的表项Table [Ll_base_idx]中min和max进行比较,计算出new_min = min {new_12_first_idx, min}和 new_max = max{num_entry+new_12_first_idx, max},如果 old—size=max-min+l大于等于new_size=new_max_new_min+l则表明第二级表的存储空间可以满足添加该路由,进而转步骤303进行处理;否则,表明第二级表的存储空间不够,需要重新申请更大的内存,转步骤305进行处理;
步骤303 :结合第一级表中的min值计算出该路由在第二表中的偏移起始位置 new_entry_offset = new_12_first_idx-min ;
步骤304 :在第二级表中,从偏移起始位置Table [new_entry_offset]到 Table [new_entry_offset+num_entry],对表中前缀长度 Len 小于 Maske_len 的表项进行添加,并更新路由信息,添加完成后转步骤50 ;
步骤305 :根据new_size计算出新的表项在第二级表中需要的存储空间,并申请相应的大小的内存,复制第二级表中原有的表项,并修改第一级表中的I l_entry指向新的起始地址,并计算该路由在第二表中的偏移起始位置new_entry_offset = new_12_first_ idx-min ;
步骤306 :从第二级表中的表项起始位置到Table [new_entry_offset+num_ entry],对表中前缀长度Len小于Maske_len的表项进行添加,并更新路由信息,完成后转步骤50。
上述方法中,步骤40包括以下步骤
步骤401 :找到路由表的第二级表中对应的表项Table [L2_base_idx]。
步骤402 :结合前缀长度Mask_Len计算路由前缀IP低8位有效数值new_13_ first_idx,同时根据前缀长度Mask_Len计算出添加表项作用域长度num_entry = 2' (24_Mask_len)-l,将 new_13_first_idx 和 num_entry+new_13_first_idx 的值分别与第二级表中的表项Table [L2_base_idx]中min和max进行比较,计算出的new_min = min {new_ 13_f irst_idx, min})和 new_max = max{num_entry+new_13_first_idx, max},如果 old— size = max-min+1大于等于new_size = new_max-new_min+l则表明第三级表的存储空间可以满足添加该路由,进而转步骤403进行处理;否则,表明第三级表的存储空间不够,需要重新申请更大的内存,转步骤405进行处理;
步骤403 :结合第二级表中的min值计算出该路由在第三级表中的偏移起始位置 new_entry_offset = new_13_first_idx-min ;
步骤404 :从第三级表的 Table[new_entry_offset]开始到 Table[new_entry_ offset+num_entry],对表中前缀长度Len小于Maske_len的表项进行添加,并更新路由信息,完成后进入步骤50 ;
步骤405 :根据new_size计算出新的表项在第三级表中需要的存储空间,并申请相应大小的内存,复制第三级表中的原有表项,并修改第二级表中L2_entry指向新的起始地址,并计算该路由在第三表中的偏移起始位置new_entry_offset = new_13_first_ idx-min ;
步骤406 :从第三级表中的起始表项Table [new_entry_offset+num_entry],对表中前缀长度Len小于Maske_len的表项进行添加,并更新路由信息,完成后进入步骤50。
本发明还提供了一种采用上述路由表组织方法构建的路由表查找路由的方法,包括以下步骤
路由表的上一级表中设有两个数据域Valid和Cont,Valid为表有效性标志位,取值为I或0,valid = I表明当前表有效,valid = O表明当前表为空;Cont为是否有更长路由可供查找的标志位,取值为I或0,cont = I表明可以在路由表的第二级中进行查找, cont = O表明无须在路由表的第二级中进行查找;
依次根据路由表的上一级表中的valid和cont值判断是否在下一级中继续查找。在上述查找路由的方法中,依次根据路由表的上一级表中的valid和cont值判断是否在下一级中继续查找的方法如下如果valid = l、cont= I表明有比当前长度更长的路由表项存在于下一级表中,需要从路由的IP地址中抽取下一级表的数值计算偏移量,偏移量等于上一级表的表项位置减去指向下一级表中相应表项的起始位置,查找范围为下一级表中相应表项的起始位置到下一级表中相应表项的起始位置+偏移量,直到最长匹配;如果valib=l,cont=0,表示不存在下一级更长的路由匹配,当前查找的即为最长匹配,则返回当前查找的表项作为最长匹配的路由信息;如果Valib=O,表示当前表项无效,继续查找则毫无意义。本发明,路由表初始化后,第一级表是完全展开的,但是路由表的第二级和第三级 表没有展开,当有路由添加时,才根据添加路由的前缀长度,在第二级和第三级表中选择性地展开,实现了分段地址存储机制下,第二级和第三级表的表项最小区域空间存储,消除了第二级和第三级表中的冗余数据,降低了存储空间的消耗量。


图I为本发明中路由表的第一级表的结构示意图;图2为本发明中路由的添加方法流程图;图3为具体实施例所示三条表项在路由表中的存储示意图;图4为本发明中路由查找的示意图。
具体实施例方式本发明的核心是分段地址路由的路由表结构、如何组织以及如何添加和查找路由,下面以DIR-16-8-8算法为例,结合说明书附图和具体实施方式
对本发明作出详细的说明。DIR-21-3-8、DIR-24-8等其它算法与DIR-16-8-8基本类似,在此不再重复介绍。本发明提供的分段地址路由的路由表组织方法,根据路由前缀长度将路由分为多类,并相应地添加在路由表的多级表中进行路由管理,本实施例中,根据路由前缀长度分为三类,利用三级路由表结构对上述三类路由进行管理,具体地说(I)当路由前缀长度小于等于16时,添加到路由表的第一级表itbl_ll_entry中;(2)当路由前缀长度介于17-24之间时,添加到路由表的第二级表itbl_12_entry中;(3)当路由前缀长度介于25-32之间时,添加到路由表的第三级表itbl_13_entry中。路由表的上一级表中设有指向下一级表的起始位置和结束位置的两个数据域,同时还设有指向下一级表中相应表项起始位置的数据域。图I为路由表的第一级表结构,包括如下的数据域有效性标志位Valid,取值为I或O, valid = I表明当前表有效,valid = O表明当前表为空。
是否有更长路由可供查找的标志位Cont,取值为I或0,cont = I表明可以在路由表的第二级表中进行查找,cont = O表明无须在路由表的第二级表中进行查找。
如果valid = l、cont = O,则表明当前查找到的路由表项是唯一最长匹配的路由, 可以在该表项的info指针指向的地址中直接获取下一跳信息。
当前表项路由前缀长度用Ien表示。
第二级表的起始位置min和结束位置max, max-min+1表示第二级表中可供查找的表项数,max和min的取值都不超过第二级表的最大有效表项数。
inf ο,路由信息指针,指向路由的下一跳信息。
ll_entry,指向第二级表中相应表项的起始位置。
路由的添加方法如图2所示,包括以下步骤
步骤10、根据路由前缀长度Mask_len判断是否将其添加到路由表的第一级表中, 如果是则在第一级表中添加路由,否则转步骤20 ;
步骤20、根据路由前缀长度Mask_len判断是否将其添加到路由表的第二级表中, 如果是转步骤30,否则转步骤40 ;
步骤30、判断第二级表的存储空间是否够用,如果够用则结合第一级表中的max 和min计算出该路由在第二级表中的偏移起始位置,然后进行添加并更新第一级表中的指向第二级表中相应表项的起始位置的数据域,完成后转步骤50 ;否则,根据路由的IP地址的17-24位数值重新申请第二级表的相应内存,再进行添加,完成后转步骤50 ;
步骤40、判断第三级表的存储空间是否够用,如果够用则结合第二级表中的max 和min计算出该路由在第三级表中的偏移起始位置,然后进行添加并更新第二级表中的指向第三级表中相应表项的起始位置的数据域,完成后转步骤50 ;否则,根据路由的IP地址的25-32位数值重新申请第三级表的相应内存,再进行添加,完成后转步骤50 ;
步骤50 :路由表项添加结束。
在上述方法中,步骤10包括以下步骤
步骤101 :判断路由前缀长度Mask_len是否大于16,如果Mask_len小于等于16, 表明该路由应添加到第一级表中,转步骤102 ;否则表明该路由应添加到第二级或第三级表中,转步骤20进行处理。
步骤102 :结合前缀长度Mask_Len计算出路由的IP地址的高16位有效数值11_ base_idx,以确定该路由对应的表项在第一级表中的偏移起始位置Table[Ll_base_idx], 并计算表项的作用域 num_entry, num_entry= (2' (16_Mask_len)-I)。
步骤103 自第一级表中的偏移起始位置Table [Ll_base_idx]开始至Table [11_ base_idx+num_entry]结束,对表中前缀长度Len小于Maske_len的表项进行添加,添加完成后转步骤50。
步骤30包括以下步骤
步骤301:找到第一级表中对应的表项Table [Ll_base_idx];
步骤302 :结合前缀长度Mask_Len计算出路由的IP地址的17_24位有效数值 new_12_first_idx,同时根据前缀长度Mask_Len计算出添加表项作用域长度num_entry, num_entry= (2' (24_Mask_len) -I),将 new_l2_first_idx 和 num_entry+new_12_first_ idx的值分别与第一级表中的表项Table [Ll_base_idx]中min和max进行比较,计算出new_min (等于(min {new_12_first_idx, min})和 new_max (等于 max {num_entry+new_l2_first—idx, max}),如果 old_size=max_min+l 大于等于 new_size=new_max-new_min+l 贝[I表明第二级表的存储空间可以满足添加该路由,进而转步骤303进行处理;否则,表明第二级表的存储空间不够,需要重新申请更大的内存,转步骤305进行处理。步骤303 :结合第一级表中的min值计算出该路由在第二表中的偏移起始位置new_entry_offset (等于 new_12_first_idx_min)0步骤304 :在第二级表中,从偏移起始位置Table [new_entry_offset]到Table [new_entry_offset+num_entry],对表中前缀长度 Len 小于 Maske_len 的表项进行添力口,并更新路由信息,添加完成后转步骤50。步骤305 :根据new_size计算出新的表项在第二级表中需要的存储空间,并申请相应的大小的内存,复制第二级表中原有的表项,并修改第一级表中的ll_entry指向新
的起始地址,并计算该路由在第二表中的偏移起始位置new_entry_offset (等于new_12_first_idx-min)。步骤306 :从第二级表中的表项起始位置到Table [new_entry_offset+num_entry],对表中前缀长度Len小于Maske_len的表项进行添加,并更新路由信息,完成后转步骤50。步骤40包括以下步骤步骤401 :找到路由表的第二级表中对应的表项Table[L2_base_idx]。步骤402 :结合前缀长度Mask_Len计算路由前缀IP低8位有效数值new_13_first_idx,同时根据前缀长度Mask_Len计算出添加表项作用域长度num_entry (等于2' (24_Mask_len) -I),将 new_13_first_idx 和 num_entry+new_13_first_idx 的值分别第二级表中的表项Table[L2_base_idx]中min和max进行比较,计算出的new_min(等于 min{new_13_first_idx, min})和 new_max (等于 max{num_entry+new_13_first_idx, max}),如果 old_size (等于 max-min+1)大于等于 new_size (等于 new_max~new_min+1)则表明第三级表的存储空间可以满足添加该路由,进而转步骤403进行处理;否则,表明第三级表的存储空间不够,需要重新申请更大的内存,转步骤405进行处理。步骤403 :结合第二级表中的min值计算出该路由在第三级表中的偏移起始位置new_entry_offset (等于 new_13_first_idx_min)。步骤404 :从第三级表的 Table[new_entry_offset]开始到 Table[new_entry_offset+num_entry],对表中前缀长度Len小于Maske_len的表项进行添加,并更新路由信息,完成后进入步骤50 ;步骤405 :根据new_size计算出新的表项在第三级表中需要的存储空间,并申请相应大小的内存,复制第三级表中的原有表项,并修改第二级表中L2_entry指向新的起始地址,并计算该路由在第三表中的偏移起始位置new_entry_offset (等于new_12_first_idx-min)。步骤 406 :从第三级表中的起始表项 Table [new_entry_offset+num_entry],对表中如缀长度Len小于Maske_len的表项进行添加,并更新路由/[目息,完成后进入步骤50。例如路由N A. B. C. 0/24,下一跳是N,如果该路由在第一级表中的原有标志位cont=0,表明对应的下一级表项的空间尚未分配,第一次分配的空间大小为255-C+1,返回的空间起始地址赋给第一级表的L2_entry,并将min设置为C, max设置为255, max-min+1表示下一级表的空间大小,对应的第二级表中的表项从C到255都指向下一跳N。
如果当再有一条路由需要添加,例如M A. B. D. 0/24,如果D>C,则表明表项在第二级表中的有效作用空间为D到255,标号为D到255的下一跳信息被覆盖为M,上一级表中的min、max和L2_entry都不需要进行任何修改。
如果又有一条路由需要添加,为P A. B. E. 0/24,此时E〈C〈D,表明该表项在第二级表的作用域从E到255,但是此时的表项的存储空间是没有这么大的,需要重新申请大小为 255-E+1的连续存储空间,并将原有空间内的数据拷贝到新的空间中,对应的表项中从E到 C的标号下一跳指向P。上一级表中min中的值将改为E,L2_entry装入的是新地址块的起始地址。
二条表项在路由表中的存储不意图如图3所不。
这种路由表存储机制,初始化后,路由表的第一级表是完全展开的,并固定为 Table
到Table[2~16_l],但是路由表的第二级和第三级表没有展开,当有路由添加时, 才根据添加路由的前缀长度,在第二级和第三级表中选择性地展开,所以实现了分段地址存储机制下,第二级和第三级表的表项最小区域空间存储,在一定条件下消除了第二级和第三级表中的冗余数据,降低了存储空间的消耗量。
本发明还提供了采用上述路由表组织方法构建的路由表的查找路由的方法,如图 4所示,依次根据路由表的上一级中的valid和cont值判断是否在下一级中继续查找。
以路由表的第一级为例
如果valid = l、cont= I表明有比当前长度更长的路由表项存在于第二级表中, 需要从路由的IP地址中的抽取第二级表的数值计算偏移量offset, offset等于new_12_ first_idx减去L2_entry,自第二级表的起始位址L2_entry至L2_entry+offset查找路由,直到最长匹配。
如果valib=l,cont=0,表示不存在下一级更长的路由匹配,当前查找的即为最长匹配,则返回当前查找的表项作为最长匹配的路由信息(info)。
如果Valib=O,表示当前表项无效,继续查找则毫无意义。
路由表的其它级的表项判别过程与此类似,主要对两个标志位valid和cont进行判别,区分是查找成功、失败或还是需要进入下一步中继续查找。
依据权威统计数据显示,现行IPv4路由表项中99. 93%的前缀长度小于等于24。 如果采用地址分段路由实现查找算法,在二三级上实际存储的有效路由是非常稀疏的。而本发明提供的方法,由于路由表的第一级的表项中,min和max数值记录了下一级的最小和最大的表项标号,对应的表明下一级需要的存储空间就是max-min+Ι个表项单位,该值总是不会超过256的。在最极端的条件min为O的情况下,该级表项才需要申请256个表项单位的存储空间,但是这种情况显然不可能同时出现在所有的第二级、第三级表项结构中。 因此,与传统方法相比,本发明具有如下优点
( I)与传统查找速度比较
对于路由表的第一级,查找方法与传统完全一样;
对于路由表的其他级的查找,本发明需要通过该级起始地址和第一级的表项中记录的该级表项最小值min,来推算出查找表项的偏移量,从运算的角度讲,两者在查找过程中时间复杂度基本相同。
(2)与传统存储空间比较传统方法进行下一级存储的时,标号总是从O到255,需要的存储块大小统一都是256个表项空间,造成空间的极大浪费。而本发明,初始化后,路由表的第一级是完全展开的,并固定为Table
到Table[2~16_l],但是路由表的第二级、第三级没有展开,当有表项添加时,才根据添加路由的前缀长度,在第二级、第三级选上择性地展开,所以实现了分段地址存储机制下,第二级、第三级表项的最小区域空间存储,在一定条件下消除了二、三级表中的冗余数据,降低了存储空间的消耗量。
本发明不局限于上述最佳实施方式,任何人应该得知在本发明的启示下作出的结构变化,凡是与本发明具有相同或相近的技术方案,均落入本发明的保护范围之内。
权利要求
1.分段地址路由的路由表组织方法,其特征在于,包括以下步骤 根据路由前缀长度将路由分为多类,并相应地添加在路由表的多级表中,路由表的上一级表中设有记录下一级表的路由起始值和结束值的数据域max和min以及指向下一级表中相应表项的起始位置的数据域;初始化后,路由表的第一级表完全展开,下一级表则根据添加路由的前缀长度和当前路由存储空间大小进行比较,选择性的调整存储空间的大小,并利用上一级表中的max和min值间接的记录路由存储空间大小。
2.如权利要求I所述的分段地址路由的路由表组织方法,其特征在于, 当路由前缀长度小于等于16时,添加到路由表的第一级表中; 当路由前缀长度介于17-24之间时,添加到路由表的第二级表中; 当路由前缀长度介于25-32之间时,添加到路由表的第三级表中。
3.如权利要求I所述的分段地址路由的路由表组织方法,其特征在于,添加路由包括以下步骤 步骤10、根据路由前缀长度Mask_len判断是否将其添加到路由表的第一级表中,如果是则在第一级表中添加路由,否则转步骤20 ; 步骤20、根据路由前缀长度Mask_len判断是否将其添加到路由表的第二级表中,如果是转步骤30,否则转步骤40 ; 步骤30、判断第二级表的存储空间是否够用,如果够用则结合第一级表中的max和min计算出该路由在第二级表中的偏移起始位置,然后进行添加并更新第一级表中的指向第二级表中相应表项的起始位置的数据域,完成后转步骤50;否则,根据路由的IP地址的17-24位数值重新申请第二级表的相应内存,再进行添加,完成后转步骤50 ; 步骤40、判断第三级表的存储空间是否够用,如果够用则结合第二级表中的max和min计算出该路由在第三级表中的偏移起始位置,然后进行添加并更新第二级表中的指向第三级表中相应表项的起始位置的数据域,完成后转步骤50 ;否则,根据路由的IP地址的25-32位数值重新申请第三级表的相应内存,再进行添加,完成后转步骤50 ; 步骤50 :路由表项添加结束。
4.如权利要求I所述的分段地址路由的路由表组织方法,其特征在于,步骤10包括以下步骤 步骤101 :判断路由前缀长度Mask_len是否大于16,如果Mask_len小于等于16,转步骤102 ;否则转步骤20进行处理; 步骤102 :结合前缀长度Mask_Len计算出路由的IP地址的高16位有效数值ll_base_idx,以确定该路由对应的表项在第一级表中的偏移起始位置Table [Ll_base_idx],并计算表项的作用域 num_entry=2~ (16_Mask_len) -I ; 步骤103 :自第一级表中的偏移起始位置Table[Ll_base_idx]开始至Table[ll_base_idx+num_entry]结束,对表中前缀长度Len小于Maske_len的表项进行添加,添加完成后转步骤50。
5.如权利要求4所述的分段地址路由的路由表组织方法,其特征在于,步骤30包括以下步骤 步骤301 :找到第一级表中对应的表项Table [Ll_base_idx]; 步骤302 :结合前缀长度Mask_Len计算出路由的IP地址的17-24位有效数值new_12_first_idx,同时根据前缀长度Mask_Len计算出添加表项作用域长度num_entry=2~(24_Mask_len)-l,将 new_12_first_idx 和 num_entry+new_12_first_idx 的值分别与第一级表中的表项Table [Ll_base_idx]中min和max进行比较,计算出new_min = min {new_12_first_idx, min}和 new_max = max{num_entry+new_12_first_idx, max},如果 old—size=max-min+l大于等于new_size=new_max_new_min+l则表明第二级表的存储空间可以满足添加该路由,进而转步骤303进行处理;否则,表明第二级表的存储空间不够,需要重新申请更大的内存,转步骤305进行处理; 步骤303 :结合第一级表中的min值计算出该路由在第二表中的偏移起始位置new_entry_offset = new_12_first_idx-min ; 步骤304 :在第二级表中,从偏移起始位置Table[new_entry_offset]到Table[new_entry_offset+num_entry],对表中前缀长度Len小于Maske_len的表项进行添加,并更新路由信息,添加完成后转步骤50 ; 步骤305 :根据new_size计算出新的表项在第二级表中需要的存储空间,并申请相应的大小的内存,复制第二级表中原有的表项,并修改第一级表中的ll_entry指向新的起始地址,并计算该路由在第二表中的偏移起始位置new_entry_offset = new_12_first_idx-min ; 步骤306 :从第二级表中的表项起始位置到Table [new_entry_offset+num_entry],对表中前缀长度Len小于Maske_len的表项进行添加,并更新路由信息,完成后转步骤50。
6.如权利要求5所述的分段地址路由的路由表组织方法,其特征在于,步骤40包括以下步骤 步骤401 :找到路由表的第二级表中对应的表项Table[L2_base_idx]。
步骤402 :结合前缀长度Mask_Len计算路由前缀IP低8位有效数值new_13_first_idx,同时根据前缀长度Mask_Len计算出添加表项作用域长度num_entry = 2" (24_Mask_len) -I,将 new_13_first_idx 和 num_entry+new_13_first_idx 的值分别与第二级表中的表项 Table [L2_base_idx]中 min 和 max 进行比较,计算出的 new_min = min {new_13_first_idx, min})和 new_max = max {num_entry+new_13_first_idx, max},如果 old_size=max-min+1大于等于new_size = new_max-new_min+l则表明第三级表的存储空间可以满足添加该路由,进而转步骤403进行处理;否则,表明第三级表的存储空间不够,需要重新申请更大的内存,转步骤405进行处理; 步骤403 :结合第二级表中的min值计算出该路由在第三级表中的偏移起始位置new_entry_offset = new_13_first_idx-min ; 步骤 404 :从第三级表的 Table [new_entry_offset]开始到 Table [new_entry_offset+num_entry],对表中前缀长度Len小于Maske_len的表项进行添加,并更新路由信息,完成后进入步骤50 ; 步骤405 :根据new_size计算出新的表项在第三级表中需要的存储空间,并申请相应大小的内存,复制第三级表中的原有表项,并修改第二级表中L2_entry指向新的起始地址,并计算该路由在第三表中的偏移起始位置new_entry_offset = new_13_first_idx-min ; 步骤406 :从第三级表中的起始表项Table [new_entry_offset+num_entry],对表中前缀长度Len小于Maske_len的表项进行添加,并更新路由信息,完成后进入步骤50。
7.采用如权利要求I所述的路由表组织方法构建的路由表查找路由的方法,其特征在于,包括以下步骤 路由表的上一级表中设有两个数据域Valid和Cont,Valid为表有效性标志位,取值为I或O, valid = I表明当前表有效,valid = O表明当前表为空;Cont为是否有更长路由可供查找的标志位,取值为I或0,cont = I表明可以在路由表的第二级中进行查找,cont =O表明无须在路由表的第二级中进行查找; 依次根据路由表的上一级表中的valid和cont值判断是否在下一级中继续查找。
8.如权利要求7所述的查找路由的方法,其特征在于,依次根据路由表的上一级表中的valid和cont值判断是否在下一级中继续查找的方法如下 如果valid = l、cont = I表明有比当前长度更长的路由表项存在于下一级表中,需要从路由的IP地址中抽取下一级表的数值计算偏移量,偏移量等于上一级表的表项位置减去指向下一级表中相应表项的起始位置,查找范围为下一级表中相应表项的起始位置到下一级表中相应表项的起始位置+偏移量,直到最长匹配; 如果Valib=l,cont=0,表示不存在下一级更长的路由匹配,当前查找的即为最长匹配,则返回当前查找的表项作为最长匹配的路由信息; 如果Valib=O,表示当前表项无效,继续查找则毫无意义。
全文摘要
本发明公开了一种分段地址路由的路由表组织方法及查找路由的方法,路由表组织方法包括以下步骤根据路由前缀长度将路由分为多类,并相应地添加在路由表的多级表中,路由表的上一级表中设有记录下一级表的路由起始值和结束值的数据域max和min以及指向下一级表中相应表项的起始位置的数据域;初始化后,路由表的第一级表完全展开,下一级表则根据添加路由的前缀长度和当前路由存储空间大小进行比较,选择性的调整存储空间的大小,并利用上一级表中的max和min值间接的记录路由存储空间大小。本发明,路由表的第二、第三级表只有当有路由添加时才根据添加路由的前缀长度选择性地展开,消除了第二、第三级表中的冗余数据,降低了存储空间的消耗量。
文档编号H04L12/741GK102984071SQ20121059487
公开日2013年3月20日 申请日期2012年12月31日 优先权日2012年12月31日
发明者范富明 申请人:武汉烽火网络有限责任公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1