skip to main content
10.1145/1176760.1176801acmconferencesArticle/Chapter ViewAbstractPublication PagesesweekConference Proceedingsconference-collections
Article

High-performance packet classification algorithm for many-core and multithreaded network processor

Published: 22 October 2006 Publication History

Abstract

Packet classification is crucial for the Internet to provide more value-added services and guaranteed quality of service. Besides hardware-based solutions, many software-based classification algorithms have been proposed. However, classifying at 10Gbps speed or higher is a challenging problem and it is still one of the performance bottlenecks in core routers. In general, classification algorithms face the same challenge of balancing between high classification speed and low memory requirements. This paper proposes a modified Recursive Flow Classification (RFC) algorithm, Bitmap-RFC, which significantly reduces the memory requirements of RFC by applying a bitmap compression technique. To speed up classifying speed, we experiment on exploiting the architectural features of a many-core and multithreaded architecture from algorithm design to algorithm implementation. As a result, Bitmap-RFC strikes a good balance between speed and space. It can not only keep high classification speed but also reduce memory space significantly.This paper investigates the main NPU software design aspects that have dramatic performance impacts on any NPU-based implementations: memory space reduction, instruction selection, data allocation, task partitioning, and latency hiding. We experiment with an architecture-aware design principle to guarantee the high performance of the classification algorithm on an NPU implementation. The experimental results show that the Bitmap-RFC algorithm achieves 10Gbps speed or higher and has a good scalability on Intel IXP2800 NP.

References

