

# S32G Linux PFE Driver User's Manual



# **Contents**

| 1 | Revision History   |                                                                                                                                         |        |  |  |  |  |
|---|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--------|--|--|--|--|
| 2 | Intr               | roduction                                                                                                                               | 5      |  |  |  |  |
| 3 | Building Procedure |                                                                                                                                         |        |  |  |  |  |
|   | 3.1                | Building the driver                                                                                                                     | 6      |  |  |  |  |
|   |                    | <ul><li>3.1.1 Variant 1: Building within NXP Auto Linux BSP source tree by Yocto</li><li>3.1.2 Variant 2: Building standalone</li></ul> | 6<br>6 |  |  |  |  |
|   |                    | 5.1.2 Variant 2. Building Standarone                                                                                                    | O      |  |  |  |  |
| 4 | Usa                | ge                                                                                                                                      | 8      |  |  |  |  |
|   | 4.1                | Prerequisites                                                                                                                           | 8      |  |  |  |  |
|   |                    | 4.1.1 NXP S32G274A silicon platform EVB, RDB or RDB2                                                                                    | 8      |  |  |  |  |
|   | 4.2                | Supported development boards                                                                                                            | 8      |  |  |  |  |
|   | 4.3                | Running the driver                                                                                                                      | 8      |  |  |  |  |
|   | 4.4                | The driver configuration - device tree                                                                                                  | 9      |  |  |  |  |
|   | 4.5                | Performance consideration                                                                                                               | 15     |  |  |  |  |
|   | 4.6                | Silicon cut 1.1 backward compatibility                                                                                                  | 16     |  |  |  |  |
| 5 | Pow                | ver management                                                                                                                          | 17     |  |  |  |  |
|   | 5.1                | Prerequisite                                                                                                                            | 17     |  |  |  |  |
|   |                    | 5.1.1 Compile time                                                                                                                      | 17     |  |  |  |  |
|   |                    | 5.1.2 Run time                                                                                                                          | 17     |  |  |  |  |
|   | 5.2                | Suspend to RAM                                                                                                                          | 17     |  |  |  |  |
|   |                    | 5.2.1 Suspend                                                                                                                           | 17     |  |  |  |  |
|   |                    | 5.2.2 Resume                                                                                                                            | 18     |  |  |  |  |
| 6 | Mas                | ster-Slave feature                                                                                                                      | 19     |  |  |  |  |
|   | 6.1                | Prerequisite                                                                                                                            | 19     |  |  |  |  |
|   | 6.2                | Master                                                                                                                                  | 19     |  |  |  |  |
|   | 6.3                | Slave                                                                                                                                   | 19     |  |  |  |  |
|   | 6.4                | Running                                                                                                                                 | 20     |  |  |  |  |
| 7 | IEE                | E1588 Support                                                                                                                           | 21     |  |  |  |  |
|   | 7.1                | Clock configuration                                                                                                                     | 21     |  |  |  |  |
|   |                    | 7.1.1 Internal Timestamp Mode(full line figure 7.1)                                                                                     | 22     |  |  |  |  |
|   |                    | 7.1.2 External Timestamp Mode(dashed line figure 7.1)                                                                                   | 22     |  |  |  |  |
|   | 7.2                | Driver interface                                                                                                                        | 22     |  |  |  |  |
|   |                    | 7.2.1 IOCTL                                                                                                                             | 22     |  |  |  |  |
|   |                    | 7.2.2 PTP hardware clock device                                                                                                         | 23     |  |  |  |  |
|   |                    | 7.2.3 ethtool                                                                                                                           | 23     |  |  |  |  |
|   | 7.3                | BSP yocto support                                                                                                                       | 23     |  |  |  |  |

#### **CONTENTS**



| 8 | LibFCI                                     | <b>2</b> 4 |  |  |
|---|--------------------------------------------|------------|--|--|
|   | 8.1 The libfci                             | 24         |  |  |
|   | 8.2 Building libfci library                | 24         |  |  |
|   | 8.3 Entering Yocto development environment | 24         |  |  |
| 9 | Reserved Memory Regions                    |            |  |  |
|   | 9.1 PFE System Buffers region              | 25         |  |  |
|   | 9.2 Buffer Descriptor Rings region         | 25         |  |  |
|   | 9.3 DMA shared pool region                 | 26         |  |  |



# **Revision History**

| Revision     | Change Description                                    |
|--------------|-------------------------------------------------------|
| preEAR 0.4.0 | Initial version for preEAR (FPGA/x86 platform) [JPet] |
| preEAR 0.4.1 | Added VDK info [JPet]                                 |
| preEAR 0.4.3 | Removed VDK, Added S32G [JPet]                        |
| EAR 0.8.0    | Added device-tree config [JPet]                       |
| EAR 0.8.0 P1 | Added libfci [JPet]                                   |
| BETA 0.9.0   | DTS update for kernel 5.4-rt [JPet]                   |
| BETA 0.9.1   | Added Master/Slave [JPet]                             |
| BETA 0.9.2   | Added performance info [JPet]                         |
| BETA 0.9.3   | Added PTP [OSpac], Added cut1.1 info [JPet]           |
| BETA 0.9.4   | Added mem internals [CMan], STR, DT updates [JPet]    |

