2019-06-25 11:12:58 +00:00
|
|
|
.. SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
Copyright(c) 2010-2017 Intel Corporation.
|
2017-04-21 10:43:26 +00:00
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
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.
|
|
|
|
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
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.
|
2020-06-18 16:55:50 +00:00
|
|
|
Please refer to :doc:`EAL parameters (Linux) <../linux_gsg/linux_eal_parameters>`
|
|
|
|
or :doc:`EAL parameters (FreeBSD) <../freebsd_gsg/freebsd_eal_parameters>` for
|
|
|
|
a list of available EAL command-line options.
|
2019-06-25 11:12:58 +00:00
|
|
|
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
The DPDK Sample Applications
|
|
|
|
----------------------------
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
There are many sample applications available in the examples directory of DPDK.
|
2018-05-15 09:49:22 +00:00
|
|
|
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.
|
|
|
|
|
|
|
|
|
|
|
|
* :doc:`Hello World<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.
|
|
|
|
|
|
|
|
* :doc:`Basic Forwarding/Skeleton Application<skeleton>`: 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.
|
|
|
|
|
|
|
|
* :doc:`Network Layer 2 forwarding<l2_forward_real_virtual>`: The Network Layer 2
|
|
|
|
forwarding, or ``l2fwd`` application does forwarding based on Ethernet MAC
|
|
|
|
addresses like a simple switch.
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
* :doc:`Network Layer 2 forwarding<l2_forward_event>`: 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.
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
* :doc:`Network Layer 3 forwarding<l3_forward>`: The Network Layer3
|
|
|
|
forwarding, or ``l3fwd`` application does forwarding based on Internet
|
|
|
|
Protocol, IPv4 or IPv6 like a simple router.
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
* :doc:`Network Layer 3 forwarding Graph<l3_forward_graph>`: The Network Layer3
|
|
|
|
forwarding Graph, or ``l3fwd_graph`` application does forwarding based on IPv4
|
|
|
|
like a simple router with DPDK Graph framework.
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
* :doc:`Hardware packet copying<dma>`: The Hardware packet copying,
|
|
|
|
or ``dmafwd`` application demonstrates how to use DMAdev library for
|
2020-06-18 16:55:50 +00:00
|
|
|
copying packets between two threads.
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
* :doc:`Packet Distributor<dist_app>`: The Packet Distributor
|
|
|
|
demonstrates how to distribute packets arriving on an Rx port to different
|
|
|
|
cores for processing and transmission.
|
|
|
|
|
|
|
|
* :doc:`Multi-Process Application<multi_process>`: The
|
|
|
|
multi-process application shows how two DPDK processes can work together using
|
|
|
|
queues and memory pools to share information.
|
|
|
|
|
|
|
|
* :doc:`RX/TX callbacks Application<rxtx_callbacks>`: 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.
|
|
|
|
|
2019-06-26 10:17:41 +00:00
|
|
|
* :doc:`IPsec Security Gateway<ipsec_secgw>`: The IPsec Security
|
2018-05-15 09:49:22 +00:00
|
|
|
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.
|
|
|
|
|
|
|
|
* :doc:`Precision Time Protocol (PTP) client<ptpclient>`: 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.
|
|
|
|
|
|
|
|
* :doc:`Quality of Service (QoS) Scheduler<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.
|