From: Walter Heymans <walter.heym...@corigine.com> The NFP PMD documentation is updated to include information about Corigine and their new vendor device ID.
Outdated information regarding the use of the PMD is also updated. While making major changes to the document, the maximum number of characters per line is updated to 80 characters to improve the readability in raw format. Signed-off-by: Walter Heymans <walter.heym...@corigine.com> Reviewed-by: Niklas Söderlund <niklas.soderl...@corigine.com> Reviewed-by: Chaoyong He <chaoyong...@corigine.com> --- doc/guides/nics/nfp.rst | 168 +++++++++++++++++++++------------------- 1 file changed, 90 insertions(+), 78 deletions(-) diff --git a/doc/guides/nics/nfp.rst b/doc/guides/nics/nfp.rst index a085d7d9ae..6fea280411 100644 --- a/doc/guides/nics/nfp.rst +++ b/doc/guides/nics/nfp.rst @@ -1,35 +1,34 @@ .. SPDX-License-Identifier: BSD-3-Clause Copyright(c) 2015-2017 Netronome Systems, Inc. All rights reserved. - All rights reserved. + Copyright(c) 2021 Corigine, Inc. All rights reserved. NFP poll mode driver library ============================ -Netronome's sixth generation of flow processors pack 216 programmable -cores and over 100 hardware accelerators that uniquely combine packet, -flow, security and content processing in a single device that scales +Netronome and Corigine's sixth generation of flow processors pack 216 +programmable cores and over 100 hardware accelerators that uniquely combine +packet, flow, security and content processing in a single device that scales up to 400-Gb/s. -This document explains how to use DPDK with the Netronome Poll Mode -Driver (PMD) supporting Netronome's Network Flow Processor 6xxx -(NFP-6xxx), Netronome's Network Flow Processor 4xxx (NFP-4xxx) and -Netronome's Network Flow Processor 38xx (NFP-38xx). +This document explains how to use DPDK with the Network Flow Processor (NFP) +Poll Mode Driver (PMD) supporting Netronome and Corigine's NFP-6xxx, NFP-4xxx +and NFP-38xx product lines. -NFP is a SRIOV capable device and the PMD supports the physical -function (PF) and the virtual functions (VFs). +NFP is a SR-IOV capable device and the PMD supports the physical function (PF) +and the virtual functions (VFs). Dependencies ------------ -Before using the Netronome's DPDK PMD some NFP configuration, -which is not related to DPDK, is required. The system requires -installation of **Netronome's BSP (Board Support Package)** along -with a specific NFP firmware application. Netronome's NSP ABI -version should be 0.20 or higher. +Before using the NFP DPDK PMD some NFP configuration, which is not related to +DPDK, is required. The system requires installation of +**NFP-BSP (Board Support Package)** along with a specific NFP firmware +application. The NSP ABI version should be 0.20 or higher. -If you have a NFP device you should already have the code and -documentation for this configuration. Contact -**supp...@netronome.com** to obtain the latest available firmware. +If you have a NFP device you should already have the documentation to perform +this configuration. Contact **supp...@netronome.com** (for Netronome products) +or **smartnic-supp...@corigine.com** (for Corigine products) to obtain the +latest available firmware. The NFP Linux netdev kernel driver for VFs has been a part of the vanilla kernel since kernel version 4.5, and support for the PF @@ -44,11 +43,11 @@ Linux kernel driver. Building the software --------------------- -Netronome's PMD code is provided in the **drivers/net/nfp** directory. -Although NFP PMD has Netronome´s BSP dependencies, it is possible to -compile it along with other DPDK PMDs even if no BSP was installed previously. -Of course, a DPDK app will require such a BSP installed for using the -NFP PMD, along with a specific NFP firmware application. +The NFP PMD code is provided in the **drivers/net/nfp** directory. Although +NFP PMD has BSP dependencies, it is possible to compile it along with other +DPDK PMDs even if no BSP was installed previously. Of course, a DPDK app will +require such a BSP installed for using the NFP PMD, along with a specific NFP +firmware application. Once the DPDK is built all the DPDK apps and examples include support for the NFP PMD. @@ -57,27 +56,20 @@ the NFP PMD. Driver compilation and testing ------------------------------ -Refer to the document :ref:`compiling and testing a PMD for a NIC <pmd_build_and_test>` -for details. +Refer to the document +:ref:`compiling and testing a PMD for a NIC <pmd_build_and_test>` for details. Using the PF ------------ -NFP PMD supports using the NFP PF as another DPDK port, but it does not -have any functionality for controlling VFs. In fact, it is not possible to use -the PMD with the VFs if the PF is being used by DPDK, that is, with the NFP PF -bound to ``igb_uio`` or ``vfio-pci`` kernel drivers. Future DPDK versions will -have a PMD able to work with the PF and VFs at the same time and with the PF -implementing VF management along with other PF-only functionalities/offloads. - The PMD PF has extra work to do which will delay the DPDK app initialization -like uploading the firmware and configure the Link state properly when starting or -stopping a PF port. Since DPDK 18.05 the firmware upload happens when +like uploading the firmware and configure the Link state properly when starting +or stopping a PF port. Since DPDK 18.05 the firmware upload happens when a PF is initialized, which was not always true with older DPDK versions. -Depending on the Netronome product installed in the system, firmware files -should be available under ``/lib/firmware/netronome``. DPDK PMD supporting the -PF looks for a firmware file in this order: +Depending on the product installed in the system, firmware files should be +available under ``/lib/firmware/netronome``. DPDK PMD supporting the PF looks +for a firmware file in this order: 1) First try to find a firmware image specific for this device using the NFP serial number: @@ -92,18 +84,21 @@ PF looks for a firmware file in this order: nic_AMDA0099-0001_2x25.nffw -Netronome's software packages install firmware files under ``/lib/firmware/netronome`` -to support all the Netronome's SmartNICs and different firmware applications. -This is usually done using file names based on SmartNIC type and media and with a -directory per firmware application. Options 1 and 2 for firmware filenames allow -more than one SmartNIC, same type of SmartNIC or different ones, and to upload a -different firmware to each SmartNIC. +Netronome and Corigine's software packages install firmware files under +``/lib/firmware/netronome`` to support all the SmartNICs and different firmware +applications. This is usually done using file names based on SmartNIC type and +media and with a directory per firmware application. Options 1 and 2 for +firmware filenames allow more than one SmartNIC, same type of SmartNIC or +different ones, and to upload a different firmware to each SmartNIC. .. Note:: - Currently the NFP PMD supports using the PF with Agilio Firmware with NFD3 - and Agilio Firmware with NFDk. See https://help.netronome.com/support/solutions + Currently the NFP PMD supports using the PF with Agilio Firmware with + NFD3 and Agilio Firmware with NFDk. See + `Netronome Support <https://help.netronome.com/support/solutions>`_. for more information on the various firmwares supported by the Netronome - Agilio CX smartNIC. + Agilio SmartNICs range, or + `Corigine Support <https://www.corigine.com/productsOverviewList-30.html>`_. + for more information about Corigine's range. PF multiport support -------------------- @@ -118,7 +113,7 @@ this particular configuration requires the PMD to create ports in a special way, although once they are created, DPDK apps should be able to use them as normal PCI ports. -NFP ports belonging to same PF can be seen inside PMD initialization with a +NFP ports belonging to the same PF can be seen inside PMD initialization with a suffix added to the PCI ID: wwww:xx:yy.z_portn. For example, a PF with PCI ID 0000:03:00.0 and four ports is seen by the PMD code as: @@ -137,50 +132,67 @@ suffix added to the PCI ID: wwww:xx:yy.z_portn. For example, a PF with PCI ID PF multiprocess support ----------------------- -Due to how the driver needs to access the NFP through a CPP interface, which implies -to use specific registers inside the chip, the number of secondary processes with PF -ports is limited to only one. +Due to how the driver needs to access the NFP through a CPP interface, which +implies to use specific registers inside the chip, the number of secondary +processes with PF ports is limited to only one. -This limitation will be solved in future versions but having basic multiprocess support -is important for allowing development and debugging through the PF using a secondary -process which will create a CPP bridge for user space tools accessing the NFP. +This limitation will be solved in future versions, but having basic +multiprocess support is important for allowing development and debugging +through the PF using a secondary process, which will create a CPP bridge +for user space tools accessing the NFP. System configuration -------------------- #. **Enable SR-IOV on the NFP device:** The current NFP PMD supports the PF and - the VFs on a NFP device. However, it is not possible to work with both at the - same time because the VFs require the PF being bound to the NFP PF Linux - netdev driver. Make sure you are working with a kernel with NFP PF support or - get the drivers from the above Github repository and follow the instructions - for building and installing it. + the VFs on a NFP device. However, it is not possible to work with both at + the same time when using the netdev NFP Linux netdev driver. It is possible + to bind the PF to the ``vfio-pci`` kernel module, and create VFs afterwards. + This requires loading the ``vfio-pci`` module with the following parameters: + + .. code-block:: console + + modprobe vfio-pci enable_sriov=1 disable_idle_d3=1 + + VFs need to be enabled before they can be used with the PMD. Before enabling + the VFs it is useful to obtain information about the current NFP PCI device + detected by the system. This can be done on Netronome SmartNICs using: + + .. code-block:: console + + lspci -d 19ee: - VFs need to be enabled before they can be used with the PMD. - Before enabling the VFs it is useful to obtain information about the - current NFP PCI device detected by the system: + and on Corigine SmartNICs using: .. code-block:: console - lspci -d19ee: + lspci -d 1da8: - Now, for example, configure two virtual functions on a NFP-6xxx device + Now, for example, to configure two virtual functions on a NFP device whose PCI system identity is "0000:03:00.0": .. code-block:: console echo 2 > /sys/bus/pci/devices/0000:03:00.0/sriov_numvfs - The result of this command may be shown using lspci again: + The result of this command may be shown using lspci again on Netronome + SmartNICs: + + .. code-block:: console + + lspci -d 19ee: -k + + and on Corigine SmartNICs: .. code-block:: console - lspci -d19ee: -k + lspci -d 1da8: -k Two new PCI devices should appear in the output of the above command. The - -k option shows the device driver, if any, that devices are bound to. - Depending on the modules loaded at this point the new PCI devices may be - bound to nfp_netvf driver. + -k option shows the device driver, if any, that the devices are bound to. + Depending on the modules loaded, at this point the new PCI devices may be + bound to the ``nfp`` kernel driver or ``vfio-pci``. Flow offload @@ -193,13 +205,13 @@ The flower firmware application requires the PMD running two services: * PF vNIC service: handling the feedback traffic. * ctrl vNIC service: communicate between PMD and firmware through - control message. + control messages. To achieve the offload of flow, the representor ports are exposed to OVS. -The flower firmware application support representor port for VF and physical -port. There will always exist a representor port for each physical port, -and the number of the representor port for VF is specified by the user through -parameter. +The flower firmware application supports VF, PF, and physical port representor +ports. There will always exist a representor port for a PF and each physical +port. The number of the representor ports for VFs are specified by the user +through a parameter. In the Rx direction, the flower firmware application will prepend the input port information into metadata for each packet which can't offloaded. The PF @@ -207,12 +219,12 @@ vNIC service will keep polling packets from the firmware, and multiplex them to the corresponding representor port. In the Tx direction, the representor port will prepend the output port -information into metadata for each packet, and then send it to firmware through -PF vNIC. +information into metadata for each packet, and then send it to the firmware +through the PF vNIC. -The ctrl vNIC service handling various control message, like the creation and -configuration of representor port, the pattern and action of flow rules, the -statistics of flow rules, and so on. +The ctrl vNIC service handles various control messages, for example, the +creation and configuration of a representor port, the pattern and action of +flow rules, the statistics of flow rules, etc. Metadata Format --------------- -- 2.29.3