Table 1.1: Revision History



## Introduction

The Linux PFE driver is, in general, an OS-specific SW component responsible for the complex PFE management. It consists of three main functional blocks:

- The platform driver
  - This part covers the initial, low-level PFE HW bring-up, configuration, firmware upload, and the SW representation of the PFE HW components. This part can be described as a low-level PFE driver providing the interface to the hardware (including the firmware).
- The data-path driver
  - Data-path driver covers tasks related to the Ethernet data traffic in terms of passing the packets between the PFE and the networking stack. This includes the implementation of the Host Interface (HIF) driver and connection with the host OS-provided the networking stack.
- Control path driver

The block in charge of the functionality related to runtime PFE engine configuration and monitoring, implementing the Fast Control Interface (FCI) endpoint which is accessible from the user-space through related FCI library.

The driver runs within the target host OS environment and connects the PFE with networking stack. It provides access to physical Ethernet interfaces via exposing logical interfaces to the OS, and the OS together with user's applications can use the Ethernet connectivity via standard OS-provided interfaces (i.e. network sockets).



# **Building Procedure**

## 3.1 Building the driver

The PFE driver consists of number of smaller software modules. The main module producing the final driver is called *linux-pfeng* and depends on all the others. Successful build gives the final driver library *pfeng.ko* which is an Ethernet driver for particular Linux kernel. Its location within the project tree in <code>sw/linux-pfeng/</code>. There are two ways to build the driver:

- 1. Integrated build by NXP Automotive Linux BSP, powered by Yocto
- 2. Standalone

### 3.1.1 Variant 1: Building within NXP Auto Linux BSP source tree by Yocto

- 1. As prerequisite, save the PFE firmware files to any location on the local disk. Ask NXP representative for PFE firmware package.
- 2. Build standard NXP Auto Linux BSP to check that all necessary componens are ready. This step is not only for verification but it precompiles most of necessary part of BSP which will be used later for creating sdcard image with included pfeng Linux driver.
- 3. Configure additional component by adding the following two lines to the conf/local.conf

```
DISTRO_FEATURES_append = " pfe "
PFE_LOCAL_FIRMWARE_DIR = "<directory path where fw file was saved>"
or (on ALB BSP 28.0 or higher)
NXP_FIRMWARE_LOCAL_DIR = <directory path where fw file was saved>"
```

4. Rebuild BSP to get PFE drivers + firmware included in the sdcard image

### 3.1.2 Variant 2: Building standalone

- 1. As prerequisite check all necessary development requirements:
  - (a) Host development GNU toolchain, including GNU-cc, GNU-make
  - (b) Linux kernel development files
- 2. Go to sw/linux-pfeng/.

2018-2021 NXP Public 0



- 3. Make sure that the following environment variables are set and points to the right directories:
  - (a) KERNELDIR

The direcory where the Linux kernel development files are located.

- (b) Optionally also PLATFORM

  The name of the GNU toolchain platform. In case of NXP Auto Linux BSP, it is "aarch64-linux-gnu"
- (c) Optionally declare compilation for S32G2 cut 1.1 compatibility by adding PFE\_CFG\_IP\_VERSION=PFE\_CFG\_IP\_VERSION\_NPU\_7\_14 (note: without 'a' at the end)
- 4. Clean working directories:

make KERNELDIR=<path to kernel> PLATFORM=aarch64-linux-gnu drv-clean

5. Build the driver:

make KERNELDIR=<path to kernel> PLATFORM=aarch64-linux-gnu all



## **Usage**

### 4.1 Prerequisites

### 4.1.1 NXP S32G274A silicon platform EVB, RDB or RDB2

For usage the software on S32G EVB or RDB/RDB2 boards, the following shall be fullfiled:

• Compatible PFE firmware files.

The compatibility requirements can be find in the driver public repository: https://source.codeaurora.org/external/autobsp32/extra/pfeng

Auto Linux BSP version 29.0 or higher for creation of sdcard bootable image

Note that PFE firmware is being delivered as a standalone product package.

## 4.2 Supported development boards

NXP offers two development boards for S32G274A:

- 1. S32G-VNP-EVB
- 2. S32G-VNP-RDB2

Please refer to board specific user guide to check possible ethernet connectivity. Also check 'NXP Automotive Linux BSP User Manual' which provides comprehensive information for ethernet controllers, including PFE, with supported configurations for U-boot and Linux.

## 4.3 Running the driver

- 1. The *pfeng.ko* driver is embedded in the Auto Linux BSP sdcard image and as such is automatically loaded on Linux startup.
- 2. To check available network interfaces:

```
root@s32g274aevb:~# ifconfig -a
```

there should be some, based on config, *pfeX* interfaces.



3. Configure the IP addresses and bring the interfaces up by executing:

```
root@s32g274aevb:~# ifconfig pfe<0-2> <interface_ip_address>/<mask>
```

4. The *ping* utility can be used to test the connection:

```
root@s32g274aevb:~# ping <remote_ip_address>
```

## 4.4 The driver configuration - device tree

The driver is configurable by changes in the device-tree pfeng node. Usually, the device tree files are using multi-level organization, for example the *fsl-s32g274a-evb.dtb* is built by integration:

