2014-11-11 12:27:01 +00:00
|
|
|
.. BSD LICENSE
|
|
|
|
Copyright(c) 2010-2014 Intel Corporation. All rights reserved.
|
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
are met:
|
|
|
|
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in
|
|
|
|
the documentation and/or other materials provided with the
|
|
|
|
distribution.
|
|
|
|
* Neither the name of Intel Corporation nor the names of its
|
|
|
|
contributors may be used to endorse or promote products derived
|
|
|
|
from this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
L3 Forwarding in a Virtualization Environment Sample Application
|
|
|
|
================================================================
|
|
|
|
|
2014-12-18 10:51:19 +00:00
|
|
|
The L3 Forwarding in a Virtualization Environment sample application is a simple example of packet processing using the DPDK.
|
2014-11-11 12:27:01 +00:00
|
|
|
The application performs L3 forwarding that takes advantage of Single Root I/O Virtualization (SR-IOV) features
|
|
|
|
in a virtualized environment.
|
|
|
|
|
|
|
|
Overview
|
|
|
|
--------
|
|
|
|
|
2014-12-18 10:51:19 +00:00
|
|
|
The application demonstrates the use of the hash and LPM libraries in the DPDK to implement packet forwarding.
|
2016-02-25 18:02:27 +01:00
|
|
|
The initialization and run-time paths are very similar to those of the :doc:`l3_forward`.
|
2014-11-11 12:27:01 +00:00
|
|
|
The forwarding decision is taken based on information read from the input packet.
|
|
|
|
|
|
|
|
The lookup method is either hash-based or LPM-based and is selected at compile time.
|
|
|
|
When the selected lookup method is hash-based, a hash object is used to emulate the flow classification stage.
|
|
|
|
The hash object is used in correlation with the flow table to map each input packet to its flow at runtime.
|
|
|
|
|
|
|
|
The hash lookup key is represented by the DiffServ 5-tuple composed of the following fields read from the input packet:
|
|
|
|
Source IP Address, Destination IP Address, Protocol, Source Port and Destination Port.
|
|
|
|
The ID of the output interface for the input packet is read from the identified flow table entry.
|
|
|
|
The set of flows used by the application is statically configured and loaded into the hash at initialization time.
|
|
|
|
When the selected lookup method is LPM based, an LPM object is used to emulate the forwarding stage for IPv4 packets.
|
|
|
|
The LPM object is used as the routing table to identify the next hop for each input packet at runtime.
|
|
|
|
|
|
|
|
The LPM lookup key is represented by the Destination IP Address field read from the input packet.
|
|
|
|
The ID of the output interface for the input packet is the next hop returned by the LPM lookup.
|
|
|
|
The set of LPM rules used by the application is statically configured and loaded into the LPM object at the initialization time.
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
2016-02-25 18:02:27 +01:00
|
|
|
Please refer to :ref:`l2_fwd_vf_setup` for virtualized test case setup.
|
2014-11-11 12:27:01 +00:00
|
|
|
|
|
|
|
Compiling the Application
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
To compile the application:
|
|
|
|
|
|
|
|
#. Go to the sample application directory:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
export RTE_SDK=/path/to/rte_sdk
|
|
|
|
cd ${RTE_SDK}/examples/l3fwd-vf
|
|
|
|
|
|
|
|
#. Set the target (a default target is used if not specified). For example:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
export RTE_TARGET=x86_64-native-linuxapp-gcc
|
|
|
|
|
2014-12-18 10:51:19 +00:00
|
|
|
See the *DPDK Getting Started Guide* for possible RTE_TARGET values.
|
2014-11-11 12:27:01 +00:00
|
|
|
|
|
|
|
#. Build the application:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
make
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
|
|
The compiled application is written to the build subdirectory.
|
|
|
|
To have the application written to a different location,
|
|
|
|
the O=/path/to/build/directory option may be specified in the make command.
|
|
|
|
|
|
|
|
Running the Application
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
The application has a number of command line options:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
./build/l3fwd-vf [EAL options] -- -p PORTMASK --config(port,queue,lcore)[,(port,queue,lcore)] [--no-numa]
|
|
|
|
|
|
|
|
where,
|
|
|
|
|
|
|
|
* --p PORTMASK: Hexadecimal bitmask of ports to configure
|
|
|
|
|
|
|
|
* --config (port,queue,lcore)[,(port,queue,lcore]: determines which queues from which ports are mapped to which cores
|
|
|
|
|
|
|
|
* --no-numa: optional, disables numa awareness
|
|
|
|
|
2016-12-19 16:34:12 +00:00
|
|
|
For example, consider a dual processor socket platform with 8 physical cores, where cores 0-7 and 16-23 appear on socket 0,
|
|
|
|
while cores 8-15 and 24-31 appear on socket 1.
|
2014-11-11 12:27:01 +00:00
|
|
|
|
2016-12-19 16:34:12 +00:00
|
|
|
To enable L3 forwarding between two ports, assuming that both ports are in the same socket, using two cores, cores 1 and 2,
|
|
|
|
(which are in the same socket too), use the following command:
|
2014-11-11 12:27:01 +00:00
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
2016-12-19 16:34:12 +00:00
|
|
|
./build/l3fwd-vf -l 1,2 -n 4 -- -p 0x3 --config="(0,0,1),(1,0,2)"
|
2014-11-11 12:27:01 +00:00
|
|
|
|
|
|
|
In this command:
|
|
|
|
|
2016-12-19 16:34:12 +00:00
|
|
|
* The -l option enables cores 1 and 2
|
2014-11-11 12:27:01 +00:00
|
|
|
|
|
|
|
* The -p option enables ports 0 and 1
|
|
|
|
|
|
|
|
* The --config option enables one queue on each port and maps each (port,queue) pair to a specific core.
|
|
|
|
The following table shows the mapping in this example:
|
|
|
|
|
|
|
|
+----------+-----------+-----------+------------------------------------+
|
|
|
|
| **Port** | **Queue** | **lcore** | **Description** |
|
|
|
|
| | | | |
|
|
|
|
+==========+===========+===========+====================================+
|
2016-12-19 16:34:12 +00:00
|
|
|
| 0 | 0 | 1 | Map queue 0 from port 0 to lcore 1 |
|
2014-11-11 12:27:01 +00:00
|
|
|
| | | | |
|
|
|
|
+----------+-----------+-----------+------------------------------------+
|
2016-12-19 16:34:12 +00:00
|
|
|
| 1 | 0 | 2 | Map queue 0 from port 1 to lcore 2 |
|
2014-11-11 12:27:01 +00:00
|
|
|
| | | | |
|
|
|
|
+----------+-----------+-----------+------------------------------------+
|
|
|
|
|
2014-12-18 10:51:19 +00:00
|
|
|
Refer to the *DPDK Getting Started Guide* for general information on running applications
|
2014-11-11 12:27:01 +00:00
|
|
|
and the Environment Abstraction Layer (EAL) options.
|
|
|
|
|
|
|
|
Explanation
|
|
|
|
-----------
|
|
|
|
|
|
|
|
The operation of this application is similar to that of the basic L3 Forwarding Sample Application.
|
2016-02-25 18:02:27 +01:00
|
|
|
See :ref:`l3_fwd_explanation` for more information.
|