1. Introduction to the DPDK Sample Applications

The DPDK Sample Applications are small standalone applications which demonstrate various features of DPDK. They can be considered as a cookbook of DPDK features. Users interested in getting started with DPDK can take the applications, try out the features, and then extend them to fit their needs.

1.1. Running Sample Applications

Some sample applications may have their own command-line parameters described in their respective guides, however all of them also share the same EAL parameters. Please refer to EAL parameters (Linux) or EAL parameters (FreeBSD) for a list of available EAL command-line options.

1.2. The DPDK Sample Applications

There are many sample applications available in the examples directory of DPDK. These examples range from simple to reasonably complex but most are designed to demonstrate one particular feature of DPDK. Some of the more interesting examples are highlighted below.

  • Hello World: As with most introductions to a programming framework a good place to start is with the Hello World application. The Hello World example sets up the DPDK Environment Abstraction Layer (EAL), and prints a simple “Hello World” message to each of the DPDK enabled cores. This application doesn’t do any packet forwarding but it is a good way to test if the DPDK environment is compiled and set up properly.
  • Basic Forwarding/Skeleton Application: The Basic Forwarding/Skeleton contains the minimum amount of code required to enable basic packet forwarding with DPDK. This allows you to test if your network interfaces are working with DPDK.
  • Network Layer 2 forwarding: The Network Layer 2 forwarding, or l2fwd application does forwarding based on Ethernet MAC addresses like a simple switch.
  • Network Layer 2 forwarding: The Network Layer 2 forwarding, or l2fwd-event application does forwarding based on Ethernet MAC addresses like a simple switch. It demonstrates usage of poll and event mode IO mechanism under a single application.
  • Network Layer 3 forwarding: The Network Layer3 forwarding, or l3fwd application does forwarding based on Internet Protocol, IPv4 or IPv6 like a simple router.
  • Network Layer 3 forwarding Graph: The Network Layer3 forwarding Graph, or l3fwd_graph application does forwarding based on IPv4 like a simple router with DPDK Graph framework.
  • Hardware packet copying: The Hardware packet copying, or ioatfwd application demonstrates how to use IOAT rawdev driver for copying packets between two threads.
  • Packet Distributor: The Packet Distributor demonstrates how to distribute packets arriving on an Rx port to different cores for processing and transmission.
  • Multi-Process Application: The multi-process application shows how two DPDK processes can work together using queues and memory pools to share information.
  • RX/TX callbacks Application: The RX/TX callbacks sample application is a packet forwarding application that demonstrates the use of user defined callbacks on received and transmitted packets. The application calculates the latency of a packet between RX (packet arrival) and TX (packet transmission) by adding callbacks to the RX and TX packet processing functions.
  • IPsec Security Gateway: The IPsec Security Gateway application is minimal example of something closer to a real world example. This is also a good example of an application using the DPDK Cryptodev framework.
  • Precision Time Protocol (PTP) client: The PTP client is another minimal implementation of a real world application. In this case the application is a PTP client that communicates with a PTP master clock to synchronize time on a Network Interface Card (NIC) using the IEEE1588 protocol.
  • Quality of Service (QoS) Scheduler: The QoS Scheduler application demonstrates the use of DPDK to provide QoS scheduling.

There are many more examples shown in the following chapters. Each of the documented sample applications show how to compile, configure and run the application as well as explaining the main functionality of the code.