- 1. Family DT file fsl-s32-gen1.dtsi
- 2. SoC DT file fsl-s32g274a.dtsi
- 3. Board specific DT file fsl-s32g274a-evb.dts

Device tree bindings for fsl-pfeng:

```
* Copyright 2020-2021 NXP
* NXP S32G274A PFE networking accelerator (pfeng)
Required properties:
- compatible : Should be "fsl, s32g274a-pfeng"
- reg : Address and length of the register set for the device
- resets: Specify PFE partition reset
- interrupts : Should contain all pfeng interrupts but hifs: bmu,upegpt,
- clocks : Should contain at least: pfe_sys, pfe_pe
- memory-region : Physical address space for PFE buffers
                  The following memory regions are required in this exact
                  1) reserved region for the BMU2 buffer pool, must be in
                     the range 0x00020000 - 0xbfffffff;
                  "fsl,pfe-bmu2-pool" compatible;
                  2) reserved region for non-cacheable DMA buffers,
                  "shared-dma-pool" compatible;
                  3) reserved region for buffer descriptor rings,
                  "fsl,pfe-bdr-pool" compatible;
Optional properties:
- dma-coherent : Declare driver DMA cohereenty (S32G2xx cut 2.0+ only)
- fsl, fw-class-name : PFE CLASS firmware filename
- fsl, fw-util-name : PFE UTIL firmware filename
- fsl,pfeng-master-hif-channel : [slave only] The number of master's HIF
   channel (0-3)
- phys : Serdes phys for sgmii interfaces
Required subnode:
- hif : specifies the PFE HIF channel
- emac : [master only] specifies the PFE EMAC interface
```



```
- ethernet : specifies the logical network interface
Required properties for 'hif' subnode:
- compatible : Should be "fsl,pfeng-hif"
- reg : Small number, indexing the HIF channel
- interrupts : Should contain HIF channel interrupt
- fsl,pfeng-hif-mode : Should contain channel mode
- fsl,pfeng-ihc : [master/slave only] Annotate for IHC traffic
Required properties for 'emac' subnode:
- compatible : Should be "fsl,pfeng-emac"
- reg : Small number, indexing the EMAC
- phy-mode : See ethernet.txt file in the same directory
Optional properties for 'emac' subnode:
- clocks : array of TX clocks
Optional subnode for 'emac':
- mdio : specifies the mdio bus, used as a container for phy nodes
  according to phy.txt in the same directory
Requires properties for 'mdio' subnode:
- compatible = Should be "fsl, pfeng-mdio"
Requires properties for 'ethernet' subnode:
- compatible : Should be "fsl,pfeng-logif"
- reg : Small number, indexing the network interfaces
- fsl,pfeng-if-name : Logical interface name visible in the Linux
- fsl,pfeng-logif-mode : 0 for now
- fsl,pfeng-hif-channels : array of phandles of 'hif' nodes
- fsl,pfeng-emac-link : [master/standalone only] phandle to coresponding ^{\prime}
   emac' node
- fsl,pfeng-emac-id : [slave only] PFE EMAC id (0..2)
Optional properties for 'ethernet' subnode:
- fsl,pfeng-ihc : [master/slave only] Declares the interface for IHC
   traffic
- local-mac-address : MAC address
- phy-handle : phandle to the PHY device connected to this device.
- fixed-link : Assume a fixed link. See fixed-link.txt in the same
   directory.
  Use instead of phy-handle.
Example:
reserved-memory {
        #address-cells = <2>;
        \#size-cells = <2>;
        ranges;
        pfe_reserved_bmu2: pfebufs@83000000 {
                compatible = "fsl,pfe-bmu2-pool";
                reg = <0 0x83000000 0 0x200000>;
                no-map;
                status = "okay";
        };
        pfe_reserved: pfebufs@83200000 {
```



```
compatible = "shared-dma-pool";
                reg = <0 0x83200000 0 0x9e0000>;
                no-map;
                status = "okay";
        };
        pfe_reserved_bdr: pfebufs@83bf0000 {
                compatible = "fsl,pfe-bdr-pool";
                reg = <0 0x83be0000 0 0x20000>;
                status = "okay";
        };
};
pfe@46000000 {
        compatible = "fsl,s32g274a-pfeng";
        pfe: pfe@46000000 {
                compatible = "fsl,s32g274a-pfeng";
                reg = \langle 0x0 \ 0x46000000 \ 0x0 \ 0x1000000 \rangle, /* PFE controller
                           <0x0 0x4007ca00 0x0 0x4>; /* S32G274a syscon
                reg-names = "cbus", "gpr";
                #address-cells = <1>;
                \#size-cells = <0>;
                interrupt-parent = <&gic>;
                interrupts = <GIC_SPI 194 IRQ_TYPE_EDGE_RISING>,
                               <GIC_SPI 195 IRQ_TYPE_EDGE_RISING>,
                               <GIC_SPI 196 IRQ_TYPE_EDGE_RISING>,
                               <GIC_SPI 197 IRQ_TYPE_EDGE_RISING>;
                interrupt-names = "bmu", "nocpy", "upegpt", "safety";
                dma-coherent;
                resets = <&reset S32GEN1_SCMI_RST_PART2>;
                reset-names = "pfe_part";
                clocks = <&clks S32G_SCMI_CLK_PFE_AXI>,
                         <&clks S32G_SCMI_CLK_PFE_PE>,
                         <&clks S32G_SCMI_CLK_PFE_TS>;
                clock-names = "pfe_sys", "pfe_pe", "pfe_ts";
                memory-region = <&pfe_reserved_bmu2>, <&pfe_reserved>, <&</pre>
                   pfe_reserved_bdr>;
                fsl, fw-class-name = "s32g_pfe_class.fw";
                fsl, fw-util-name = "s32g_pfe_util.fw";
                phys = <&serdes1 PHY_TYPE_XPCS 0 0>,
                         <&serdes1 PHY_TYPE_XPCS 1 1>,
                          <&serdes0 PHY_TYPE_XPCS 1 1>;
                phy-names = "emac0_xpcs", "emac1_xpcs", "emac2_xpcs";
                nvmem-cells = <&soc_revision>;
                nvmem-cell-names = "soc_revision";
                /* PFE_HIF_0 */
                pfe_hif0: hif@0 {
                         compatible = "fsl,pfeng-hif";
                         #address-cells = <1>;
                         \#size-cells = <0>;
                         status = "disabled";
                         interrupts = <GIC_SPI 190 IRQ_TYPE_EDGE_RISING>;
                         req = <0>;
                         fsl,pfeng-hif-mode = <PFENG HIF MODE EXCLUSIVE>;
                         fsl,pfeng-ihc;
```



