mirror of https://github.com/F-Stack/f-stack.git
37 lines
1.3 KiB
ReStructuredText
37 lines
1.3 KiB
ReStructuredText
.. SPDX-License-Identifier: BSD-3-Clause
|
|
Copyright(c) 2020 Intel Corporation.
|
|
|
|
|
|
Using AVX-512 with DPDK
|
|
=======================
|
|
|
|
AVX-512 is not used by default in DPDK, but it can be selected at runtime by apps through the use of EAL API,
|
|
and by the user with a commandline argument. DPDK has a setting for max SIMD bitwidth,
|
|
which can be modified and will then limit the vector path taken by the code.
|
|
|
|
|
|
Using the API in apps
|
|
---------------------
|
|
|
|
Apps can request DPDK uses AVX-512 at runtime, if it provides improved application performance.
|
|
This can be done by modifying the EAL setting for max SIMD bitwidth to 512, as by default it is 256,
|
|
which does not allow for AVX-512.
|
|
|
|
.. code-block:: c
|
|
|
|
rte_vect_set_max_simd_bitwidth(RTE_VECT_SIMD_512);
|
|
|
|
This API should only be called once at initialization, before EAL init.
|
|
For more information on the possible enum values to use as a parameter, go to :ref:`max_simd_bitwidth`:
|
|
|
|
|
|
Using the command-line argument
|
|
---------------------------------------------
|
|
|
|
The user can select to use AVX-512 at runtime, using the following argument to set the max bitwidth::
|
|
|
|
./app/dpdk-testpmd --force-max-simd-bitwidth=512
|
|
|
|
This will override any further changes to the max SIMD bitwidth in DPDK,
|
|
which is useful for testing purposes.
|