Vector Packet Processing Explained

Vector Packet Processing (VPP) platform is an extensible, open-source framework, which offers the functionality of network switches or routers.[1] Vector processing is the process of processing multiple packets at a time, with low latency. Single packet processing and high latency are present in the scalar processing approach, which VPP aims to make obsolete.[2] [3]

This open-source, Linux Foundation backed[4] framework is part of the Fast Data Project (FD.io). VPP uses the Data Plane Development Kit device drivers and libraries for many of its layer 1 functions - however, this functionality is separated into an optional plugin-in for VPP.

Technology

In order to push for scalability of networks, VPP reads the largest available vector of packets in the networks I/O layer. Instead of processing each packet individually throughout an entire graph with several nodes, VPP selects the entire vector of packets and pushes them through a graph node, before moving on to the next node. The instruction cache then adapts to the process and the remaining packets are processed even faster, due to the previously learned instructions from the first vector packet.[5]

External links

Notes and References

  1. Web site: 2017-05-27. What is VPP?. 2020-08-12. FD.io Wiki.
  2. Web site: Scalar vs Vector packet processing — The Vector Packet Processor 20.01 documentation. 2020-08-12. fd.io.
  3. Web site: 2020-01-03. [Guide] Intro to Vector Packet Processing (VPP)]. 2020-08-12. PANTHEON.tech. en-US.
  4. Web site: VPP fd.io. 29 December 2016. wiki.fd.io. Linux Foundation.
  5. Web site: VPP Technology. 2020-08-12. fd.io.