doc: getting started guide for linux
The 1.7 DPDK_Linux_GSG document in MSWord has been converted to rst format for use with Sphinx. There is an rst file for each chapter and an index.rst file which contains the table of contents. This is the first document from a set of documents. Signed-off-by: Bernard Iremonger <bernard.iremonger@intel.com>
This commit is contained in:
parent
b82da75977
commit
1ab07743b2
@ -1,3 +1,33 @@
|
|||||||
|
# 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.
|
||||||
|
|
||||||
import subprocess
|
import subprocess
|
||||||
|
|
||||||
project = 'DPDK'
|
project = 'DPDK'
|
||||||
|
@ -1,4 +1,40 @@
|
|||||||
|
.. 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.
|
||||||
|
|
||||||
DPDK documentation
|
DPDK documentation
|
||||||
==================
|
==================
|
||||||
|
|
||||||
|
Contents:
|
||||||
|
|
||||||
.. toctree::
|
.. toctree::
|
||||||
|
:maxdepth: 1
|
||||||
|
:titlesonly:
|
||||||
|
|
||||||
|
linux_gsg/index
|
||||||
|
270
doc/guides/linux_gsg/build_dpdk.rst
Executable file
270
doc/guides/linux_gsg/build_dpdk.rst
Executable file
@ -0,0 +1,270 @@
|
|||||||
|
.. 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.
|
||||||
|
|
||||||
|
Compiling the Intel® DPDK Target from Source
|
||||||
|
============================================
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
Parts of this process can also be done using the setup script described in Chapter 6 of this document.
|
||||||
|
|
||||||
|
Install the Intel® DPDK and Browse Sources
|
||||||
|
------------------------------------------
|
||||||
|
|
||||||
|
First, uncompress the archive and move to the uncompressed Intel® DPDK source directory:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
user@host:~$ unzip DPDK-<version>.zip
|
||||||
|
user@host:~$ cd DPDK-<version>
|
||||||
|
user@host:~/DPDK-<version>$ ls
|
||||||
|
app/ config/ examples/ lib/ LICENSE.GPL LICENSE.LGPL Makefile mk/ scripts/ tools/
|
||||||
|
|
||||||
|
The Intel® DPDK is composed of several directories:
|
||||||
|
|
||||||
|
* lib: Source code of Intel® DPDK libraries
|
||||||
|
|
||||||
|
* app: Source code of Intel® DPDK applications (automatic tests)
|
||||||
|
|
||||||
|
* examples: Source code of Intel® DPDK application examples
|
||||||
|
|
||||||
|
* config, tools, scripts, mk: Framework-related makefiles, scripts and configuration
|
||||||
|
|
||||||
|
Installation of Intel® DPDK Target Environments
|
||||||
|
-----------------------------------------------
|
||||||
|
|
||||||
|
The format of a Intel® DPDK target is:
|
||||||
|
|
||||||
|
ARCH-MACHINE-EXECENV-TOOLCHAIN
|
||||||
|
|
||||||
|
where:
|
||||||
|
|
||||||
|
* ARCH can be: i686, x86_64
|
||||||
|
|
||||||
|
* MACHINE can be: native, ivshmem
|
||||||
|
|
||||||
|
* EXECENV can be: linuxapp, bsdapp
|
||||||
|
|
||||||
|
* TOOLCHAIN can be: gcc, icc
|
||||||
|
|
||||||
|
The targets to be installed depend on the 32-bit and/or 64-bit packages and compilers installed on the host.
|
||||||
|
Available targets can be found in the DPDK/config directory.
|
||||||
|
The defconfig\_ prefix should not be used.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
Configuration files are provided with the RTE_MACHINE optimization level set.
|
||||||
|
Within the configuration files, the RTE_MACHINE configuration value is set to native,
|
||||||
|
which means that the compiled software is tuned for the platform on which it is built.
|
||||||
|
For more information on this setting, and its possible values, see the *Intel® DPDK Programmers Guide*.
|
||||||
|
|
||||||
|
When using the Intel® C++ Compiler (icc), one of the following commands should be invoked for 64-bit or 32-bit use respectively.
|
||||||
|
Notice that the shell scripts update the $PATH variable and therefore should not be performed in the same session.
|
||||||
|
Also, verify the compiler's installation directory since the path may be different:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
source /opt/intel/bin/iccvars.sh intel64
|
||||||
|
source /opt/intel/bin/iccvars.sh ia32
|
||||||
|
|
||||||
|
To install and make targets, use the make install T=<target> command in the top-level Intel® DPDK directory.
|
||||||
|
|
||||||
|
For example, to compile a 64-bit target using icc, run:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
make install T=x86_64-native-linuxapp-icc
|
||||||
|
|
||||||
|
To compile a 32-bit build using gcc, the make command should be:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
make install T=i686-native-linuxapp-gcc
|
||||||
|
|
||||||
|
To compile all 64-bit targets using gcc, use:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
make install T=x86_64*gcc
|
||||||
|
|
||||||
|
To compile all 64-bit targets using both gcc and icc, use:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
make install T=x86_64-*
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
The wildcard operator (*) can be used to create multiple targets at the same time.
|
||||||
|
|
||||||
|
To prepare a target without building it, for example, if the configuration changes need to be made before compilation,
|
||||||
|
use the make config T=<target> command:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
make config T=x86_64-native-linuxapp-gcc
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
The igb_uio module must be compiled with the same kernel as the one running on the target.
|
||||||
|
If the Intel® DPDK is not being built on the target machine,
|
||||||
|
the RTE_KERNELDIR environment variable should be used to point the compilation at a copy of the kernel version to be used on the target machine.
|
||||||
|
|
||||||
|
Once the target environment is created, the user may move to the target environment directory and continue to make code changes and re-compile.
|
||||||
|
The user may also make modifications to the compile-time Intel® DPDK configuration by editing the .config file in the build directory.
|
||||||
|
(This is a build-local copy of the defconfig file from the top- level config directory).
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
cd x86_64-native-linuxapp-gcc
|
||||||
|
vi .config
|
||||||
|
make
|
||||||
|
|
||||||
|
In addition, the make clean command can be used to remove any existing compiled files for a subsequent full, clean rebuild of the code.
|
||||||
|
|
||||||
|
Browsing the Installed Intel® DPDK Environment Target
|
||||||
|
-----------------------------------------------------
|
||||||
|
|
||||||
|
Once a target is created it contains all libraries and header files for the Intel® DPDK environment that are required to build customer applications.
|
||||||
|
In addition, the test and testpmd applications are built under the build/app directory, which may be used for testing.
|
||||||
|
In the case of Linux, a kmod directory is also present that contains a module to install:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ ls x86_64-native-linuxapp-gcc
|
||||||
|
app build hostapp include kmod lib Makefile
|
||||||
|
|
||||||
|
Loading the Intel® DPDK igb_uio Module
|
||||||
|
--------------------------------------
|
||||||
|
|
||||||
|
To run any Intel® DPDK application, the igb_uio module can be loaded into the running kernel.
|
||||||
|
The module is found in the kmod sub-directory of the Intel® DPDK target directory.
|
||||||
|
This module should be loaded using the insmod command as shown below (assuming that the current directory is the Intel® DPDK target directory).
|
||||||
|
In many cases, the uio support in the Linux* kernel is compiled as a module rather than as part of the kernel,
|
||||||
|
so it is often necessary to load the uio module first:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
sudo modprobe uio
|
||||||
|
sudo insmod kmod/igb_uio.ko
|
||||||
|
|
||||||
|
Since Intel® DPDK release 1.7 provides VFIO support, compilation and use of igb_uio module has become optional for platforms that support using VFIO.
|
||||||
|
|
||||||
|
Loading VFIO Module
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
To run an Intel® DPDK application and make use of VFIO, the vfio-pci module must be loaded:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
sudo modprobe vfio-pci
|
||||||
|
|
||||||
|
Note that in order to use VFIO, your kernel must support it.
|
||||||
|
VFIO kernel modules have been included in the Linux kernel since version 3.6.0 and are usually present by default,
|
||||||
|
however please consult your distributions documentation to make sure that is the case.
|
||||||
|
|
||||||
|
Also, to use VFIO, both kernel and BIOS must support and be configured to use IO virtualization (such as Intel® VT-d).
|
||||||
|
|
||||||
|
For proper operation of VFIO when running Intel® DPDK applications as a non-privileged user, correct permissions should also be set up.
|
||||||
|
This can be done by using the Intel® DPDK setup script (called setup.sh and located in the tools directory).
|
||||||
|
|
||||||
|
Binding and Unbinding Network Ports to/from the igb_uioor VFIO Modules
|
||||||
|
----------------------------------------------------------------------
|
||||||
|
|
||||||
|
As of release 1.4, Intel® DPDK applications no longer automatically unbind all supported network ports from the kernel driver in use.
|
||||||
|
Instead, all ports that are to be used by an Intel® DPDK application must be bound to the igb_uio or vfio-pci module before the application is run.
|
||||||
|
Any network ports under Linux* control will be ignored by the Intel® DPDK poll-mode drivers and cannot be used by the application.
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
The Intel® DPDK will, by default, no longer automatically unbind network ports from the kernel driver at startup.
|
||||||
|
Any ports to be used by an Intel® DPDK application must be unbound from Linux* control and bound to the igb_uio or vfio-pci module before the application is run.
|
||||||
|
|
||||||
|
To bind ports to the igb_uio or vfio-pci module for Intel® DPDK use, and then subsequently return ports to Linux* control,
|
||||||
|
a utility script called dpdk_nic _bind.py is provided in the tools subdirectory.
|
||||||
|
This utility can be used to provide a view of the current state of the network ports on the system,
|
||||||
|
and to bind and unbind those ports from the different kernel modules, including igb_uio and vfio-pci.
|
||||||
|
The following are some examples of how the script can be used.
|
||||||
|
A full description of the script and its parameters can be obtained by calling the script with the --help or --usage options.
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
Due to the way VFIO works, there are certain limitations to which devices can be used with VFIO.
|
||||||
|
Mainly it comes down to how IOMMU groups work.
|
||||||
|
Any Virtual Function device can be used with VFIO on its own, but physical devices will require either all ports bound to VFIO,
|
||||||
|
or some of them bound to VFIO while others not being bound to anything at all.
|
||||||
|
|
||||||
|
If your device is behind a PCI-to-PCI bridge, the bridge will then be part of the IOMMU group in which your device is in.
|
||||||
|
Therefore, the bridge driver should also be unbound from the bridge PCI device for VFIO to work with devices behind the bridge.
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
While any user can run the dpdk_nic_bind.py script to view the status of the network ports,
|
||||||
|
binding or unbinding network ports requires root privileges.
|
||||||
|
|
||||||
|
To see the status of all network ports on the system:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
root@host:DPDK# ./tools/dpdk_nic_bind.py --status
|
||||||
|
|
||||||
|
Network devices using IGB_UIO driver
|
||||||
|
====================================
|
||||||
|
0000:82:00.0 '82599EB 10-Gigabit SFI/SFP+ Network Connection' drv=igb_uio unused=ixgbe
|
||||||
|
0000:82:00.1 '82599EB 10-Gigabit SFI/SFP+ Network Connection' drv=igb_uio unused=ixgbe
|
||||||
|
|
||||||
|
Network devices using kernel driver
|
||||||
|
===================================
|
||||||
|
0000:04:00.0 'I350 Gigabit Network Connection' if=em0 drv=igb unused=igb_uio *Active*
|
||||||
|
0000:04:00.1 'I350 Gigabit Network Connection' if=eth1 drv=igb unused=igb_uio
|
||||||
|
0000:04:00.2 'I350 Gigabit Network Connection' if=eth2 drv=igb unused=igb_uio
|
||||||
|
0000:04:00.3 'I350 Gigabit Network Connection' if=eth3 drv=igb unused=igb_uio
|
||||||
|
|
||||||
|
Other network devices
|
||||||
|
=====================
|
||||||
|
<none>
|
||||||
|
|
||||||
|
To bind device eth1, 04:00.1, to the igb_uio driver:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
root@host:DPDK# ./tools/dpdk_nic_bind.py --bind=igb_uio 04:00.1
|
||||||
|
|
||||||
|
or, alternatively,
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
root@host:DPDK# ./tools/dpdk_nic_bind.py --bind=igb_uio eth1
|
||||||
|
|
||||||
|
To restore device 82:00.0 to its original kernel binding:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
root@host:DPDK# ./tools/dpdk_nic_bind.py --bind=ixgbe 82:00.0
|
233
doc/guides/linux_gsg/build_sample_apps.rst
Executable file
233
doc/guides/linux_gsg/build_sample_apps.rst
Executable file
@ -0,0 +1,233 @@
|
|||||||
|
.. 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.
|
||||||
|
|
||||||
|
Compiling and Running Sample Applications
|
||||||
|
=========================================
|
||||||
|
|
||||||
|
The chapter describes how to compile and run applications in an Intel® DPDK environment.
|
||||||
|
It also provides a pointer to where sample applications are stored.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
Parts of this process can also be done using the setup script described in **Chapter 6** of this document.
|
||||||
|
|
||||||
|
Compiling a Sample Application
|
||||||
|
------------------------------
|
||||||
|
|
||||||
|
Once an Intel® DPDK target environment directory has been created (such as x86_64-native-linuxapp-gcc),
|
||||||
|
it contains all libraries and header files required to build an application.
|
||||||
|
|
||||||
|
When compiling an application in the Linux* environment on the Intel® DPDK, the following variables must be exported:
|
||||||
|
|
||||||
|
* RTE_SDK - Points to the Intel® DPDK installation directory.
|
||||||
|
|
||||||
|
* RTE_TARGET - Points to the Intel® DPDK target environment directory.
|
||||||
|
|
||||||
|
The following is an example of creating the helloworld application, which runs in the Intel® DPDK Linux environment.
|
||||||
|
This example may be found in the ${RTE_SDK}/examples directory.
|
||||||
|
|
||||||
|
The directory contains the main.c file. This file, when combined with the libraries in the Intel® DPDK target environment,
|
||||||
|
calls the various functions to initialize the Intel® DPDK environment,
|
||||||
|
then launches an entry point (dispatch application) for each core to be utilized.
|
||||||
|
By default, the binary is generated in the build directory.
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
user@host:~/DPDK$ cd examples/helloworld/
|
||||||
|
user@host:~/DPDK/examples/helloworld$ export RTE_SDK=$HOME/DPDK
|
||||||
|
user@host:~/DPDK/examples/helloworld$ export RTE_TARGET=x86_64-native-linuxapp-gcc
|
||||||
|
user@host:~/DPDK/examples/helloworld$ make
|
||||||
|
CC main.o
|
||||||
|
LD helloworld
|
||||||
|
INSTALL-APP helloworld
|
||||||
|
INSTALL-MAP helloworld.map
|
||||||
|
|
||||||
|
user@host:~/DPDK/examples/helloworld$ ls build/app
|
||||||
|
helloworld helloworld.map
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
In the above example, helloworld was in the directory structure of the Intel® DPDK.
|
||||||
|
However, it could have been located outside the directory structure to keep the Intel® DPDK structure intact.
|
||||||
|
In the following case, the helloworld application is copied to a new directory as a new starting point.
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
user@host:~$ export RTE_SDK=/home/user/DPDK
|
||||||
|
user@host:~$ cp -r $(RTE_SDK)/examples/helloworld my_rte_app
|
||||||
|
user@host:~$ cd my_rte_app/
|
||||||
|
user@host:~$ export RTE_TARGET=x86_64-native-linuxapp-gcc
|
||||||
|
user@host:~/my_rte_app$ make
|
||||||
|
CC main.o
|
||||||
|
LD helloworld
|
||||||
|
INSTALL-APP helloworld
|
||||||
|
INSTALL-MAP helloworld.map
|
||||||
|
|
||||||
|
Running a Sample Application
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
The UIO drivers and hugepages must be setup prior to running an application.
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
Any ports to be used by the application must be already bound to the igb_uio module, as described in Section 3.5, prior to running the application.
|
||||||
|
|
||||||
|
The application is linked with the Intel® DPDK target environment's Environmental Abstraction Layer (EAL) library,
|
||||||
|
which provides some options that are generic to every Intel® DPDK application.
|
||||||
|
|
||||||
|
The following is the list of options that can be given to the EAL:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
./rte-app -c COREMASK -n NUM [-b <domain:bus:devid.func>] [--socket-mem=MB,...] [-m MB] [-r NUM] [-v] [--file-prefix] [--proc-type <primary|secondary|auto>] [-- xen-dom0]
|
||||||
|
|
||||||
|
The EAL options are as follows:
|
||||||
|
|
||||||
|
* -c COREMASK: An hexadecimal bit mask of the cores to run on. Note that core numbering can change between platforms and should be determined beforehand.
|
||||||
|
|
||||||
|
* -n NUM: Number of memory channels per processor socket
|
||||||
|
|
||||||
|
* -b <domain:bus:devid.func>: blacklisting of ports; prevent EAL from using specified PCI device (multiple -b options are allowed)
|
||||||
|
|
||||||
|
* --use-device: use the specified ethernet device(s) only. Use comma-separate <[domain:]bus:devid.func> values. Cannot be used with -b option
|
||||||
|
|
||||||
|
* --socket-mem: Memory to allocate from hugepages on specific sockets
|
||||||
|
|
||||||
|
* -m MB: Memory to allocate from hugepages, regardless of processor socket. It is recommended that --socket-mem be used instead of this option.
|
||||||
|
|
||||||
|
* -r NUM: Number of memory ranks
|
||||||
|
|
||||||
|
* -v: Display version information on startup
|
||||||
|
|
||||||
|
* --huge-dir: The directory where hugetlbfs is mounted
|
||||||
|
|
||||||
|
* --file-prefix: The prefix text used for hugepage filenames
|
||||||
|
|
||||||
|
* --proc-type: The type of process instance
|
||||||
|
|
||||||
|
* --xen-dom0: Support application running on Xen Domain0 without hugetlbfs
|
||||||
|
|
||||||
|
* --vmware-tsc-map: use VMware TSC map instead of native RDTSC
|
||||||
|
|
||||||
|
* --base-virtaddr: specify base virtual address
|
||||||
|
|
||||||
|
* --vfio-intr: specify interrupt type to be used by VFIO (has no effect if VFIO is not used)
|
||||||
|
|
||||||
|
The -c and the -n options are mandatory; the others are optional.
|
||||||
|
|
||||||
|
Copy the Intel® DPDK application binary to your target, then run the application as follows
|
||||||
|
(assuming the platform has four memory channels per processor socket,
|
||||||
|
and that cores 0-3 are present and are to be used for running the application):
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
user@target:~$ ./helloworld -c f -n 4
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
The --proc-type and --file-prefix EAL options are used for running multiple Intel® DPDK processes.
|
||||||
|
See the “Multi-process Sample Application” chapter in the *Intel® DPDK Sample Applications User Guide* and
|
||||||
|
the *Intel® DPDK Programmers Guide* for more details.
|
||||||
|
|
||||||
|
Logical Core Use by Applications
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The coremask parameter is always mandatory for Intel® DPDK applications.
|
||||||
|
Each bit of the mask corresponds to the equivalent logical core number as reported by Linux.
|
||||||
|
Since these logical core numbers, and their mapping to specific cores on specific NUMA sockets, can vary from platform to platform,
|
||||||
|
it is recommended that the core layout for each platform be considered when choosing the coremask to use in each case.
|
||||||
|
|
||||||
|
On initialization of the EAL layer by an Intel® DPDK application, the logical cores to be used and their socket location are displayed.
|
||||||
|
This information can also be determined for all cores on the system by examining the /proc/cpuinfo file, for example, by running cat /proc/cpuinfo.
|
||||||
|
The physical id attribute listed for each processor indicates the CPU socket to which it belongs.
|
||||||
|
This can be useful when using other processors to understand the mapping of the logical cores to the sockets.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
A more graphical view of the logical core layout may be obtained using the lstopo Linux utility.
|
||||||
|
On Fedora* 18, this may be installed and run using the following command:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
sudo yum install hwloc
|
||||||
|
./lstopo
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
The logical core layout can change between different board layouts and should be checked before selecting an application coremask.
|
||||||
|
|
||||||
|
Hugepage Memory Use by Applications
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
When running an application, it is recommended to use the same amount of memory as that allocated for hugepages.
|
||||||
|
This is done automatically by the Intel® DPDK application at startup,
|
||||||
|
if no -m or --socket-mem parameter is passed to it when run.
|
||||||
|
|
||||||
|
If more memory is requested by explicitly passing a -m or --socket-mem value, the application fails.
|
||||||
|
However, the application itself can also fail if the user requests less memory than the reserved amount of hugepage-memory, particularly if using the -m option.
|
||||||
|
The reason is as follows.
|
||||||
|
Suppose the system has 1024 reserved 2 MB pages in socket 0 and 1024 in socket 1.
|
||||||
|
If the user requests 128 MB of memory, the 64 pages may not match the constraints:
|
||||||
|
|
||||||
|
* The hugepage memory by be given to the application by the kernel in socket 1 only.
|
||||||
|
In this case, if the application attempts to create an object, such as a ring or memory pool in socket 0, it fails.
|
||||||
|
To avoid this issue, it is recommended that the -- socket-mem option be used instead of the -m option.
|
||||||
|
|
||||||
|
* These pages can be located anywhere in physical memory, and, although the Intel® DPDK EAL will attempt to allocate memory in contiguous blocks,
|
||||||
|
it is possible that the pages will not be contiguous. In this case, the application is not able to allocate big memory pools.
|
||||||
|
|
||||||
|
The socket-mem option can be used to request specific amounts of memory for specific sockets.
|
||||||
|
This is accomplished by supplying the --socket-mem flag followed by amounts of memory requested on each socket,
|
||||||
|
for example, supply --socket-mem=0,512 to try and reserve 512 MB for socket 1 only.
|
||||||
|
Similarly, on a four socket system, to allocate 1 GB memory on each of sockets 0 and 2 only, the parameter --socket-mem=1024,0,1024 can be used.
|
||||||
|
No memory will be reserved on any CPU socket that is not explicitly referenced, for example, socket 3 in this case.
|
||||||
|
If the Intel® DPDK cannot allocate enough memory on each socket, the EAL initialization fails.
|
||||||
|
|
||||||
|
Additional Sample Applications
|
||||||
|
------------------------------
|
||||||
|
|
||||||
|
Additional sample applications are included in the ${RTE_SDK}/examples directory.
|
||||||
|
These sample applications may be built and run in a manner similar to that described in earlier sections in this manual.
|
||||||
|
In addition, see the *Intel® DPDK Sample Applications User Guide* for a description of the application,
|
||||||
|
specific instructions on compilation and execution and some explanation of the code.
|
||||||
|
|
||||||
|
Additional Test Applications
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
In addition, there are two other applications that are built when the libraries are created.
|
||||||
|
The source files for these are in the DPDK/app directory and are called test and testpmd.
|
||||||
|
Once the libraries are created, they can be found in the build/app directory.
|
||||||
|
|
||||||
|
* The test application provides a variety of specific tests for the various functions in the Intel® DPDK.
|
||||||
|
|
||||||
|
* The testpmd application provides a number of different packet throughput tests and
|
||||||
|
examples of features such as how to use the Flow Director found in the Intel® 82599 10 Gigabit Ethernet Controller.
|
200
doc/guides/linux_gsg/enable_func.rst
Executable file
200
doc/guides/linux_gsg/enable_func.rst
Executable file
@ -0,0 +1,200 @@
|
|||||||
|
.. 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.
|
||||||
|
|
||||||
|
.. _Enabling_Additional_Functionality:
|
||||||
|
|
||||||
|
Enabling Additional Functionality
|
||||||
|
=================================
|
||||||
|
|
||||||
|
.. _High_Precision_Event_Timer:
|
||||||
|
|
||||||
|
High Precision Event Timer HPET) Functionality
|
||||||
|
----------------------------------------------
|
||||||
|
|
||||||
|
BIOS Support
|
||||||
|
~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The High Precision Timer (HPET) must be enabled in the platform BIOS if the HPET is to be used.
|
||||||
|
Otherwise, the Time Stamp Counter (TSC) is used by default.
|
||||||
|
The BIOS is typically accessed by pressing F2 while the platform is starting up.
|
||||||
|
The user can then navigate to the HPET option. On the Crystal Forest platform BIOS, the path is:
|
||||||
|
**Advanced -> PCH-IO Configuration -> High Precision Timer ->** (Change from Disabled to Enabled if necessary).
|
||||||
|
|
||||||
|
On a system that has already booted, the following command can be issued to check if HPET is enabled:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
# grep hpet /proc/timer_list
|
||||||
|
|
||||||
|
If no entries are returned, HPET must be enabled in the BIOS (as per the instructions above) and the system rebooted.
|
||||||
|
|
||||||
|
Linux Kernel Support
|
||||||
|
~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The Intel® DPDK makes use of the platform HPET timer by mapping the timer counter into the process address space, and as such,
|
||||||
|
requires that the HPET_MMAP kernel configuration option be enabled.
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
On Fedora*, and other common distributions such as Ubuntu*, the HPET_MMAP kernel option is not enabled by default.
|
||||||
|
To recompile the Linux kernel with this option enabled, please consult the distributions documentation for the relevant instructions.
|
||||||
|
|
||||||
|
Enabling HPET in the Intel® DPDK
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
By default, HPET support is disabled in the Intel® DPDK build configuration files.
|
||||||
|
To use HPET, the CONFIG_RTE_LIBEAL_USE_HPET setting should be changed to “y”, which will enable the HPET settings at compile time.
|
||||||
|
|
||||||
|
For an application to use the rte_get_hpet_cycles() and rte_get_hpet_hz() API calls,
|
||||||
|
and optionally to make the HPET the default time source for the rte_timer library,
|
||||||
|
the new rte_eal_hpet_init() API call should be called at application initialization.
|
||||||
|
This API call will ensure that the HPET is accessible, returning an error to the application if it is not,
|
||||||
|
for example, if HPET_MMAP is not enabled in the kernel.
|
||||||
|
The application can then determine what action to take, if any, if the HPET is not available at run-time.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
For applications that require timing APIs, but not the HPET timer specifically,
|
||||||
|
it is recommended that the rte_get_timer_cycles() and rte_get_timer_hz() API calls be used instead of the HPET-specific APIs.
|
||||||
|
These generic APIs can work with either TSC or HPET time sources, depending on what is requested by an application call to rte_eal_hpet_init(),
|
||||||
|
if any, and on what is available on the system at runtime.
|
||||||
|
|
||||||
|
Running Intel® DPDK Applications Without Root Privileges
|
||||||
|
--------------------------------------------------------
|
||||||
|
|
||||||
|
Although applications using the Intel® DPDK use network ports and other hardware resources directly,
|
||||||
|
with a number of small permission adjustments it is possible to run these applications as a user other than “root”.
|
||||||
|
To do so, the ownership, or permissions, on the following Linux file system objects should be adjusted to ensure that
|
||||||
|
the Linux user account being used to run the Intel® DPDK application has access to them:
|
||||||
|
|
||||||
|
* All directories which serve as hugepage mount points, for example, /mnt/huge
|
||||||
|
|
||||||
|
* The userspace-io device files in /dev, for example, /dev/uio0, /dev/uio1, and so on
|
||||||
|
|
||||||
|
* If the HPET is to be used, /dev/hpet
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
On some Linux installations, /dev/hugepages is also a hugepage mount point created by default.
|
||||||
|
|
||||||
|
Power Management and Power Saving Functionality
|
||||||
|
-----------------------------------------------
|
||||||
|
|
||||||
|
Enhanced Intel SpeedStep® Technology must be enabled in the platform BIOS if the power management feature of Intel® DPDK is to be used.
|
||||||
|
Otherwise, the sys file folder /sys/devices/system/cpu/cpu0/cpufreq will not exist, and the CPU frequency- based power management cannot be used.
|
||||||
|
Consult the relevant BIOS documentation to determine how these settings can be accessed.
|
||||||
|
|
||||||
|
For example, on some Intel reference platform BIOS variants, the path to Enhanced Intel SpeedStep® Technology is:
|
||||||
|
|
||||||
|
**Advanced->Processor Configuration->Enhanced Intel SpeedStep® Tech**
|
||||||
|
|
||||||
|
In addition, C3 and C6 should be enabled as well for power management. The path of C3 and C6 on the same platform BIOS is:
|
||||||
|
|
||||||
|
**Advanced->Processor Configuration->Processor C3 Advanced->Processor Configuration-> Processor C6**
|
||||||
|
|
||||||
|
Using Linux* Core Isolation to Reduce Context Switches
|
||||||
|
------------------------------------------------------
|
||||||
|
|
||||||
|
While the threads used by an Intel® DPDK application are pinned to logical cores on the system,
|
||||||
|
it is possible for the Linux scheduler to run other tasks on those cores also.
|
||||||
|
To help prevent additional workloads from running on those cores,
|
||||||
|
it is possible to use the isolcpus Linux* kernel parameter to isolate them from the general Linux scheduler.
|
||||||
|
|
||||||
|
For example, if Intel® DPDK applications are to run on logical cores 2, 4 and 6,
|
||||||
|
the following should be added to the kernel parameter list:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
isolcpus=2,4,6
|
||||||
|
|
||||||
|
Loading the Intel® DPDK KNI Kernel Module
|
||||||
|
-----------------------------------------
|
||||||
|
|
||||||
|
To run the Intel® DPDK Kernel NIC Interface (KNI) sample application, an extra kernel module (the kni module) must be loaded into the running kernel.
|
||||||
|
The module is found in the kmod sub-directory of the Intel® DPDK target directory.
|
||||||
|
Similar to the loading of the igb_uio module, this module should be loaded using the insmod command as shown below
|
||||||
|
(assuming that the current directory is the Intel® DPDK target directory):
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
#insmod kmod/rte_kni.ko
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
See the “Kernel NIC Interface Sample Application” chapter in the *Intel® DPDK Sample Applications User Guide* for more details.
|
||||||
|
|
||||||
|
Using Linux IOMMU Pass-Through to Run Intel® DPDK with Intel® VT-d
|
||||||
|
------------------------------------------------------------------
|
||||||
|
|
||||||
|
To enable Intel® VT-d in a Linux kernel, a number of kernel configuration options must be set. These include:
|
||||||
|
|
||||||
|
* IOMMU_SUPPORT
|
||||||
|
|
||||||
|
* IOMMU_API
|
||||||
|
|
||||||
|
* INTEL_IOMMU
|
||||||
|
|
||||||
|
In addition, to run the Intel® DPDK with Intel® VT-d, the iommu=pt kernel parameter must be used when using igb_uio driver.
|
||||||
|
This results in pass-through of the DMAR (DMA Remapping) lookup in the host.
|
||||||
|
Also, if INTEL_IOMMU_DEFAULT_ON is not set in the kernel, the intel_iommu=on kernel parameter must be used too.
|
||||||
|
This ensures that the Intel IOMMU is being initialized as expected.
|
||||||
|
|
||||||
|
Please note that while using iommu=pt is compulsory for igb_uio driver, the vfio-pci driver can actually work with both iommu=pt and iommu=on.
|
||||||
|
|
||||||
|
High Performance of Small Packets on 40G NIC
|
||||||
|
--------------------------------------------
|
||||||
|
|
||||||
|
Enabling Extended Tag and Setting Max Read Request Size
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
PCI configurations of extended_tag and max _read_requ st_size have big impacts on performance of small packets on 40G NIC.
|
||||||
|
Enabling extended_tag and setting max _read_requ st_size to small size such as 128 bytes provide great helps to high performance of small packets.
|
||||||
|
|
||||||
|
* These can be done in some BIOS implementations.
|
||||||
|
|
||||||
|
* For other BIOS implementations, PCI configurations can be changed by using command of setpci, or special configurations in DPDK config file of common_linux.
|
||||||
|
|
||||||
|
* Bits 7:5 at address of 0xA8 of each PCI device is used for setting the max_read_request_size,
|
||||||
|
and bit 8 of 0xA8 of each PCI device is used for enabling/disabling the extended_tag.
|
||||||
|
lspci and setpci can be used to read the values of 0xA8 and then write it back after being changed.
|
||||||
|
|
||||||
|
* In config file of common_linux, below three configurations can be changed for the same purpose.
|
||||||
|
|
||||||
|
CONFIG_RTE_PCI_CONFIG
|
||||||
|
|
||||||
|
CONFIG_RTE_PCI_EXTENDED_TAG
|
||||||
|
|
||||||
|
CONFIG_RTE_PCI_MAX_READ_REQUEST_SIZE
|
||||||
|
|
||||||
|
Use 16 Bytes RX Descriptor Size
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
As i40e PMD supports both 16 and 32 bytes RX descriptor sizes, and 16 bytes size can provide helps to high performance of small packets.
|
||||||
|
Configuration of CONFIG_RTE_LIBRTE_I40E_16BYTE_RX_DESC in config files can be changed to use 16 bytes size RX descriptors.
|
85
doc/guides/linux_gsg/index.rst
Executable file
85
doc/guides/linux_gsg/index.rst
Executable file
@ -0,0 +1,85 @@
|
|||||||
|
.. 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.
|
||||||
|
|
||||||
|
Getting Started Guide
|
||||||
|
=====================
|
||||||
|
|
||||||
|
June 2014
|
||||||
|
|
||||||
|
INFORMATION IN THIS DOCUMENT IS PROVIDED IN CONNECTION WITH INTEL PRODUCTS.
|
||||||
|
NO LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE, TO ANY INTELLECTUAL PROPERTY RIGHTS IS GRANTED BY THIS DOCUMENT.
|
||||||
|
EXCEPT AS PROVIDED IN INTEL'S TERMS AND CONDITIONS OF SALE FOR SUCH PRODUCTS, INTEL ASSUMES NO LIABILITY WHATSOEVER AND INTEL DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY,
|
||||||
|
RELATING TO SALE AND/OR USE OF INTEL PRODUCTS INCLUDING LIABILITY OR WARRANTIES RELATING TO FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR INFRINGEMENT OF ANY PATENT,
|
||||||
|
COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT.
|
||||||
|
|
||||||
|
A “Mission Critical Application” is any application in which failure of the Intel Product could result, directly or indirectly, in personal injury or death.
|
||||||
|
SHOULD YOU PURCHASE OR USE INTEL'S PRODUCTS FOR ANY SUCH MISSION CRITICAL APPLICATION, YOU SHALL INDEMNIFY AND HOLD INTEL AND ITS SUBSIDIARIES, SUBCONTRACTORS AND AFFILIATES,
|
||||||
|
AND THE DIRECTORS, OFFICERS, AND EMPLOYEES OF EACH, HARMLESS AGAINST ALL CLAIMS COSTS, DAMAGES, AND EXPENSES AND REASONABLE ATTORNEYS' FEES ARISING OUT OF, DIRECTLY OR INDIRECTLY,
|
||||||
|
ANY CLAIM OF PRODUCT LIABILITY, PERSONAL INJURY, OR DEATH ARISING IN ANY WAY OUT OF SUCH MISSION CRITICAL APPLICATION, WHETHER OR NOT INTEL OR
|
||||||
|
ITS SUBCONTRACTOR WAS NEGLIGENT IN THE DESIGN, MANUFACTURE, OR WARNING OF THE INTEL PRODUCT OR ANY OF ITS PARTS.
|
||||||
|
|
||||||
|
Intel may make changes to specifications and product descriptions at any time, without notice.
|
||||||
|
Designers must not rely on the absence or characteristics of any features or instructions marked “reserved” or “undefined.”
|
||||||
|
Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them.
|
||||||
|
The information here is subject to change without notice. Do not finalize a design with this information.
|
||||||
|
|
||||||
|
The products described in this document may contain design defects or errors known as errata which may cause the product to deviate from published specifications.
|
||||||
|
Current characterized errata are available on request.
|
||||||
|
|
||||||
|
Contact your local Intel sales office or your distributor to obtain the latest specifications and before placing your product order.
|
||||||
|
|
||||||
|
Copies of documents which have an order number and are referenced in this document, or other Intel literature, may be obtained by calling 1-800-548-4725,
|
||||||
|
or go to: http://www.intel.com/design/literature.htm
|
||||||
|
|
||||||
|
Any software source code reprinted in this document is furnished for informational purposes only and may only be used or copied and no license,
|
||||||
|
express or implied, by estoppel or otherwise, to any of the reprinted source code is granted by this document.
|
||||||
|
|
||||||
|
Code Names are only for use by Intel to identify products, platforms, programs, services, etc. (“products”) in development by Intel
|
||||||
|
that have not been made commercially available to the public, i.e., announced, launched or shipped.
|
||||||
|
They are never to be used as “commercial” names for products. Also, they are not intended to function as trademarks.
|
||||||
|
|
||||||
|
Intel and the Intel logo are trademarks of Intel Corporation in the U.S. and/or other countries.
|
||||||
|
|
||||||
|
\*Other names and brands may be claimed as the property of others.
|
||||||
|
|
||||||
|
Copyright © 2012-2014, Intel Corporation. All rights reserved.
|
||||||
|
|
||||||
|
Contents
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 2
|
||||||
|
:numbered:
|
||||||
|
|
||||||
|
intro
|
||||||
|
sys_reqs
|
||||||
|
build_dpdk
|
||||||
|
build_sample_apps
|
||||||
|
enable_func
|
||||||
|
quick_start
|
67
doc/guides/linux_gsg/intro.rst
Executable file
67
doc/guides/linux_gsg/intro.rst
Executable file
@ -0,0 +1,67 @@
|
|||||||
|
.. 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.
|
||||||
|
|
||||||
|
Introduction
|
||||||
|
============
|
||||||
|
|
||||||
|
This document contains instructions for installing and configuring the Intel® Data Plane Development Kit (Intel® DPDK) software.
|
||||||
|
It is designed to get customers up and running quickly.
|
||||||
|
The document describes how to compile and run an Intel® DPDK application in a Linux* application (linuxapp) environment,
|
||||||
|
without going deeply into detail.
|
||||||
|
|
||||||
|
Documentation Roadmap
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
The following is a list of Intel® DPDK documents in the suggested reading order:
|
||||||
|
|
||||||
|
* Release Notes: Provides release-specific information, including supported features, limitations, fixed issues, known issues and so on.
|
||||||
|
Also, provides the answers to frequently asked questions in FAQ format.
|
||||||
|
|
||||||
|
* Getting Started Guide (this document): Describes how to install and configure the Intel® DPDK; designed to get users up and running quickly with the software.
|
||||||
|
|
||||||
|
* Programmer's Guide: Describes:
|
||||||
|
|
||||||
|
* The software architecture and how to use it (through examples), specifically in a Linux* application (linuxapp) environment
|
||||||
|
|
||||||
|
* The content of the Intel® DPDK, the build system (including the commands that can be used in the root Intel® DPDK Makefile to build the development kit and
|
||||||
|
an application) and guidelines for porting an application
|
||||||
|
|
||||||
|
* Optimizations used in the software and those that should be considered for new development
|
||||||
|
|
||||||
|
A glossary of terms is also provided.
|
||||||
|
|
||||||
|
* API Reference: Provides detailed information about Intel® DPDK functions, data structures and other programming constructs.
|
||||||
|
|
||||||
|
* Sample Applications User Guide: Describes a set of sample applications.
|
||||||
|
Each chapter describes a sample application that showcases specific functionality and provides instructions on how to compile, run and use the sample application.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
These documents are available for download as a separate documentation package at the same location as the Intel® DPDK code package.
|
328
doc/guides/linux_gsg/quick_start.rst
Executable file
328
doc/guides/linux_gsg/quick_start.rst
Executable file
@ -0,0 +1,328 @@
|
|||||||
|
.. 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.
|
||||||
|
|
||||||
|
Quick Start Setup Script
|
||||||
|
========================
|
||||||
|
|
||||||
|
The setup.sh script, found in the tools subdirectory, allows the user to perform the following tasks:
|
||||||
|
|
||||||
|
* Build the Intel® DPDK libraries
|
||||||
|
|
||||||
|
* Insert and remove the Intel® DPDK IGB_UIO kernel module
|
||||||
|
|
||||||
|
* Insert and remove VFIO kernel modules
|
||||||
|
|
||||||
|
* Insert and remove the Intel® DPDK KNI kernel module
|
||||||
|
|
||||||
|
* Create and delete hugepages for NUMA and non-NUMA cases
|
||||||
|
|
||||||
|
* View network port status and reserve ports for Intel® DPDK application use
|
||||||
|
|
||||||
|
* Set up permissions for using VFIO as a non-privileged user
|
||||||
|
|
||||||
|
* Run the test and testpmd applications
|
||||||
|
|
||||||
|
* Look at hugepages in the meminfo
|
||||||
|
|
||||||
|
* List hugepages in /mnt/huge
|
||||||
|
|
||||||
|
* Remove built Intel® DPDK libraries
|
||||||
|
|
||||||
|
Once these steps have been completed for one of the EAL targets,
|
||||||
|
the user may compile their own application that links in the EAL libraries to create the Intel® DPDK image.
|
||||||
|
|
||||||
|
Script Organization
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
The setup.sh script is logically organized into a series of steps that a user performs in sequence.
|
||||||
|
Each step provides a number of options that guide the user to completing the desired task.
|
||||||
|
The following is a brief synopsis of each step.
|
||||||
|
|
||||||
|
**Step 1: Build DPDK Libraries**
|
||||||
|
|
||||||
|
Initially, the user must select an Intel® DPDK target to choose the correct target type and compiler options to use when building the libraries.
|
||||||
|
|
||||||
|
The user must have all libraries, modules, updates and compilers installed in the system prior to this,
|
||||||
|
as described in the earlier chapters in this Getting Started Guide.
|
||||||
|
|
||||||
|
**Step 2: Setup Environment**
|
||||||
|
|
||||||
|
The user configures the Linux* environment to support the running of Intel® DPDK applications.
|
||||||
|
Hugepages can be set up for NUMA or non-NUMA systems. Any existing hugepages will be removed.
|
||||||
|
The Intel® DPDK kernel module that is needed can also be inserted in this step,
|
||||||
|
and network ports may be bound to this module for Intel® DPDK application use.
|
||||||
|
|
||||||
|
**Step 3: Run an Application**
|
||||||
|
|
||||||
|
The user may run the test application once the other steps have been performed.
|
||||||
|
The test application allows the user to run a series of functional tests for the Intel® DPDK.
|
||||||
|
The testpmd application, which supports the receiving and sending of packets, can also be run.
|
||||||
|
|
||||||
|
**Step 4: Examining the System**
|
||||||
|
|
||||||
|
This step provides some tools for examining the status of hugepage mappings.
|
||||||
|
|
||||||
|
**Step 5: System Cleanup**
|
||||||
|
|
||||||
|
The final step has options for restoring the system to its original state.
|
||||||
|
|
||||||
|
Use Cases
|
||||||
|
---------
|
||||||
|
|
||||||
|
The following are some example of how to use the setup.sh script.
|
||||||
|
The script should be run using the source command.
|
||||||
|
Some options in the script prompt the user for further data before proceeding.
|
||||||
|
|
||||||
|
.. warning::
|
||||||
|
|
||||||
|
The setup.sh script should be run with root privileges.
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
user@host:~/rte$ source tools/setup.sh
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
RTE_SDK exported as /home/user/rte
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Step 1: Select the DPDK environment to build
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
[1] i686-native-linuxapp-gcc
|
||||||
|
|
||||||
|
[2] i686-native-linuxapp-icc
|
||||||
|
|
||||||
|
[3] x86_64-ivshmem-linuxapp-gcc
|
||||||
|
|
||||||
|
[4] x86_64-ivshmem-linuxapp-icc
|
||||||
|
|
||||||
|
[5] x86_64-native-bsdapp-gcc
|
||||||
|
|
||||||
|
[6] x86_64-native-linuxapp-gcc
|
||||||
|
|
||||||
|
[7] x86_64-native-linuxapp-icc
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Step 2: Setup linuxapp environment
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
[8] Insert IGB UIO module
|
||||||
|
|
||||||
|
[9] Insert VFIO module
|
||||||
|
|
||||||
|
[10] Insert KNI module
|
||||||
|
|
||||||
|
[11] Setup hugepage mappings for non-NUMA systems
|
||||||
|
|
||||||
|
[12] Setup hugepage mappings for NUMA systems
|
||||||
|
|
||||||
|
[13] Display current Ethernet device settings
|
||||||
|
|
||||||
|
[14] Bind Ethernet device to IGB UIO module
|
||||||
|
|
||||||
|
[15] Bind Ethernet device to VFIO module
|
||||||
|
|
||||||
|
[16] Setup VFIO permissions
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Step 3: Run test application for linuxapp environment
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
[17] Run test application ($RTE_TARGET/app/test)
|
||||||
|
|
||||||
|
[18] Run testpmd application in interactive mode ($RTE_TARGET/app/testpmd)
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Step 4: Other tools
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
[19] List hugepage info from /proc/meminfo
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Step 5: Uninstall and system cleanup
|
||||||
|
|
||||||
|
------------------------------------------------------------------------
|
||||||
|
|
||||||
|
[20] Uninstall all targets
|
||||||
|
|
||||||
|
[21] Unbind NICs from IGB UIO driver
|
||||||
|
|
||||||
|
[22] Remove IGB UIO module
|
||||||
|
|
||||||
|
[23] Remove VFIO module
|
||||||
|
|
||||||
|
[24] Remove KNI module
|
||||||
|
|
||||||
|
[25] Remove hugepage mappings
|
||||||
|
|
||||||
|
[26] Exit Script
|
||||||
|
|
||||||
|
Option:
|
||||||
|
|
||||||
|
The following selection demonstrates the creation of the x86_64-native-linuxapp-gcc Intel® DPDK library.
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
Option: 4
|
||||||
|
|
||||||
|
================== Installing x86_64-native-linuxapp-gcc
|
||||||
|
|
||||||
|
Configuration done
|
||||||
|
== Build scripts
|
||||||
|
== Build scripts/testhost
|
||||||
|
HOSTCC testhost.o
|
||||||
|
...
|
||||||
|
Build complete
|
||||||
|
RTE_TARGET exported as x86_64-native -linuxapp-gcc
|
||||||
|
|
||||||
|
The following selection demonstrates the starting of the Intel® DPDK UIO driver.
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
Option: 5
|
||||||
|
|
||||||
|
Unloading any existing DPDK UIO module
|
||||||
|
Loading DPDK UIO module
|
||||||
|
|
||||||
|
The following selection demonstrates the creation of hugepages in a NUMA system.
|
||||||
|
1024 2 Mbyte pages are assigned to each node.
|
||||||
|
The result is that the application should use -m 4096 for starting the application to access both memory areas
|
||||||
|
(this is done automatically if the -m option is not provided).
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
If prompts are displayed to remove temporary files, type ‘y’.
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
Option: 11
|
||||||
|
|
||||||
|
Removing currently reserved hugepages
|
||||||
|
nmounting /mnt/huge and removing directory
|
||||||
|
Input the number of 2MB pages for each node
|
||||||
|
Example: to have 128MB of hugepages available per node,
|
||||||
|
enter '64' to reserve 64 * 2MB pages on each node
|
||||||
|
Number of pages for node0: 1024
|
||||||
|
Number of pages for node1: 1024
|
||||||
|
Reserving hugepages
|
||||||
|
Creating /mnt/huge and mounting as hugetlbfs
|
||||||
|
|
||||||
|
The following selection demonstrates the launch of the test application to run on a single core.
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
Option: 14
|
||||||
|
|
||||||
|
Enter hex bitmask of cores to execute test app on
|
||||||
|
Example: to execute app on cores 0 to 7, enter 0xff
|
||||||
|
bitmask: 0x01
|
||||||
|
Launching app
|
||||||
|
EAL: coremask set to 1
|
||||||
|
EAL: Detected lcore 0 on socket 0
|
||||||
|
...
|
||||||
|
EAL: Master core 0 is ready (tid=1b2ad720)
|
||||||
|
RTE>>
|
||||||
|
|
||||||
|
Applications
|
||||||
|
------------
|
||||||
|
|
||||||
|
Once the user has run the setup.sh script, built one of the EAL targets and set up hugepages (if using one of the Linux EAL targets),
|
||||||
|
the user can then move on to building and running their application or one of the examples provided.
|
||||||
|
|
||||||
|
The examples in the /examples directory provide a good starting point to gain an understanding of the operation of the Intel® DPDK.
|
||||||
|
The following command sequence shows how the helloworld sample application is built and run.
|
||||||
|
As recommended in Section 4.2.1 , “Logical Core Use by Applications ” on page 14,
|
||||||
|
the logical core layout of the platform should be determined when selecting a core mask to use for an application.
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
rte@rte-desktop:~/rte/examples$ cd helloworld/
|
||||||
|
rte@rte-desktop:~/rte/examples/helloworld$ make
|
||||||
|
CC main.o
|
||||||
|
LD helloworld
|
||||||
|
INSTALL-APP helloworld
|
||||||
|
INSTALL-MAP helloworld.map
|
||||||
|
|
||||||
|
rte@rte-desktop:~/rte/examples/helloworld$ sudo ./build/app/helloworld -c 0xf -n 3
|
||||||
|
[sudo] password for rte:
|
||||||
|
EAL: coremask set to f
|
||||||
|
EAL: Detected lcore 0 as core 0 on socket 0
|
||||||
|
EAL: Detected lcore 1 as core 0 on socket 1
|
||||||
|
EAL: Detected lcore 2 as core 1 on socket 0
|
||||||
|
EAL: Detected lcore 3 as core 1 on socket 1
|
||||||
|
EAL: Setting up hugepage memory...
|
||||||
|
EAL: Ask a virtual area of 0x200000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0add800000 (size = 0x200000)
|
||||||
|
EAL: Ask a virtual area of 0x3d400000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0aa0200000 (size = 0x3d400000)
|
||||||
|
EAL: Ask a virtual area of 0x400000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9fc00000 (size = 0x400000)
|
||||||
|
EAL: Ask a virtual area of 0x400000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9f600000 (size = 0x400000)
|
||||||
|
EAL: Ask a virtual area of 0x400000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9f000000 (size = 0x400000)
|
||||||
|
EAL: Ask a virtual area of 0x800000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9e600000 (size = 0x800000)
|
||||||
|
EAL: Ask a virtual area of 0x800000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9dc00000 (size = 0x800000)
|
||||||
|
EAL: Ask a virtual area of 0x400000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9d600000 (size = 0x400000)
|
||||||
|
EAL: Ask a virtual area of 0x400000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9d000000 (size = 0x400000)
|
||||||
|
EAL: Ask a virtual area of 0x400000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9ca00000 (size = 0x400000)
|
||||||
|
EAL: Ask a virtual area of 0x200000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9c600000 (size = 0x200000)
|
||||||
|
EAL: Ask a virtual area of 0x200000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a9c200000 (size = 0x200000)
|
||||||
|
EAL: Ask a virtual area of 0x3fc00000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a5c400000 (size = 0x3fc00000)
|
||||||
|
EAL: Ask a virtual area of 0x200000 bytes
|
||||||
|
EAL: Virtual area found at 0x7f0a5c000000 (size = 0x200000)
|
||||||
|
EAL: Requesting 1024 pages of size 2MB from socket 0
|
||||||
|
EAL: Requesting 1024 pages of size 2MB from socket 1
|
||||||
|
EAL: Master core 0 is ready (tid=de25b700)
|
||||||
|
EAL: Core 1 is ready (tid=5b7fe700)
|
||||||
|
EAL: Core 3 is ready (tid=5a7fc700)
|
||||||
|
EAL: Core 2 is ready (tid=5affd700)
|
||||||
|
hello from core 1
|
||||||
|
hello from core 2
|
||||||
|
hello from core 3
|
||||||
|
hello from core 0
|
287
doc/guides/linux_gsg/sys_reqs.rst
Executable file
287
doc/guides/linux_gsg/sys_reqs.rst
Executable file
@ -0,0 +1,287 @@
|
|||||||
|
.. 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.
|
||||||
|
|
||||||
|
System Requirements
|
||||||
|
===================
|
||||||
|
|
||||||
|
This chapter describes the packages required to compile the Intel® DPDK.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
If the Intel® DPDK is being used on an Intel® Communications Chipset 89xx Series platform,
|
||||||
|
please consult the *Intel® Communications Chipset 89xx Series Software for Linux* Getting Started Guide*.
|
||||||
|
|
||||||
|
BIOS Setting Prerequisite
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
For the majority of platforms, no special BIOS settings are needed to use basic Intel® DPDK functionality.
|
||||||
|
However, for additional HPET timer and power management functionality,
|
||||||
|
and high performance of small packets on 40G NIC, BIOS setting changes may be needed.
|
||||||
|
Consult :ref:`Chapter 5. Enabling Additional Functionality <Enabling_Additional_Functionality>`
|
||||||
|
for more information on the required changes.
|
||||||
|
|
||||||
|
Compilation of the Intel® DPDK
|
||||||
|
------------------------------
|
||||||
|
|
||||||
|
**Required Tools:**
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
Testing has been performed using Fedora* 18. The setup commands and installed packages needed on other systems may be different.
|
||||||
|
For details on other Linux distributions and the versions tested, please consult the Intel® DPDK Release Notes.
|
||||||
|
|
||||||
|
* GNU make
|
||||||
|
|
||||||
|
* coreutils: cmp, sed, grep, arch
|
||||||
|
|
||||||
|
* gcc: versions 4.5.x or later is recommended.
|
||||||
|
On some distributions, some specific compiler flags and linker flags are enabled by default and
|
||||||
|
affect performance (- fstack-protector, for example).
|
||||||
|
Please refer to the documentation of your distribution and to gcc -dumpspecs.
|
||||||
|
|
||||||
|
* libc headers (glibc-devel.i686 / libc6-dev-i386; glibc-devel.x86_64 for 64-bit compilation)
|
||||||
|
|
||||||
|
* Linux kernel headers or sources required to build kernel modules. (kernel- devel.x86_64)
|
||||||
|
|
||||||
|
* Additional packages required for 32-bit compilation on 64-bit systems are:
|
||||||
|
|
||||||
|
glibc.i686, libgcc.i686, libstdc++.i686 and glibc-devel.i686
|
||||||
|
|
||||||
|
* Python, version 2.6 or 2.7, to use various helper scripts included in the Intel® DPDK package
|
||||||
|
|
||||||
|
|
||||||
|
**Optional Tools:**
|
||||||
|
|
||||||
|
* Intel® C++ Compiler (icc). For installation, additional libraries may be required.
|
||||||
|
See the icc Installation Guide found in the Documentation directory under the compiler installation.
|
||||||
|
This release has been tested using version 12.1.
|
||||||
|
|
||||||
|
* libpcap headers and libraries (libpcap-devel) to compile and use the libpcap-based poll-mode driver.
|
||||||
|
This driver is disabled by default and can be enabled by setting CONFIG_RTE_LIBRTE_PMD_PCAP=y in the build time config file.
|
||||||
|
|
||||||
|
Running Intel® DPDK Applications
|
||||||
|
--------------------------------
|
||||||
|
|
||||||
|
To run an Intel® DPDK application, some customization may be required on the target machine.
|
||||||
|
|
||||||
|
System Software
|
||||||
|
~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
**Required:**
|
||||||
|
|
||||||
|
* Kernel version >= 2.6.33
|
||||||
|
|
||||||
|
The kernel version in use can be checked using the command:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
uname -r
|
||||||
|
|
||||||
|
For details of the patches needed to use the Intel® DPDK with earlier kernel versions,
|
||||||
|
see the Intel® DPDK FAQ included in the *Intel® DPDK Release Notes*.
|
||||||
|
Note also that Redhat* Linux* 6.2 and 6.3 uses a 2.6.32 kernel that already has all the necessary patches applied.
|
||||||
|
|
||||||
|
* glibc >= 2.7 (for features related to cpuset)
|
||||||
|
|
||||||
|
The version can be checked using the ldd --version command. A sample output is shown below:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
# ldd --version
|
||||||
|
|
||||||
|
ldd (GNU libc) 2.14.90
|
||||||
|
Copyright (C) 2011 Free Software Foundation, Inc.
|
||||||
|
This is free software; see the source for copying conditions. There is NO
|
||||||
|
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
|
Written by Roland McGrath and Ulrich Drepper.
|
||||||
|
|
||||||
|
* Kernel configuration
|
||||||
|
|
||||||
|
In the Fedora* OS and other common distributions, such as Ubuntu*, or RedHat Enterprise Linux*,
|
||||||
|
the vendor supplied kernel configurations can be used to run most Intel® DPDK applications.
|
||||||
|
|
||||||
|
For other kernel builds, options which should be enabled for Intel® DPDK include:
|
||||||
|
|
||||||
|
* UIO support
|
||||||
|
|
||||||
|
* HUGETLBFS
|
||||||
|
|
||||||
|
* PROC_PAGE_MONITOR support
|
||||||
|
|
||||||
|
* HPET and HPET_MMAP configuration options should also be enabled if HPET support is required.
|
||||||
|
See :ref:`Section 5.1 High Precision Event Timer (HPET) Functionality <High_Precision_Event_Timer>` for more details.
|
||||||
|
|
||||||
|
Use of Hugepages in the Linux* Environment
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Hugepage support is required for the large memory pool allocation used for packet buffers
|
||||||
|
(the HUGETLBFS option must be enabled in the running kernel as indicated in Section 2.3).
|
||||||
|
By using hugepage allocations, performance is increased since fewer pages are needed,
|
||||||
|
and therefore less Translation Lookaside Buffers (TLBs, high speed translation caches),
|
||||||
|
which reduce the time it takes to translate a virtual page address to a physical page address.
|
||||||
|
Without hugepages, high TLB miss rates would occur with the standard 4k page size, slowing performance.
|
||||||
|
|
||||||
|
Reserving Hugepages for Intel® DPDK Use
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
The allocation of hugepages should be done at boot time or as soon as possible after system boot
|
||||||
|
to prevent memory from being fragmented in physical memory.
|
||||||
|
To reserve hugepages at boot time, a parameter is passed to the Linux* kernel on the kernel command line.
|
||||||
|
|
||||||
|
For 2 MB pages, just pass the hugepages option to the kernel. For example, to reserve 1024 pages of 2 MB, use:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
hugepages=1024
|
||||||
|
|
||||||
|
For other hugepage sizes, for example 1G pages, the size must be specified explicitly and
|
||||||
|
can also be optionally set as the default hugepage size for the system.
|
||||||
|
For example, to reserve 4G of hugepage memory in the form of four 1G pages, the following options should be passed to the kernel:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
default_hugepagesz=1G hugepagesz=1G hugepages=4
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
The hugepage sizes that a CPU supports can be determined from the CPU flags.
|
||||||
|
If pse exists, 2M hugepages are supported; if pdpe1gb exists, 1G hugepages are supported.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
For 64-bit applications, it is recommended to use 1 GB hugepages if the platform supports them.
|
||||||
|
|
||||||
|
In the case of a dual-socket NUMA system,
|
||||||
|
the number of hugepages reserved at boot time is generally divided equally between the two sockets
|
||||||
|
(on the assumption that sufficient memory is present on both sockets).
|
||||||
|
|
||||||
|
See the Documentation/kernel-parameters.txt file in your Linux* source tree for further details of these and other kernel options.
|
||||||
|
|
||||||
|
**Alternative:**
|
||||||
|
|
||||||
|
For 2 MB pages, there is also the option of allocating hugepages after the system has booted.
|
||||||
|
This is done by echoing the number of hugepages required to a nr_hugepages file in the /sys/devices/ directory.
|
||||||
|
For a single-node system, the command to use is as follows (assuming that 1024 pages are required):
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
echo 1024 > /sys/kernel/mm/hugepages/hugepages-2048kB/nr_hugepages
|
||||||
|
|
||||||
|
On a NUMA machine, pages should be allocated explicitly on separate nodes:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
echo 1024 > /sys/devices/system/node/node0/hugepages/hugepages-2048kB/nr_hugepages
|
||||||
|
echo 1024 > /sys/devices/system/node/node1/hugepages/hugepages-2048kB/nr_hugepages
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
For 1G pages, it is not possible to reserve the hugepage memory after the system has booted.
|
||||||
|
|
||||||
|
Using Hugepages with the Intel® DPDK
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
Once the hugepage memory is reserved, to make the memory available for Intel® DPDK use, perform the following steps:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
mkdir /mnt/huge
|
||||||
|
mount -t hugetlbfs nodev /mnt/huge
|
||||||
|
|
||||||
|
The mount point can be made permanent across reboots, by adding the following line to the /etc/fstab file:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
nodev /mnt/huge hugetlbfs defaults 0 0
|
||||||
|
|
||||||
|
For 1GB pages, the page size must be specified as a mount option:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
nodev /mnt/huge_1GB hugetlbfs pagesize=1GB 0 0
|
||||||
|
|
||||||
|
Xen Domain0 Support in the Linux* Environment
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The existing memory management implementation is based on the Linux* kernel hugepage mechanism.
|
||||||
|
On the Xen hypervisor, hugepage support for DomainU (DomU) Guests means that Intel® DPDK applications work as normal for guests.
|
||||||
|
|
||||||
|
However, Domain0 (Dom0) does not support hugepages.
|
||||||
|
To work around this limitation, a new kernel module rte_dom0_mm is added to facilitate the allocation and mapping of memory via
|
||||||
|
**IOCTL** (allocation) and **MMAP** (mapping).
|
||||||
|
|
||||||
|
Enabling Xen Dom0 Mode in the Intel® DPDK
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
By default, Xen Dom0 mode is disabled in the Intel® DPDK build configuration files.
|
||||||
|
To support Xen Dom0, the CONFIG_RTE_LIBRTE_XEN_DOM0 setting should be changed to “y”, which enables the Xen Dom0 mode at compile time.
|
||||||
|
|
||||||
|
Furthermore, the CONFIG_RTE_EAL_ALLOW_INV_SOCKET_ID setting should also be changed to “y” in the case of the wrong socket ID being received.
|
||||||
|
|
||||||
|
Loading the Intel® DPDK rte_dom0_mm Module
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
To run any Intel® DPDK application on Xen Dom0, the rte_dom0_mm module must be loaded into the running kernel with rsv_memsize option.
|
||||||
|
The module is found in the kmod sub-directory of the Intel® DPDK target directory.
|
||||||
|
This module should be loaded using the insmod command as shown below (assuming that the current directory is the Intel® DPDK target directory):
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
sudo insmod kmod/rte_dom0_mm.ko rsv_memsize=X
|
||||||
|
|
||||||
|
The value X cannot be greater than 4096(MB).
|
||||||
|
|
||||||
|
Configuring Memory for Intel® DPDK Use
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
After the rte_dom0_mm.ko kernel module has been loaded, the user must configure the memory size for DPDK usage.
|
||||||
|
This is done by echoing the memory size to a memsize file in the /sys/devices/ directory.
|
||||||
|
Use the following command (assuming that 2048 MB is required):
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
echo 2048 /sys/kernel/mm/dom0-mm/memsize-mB/memsize
|
||||||
|
|
||||||
|
The user can also check how much memory has already been used:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
cat /sys/kernel/mm/dom0-mm/memsize-mB/memsize_rsvd
|
||||||
|
|
||||||
|
Xen Domain0 does not support NUMA configuration, as a result the --socket-mem command line option is invalid for Xen Domain0.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
The memsize value cannot be greater than the rsv_memsize value.
|
||||||
|
|
||||||
|
Running the Intel® DPDK Application on Xen Domain0
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
To run the Intel® DPDK application on Xen Domain0, an extra command line option --xen-dom0 is required.
|
Loading…
Reference in New Issue
Block a user