mirror of https://github.com/F-Stack/f-stack.git
141 lines
4.5 KiB
ReStructuredText
141 lines
4.5 KiB
ReStructuredText
|
.. SPDX-License-Identifier: BSD-3-Clause
|
||
|
Copyright 2021 NXP
|
||
|
|
||
|
ENETFEC Poll Mode Driver
|
||
|
========================
|
||
|
|
||
|
The ENETFEC NIC PMD (**librte_net_enetfec**) provides poll mode driver
|
||
|
support for the inbuilt NIC found in the ** NXP i.MX 8M Mini** SoC.
|
||
|
|
||
|
More information can be found at NXP Official Website
|
||
|
<https://www.nxp.com/products/processors-and-microcontrollers/arm-processors/i-mx-applications-processors/i-mx-8-processors/i-mx-8m-mini-arm-cortex-a53-cortex-m4-audio-voice-video:i.MX8MMINI>
|
||
|
|
||
|
This section provides an overview of the NXP ENETFEC
|
||
|
and how it is integrated into the DPDK.
|
||
|
Driver is taken as **experimental**
|
||
|
as driver depends on a Linux kernel module 'enetfec-uio',
|
||
|
which is not upstreamed yet.
|
||
|
|
||
|
Contents summary
|
||
|
|
||
|
- ENETFEC overview
|
||
|
- ENETFEC features
|
||
|
- Supported ENETFEC SoCs
|
||
|
- Prerequisites
|
||
|
- Driver compilation and testing
|
||
|
- Limitations
|
||
|
|
||
|
ENETFEC Overview
|
||
|
----------------
|
||
|
|
||
|
The i.MX 8M Mini Media Applications Processor is built
|
||
|
to achieve both high performance and low power consumption.
|
||
|
ENETFEC PMD is a hardware programmable packet forwarding engine
|
||
|
to provide high performance Ethernet interface.
|
||
|
It has only 1 GB Ethernet interface with RJ45 connector.
|
||
|
|
||
|
The diagram below shows a system level overview of ENETFEC:
|
||
|
|
||
|
.. code-block:: console
|
||
|
|
||
|
=====================================================
|
||
|
Userspace
|
||
|
+-----------------------------------------+
|
||
|
| ENETFEC Driver |
|
||
|
| +-------------------------+ |
|
||
|
| | virtual ethernet device | |
|
||
|
+-----------------------------------------+
|
||
|
^ |
|
||
|
| |
|
||
|
| |
|
||
|
RXQ | | TXQ
|
||
|
| |
|
||
|
| v
|
||
|
=====================================================
|
||
|
Kernel Space
|
||
|
+---------+
|
||
|
| fec-uio |
|
||
|
====================+=========+======================
|
||
|
Hardware
|
||
|
+-----------------------------------------+
|
||
|
| i.MX 8M MINI EVK |
|
||
|
| +-----+ |
|
||
|
| | MAC | |
|
||
|
+---------------+-----+-------------------+
|
||
|
| PHY |
|
||
|
+-----+
|
||
|
|
||
|
ENETFEC Ethernet driver is traditional DPDK PMD running in userspace.
|
||
|
'fec-uio' is the kernel driver.
|
||
|
The MAC and PHY are the hardware blocks.
|
||
|
ENETFEC PMD uses standard UIO interface to access kernel
|
||
|
for PHY initialisation and for mapping the allocated memory
|
||
|
of register & buffer descriptor with DPDK
|
||
|
which gives access to non-cacheable memory for buffer descriptor.
|
||
|
net_enetfec is logical Ethernet interface, created by ENETFEC driver.
|
||
|
|
||
|
- ENETFEC driver registers the device in virtual device driver.
|
||
|
- RTE framework scans and will invoke the probe function of ENETFEC driver.
|
||
|
- The probe function will set the basic device registers and also setups BD rings.
|
||
|
- On packet Rx the respective BD Ring status bit is set which is then used for
|
||
|
packet processing.
|
||
|
- Then Tx is done first followed by Rx via logical interfaces.
|
||
|
|
||
|
ENETFEC Features
|
||
|
----------------
|
||
|
|
||
|
- Basic stats
|
||
|
- Promiscuous
|
||
|
- VLAN offload
|
||
|
- L3/L4 checksum offload
|
||
|
- Linux
|
||
|
- ARMv8
|
||
|
|
||
|
Supported ENETFEC SoCs
|
||
|
----------------------
|
||
|
|
||
|
- i.MX 8M Mini
|
||
|
|
||
|
Prerequisites
|
||
|
-------------
|
||
|
|
||
|
There are three main pre-requisites for executing ENETFEC PMD on a i.MX 8M Mini
|
||
|
compatible board:
|
||
|
|
||
|
1. **ARM 64 Tool Chain**
|
||
|
|
||
|
For example, the `*aarch64* Linaro Toolchain
|
||
|
<https://releases.linaro.org/components/toolchain/binaries/7.4-2019.02/aarch64-linux-gnu/gcc-linaro-7.4.1-2019.02-x86_64_aarch64-linux-gnu.tar.xz>`_.
|
||
|
|
||
|
2. **Linux Kernel**
|
||
|
|
||
|
It can be obtained from `NXP's Github hosting
|
||
|
<https://source.codeaurora.org/external/qoriq/qoriq-components/linux>`_.
|
||
|
|
||
|
.. note::
|
||
|
|
||
|
Branch is 'lf-5.10.y'
|
||
|
|
||
|
3. **Rootfile system**
|
||
|
|
||
|
Any *aarch64* supporting filesystem can be used.
|
||
|
For example, Ubuntu 18.04 LTS (Bionic) or 20.04 LTS(Focal) userland
|
||
|
which can be obtained from `here
|
||
|
<http://cdimage.ubuntu.com/ubuntu-base/releases/18.04/release/ubuntu-base-18.04.1-base-arm64.tar.gz>`_.
|
||
|
|
||
|
4. The Ethernet device will be registered as virtual device,
|
||
|
so ENETFEC has dependency on **rte_bus_vdev** library
|
||
|
and it is mandatory to use `--vdev` with value `net_enetfec`
|
||
|
to run DPDK application.
|
||
|
|
||
|
Driver compilation and testing
|
||
|
------------------------------
|
||
|
|
||
|
Follow instructions available in the document :doc:`build_and_test`
|
||
|
to launch **dpdk-testpmd**.
|
||
|
|
||
|
Limitations
|
||
|
-----------
|
||
|
|
||
|
- Multi queue is not supported.
|