[1]
Agere, "Network Processors", http://www.agere.com/telecom/network_processors.html.
[2]
J. R. Allen, B. M. Bass, C. Basso, R. H. Boivie, J. L. Calvignac, G. T. Davis, L. Frelechoux, M. Heddes, A., et al., "IBM PowerNP Network Processor: Hardware, Software, and Applications", IBM J. Res. & Dev., Vol. 47 No. 2/3 MARCH/MAY 2003.
[3]
AMCC, "Network Processors", https://www.amcc.com/MyAMCC/jsp/public/browse/controller.jsp?networkLevel=COMM&superFamily=NETP.
[4]
Avici, "Avici Intros Multiservice Line Cards", http://www.lightreading.com/document.asp?doc_id=34665&site=supercomm
[5]
F. Baboescu, S. Singh, and G. Varghese, "Packet Classification for Core Routers: Is there an alternative to CAMs", Technical Report, University of California, San Diego, 2003.
[6]
F. Baboescu and G. Varghese, "Scalable Packet Classification", in Proc. of ACM SIGCOMM, 2001, pp.199--210.
[7]
Cisco Systems, "Cisco CRS-1 Carrier Routing System", http://www.cisco.com/en/US/products/ps5763/
[8]
M. Degermark, A. Brodnik, S. Carlsson, and S. Pink, "Small Forwarding Tables for Fast Routing Lookups", in Proc. of ACM SIGCOMM '97, Cannes, France, 1997, pp.3--14.
[9]
W. Eatherton, G Varghese, and Z Dittia, "Tree Bitmap: Hardware/Software IP Lookups with Incremental Updates", in Proc. of ACM SIGCOMM on Computer Communication Review, Vol. 34, Issue 2, Apr. 2004, pp.97--122.
[10]
Freescale, "C-Port Network Processors", http://www.freescale.com/webapp/sps/site/homepage.jsp?nodeId=02VS0lDFTQ3126.
[11]
P. Gupta and N. McKeown, "Packet Classification Using Hierarchical Intelligent Cuttings", IEEE Micro, Vol. 20, No. 1, Jan.-Feb. 2000, pp.34--41.
[12]
P. Gupta and N. McKeown, "Packet Classification on Multiple Fields", in Proc. of ACM SIGCOMM, Computation Communication Rev., Vol. 29, Sep. 1999, pp.147--160.
[13]
Xianghui Hu, Xinan Tang, and Bei Hua, "A High-performance IPv6 Forwarding Algorithm for a Multi-core and Multithreaded Network Processor", in Proc. of ACM PPoPP'06, Mar. 2006, pp.168--177.
[14]
Huawei, "Huawei Launches NetEngine80 Core Router At Networld Interop 2001 Exhibition in US", http://www.huawei.com/news/view.do?id=88&cid=-1001
[15]
Intel, "IXP2XXX Network Processors", http://www.intel.com/design/network/products/npfamily/ixp2xxx.htm.
[16]
M. Kounavis et al., "Directions in Packet Classification for Network Processors", in Proc. of Second Workshop on Network Processors (NP2), Feb. 2003.
[17]
C. Kulkarni, M. Gries, C. Sauer, and K. Keutzer, "Programming Challenges in Network Processor Deployment", in Proc. of the International Conference on Compilers, Architecture, and Synthesis for Embedded System, San Jose, USA, 2003, pp.178--187.
[18]
T. V. Lakshman and D. Stiliadis, "High-speed Policy-based Packet Forwarding Using Efficient Multi-dimensional Range Matching", in Proc. of ACM SIGCOMM98, Sep. 1998, pp. 191--202.
[19]
T. Sherwood, G. Varghese and B. Calder, "A Pipelined Memory Architecture for High Throughput Network Processors", in Proc. of ACM ISCA'03, 2003.
[20]
S. Singh, F. Baboescu, G. Varghese, and Jia Wang, "Packet Classification Using Multidimensional Cutting", in Proc. of ACM SIGCOMM'03, ACM Press, 2003, pp.213--224.
[21]
E. Spitznagel. "Compressed Data Structures for Recursive Flow Classification", Technical Report, WUCSE-2003-65, May 2003.
[22]
V. Srinivasan, S. Suri, G. Varghese, and M. Waldvogel, "Fast and Scalable Layer Four Switching", in Proc. of ACM SIGCOMM'98, Sep. 1998, pp. 203--14.
[23]
Xinan Tang and Guang R. Gao, "Automatically Partitioning Threads for Multithreaded Architectures", in Journal of Parallel Distributed Computing, 1999,58(2) pp.159--189.
[24]
Xinan Tang and Guang R. Gao, "How hard is thread partitioning and how bad is a list scheduling based partitioning algorithm?'', in Proc. of the tenth annual ACM symposium on Parallel Algorithms and Architectures, pp. 159--189, 1998.
[25]
Xinan Tang, J. Wang, K. Theobald, and Guang R. Gao, "Thread partitioning and scheduling based on cost model", in Proc. of the ninth annual ACM symposium on Parallel Algorithms and Architectures, pp. 272--281, 1997.
[26]
D. E. Taylor and J. S. Turner, "ClassBench: A Packet Classification Benchmark", Technical Report, WUCSE-2004-28, Department of Computer Science & Engineering, Washington University in Saint Louis, May 2004.
[27]
Yaxuan Qi and Jun Li, "Towards Effective Packet Classification", in Proc. of IASTED Conference on Communication, Network, and Information Security (CNIS), 2006.

Cited By

View all

Recommendations

Comments

Information & Contributors

Information

Published In

cover image ACM Conferences
CASES '06: Proceedings of the 2006 international conference on Compilers, architecture and synthesis for embedded systems
October 2006
448 pages
ISBN:1595935436
DOI:10.1145/1176760
Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than ACM must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected]

Sponsors

Publisher

Association for Computing Machinery

New York, NY, United States

Publication History

Published: 22 October 2006

Permissions

Request permissions for this article.

Check for updates

Author Tags

  1. architecture
  2. embedded system design
  3. multithreading
  4. network processor
  5. packet classification
  6. thread-level parallelism

Qualifiers

  • Article

Conference

ESWEEK06
ESWEEK06: Second Embedded Systems Week 2006
October 22 - 25, 2006
Seoul, Korea

Acceptance Rates

Overall Acceptance Rate 52 of 230 submissions, 23%

Contributors

Other Metrics

Bibliometrics & Citations

Bibliometrics

Article Metrics

  • Downloads (Last 12 months)2
  • Downloads (Last 6 weeks)0
Reflects downloads up to 03 Jan 2025

Other Metrics

Citations

Cited By

View all

View Options

Login options

View options

PDF

View or Download as a PDF file.

PDF

eReader

View online with eReader.

eReader

Media

Figures

Other

Tables

Share

Share

Share this Publication link

Share on social media