```
};
/* PFE HIF 1 */
pfe_hif1: hif@1 {
        compatible = "fsl,pfeng-hif";
        #address-cells = <1>;
        \#size-cells = <0>;
        status = "disabled";
        interrupts = <GIC_SPI 191 IRQ_TYPE_EDGE_RISING>;
        reg = <1>;
        fsl,pfeng-hif-mode = <PFENG_HIF_MODE_EXCLUSIVE>;
};
/* PFE HIF 2 */
pfe_hif2: hif@2 {
        compatible = "fsl,pfeng-hif";
        #address-cells = <1>;
        \#size-cells = <0>;
        status = "disabled";
        interrupts = <GIC_SPI 192 IRQ_TYPE_EDGE_RISING>;
        reg = <2>;
        fsl,pfeng-hif-mode = <PFENG HIF MODE EXCLUSIVE>;
};
/* PFE_EMAC_0 */
pfe_emac0: emac@0 {
        compatible = "fsl,pfeng-emac";
        #address-cells = <1>;
        \#size-cells = <0>;
        status = "okay";
        reg = <0>;
        clocks = <&clks S32G_SCMI_CLK_PFE0_TX_SGMII>,
                 <&clks S32G_SCMI_CLK_PFE0_TX_RGMII>,
                 <&clks S32G_SCMI_CLK_PFE0_TX_RMII>,
                 <&clks S32G_SCMI_CLK_PFE0_TX_MII>,
                 <&clks S32G_SCMI_CLK_PFE0_RX_SGMII>,
                 <&clks S32G SCMI CLK PFE0 RX RGMII>,
                 <&clks S32G_SCMI_CLK_PFE0_RX_RMII>,
                 <&clks S32G_SCMI_CLK_PFE0_RX_MII>;
        clock-names = "tx_sgmii", "tx_rgmii",
                       "tx_rmii", "tx_mii",
                      "rx_sgmii", "rx_rgmii",
                       "rx_rmii", "rx_mii";
        phy-mode = "sqmii";
        /* mdio */
        pfe_mdio0: mdio@0 {
                compatible = "fsl,pfeng-mdio";
                #address-cells = <1>;
                \#size-cells = <0>;
                reg = <0x0>;
        };
};
/* PFE EMAC 1 */
pfe emac1: emac@1 {
        compatible = "fsl,pfeng-emac";
        #address-cells = <1>;
```



```
\#size-cells = <0>;
        status = "okay";
        reg = <1>;
        clocks = <&clks S32G_SCMI_CLK_PFE1_TX_SGMII>,
                 <&clks S32G_SCMI_CLK_PFE1_TX_RGMII>,
                 <&clks S32G_SCMI_CLK_PFE1_TX_RMII>,
                 <&clks S32G_SCMI_CLK_PFE1_TX_MII>,
                 <&clks S32G_SCMI_CLK_PFE1_RX_SGMII>,
                 <&clks S32G_SCMI_CLK_PFE1_RX_RGMII>,
                 <&clks S32G_SCMI_CLK_PFE1_RX_RMII>,
                 <&clks S32G_SCMI_CLK_PFE1_RX_MII>;
        clock-names = "tx_sgmii", "tx_rgmii",
                      "tx_rmii", "tx_mii",
                      "rx_sgmii", "rx_rgmii",
                      "rx_rmii", "rx_mii";
        phy-mode = "rgmii-id";
        /* mdio */
        pfe_mdio1: mdio@1 {
                compatible = "fsl,pfeng-mdio";
                #address-cells = <1>;
                \#size-cells = <0>;
                reg = <0x1>;
        };
};
/* PFE_EMAC_2 */
pfe_emac2: emac@2 {
        compatible = "fsl,pfeng-emac";
        #address-cells = <1>;
        \#size-cells = <0>;
        status = "okay";
        reg = <2>;
        clocks = <&clks S32G SCMI CLK PFE2 TX SGMII>,
                 <&clks S32G_SCMI_CLK_PFE2_TX_RGMII>,
                 <&clks S32G_SCMI_CLK_PFE2_TX_RMII>,
                 <&clks S32G SCMI CLK PFE2 TX MII>,
                 <&clks S32G_SCMI_CLK_PFE2_RX_SGMII>,
                 <&clks S32G_SCMI_CLK_PFE2_RX_RGMII>,
                 <&clks S32G_SCMI_CLK_PFE2_RX_RMII>,
                 <&clks S32G_SCMI_CLK_PFE2_RX_MII>;
        clock-names = "tx_sgmii", "tx_rgmii",
                      "tx_rmii", "tx_mii",
                       "rx_sqmii", "rx_rqmii",
                      "rx_rmii", "rx_mii";
        phy-mode = "rgmii-id";
        /* mdio */
        pfe_mdio2: mdio@2 {
                compatible = "fsl,pfeng-mdio";
                #address-cells = <1>;
                \#size-cells = <0>;
                reg = <0x2>;
        };
};
/* Logical network interface 'pfe0' */
pfe_logif0: ethernet@0 {
```



```
#address-cells = <1>;
                         \#size-cells = <0>;
                        status = "disabled";
                        local-mac-address = [ 00 04 9F BE EF 00 ];
                        fsl,pfeng-if-name = "pfe0";
                        fsl,pfeng-logif-mode = <0>;
                         fsl,pfeng-emac-link = <&pfe_emac0>;
                         fsl,pfeng-hif-channels = <&pfe_hif0>;
                };
                /* Logical network interface 'pfe1' */
                pfe_logif1: ethernet@1 {
                        compatible = "fsl,pfeng-logif";
                         #address-cells = <1>;
                         \#size-cells = <0>;
                        status = "disabled";
                        local-mac-address = [ 00 04 9F BE EF 01 ];
                        fsl,pfeng-if-name = "pfe1";
                        fsl,pfeng-logif-mode = <0>;
                        fsl,pfeng-emac-link = <&pfe_emac1>;
                        fsl,pfeng-hif-channels = <&pfe hif1>;
                };
                /* Logical network interface 'pfe2' */
                pfe_logif2: ethernet@2 {
                        compatible = "fsl,pfeng-logif";
                         #address-cells = <1>;
                         \#size-cells = <0>;
                        status = "disabled";
                        local-mac-address = [ 00 04 9F BE EF 02 ];
                        fsl,pfeng-if-name = "pfe2";
                        fsl,pfeng-logif-mode = <0>;
                         fsl,pfeng-emac-link = <&pfe_emac2>;
                         fsl,pfeng-hif-channels = <&pfe_hif2>;
                };
        };
};
/* Example of PFE slave driver entry. Requires SLAVE mode driver */
pfe_slave: pfe_slave@46000000 {
        compatible = "fsl,s32g274a-pfeng-slave";
        reg = <0x0 0x46000000 0x0 0x1000000>;
                                                 /* PFE controller */
        \#address-cells = <0x01>;
        \#size-cells = <0x00>;
        interrupt-parent = <&gic>;
        dma-coherent;
        memory-region = <&pfe_reserved_slave>,
                        <&pfe_reserved_bdr_slave>;
        fsl,pfeng-master-hif-channel = <0>;
        status = "disabled";
        /* PFE HIF 3 */
        pfesl_hif3: hif@3 {
                compatible = "fsl,pfeng-hif";
                #address-cells = <1>;
                \#size-cells = <0>;
                status = "okay";
```

compatible = "fsl,pfeng-logif";



```
interrupts = <GIC SPI 193 IRQ TYPE EDGE RISING>;
                rea = <3>;
                fsl,pfeng-hif-mode = <PFENG HIF MODE SHARED>;
                fsl, pfeng-ihc;
        };
        /* Logical network interface 'pfe0sl' */
        pfesl_logif0: ethernet@0 {
                compatible = "fsl,pfeng-logif";
                #address-cells = <1>;
                \#size-cells = <0>;
                status = "okay";
                local-mac-address = [ 00 04 9F BE FF 10 ];
                fsl,pfeng-if-name = "pfe0sl";
                fsl,pfeng-logif-mode = <0>;
                fsl,pfeng-emac-id = <0>; /* PFE_EMAC_0 */
                fsl,pfeng-hif-channels = <&pfesl_hif3>;
        };
        /* Logical network interface 'pfe1sl' */
        pfesl_logif1: ethernet@1 {
                compatible = "fsl,pfeng-logif";
                #address-cells = <1>;
                \#size-cells = <0>;
                status = "okay";
                local-mac-address = [ 00 04 9F BE FF 11 ];
                fsl,pfeng-if-name = "pfe1sl";
                fsl,pfeng-logif-mode = <0>;
                fsl,pfeng-emac-id = <1>; /* PFE_EMAC_1 */
                fsl,pfeng-hif-channels = <&pfesl_hif3>;
        };
};
```

### 4.5 Performance consideration

To gain highest possible throughput on host interface, several options exist to enhance performance, loosing other features or resources:

- Double key ring size
  - Better throughput can be achieved by doubling HIF channel ring size. By default there is 256 entries in the ring. It's compile time option which must be changed in source code header file 'pfe\_platform/public/pfe\_platform\_cfg.h', in named constant PFE\_- HIF\_RING\_CFG\_LENGTH.
  - Restriction applies: not all interfaces can be enabled or reserved memory region has to be enlarged in device tree.
- Restrict RAM to 1GB (mem=1g)
  - Restrict Linux kernel memory to 1G limit. It minimizes bounce buffering on TX.
  - Disadvantage: waste memory.



## 4.6 Silicon cut 1.1 backward compatibility

By default, the driver is built for the cut 2.0 S32G silicon version.

For the older cut 1.1 silicon version the driver contains compile time errata workarounds that affect the overall PFE performance when activated.

The driver cannot accommodate both silicon versions at runtime, so users of the cut 1.1 variant have to rebuild the driver manually by adding the 'PFE\_CFG\_IP\_VERSION=PFE\_CFG\_IP\_VERSION\_NPU\_7\_14' compile time option to the driver 'make' command line.

The table below summarizes configuration requirements for the two driver modes based on silicon version:

| Driver version           | Compatible string           | DMA coherency  |
|--------------------------|-----------------------------|----------------|
| cut 2.0 driver (default) | 'fsl,s32g274a-pfeng'        | 'dma-coherent' |
| cut 1.1 driver           | 'fsl,s32g274a-pfeng-cut1.1' | -              |

Note that the cut 1.1 driver requires a special device compatibility string and the 'dmacoherency' property to be removed from the PFE device tree node. To avoid building different device tree blobs for the two driver modes, the bootloader should provide the above changes as device tree fixups for the cut1.1 silicon version.



## Power management

### 5.1 Prerequisite

### **5.1.1** Compile time

• Linux kernel source configured with CONFIG\_PM and CONFIG\_SUSPEND

#### **5.1.2** Run time

Linux kernel with support for Suspend to RAM (STR) together with kernel reset controller driver for S32G

Please read more about STR in 'Linux BSP User Manual', chapter 'Power Management'.

· Hardware, capable of doing suspend

For hardware reasons, the power management features are only supported on S32G-VNP-RDB2 boards

## **5.2** Suspend to RAM

The driver implements .*suspend()* and .*resume()* callbacks, which are used by system to manage power states.

### **5.2.1 Suspend**

During suspend, the driver does ordered stopping of all managed components:

- Network interfaces (pfe0, pfe1 ...)
- PFE EMACs and its clocks (RX/TX)
- PFE HIF channels
- PFE Platform
- PFE clocks



#### **5.2.2** Resume

On resume, the steps are way around, but preceding by S32G PFE partition reset.

The driver don't preserve any configuration set by FCI API.

In case of additional, post-startup changes, made by FCI API, it is user's reponsibility to restore them after return from suspend.

2018-2021 NXP Public 18



## **Master-Slave feature**

## 6.1 Prerequisite

The driver can run in multiple instances within the same system to allow sharing the PFE-provided connectivity using dedicated host interfaces. To enable Master-Slave, the driver gets extended to two binaries, *pfeng.ko* which additionally contains Inter-HIF-communication (aka 'IHC') support and which acts as Master and *pfeng-slave.ko*, which also contains IHC, but has lack of direct PFE controller manageability.

Master-Slave feature requires additional configuration in device tree

### 6.2 Master

To build PFE driver with Master functionality, additional comple-time option is required:

```
make <options> PFE_CFG_MULTI_INSTANCE_SUPPORT=1 PFE_CFG_PFE_MASTER=1 ...
```

The Master requires marking one of the configured network interface for IHC transport in device tree by setting *fsl,pfeng-ihc* property, for example:

```
&pfe_logif0 {
          fsl,pfeng-ihc;
          phy-handle = <&mdio_a_phy4>;
};
```

Only one network interface can carry 'fsl,pfeng-ihc property'

### 6.3 Slave

To build PFE driver with Slave functionality, additional comiple-time option is required:

```
make <options> PFE_CFG_MULTI_INSTANCE_SUPPORT=1 PFE_CFG_PFE_MASTER=0 ...
```

The Slave requires two configuration options in device tree:

• setting global configuration option 'fsl,pfeng-master-hif-channel' with Master's HIF channel number (see example in Master section). The option can be overwritten by command line parameter *master\_ihc\_chnl*.



• marking one of the configured network interface for IHC transport in device tree by setting *fsl,pfeng-ihc* property, similarly like in Master section 6.2.

Only one network interface can carry 'fsl,pfeng-ihc property'

### 6.4 Running

When running a master-slave scenario, following points apply:

- Master driver must always be executed first to allow slave drivers to connect to it during their start-up phase.
- Slave driver(s) configure the PFE to ensure that packets can reach the driver. The PFE then distributes traffic to particular driver instances using destination MAC address of received packets following given rules:
  - Packets received via PFE EMAC interfaces with destination MAC address matching some running slave driver instance are delivered to that instance.
  - All remaining traffic is delivered to the master driver instance.
  - Default MAC address-based traffic distribution can be changed using FCI.
  - When master driver is reset, all slaves must be subsequently reset too

2018-2021 NXP Public 20



## **IEEE1588 Support**

The PFE is capable of providing precise, adjustable time reference with ability to timestamp ingress and egress PTP frames. Once enabled the driver ensures that ingress and egress PTP frames are timestamped at MAC level and provides timestamp to the stack. Supported synchronization modes:

- End to End SYNC, Follow\_Up, Delay\_Req, Delay\_Resp
  - For UDP supported only on IP: 224.0.1.129, 224.0.1.130, 224.0.1.131, 224.0.1.132
- Peer to Peer Pdelay\_Req, Pdelay\_Resp, Pdelay\_Resp\_Follow\_Up
  - For UDP supported only on IP: 224.0.0.107

#### Transport layers:

- Ethernet Supported
- UDP over IPv4 Supporetd
- UDP over IPV6 Currently not supported. Support will be added in future.

## 7.1 Clock configuration

S32G platform allows multiple clock configurations depicted in figure 7.1.



Figure 7.1: S32G2 IEEE1588 clock distribution



### 7.1.1 Internal Timestamp Mode(full line figure 7.1)

In this mode the PFE\_EMAC is maintaining system time using internal timer clocked by reference signal and uses the timer value to timestamp frames or report current system time. GMAC\_TS\_CLK is used as reference. This is the only supported configuration. For this to work you have to add "pfe\_ts" clock to the device tree.

Example (from *fsl-s32g274a.dtsi*):

In case the "pfe ts" clock is not provided, the timestamping feature is disabled

In Internal Timestamp Mode the 'GMAC\_TS\_CLK' (RM clock name) resp. 'S32G\_SCMI\_-CLK\_PFE\_TS' (SCMI clock name) should be configured with respect to recommended frequency:

| Mode                 | Minimum Frequency |
|----------------------|-------------------|
| 10 Mbps Full Duplex  | 5 MHz             |
| 10 Mbps Half Duplex  | 5 MHz             |
| 100 Mbps Full Duplex | 5 MHz             |
| 100 Mbps Half Duplex | 5 MHz             |
| 1 Gbps Full Duplex   | 5 MHz             |
| 1 Gbps Half Duplex   | 18.75 MHz         |
| 2.5 Gbps Full Duplex | 11.72 MHz         |
| 2.5 Gbps Half Duplex | 46.875 MHz        |

### 7.1.2 External Timestamp Mode(dashed line figure 7.1)

The internal PFE\_EMAC timer is disabled and PFE\_EMAC is using time information delivered from external source. This source can be PFE\_EMAC0 or the GMAC instance as shown in figure with the dashed line. NOTE: This configuration is currently not supported.

### 7.2 Driver interface

Driver implements standard Linux API for HW timestamping configuration.

#### **7.2.1 IOCTL**

The driver supports standart ioctl for timestamp configuration. This API is typically called by PTP stack.

- SIOCSHWTSTAMP Set configuration (struct hwtstamp\_config)
  - TX configuration: Timestamping on/off
  - RX configuration: Message specific configuration currently not supported, all P2P and E2E packets are always timestamped.



• SIOCGHWTSTAMP - Get configuration (struct hwtstamp\_config)

#### 7.2.2 PTP hardware clock device

After driver initialization there should be one device /dev/ptpX for each PFE\_EMAC. Association of clock and interface is available in ethtool as "PTP Hardware Clock" number.

#### **7.2.3** ethtool

Driver implements standard ethtool API for getting timestamp options via ETHTOOL\_GET\_-TS\_INFO.

Example output:

```
root@s32g274aevb:~# ethtool -T pfe0
Time stamping parameters for pfe0:
Capabilities:
            hardware-transmit (SOF_TIMESTAMPING_TX_HARDWARE) software-transmit (SOF_TIMESTAMPING_TX_SOFTWARE)
            hardware-receive (SOF_TIMESTAMPING_RX_HARDWARE) software-receive (SOF_TIMESTAMPING_RX_SOFTWARE)
             software-system-clock (SOF_TIMESTAMPING_SOFTWARE)
                                                (SOF_TIMESTAMPING_RAW_HARDWARE)
            hardware-raw-clock
PTP Hardware Clock: 0
Hardware Transmit Timestamp Modes:
                                                (HWTSTAMP_TX_OFF)
                                                (HWTSTAMP_TX_ON)
Hardware Receive Filter Modes:
                                                (HWTSTAMP_FILTER NONE)
             none
                                                (HWTSTAMP_FILTER_SOME)
             some
            ptpv1-14-event
ptpv1-14-sync
ptpv1-14-delay-req
                                                (HWTSTAMP_FILTER_PTP_V1_L4_EVENT)
                                                (HWTSTAMP FILTER PTP V1 L4 SYNC)
                                                (HWTSTAMP_FILTER_PTP_V1_L4_DELAY_REQ)
            ptpv1-14-delay-req ptpv2-14-event (HWTSTAMP_FILTER_PTP_V2_L4_EVENT)
ptpv2-14-sync (HWTSTAMP_FILTER_PTP_V2_L4_SYNC)
ptpv2-14-delay-req (HWTSTAMP_FILTER_PTP_V2_L4_DELAY_REQ)
ptpv2-12-event (HWTSTAMP_FILTER_PTP_V2_L2_EVENT)
ptpv2-12-delay-req (HWTSTAMP_FILTER_PTP_V2_L2_SYNC)
ptpv2-12-delay-req (HWTSTAMP_FILTER_PTP_V2_L2_DELAY_REQ)
ptpv2-event (HWTSTAMP_FILTER_PTP_V2_EVENT)
(HWTSTAMP_FILTER_PTP_V2_SYNC)
            ptpv2-sync
                                                (HWTSTAMP_FILTER_PTP_V2_SYNC)
             ptpv2-delay-req
                                                (HWTSTAMP_FILTER_PTP_V2_DELAY_REQ)
```

### 7.3 BSP vocto support

Hint: add package 'linuxptp' to your Yocto configuration file. With this configuration you get acces to Linux PTP stack ptp4l and clock synchronization demon "phc2sys" for advanced configurations.

```
IMAGE_INSTALL_append = " linuxptp"
```



## LibFCI

### 8.1 The libfci

Additional features provided by the PFE can be managed using FCI API. The driver release package contains library sources which can be used to control PFE from custom user's application. Details about usage of the library can be found in 'FCI API Reference' document.

### 8.2 Building libfci library

The simplest way, how to get in touch with libfci framework, is using the Auto Linux BSP facitilies. The BSP contains libfci recipe in meta-alb/recipes-extended subdirectory, which is intendent for quick jump-in to the FCI development. By default, the libfci is not enabled, so the first step is to create libfci.a library:

```
user@dev:~/fsl-auto-yocto-bsp/build_s32g274aevb$ bitbake -c compile libfci
```

## 8.3 Entering Yocto development environment

Yocto offers extra task called devshell. The task will deposit all the libfci source code into a directory, apply all patches included in the recipe, and then open a terminal in that directory:

```
user@dev:~/fsl-auto-yocto-bsp/build_s32g274aevb$ bitbake -c devshell libfci
```

When invoked, all environmental variables are set up exactly like for compilation. Use predefined *\$CC*, *\$CXX*, *\$PATH*. The libfci.a library, which was compiled in previous step, is located in sw/xfci/libfci/build/release directory, what can checked by *find* command, inside devshell terminal:

```
root@dev:~/fsl-auto-.../libfci/0.9.4-r0/git# find . -name libfci.a
./sw/xfci/libfci/build/release/libfci.a
```

The same way it can be checked for required header files:

```
root@dev:~/fsl-auto-.../libfci/0.9.4-r0/git# find . -name libfci.h
./sw/xfci/libfci/public/libfci.h
```

The above information is enough to have all necessary bits for libfci-enabled application development.

2018-2021 NXP Public 24



# **Reserved Memory Regions**

The PFE accesses various data structures stored in the host memory. The location of some of these data structures is configurable to allow the integrator to place them in such a way as to either optimize performance (place some data structures in faster memory) and/or tune the application from security/safety perspective (place some data structures into dedicated container with restricted access permissions). The following reserved memory regions are currently defined for the Linux PFE driver:

## 9.1 PFE System Buffers region

This is the memory region where Ethernet frames should be stored while they are being processed by the PFE. The region is defined in the device tree by a dedicated 'reserved-memory' sub-node having the 'fsl,pfe-bmu2-pool' compatibility string. The memory region is exclusively reserved for PFE's BMU2 hardware block managing the buffers for in-transit Ethernet frames. The physical start address, alignment and size of this region meet the restrictions imposed by the BMU2 hardware block. The allocation of the BMU2 buffer pool is also controlled by the PFE\_CFG\_SYS\_MEM compile time configuration option. To allocate the BMU2 buffer pool inside this exclusive memory region PFE\_CFG\_SYS\_MEM should be set to 'pfe-bmu2-pool' (current default). The BMU2 buffer pool can also be allocated inside the DMA shared pool region by setting PFE\_CFG\_SYS\_MEM to 'pfe\_ddr' but this is not recommended (sub-optimal).

### 9.2 Buffer Descriptor Rings region

This is a cache enabled memory region reserved for performance critical data structures. It is intended mainly for the Rx and Tx buffer descriptor rings, but it is also used for storing preallocated Tx packet metadata headers. The memory region is defined in the device tree by a dedicated 'reserved-memory' sub-node having the 'fsl,pfe-bdr-pool' compatibility string. This is a cache coherent memory region that meets the DMA address range restrictions of the PFE hardware. Allocation in this region is also controlled by the PFE\_CFG\_BDR\_MEM compile time configuration option, which should be set to 'pfe-bdr-pool' (current default). By setting PFE\_CFG\_BDR\_MEM to 'pfe\_ddr', all allocations targeting the PFE\_CFG\_BDR\_MEM memory pool (buffer descriptors and Tx headers) will be made in the non-cacheable DMA shared pool region resulting in performance degradation.



## 9.3 DMA shared pool region

This is the common memory region reserved for the remaining DMA structures used by PFE, most notable the routing table. It is a 'shared-dma-pool' compatible memory region, managed by the Linux kernel system code, and all DMA-API allocations are performed from here. Linux maps this zone as non-cacheable. To allocate memory pools inside this shared memory region set the corresponding PFE\_CFG\_\*\_MEM compile time configuration options to 'pfe\_ddr'.