2019-06-25 11:12:58 +00:00
|
|
|
.. SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
Copyright(c) 2017 Cavium, Inc
|
|
|
|
|
|
|
|
OCTEON TX Board Support Package
|
|
|
|
===============================
|
|
|
|
|
|
|
|
This doc has information about steps to setup OCTEON TX platform
|
2018-05-15 09:49:22 +00:00
|
|
|
and information about common offload hw block drivers of
|
2019-06-25 11:12:58 +00:00
|
|
|
**Cavium OCTEON TX** SoC family.
|
2018-05-15 09:49:22 +00:00
|
|
|
|
|
|
|
|
|
|
|
More information about SoC can be found at `Cavium, Inc Official Website
|
|
|
|
<http://www.cavium.com/OCTEON-TX_ARM_Processors.html>`_.
|
|
|
|
|
|
|
|
Common Offload HW Block Drivers
|
|
|
|
-------------------------------
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
1. **Crypto Driver**
|
|
|
|
See :doc:`../cryptodevs/octeontx` for octeontx crypto driver
|
2018-05-15 09:49:22 +00:00
|
|
|
information.
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
2. **Eventdev Driver**
|
|
|
|
See :doc:`../eventdevs/octeontx` for octeontx ssovf eventdev driver
|
|
|
|
information.
|
|
|
|
|
|
|
|
3. **Mempool Driver**
|
|
|
|
See :doc:`../mempool/octeontx` for octeontx fpavf mempool driver
|
2018-05-15 09:49:22 +00:00
|
|
|
information.
|
|
|
|
|
|
|
|
Steps To Setup Platform
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
There are three main pre-prerequisites for setting up Platform drivers on
|
2019-06-25 11:12:58 +00:00
|
|
|
OCTEON TX compatible board:
|
2018-05-15 09:49:22 +00:00
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
1. **OCTEON TX Linux kernel PF driver for Network acceleration HW blocks**
|
2018-05-15 09:49:22 +00:00
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
The OCTEON TX Linux kernel drivers (includes the required PF driver for the
|
2018-05-15 09:49:22 +00:00
|
|
|
Platform drivers) are available on Github at `octeontx-kmod <https://github.com/caviumnetworks/octeontx-kmod>`_
|
|
|
|
along with build, install and dpdk usage instructions.
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
.. note::
|
|
|
|
|
|
|
|
The PF driver and the required microcode for the crypto offload block will be
|
|
|
|
available with OCTEON TX SDK only. So for using crypto offload, follow the steps
|
|
|
|
mentioned in :ref:`setup_platform_using_OCTEON_TX_SDK`.
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
2. **ARM64 Tool Chain**
|
|
|
|
|
|
|
|
For example, the *aarch64* Linaro Toolchain, which can be obtained from
|
|
|
|
`here <https://releases.linaro.org/components/toolchain/binaries/4.9-2017.01/aarch64-linux-gnu>`_.
|
|
|
|
|
|
|
|
3. **Rootfile system**
|
|
|
|
|
|
|
|
Any *aarch64* supporting filesystem can be used. For example,
|
|
|
|
Ubuntu 15.10 (Wily) or 16.04 LTS (Xenial) userland which can be obtained
|
|
|
|
from `<http://cdimage.ubuntu.com/ubuntu-base/releases/16.04/release/ubuntu-base-16.04.1-base-arm64.tar.gz>`_.
|
|
|
|
|
|
|
|
As an alternative method, Platform drivers can also be executed using images provided
|
|
|
|
as part of SDK from Cavium. The SDK includes all the above prerequisites necessary
|
2019-06-25 11:12:58 +00:00
|
|
|
to bring up a OCTEON TX board. Please refer :ref:`setup_platform_using_OCTEON_TX_SDK`.
|
|
|
|
|
|
|
|
- Follow the DPDK :doc:`../linux_gsg/index` to setup the basic DPDK environment.
|
|
|
|
|
|
|
|
.. _setup_platform_using_OCTEON_TX_SDK:
|
|
|
|
|
|
|
|
Setup Platform Using OCTEON TX SDK
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
The OCTEON TX platform drivers can be compiled either natively on
|
|
|
|
**OCTEON TX** :sup:`®` board or cross-compiled on an x86 based platform.
|
|
|
|
|
|
|
|
The **OCTEON TX** :sup:`®` board must be running the linux kernel based on
|
|
|
|
OCTEON TX SDK 6.2.0 patch 3. In this, the PF drivers for all hardware
|
|
|
|
offload blocks are already built in.
|
|
|
|
|
|
|
|
Native Compilation
|
|
|
|
~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
If the kernel and modules are cross-compiled and copied to the target board,
|
|
|
|
some intermediate binaries required for native build would be missing on the
|
|
|
|
target board. To make sure all the required binaries are available in the
|
|
|
|
native architecture, the linux sources need to be compiled once natively.
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
cd /lib/modules/$(uname -r)/source
|
|
|
|
make menuconfig
|
|
|
|
make
|
|
|
|
|
|
|
|
The above steps would rebuild the modules and the required intermediate binaries.
|
|
|
|
Once the target is ready for native compilation, the OCTEON TX platform
|
|
|
|
drivers can be compiled with the following steps,
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
meson build -Dexamples=<application>
|
|
|
|
ninja -C build
|
2019-06-25 11:12:58 +00:00
|
|
|
|
|
|
|
The example applications can be compiled using the following:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
meson build -Dexamples=<application>
|
|
|
|
ninja -C build
|
2019-06-25 11:12:58 +00:00
|
|
|
|
|
|
|
Cross Compilation
|
|
|
|
~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
The DPDK applications can be cross-compiled on any x86 based platform. The
|
|
|
|
OCTEON TX SDK need to be installed on the build system. The SDK package will
|
|
|
|
provide the required toolchain etc.
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
Refer to :doc:`../linux_gsg/cross_build_dpdk_for_arm64` for generic arm64 details.
|
2019-06-25 11:12:58 +00:00
|
|
|
|
|
|
|
The following steps can be used to perform cross-compilation with OCTEON TX
|
|
|
|
SDK 6.2.0 patch 3:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
cd <sdk_install_dir>
|
|
|
|
source env-setup
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
The above steps will prepare build system with required toolchain.
|
|
|
|
Now this build system can be used to build applications for **OCTEON TX** :sup:`®` platforms.
|
2019-06-25 11:12:58 +00:00
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
cd <dpdk directory>
|
2021-02-05 08:48:47 +00:00
|
|
|
meson build --cross-file config/arm/arm64_thunderx_linux_gcc
|
|
|
|
ninja -C build
|
2019-06-25 11:12:58 +00:00
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
The example applications can be compiled using the following:
|
2019-06-25 11:12:58 +00:00
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
cd <dpdk directory>
|
|
|
|
meson build --cross-file config/arm/arm64_thunderx_linux_gcc -Dexamples=<application>
|
|
|
|
ninja -C build
|
|
|
|
|
|
|
|
.. note::
|
2018-05-15 09:49:22 +00:00
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
By default, meson cross compilation uses ``aarch64-linux-gnu-gcc`` toolchain,
|
|
|
|
if OCTEON TX SDK 6.2.0 patch 3 is available then it can be used by
|
|
|
|
overriding the c, cpp, ar, strip ``binaries`` attributes to respective thunderx
|
|
|
|
toolchain binaries in ``config/arm/arm64_thunderx_linux_gcc`` file.
|
2018-05-15 09:49:22 +00:00
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
SDK and related information can be obtained from: `Cavium support site <https://support.cavium.com/>`_.
|