CN112769704B - 一种基于hash表的高速可扩展IP路由查找硬件装置 - Google Patents
一种基于hash表的高速可扩展IP路由查找硬件装置 Download PDFInfo
- Publication number
- CN112769704B CN112769704B CN202110173860.5A CN202110173860A CN112769704B CN 112769704 B CN112769704 B CN 112769704B CN 202110173860 A CN202110173860 A CN 202110173860A CN 112769704 B CN112769704 B CN 112769704B
- Authority
- CN
- China
- Prior art keywords
- lookup
- hash
- service
- lookup table
- expanded
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L45/00—Routing or path finding of packets in data switching networks
- H04L45/74—Address processing for routing
- H04L45/745—Address table lookup; Address filtering
- H04L45/74591—Address table lookup; Address filtering using content-addressable memories [CAM]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L45/00—Routing or path finding of packets in data switching networks
- H04L45/74—Address processing for routing
- H04L45/745—Address table lookup; Address filtering
- H04L45/7453—Address table lookup; Address filtering using hashing
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明公开了一种基于hash表的高速可扩展IP路由查找硬件装置,包括最小单元查找表结构,该结构利用hash函数算法对应的多项式对IP地址运算,产生的结果作为sram的操作地址,查找到对应的目标key;当IP地址值和目标值key在hash查找模块规则比较中一致,那么就表示命中此规则并输出命中结果;同一个hash函数算法的算法框架下能够扩展n个命中规则;最小单元查找表结构能够拓展成并行和流水查表结构;并行和流水查表结构能够根据新增的查找业务进行复制,拓展成为复制流水电路结构。本发明支持并行和流水查表结构,结构复制简单且满足性能要求;能够根据实际业务需求,进行结构拓展支持大容量查找表;此外,更新查找表内容时间短。
Description
技术领域
本发明涉及路由查找技术领域,具体是一种基于hash表的高速可扩展IP路由查找硬件装置。
背景技术
路由器作为互联网中的关键节点设备,负责数据的各类业务处理工作。当路由器接收到一个数据包后,将会根据目的IP地址来查找路由器中的路由表,然后根据路由表中查找得到的结果,选择最合适的端口进行业务处理。因此路由器的查表速率的快慢决定了整个互联网的承载能力的条件之一。
目前路由查表主要由TCAM硬件算法完成。缺点是TCAM硬件容量小,电路工作时的功耗大,单位比特昂贵,不适合用TCAM存储大型的查找表。在实际应用中,多种业务场景对应的查找表内容是非常大的,TCAM单一实现路由查找就显得不合适了。
发明内容
本发明的目的在于提供一种基于hash表的高速可扩展IP路由查找硬件装置,以解决上述背景技术中提出的问题。
为实现上述目的,本发明提供如下技术方案:
一种基于hash表的高速可扩展IP路由查找硬件装置,包括最小单元查找表结构,由最小单元查表结构拓展的仅支持一种业务查找情况的多级联查表结构,以及能够由多个级联查表结构拓展的能够支持多种业务查找情况的复制流水电路结构。
最小单元查找表结构,利用hash函数算法对应的多项式对IP地址运算,产生的结果作为sram的操作地址,查找到对应的目标key;当前的目标key是经过hash函数算法计算后得到的理论值,在电路初始化后写入的,用于和实时查找值进行比较的值;当IP地址值和目标值key在hash查找模块规则比较中一致,那么就表示命中此规则并输出命中结果;此外,在同一个hash函数算法的算法框架下能够扩展n个命中规则,即并行有hash 查找_0、hash查找_1、hash查找_2、...、hash查找_n,最后比较选择最终的命中结果。
多级联查表结构(并行和流水查表结构),其由单个group查找组拓展成多个级联group,即group_0、group_1、...、group_k,单个group查找组中包含有m个并行的hash 函数算法,即group_0中对应hash函数_0~hash函数_m、group_1中对应hash函数_0~hash 函数_m、group_k中对应hash函数_0~hash函数_m;hash函数算法即是最小单元查找表结构,每个hash函数算法对应的目标key值存储在对应的sram空间内;该并行结构能够保证当某一类业务表项内容分散在不同的sram空间内,在查表后能够保证同一时刻给出命中结果;多个级联group能够避免电路的时序变差,也支持对同一业务进行多级流水查找,最终查表结果返回给业务处理系统,告诉其业务对应的下一跳动作。
复制流水电路结构,即根据新增的若干个业务查找需求,来复制相应数量的多级联查表结构,若干个多级联查表结构能够并行查找新增业务的表内容。
进一步的:由于业务会实时更新查表内容,使用sram存储查表内容。
与现有技术相比,本发明的有益效果是:本发明支持并行和流水查表结构,结构复制简单且满足性能要求;能够根据实际业务需求,进行结构拓展支持大容量查找表;此外,更新查找表内容时间短。
附图说明
图1为一种基于hash表的高速可扩展IP路由查找硬件装置的最小单元查表结构的结构示意图。
图2为由图1所示的最小单元查表结构拓展而来的多个级联查表结构。
图3为由图2所示结构复制而来的流水电路结构。
具体实施方式
下面结合具体实施方式对本专利的技术方案作进一步详细地说明。
一种基于hash表的高速可扩展IP路由查找硬件装置,如图1所示的结构,此结构为查找表结构的最小单元,利用hash函数算法_0的对应的多项式对IP地址运算产生的结果作为sram的操作地址,查找到对应的目标key。当前的目标key是经过hash函数算法_0 计算后得到的理论值,在电路初始化后写入的,用于和实时查找值进行比较的值。
当IP地址值和目标值key在hash查找_0模块规则比较中一致,那么就表示命中此规则(此处的命中规则可以根据用户要求配置)并输出命中结果_0;同样的,在同一个hash函数算法_0的算法框架下可以扩展多个命中规则,最后比较选择最终的命中结果。
当出现多种业务查表的情况下,就需要图2所示的硬件框图;group_0查找组中包含 m个hash函数算法,每个hash函数算法对应的目标key值存储在对应的sram空间内;此种并行结构可以保证当某一类业务表项内容分散在不同的sram空间内,在查表后可以保证同一时刻给出命中结果;同时为了避免电路的时序变差,也支持对同一业务进行多级流水查找,可以扩展成多个级联group,即group_0、group_1、...、group_k;最终查表结果返回给业务处理系统,告诉其业务对应的下一跳动作。
当新增了若干个业务查找需求,则复制相应数量的多级联查表结构,若干个多级联查表结构能够并行查找新增业务的表内容。
比如,对于业务A(IP v4),可以使用group_0中对应hash函数_0,group_1中对应hash函数_0,group_k中对应hash函数_0查表返回结果;对于新增业务B(IP v6),如图3所示,复制业务A的流水电路结构,将group_0、group_1、...、group_k复制一份硬件电路结构group_0、group_1、...、group_k,并行查找新增业务的表内容。
对于目前交换芯片来说,网络处理业务种类非常多,兼容L2层及L3层交换机业务处理,对于新增业务只需要按照上述业务扩展电路结构即可。
此外,由于业务会实时更新查表内容,使用sram存储查表内容,会极大的缩短更新表内容时间。
本发明装置的硬件电路结构能够灵活扩展查表容量,从而解决现有TCAM实现业务查表的局限性。
上面对本专利的较佳实施方式作了详细说明,但是本专利并不限于上述实施方式,在本领域的普通技术人员所具备的知识范围内,还可以在不脱离本专利宗旨的前提下作出各种变化。
Claims (5)
1.一种基于hash表的高速可扩展IP路由查找硬件装置,包括最小单元查找表结构,其特征在于,
最小单元查找表结构,利用hash函数算法对应的多项式对IP地址运算,产生的结果作为sram的操作地址,查找到对应的目标key;当IP地址值和目标值key在hash查找模块规则比较中一致,那么就表示命中此规则并输出命中结果;在同一个hash函数算法的算法框架下能够扩展n个命中规则,最后比较选择最终的命中结果;
最小单元查找表结构能够拓展成并行和流水查表结构;
并行和流水查表结构,m个并行的hash函数算法能够拓展成单个group查找组,单个group查找组能够拓展成多个级联group,每个hash函数算法对应的目标key值存储在对应的sram空间内;该并行和流水查表结构能够保证当某一类业务表项内容分散在不同的sram空间内,在查表后能够保证同一时刻给出命中结果;最终查表结果返回给业务处理系统,告诉其业务对应的下一跳动作;
并行和流水查表结构能够根据新增的查找业务进行复制,拓展成为复制流水电路结构。
2.根据权利要求1所述的一种基于hash表的高速可扩展IP路由查找硬件装置,其特征在于,复制流水电路结构,根据新增的若干个业务查找需求,来复制相应数量的多级联查表结构,若干个多级联查表结构能够并行查找新增业务的表内容。
3.根据权利要求1所述的一种基于hash表的高速可扩展IP路由查找硬件装置,其特征在于,所述目标key是经过hash函数算法计算后得到的理论值,在电路初始化后写入的,用于和实时查找值进行比较的值。
4.根据权利要求1所述的一种基于hash表的高速可扩展IP路由查找硬件装置,其特征在于,所述多个级联group能够避免电路的时序变差,也支持对同一业务进行多级流水查找。
5.根据权利要求1所述的一种基于hash表的高速可扩展IP路由查找硬件装置,其特征在于,由于业务会实时更新查表内容,使用sram存储查表内容。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110173860.5A CN112769704B (zh) | 2021-02-09 | 2021-02-09 | 一种基于hash表的高速可扩展IP路由查找硬件装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110173860.5A CN112769704B (zh) | 2021-02-09 | 2021-02-09 | 一种基于hash表的高速可扩展IP路由查找硬件装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112769704A CN112769704A (zh) | 2021-05-07 |
CN112769704B true CN112769704B (zh) | 2023-04-18 |
Family
ID=75705356
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110173860.5A Active CN112769704B (zh) | 2021-02-09 | 2021-02-09 | 一种基于hash表的高速可扩展IP路由查找硬件装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112769704B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115391331A (zh) * | 2022-04-26 | 2022-11-25 | 维沃移动通信有限公司 | 查找表的处理方法和装置 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101458618A (zh) * | 2007-12-11 | 2009-06-17 | 刘勇 | 并行hash函数模式 |
CN112235197A (zh) * | 2020-10-23 | 2021-01-15 | 烽火通信科技股份有限公司 | 一种并行路由查找方法及系统 |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN100574281C (zh) * | 2007-06-22 | 2009-12-23 | 中兴通讯股份有限公司 | 一种交换机路由表的管理方法 |
CN101309216B (zh) * | 2008-07-03 | 2011-05-04 | 中国科学院计算技术研究所 | 一种ip包分类方法和设备 |
CN101827137B (zh) * | 2010-04-13 | 2013-01-30 | 西安邮电学院 | 一种基于哈希表和扩展存储器的高性能IPv6地址查找方法 |
CN102271087B (zh) * | 2011-07-27 | 2017-09-29 | 中兴通讯股份有限公司 | 一种路由查找方法和装置 |
CN104468381B (zh) * | 2014-12-01 | 2017-05-10 | 国家计算机网络与信息安全管理中心 | 一种多域流规则匹配的实现方法 |
CN106330716B (zh) * | 2015-06-30 | 2019-12-13 | 新华三技术有限公司 | Ip路由查找方法及装置 |
CN109189792A (zh) * | 2018-09-12 | 2019-01-11 | 天津芯海创科技有限公司 | 一种并行Hash查表架构和方法 |
-
2021
- 2021-02-09 CN CN202110173860.5A patent/CN112769704B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101458618A (zh) * | 2007-12-11 | 2009-06-17 | 刘勇 | 并行hash函数模式 |
CN112235197A (zh) * | 2020-10-23 | 2021-01-15 | 烽火通信科技股份有限公司 | 一种并行路由查找方法及系统 |
Also Published As
Publication number | Publication date |
---|---|
CN112769704A (zh) | 2021-05-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Song et al. | Ipv6 lookups using distributed and load balanced bloom filters for 100gbps core router line cards | |
US7418505B2 (en) | IP address lookup using either a hashing table or multiple hash functions | |
US6985483B2 (en) | Methods and systems for fast packet forwarding | |
US9819637B2 (en) | Efficient longest prefix matching techniques for network devices | |
Bando et al. | Flashtrie: Hash-based prefix-compressed trie for IP route lookup beyond 100Gbps | |
US7424468B2 (en) | Internet protocol address look-up device | |
US8059658B1 (en) | Method and system for automatic expansion and contraction of IP host forwarding database | |
Hasan et al. | Chisel: A storage-efficient, collision-free hash-based network processing architecture | |
CN103051543A (zh) | 一种路由前缀的处理、查找、增加及删除方法 | |
US10515015B2 (en) | Hash table-based mask length computation for longest prefix match caching | |
CN106330716B (zh) | Ip路由查找方法及装置 | |
Veeramani et al. | Minimization of flow table for TCAM based openflow switches by virtual compression approach | |
CN112769704B (zh) | 一种基于hash表的高速可扩展IP路由查找硬件装置 | |
US10901897B2 (en) | Method and apparatus for search engine cache | |
Veeramani et al. | Efficient IP lookup using hybrid trie-based partitioning of TCAM-based open flow switches | |
Ghosh et al. | A hash based architecture of longest prefix matching for fast IP processing | |
Mahini et al. | MLET: a power efficient approach for TCAM based, IP lookup engines in Internet routers | |
CN113343034A (zh) | Ip查找方法、系统及存储介质 | |
US7934198B2 (en) | Prefix matching structure and method for fast packet switching | |
CN107204926B (zh) | 预处理cache的路由快速查找方法 | |
Sun et al. | Content-based route lookup using CAMs | |
Chen et al. | LPR-Trie: A fast IPv6 routing lookup algorithm with virtual nodes | |
Wang et al. | FATSS: Filter-Assisted Tuple Space Search for Packet Classification | |
Le et al. | High-throughput ip-lookup supporting dynamic routing tables using fpga | |
Ray et al. | SRAM based longest prefix matching approach for multigigabit IP processing |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |