2019-06-25 11:12:58 +00:00
|
|
|
.. SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
Copyright(c) 2017 Cavium, Inc
|
2018-05-15 09:49:22 +00:00
|
|
|
|
|
|
|
ARMv8 Crypto Poll Mode Driver
|
|
|
|
=============================
|
|
|
|
|
|
|
|
This code provides the initial implementation of the ARMv8 crypto PMD.
|
|
|
|
The driver uses ARMv8 cryptographic extensions to process chained crypto
|
|
|
|
operations in an optimized way. The core functionality is provided by
|
|
|
|
a low-level library, written in the assembly code.
|
|
|
|
|
|
|
|
Features
|
|
|
|
--------
|
|
|
|
|
|
|
|
ARMv8 Crypto PMD has support for the following algorithm pairs:
|
|
|
|
|
|
|
|
Supported cipher algorithms:
|
|
|
|
|
|
|
|
* ``RTE_CRYPTO_CIPHER_AES_CBC``
|
|
|
|
|
|
|
|
Supported authentication algorithms:
|
|
|
|
|
|
|
|
* ``RTE_CRYPTO_AUTH_SHA1_HMAC``
|
|
|
|
* ``RTE_CRYPTO_AUTH_SHA256_HMAC``
|
|
|
|
|
|
|
|
Installation
|
|
|
|
------------
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
To build DPDK with this virtual crypto PMD, the user is required to:
|
2018-05-15 09:49:22 +00:00
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
* Download AArch64 crypto library source code from
|
|
|
|
`here <https://github.com/ARM-software/AArch64cryptolib>`_.
|
2018-05-15 09:49:22 +00:00
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
* Build the ``AArch64cryptolib`` library:
|
2018-05-15 09:49:22 +00:00
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
make
|
|
|
|
|
|
|
|
* Add path to `libAArch64crypto.pc` in `PKG_CONFIG_PATH` environment variable:
|
2018-05-15 09:49:22 +00:00
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
export PKG_CONFIG_PATH=<path_to_AArch64cryptolib>/pkgconfig/:$PKG_CONFIG_PATH
|
2018-05-15 09:49:22 +00:00
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
* Build DPDK:
|
|
|
|
|
|
|
|
.. code-block:: console
|
|
|
|
|
|
|
|
meson build
|
|
|
|
ninja -C build
|
2018-05-15 09:49:22 +00:00
|
|
|
|
|
|
|
The corresponding device can be created only if the following features
|
|
|
|
are supported by the CPU:
|
|
|
|
|
|
|
|
* ``RTE_CPUFLAG_AES``
|
|
|
|
* ``RTE_CPUFLAG_SHA1``
|
|
|
|
* ``RTE_CPUFLAG_SHA2``
|
|
|
|
* ``RTE_CPUFLAG_NEON``
|
|
|
|
|
|
|
|
Initialization
|
|
|
|
--------------
|
|
|
|
|
2021-02-05 08:48:47 +00:00
|
|
|
Use ``--vdev "crypto_armv8"`` in the EAL options to create virtual crypto device.
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
User can use app/test application to check how to use this PMD and to verify
|
|
|
|
crypto processing.
|
|
|
|
|
|
|
|
Test name is cryptodev_sw_armv8_autotest.
|
|
|
|
|
|
|
|
Limitations
|
|
|
|
-----------
|
|
|
|
|
|
|
|
* Maximum number of sessions is 2048.
|
|
|
|
* Only chained operations are supported.
|
|
|
|
* AES-128-CBC is the only supported cipher variant.
|
|
|
|
* Cipher input data has to be a multiple of 16 bytes.
|
|
|
|
* Digest input data has to be a multiple of 8 bytes.
|