A highly flexible, distributed multiprocessor architecture for network processing

  • Authors:
  • Muthu Venkatachalam;Prashant Chandra;Raj Yavatkar

  • Affiliations:
  • Intel Communications Group, Intel Corporation, JF3-462, 2111 NE 25th Ave, Hillsboro, OR;Intel Communications Group, Intel Corporation, JF3-462, 2111 NE 25th Ave, Hillsboro, OR;Intel Communications Group, Intel Corporation, JF3-462, 2111 NE 25th Ave, Hillsboro, OR

  • Venue:
  • Computer Networks: The International Journal of Computer and Telecommunications Networking - Network processors
  • Year:
  • 2003

Quantified Score

Hi-index 0.00

Visualization

Abstract

Network processors (NPs) are an emerging field of programmable processors that are optimized to implement data plane packet processing networking functions. Unlike the general-purpose CPUs that rely heavily on caching for improving performance, the lack of locality in packet processing and need for high-performance I/O have forced designers to come up with innovative architectures that can hide memory latency while still processing packets at high data rates. Most of these NPs use some type of multiprocessing in combination with a hierarchy of memory types to achieve high performance. In addition, to keep up with packets arriving at high data rates over multiple incoming media interfaces, an NP must perform fast I/O and memory operations such as packet storage, table lookup, and extraction of fields in packet headers. We describe an architecture that uses a combination of distributed memory architecture and one or more multithreaded processors to achieve the necessary performance. We describe the challenges in programming such a processor including the issues related to consistency and maintaining packet ordering. We also present a programming model for generic network applications that uses software pipelines. We then demonstrate the use of the programming model in implementing two applications, namely, mapping traffic management algorithms onto a multithreaded architecture and an implementation of a media gateway based on voice-over-AAL2.