# RGMII to AXI Stream IP

Green Electrons GmbH

June 17, 2022

# Contents

| 1        | Support and Contact                         | 6  |
|----------|---------------------------------------------|----|
| <b>2</b> | Introduction                                | 7  |
| 3        | Tools                                       | 8  |
| 4        | IP Package Content                          | 9  |
|          | 4.1 constraints                             | 9  |
|          | 4.2 doc                                     | 9  |
|          | 4.3 downloads                               | 9  |
|          | $4.4$ packaged_ip                           | 10 |
|          | $4.5$ packaged_ip_rmii                      | 10 |
|          | 4.6 tcl                                     | 10 |
|          | 4.7 verilog                                 | 10 |
|          | $4.8$ verilog_sim                           | 11 |
|          | 4.9 videos                                  | 11 |
|          | $4.10$ vivado_project                       | 11 |
|          | 4.10.1 Howto Create Example Vivado Projects | 11 |
|          | $4.11$ vivado_package                       | 11 |
|          | 4.11.1 Creating Packaged IP                 | 11 |
|          | 4.12 xci                                    | 12 |
| <b>5</b> | Modes of Operation                          | 13 |
|          | 5.1 Direct sampling mode                    | 13 |
|          | 5.2 RXC capture mode                        | 13 |
|          | 5.3 Which Mode to Use?                      | 13 |
| 6        | Ports and Interfaces                        | 14 |
| Ū        | 6.1 Interfaces                              | 14 |
|          | 6.1.1 maxis from PHY                        | 14 |
|          | 6.1.2 saxis TO PHY                          | 15 |
|          | 6.1.3 CBC calculation for maxis FROM PHY    | 15 |
|          | 6.1.4 CBC calculation for maxis TO PHY      | 15 |
|          | 615 RGMTT                                   | 16 |
|          | 616 RMTT                                    | 16 |
|          | 6.2 Ports                                   | 16 |
|          | 6.3 Clocks and Resets                       | 16 |
|          | 6.3.1 TX Clock                              | 17 |
|          | 6.3.2 BX Clock                              | 17 |
|          | 6.3.3 AXI Streams Clocks                    | 17 |
|          |                                             | Τ1 |
| 7        | IP Parameters and Configuration (RGMII PHY) | 18 |
|          | 7.1 PHY Type                                | 18 |
|          | 7.2 PHY Address                             | 18 |

| 7.3  | Force 100MBits Link                        | 18 |
|------|--------------------------------------------|----|
| 7.4  | Loopback Enable                            | 18 |
| 7.5  | Use RX clock to capture data               | 18 |
| 7.6  | Set RX skew                                | 18 |
| 7.7  | Use Clock Manager                          | 20 |
| 7.8  | Skew Values                                | 20 |
| 7.9  | PHY Reset Duration                         | 20 |
| 7.10 | Period of Read PHY Status                  | 20 |
| 7.11 | AXI Master Enable                          | 20 |
| 7.12 | AXI Slave Config Enable                    | 20 |
| 7.13 | AXI Streams Enable                         | 21 |
| 7.14 | AXI Stream Width (Bits)                    | 21 |
| 7.15 | Drop Preamble FSD                          | 21 |
| 7.16 | RX Drop Bad CRC                            | 21 |
| 7.17 | RX Enable CRC Check                        | 21 |
| 7.18 | TX Add CRC to Packet                       | 21 |
| 7.19 | TX Wait for Complete Packet                | 21 |
| 7.20 | IP Parameters and Configuration (RMII PHY) | 21 |
|      |                                            |    |
| Reg  | isters                                     | 23 |
| - 0  |                                            | -  |
| Evn  | nanle Designs                              | 24 |

| LXI | naple Designs              | <b>4</b> 4 |
|-----|----------------------------|------------|
| 9.1 | RXC capture                | 24         |
| 9.2 | Enabling Loopback Mode     | 25         |
| 9.3 | Packet Generator           | 28         |
| 9.4 | Programming Skew Registers | 28         |
|     |                            |            |

## 10 Tested Boards

| 1 | 1 | Revisions |
|---|---|-----------|
|   |   |           |

# List of Figures

| 1  | Simplified connectivity of the ip. (RGMII PHY)                                       | 7  |
|----|--------------------------------------------------------------------------------------|----|
| 2  | Simplified connectivity of the ip. (RMII PHY)                                        | 7  |
| 3  | Symbolic representation of the IP in Vivado design flow. (RGMII PHY)                 | 14 |
| 4  | Symbolic representation of the IP in Vivado design flow. (RMII PHY)                  | 15 |
| 5  | IP parameters configuration GUI. In this setup, IP is configured to force the        |    |
|    | PHY to 100MBits ethernet.                                                            | 19 |
| 6  | IP parameters configuration GUI. In this setup, IP is configured to connect to a     |    |
|    | RMII PHY                                                                             | 22 |
| 7  | Vivado block design of RXC capture design example. 1 GBits/s link speed              | 24 |
| 8  | Vivado block design of RXC capture design example. 100 MB<br>its/s link speed. $\ .$ | 25 |
| 9  | IP configuration 1 GBits/s link                                                      | 25 |
| 10 | IP configuration 100 MBits/s link                                                    | 26 |
| 11 | VIO setup for controlling reset and generation of packets                            | 26 |
| 12 | Captured ILA waveform of an arriving packet.                                         | 26 |
| 13 | Captured ILA waveform of transmitting a packet (RMII mode)                           | 27 |
| 14 | Wireshark capturing ARP packets produced by our packet generator IP. (Arty           |    |
|    | A7 board, RMII PHY)                                                                  | 27 |
| 15 | Example ILA waveform capture, loopback is enabled                                    | 28 |
|    |                                                                                      |    |

# List of Tables

| 1 | List of top level folders in delivered IP package |
|---|---------------------------------------------------|
| 2 | List of interfaces of the IP                      |
| 3 | List of signals used in RGMII interface           |
| 4 | List of signals used in RMII interface            |
| 5 | List of ports of the IP                           |
| 6 | List of clocks and resets of the IP               |

## **1** Support and Contact

The original web page for RGMII to AXI Stream can be found here.

Might you have any questions regarding this IP or might you face any difficulties during using the IP, please write an email to mamsadegh@green-electrons.com. We ensure your question or issue will be addressed.

Migh you think anything is missing from the IP, or might you need any further customization to the IP or its related interfaces so that you can use it successfully in your project, please also write mamsadegh@green-electrons.com.



Figure 1: Simplified connectivity of the ip. (RGMII PHY)



Figure 2: Simplified connectivity of the ip. (RMII PHY)

## 2 Introduction

RGMII-to-AXIS IP provides an easy to use interface between a RGMII or a RMII PHY and other FPGA modules.

Figure 1 show how the IP gets connected to a RGMII PHY and to other FPGA modules. Figure 2 show how the IP gets connected to a RMII PHY and to other FPGA modules.

Note that in both cases the IP is called *RGMII to AXIS* however it is capable of talking to both RGMII and RMII PHYs.

## 3 Tools

The IP is originally created and tested with Xilinx 2020.2 tools. The IP can be used with this version or any later version of the Xilinx tool.

Compatibility of the IP is planned to expand to Intel and Microchip FPGAs as well. This is currently an ongoing task.

| index Folder Description |                  | Description                                           |  |
|--------------------------|------------------|-------------------------------------------------------|--|
| 1                        | constraints      | Timing and pinning constraints files                  |  |
| 2                        | doc              | Documentation and design tests snapshots              |  |
| 3                        | downloads        | Key downloaded datasheets and documents               |  |
| 4                        | packaged_ip      | Vivado packaged ip (for RGMII PHY)                    |  |
| 5                        | packaged_ip_rmii | Vivado packaged ip (for RMII PHY)                     |  |
| 6                        | tcl              | Vivado tcl scripts                                    |  |
| 7                        | verilog          | Verilog RTL source code of the IP                     |  |
| 8                        | verilog_sim      | Verilog code of simulation and verification of the IP |  |
| 9                        | videos           | Videos describing the IP and examples                 |  |
| 10                       | vivado_package   | Project folder for packaging the IP                   |  |
| 11                       | vivado_project   | Project folder for verification of the IP             |  |
| 12                       | xci              | Folder containing xci files of IPs used in our design |  |

Table 1: List of top level folders in delivered IP package

## 4 IP Package Content

Table 4 shows the list of folders in delivered IP package.

### 4.1 constraints

This folder contains constraints files used for pinning during design examples. Pinning constraint files are board depended. Our design examples are for the following boards:

- 1. Enclustra XU5 ZYNQ Ultrascale+
- 2. Digilent Arty A7
- 3. Digilent Nexys Video

#### 4.2 doc

This folder contains the current user guide and also photos taken from hardware setups during tests or snapshots of vivado designs, simulation waveforms and similar items.

#### 4.3 downloads

This folder contains datasheets and documents related to this IP. It is advised to always download the latest version directly from Internet.

#### 4.4 packaged\_ip

RGMII to AXI stream Vivado packaged IP is inside this folder. When the IP package is delivered, it contains this folder already populated with the packaged IP. You can include this folder in repositories of your Vivado project to use the IP in your Vivado block design.

If you made changes to the RTL source code of the IP (e.g. you added a new port) then you need to package the IP again. Refer to 4.11.1 for further description of packaging the IP in Vivado.

#### 4.5 packaged\_ip\_rmii

Vivado packaged IP for talking to a RMII PHY is inside this folder. This folder is already populated when the IP package is dilevered. However, you can package the IP yourself too. Refer to 4.11.1 for further description of packaging the IP in Vivado.

#### 4.6 tcl

This folder contains tcl scripts for packaging the IP as well as creating example vivado projects. The following list shows these scripts along with their description.

- create\_example\_direct\_sampling\_zynquplus.tcl: For XU5 board, Vivado design example shows how to use RGMII to AXI stream ip in direct sampling mode.
- create\_example\_nexys\_video.tcl : For Digilent Nexys Video Artix 7 board, Vivado design example, IP is configured in RXC capture mode, link speed is 1 Gbits/s.
- create\_example\_post\_route.tcl : Vivado project for post-route simulation of the IP
- create\_example\_rxc\_capture\_100mbits\_zynquplus.tcl : For XU5 board, example Vivado project which uses the IP in 100 MBits/s mode.
- create\_example\_rxc\_capture\_zynquplus.tcl : For XU5 board, example vivado project which uses the IP in RXC capture mode. Link speed is 1 GBit/s.
- create\_example\_with\_dummy\_modem\_zynquplus.tcl : Example vivado project which shows how the IP can be connected to other on-FPGA modules.
- create\_packaged\_ip.tcl : Packaging the IP can be done using this script.
- create\_packaged\_ip\_rmii.tcl: Packaging the IP for RMII PHY can be done using this script.
- create\_example\_rxc\_capture\_100mbits\_rmii\_artix7.tcl: Creates an example design for Arty A7 board with RMII PHY.

#### 4.7 verilog

IP source code (written in Verilog) is in this folder.

#### 4.8 verilog\_sim

Verilog simulation files of the IP are in this folder.

#### 4.9 videos

Captured videos related to IP are in this folder.

#### 4.10 vivado\_project

Use this folder for creating Vivado example projects.

#### 4.10.1 Howto Create Example Vivado Projects

In Windows run Vivado. After that, within Vivado, using the tcl console go to vivado\_project folder. From there, source the tcl script that you want.

For example, imagine we have extracted the delivered file into:

 $C: \hdl \rgmii-to-axi-stream$ 

We run Vivado and in tcl console we issue:

cd C:/hdl/rgmii-to-axi-stream/vivado\_project

And then we issue:

source ../tcl/filename.tcl

Replace filename.tcl with the name of any tcl script you want to run.

In Linux, one usually sources Vivado's settings script and then changes directory into vivado\_project and then runs Vivado using the following command:

```
vivado -source ../tcl/filename.tcl
```

#### 4.11 vivado\_package

Use this folder for packaging the IP. Refer to section 4.11.1 for further instructions.

#### 4.11.1 Creating Packaged IP

The package is dilevered with RGMII to AXI stream IP already packaged inside packaged\_ip folder. However you can re-package the IP as well. Use the vivado\_package folder for packaging the IP. In Linux, go within that folder and run Vivado:

vivado -source ../tcl/create\_packaged\_ip.tcl

In windows run Vivado and then go to vivado\_package folder (as described in section 4.10.1) and source the create\_packaged\_ip.tcl script.

If you are packaging the IP for talking to a RMII PHY, then do:

vivado -source ../tcl/create\_packaged\_ip\_rmii.tcl

In this case the packaged IP will be created inside packaged\_ip\_rmii folder.

## 4.12 xci

XCI files are xilinx IP definition files. XCI files for different IPs used within the RGMII to AXI Stream bridge are in this folder.

## 5 Modes of Operation

The IP has 2 different operation modes:

- 1. Direct sampling
- 2. RXC capture

## 5.1 Direct sampling mode

In this mode the IP samples RX clock, RX valid and RX data lines all together using the provided aclk\_375MHz pulse. That means the IP does not use RXC for capturing the data, instead it treats RXC just like a data line. The IP then internally selects proper received data bits based on edges of the captured RXC.

## 5.2 RXC capture mode

In this mode the IP uses RXC as a clock. This clock will be used for flip flops who capture the RX data and control lines.

## 5.3 Which Mode to Use?

For receiving data from PHY it is always better to use RXC capture mode when possible. However sometimes the pinning of FPGA is so that the RXC pin can not be used as a clock source in the design. In these situations direct sampling mode allows the designers to still operate the RGMII link.

|    |                                                             | rgmii_to_axi_stream_0                       |
|----|-------------------------------------------------------------|---------------------------------------------|
|    | <pre>s_axis_TO_PHY aclk_375MHz aclk_50MHz aclk_250MHz</pre> | m_axis_FROM_PHY +<br>RGMII +<br>PHY_RESET_N |
| -0 | aresetn                                                     |                                             |
| _  | m_axis_FROM_PHY_aclk<br>s_axis_TO_PHY_aclk                  | debug_dropped_packet_count[15:0]            |
|    |                                                             | gmii_to_axi_stream_v1_0                     |

Figure 3: Symbolic representation of the IP in Vivado design flow. (RGMII PHY)

| index | Interface Name  | Direction | Description                        |
|-------|-----------------|-----------|------------------------------------|
| 1     | m_axis_from_PHY | Master    | Received ethernet packets from PHY |
| 2     | s_axis_TO_PHY   | Slave     | Ethernet packets to PHY            |
| 3     | RGMII           | Master    | RGMII signals to and from the PHY  |
| 4     | RMII            | Master    | RMII signals to and from the PHY   |

Table 2: List of interfaces of the IP

## 6 Ports and Interfaces

Figure 3 shows a symbolic representation of the IP in Vivado block design flow when connecting to a RGMII PHY. Figure 4 shows a symbolic representation of the IP in Vivado block design flow when connecting to a RMII PHY. As can be seen the IP has fewer clock ports when connecting to a RMII PHY.

## 6.1 Interfaces

Table 6.1 describes the interfaces of the IP. Both of m\_axis\_from\_PHY and s\_axis\_TO\_PHY use AXI stream to transfer packets between the IP and other modules. RGMII interface is used when the IP is packaged for talking to a RGMII PHY. RMII interface is used when the IP is packaged for talking to a RMII PHY.

### 6.1.1 m\_axis\_from\_PHY

Ethernet packets received by PHY from the network will be passed to our IP using RGMII interface. Our IP captures these packets, checks their CRC and passes these packets to next FPGA module using this AXI stream interface.



rgmii\_to\_axi\_stream\_v1\_0

Figure 4: Symbolic representation of the IP in Vivado design flow. (RMII PHY)

Notes about this interface:

- 1. The data (tdata) width of this AXI stream interface is by default 1 bytes.
- 2. TUSER signal indicates the CRC status of the received packet. If it is high while the IP is sending the packet out, that means packet has a CRC error.
- 3. This interface operates at m\_axis\_from\_PHY\_aclk clock domain.

#### $6.1.2 \quad \texttt{s\_axis\_TO\_PHY}$

Ethernet packets which should be sent over network will be given to our IP by other on-FPGA modules, through this interface. Our IP receives the ethernet packet and then sends it to PHY using the RGMII interface.

Notes about this interface:

- 1. The data (tdata) width of this AXI stream interface is by default 1 bytes.
- 2. This interface operates at m\_axis\_TO\_PHY\_aclk clock domain.

#### 6.1.3 CRC calculation for m\_axis\_FROM\_PHY

The IP calculates the CRC of each of the arrived packets from the PHY. As described TUSER is used to indicate if a packet has CRC error.

#### 6.1.4 CRC calculation for m\_axis\_TO\_PHY

The IP can calculate the CRC for packets before sending them to PHY. The IP also allows the user to do it himself.

In Figure 7 there is a configuration option Tx Add CRC to Packet. When set to TRUE the IP will receive your ethernet packet, will calculate its CRC and will send the result to the PHY. When set to FALSE the IP assumes the arrived ethernet packet from the previous module already contains the calculated CRC.

| index | Signal Name | Direction | Description          |
|-------|-------------|-----------|----------------------|
| 1     | RXD[3:0]    | Input     | RX Data              |
| 2     | RXC         | Input     | RX Clock             |
| 3     | RXCTL       | Input     | RX Valid and Control |
| 4     | TXD[3:0]    | Output    | TX Data              |
| 5     | TXC         | Output    | TX Clock             |
| 6     | TXCTL       | Output    | TX Valid and Control |

Table 3: List of signals used in RGMII interface.

| index | Signal Name | Direction | Description          |
|-------|-------------|-----------|----------------------|
| 1     | RXD[3:0]    | Input     | RX Data              |
| 2     | RXC         | Input     | RX Clock             |
| 3     | RXCTL       | Input     | RX Valid and Control |
| 4     | RXER        | Input     | RX error             |
| 5     | TXD[3:0]    | Output    | TX Data              |
| 6     | TXC         | Input     | TX Clock             |
| 7     | TXCTL       | Output    | TX Valid and Control |

Table 4: List of signals used in RMII interface.

#### 6.1.5 rgmII

Table 3 lists the RGMII signals between our IP and any RGMII PHY.

#### 6.1.6 RMII

Table 4 lists the RMII signals between our IP and any RMII PHY.

## 6.2 Ports

Table 5 describes the rest of the ports of the IP.

#### 6.3 Clocks and Resets

Table 6 shows the clock ports of the IP. It also shows the reset.

| index | Port Name | Direction | Description     |
|-------|-----------|-----------|-----------------|
| 1     | PHY_MDC   | IO        | MDIO Clock port |
| 2     | PHY_MDIO  | IO        | MDIO Data port  |

Table 5: List of ports of the IP

| index | Port Name   | Description                                                  |
|-------|-------------|--------------------------------------------------------------|
| 1     | aclk_50MHz  | 50 MHz clock, used for MDIO                                  |
| 2     | aclk_250MHz | TX clock used to send packets to PHY. see section 6.3.1      |
| 3     | aclk_375MHz | RX clock used to receive packets from PHY. see section 6.3.2 |
| 4     | aresetn     | active low reset, resets the entire IP.                      |

Table 6: List of clocks and resets of the IP

#### 6.3.1 TX Clock

The name chosen for TX clock port is aclk\_250MHz however, in practice this port does not necessarily need a 250 MHz clock. Here are possible scenarios:

- At 1 Gbits/s the clock should be 250 MHz.
- At 100 MBits/s the clock should be 50 MHz.

When the IP is using RMII interface this clock port does not exist.

#### 6.3.2 RX Clock

The name chosen for RX clock port is aclk\_375MHz however, in practice this port does not necessarily need a 375 MHz clock. Here are possible scenarios:

- In direct sampling mode at 1 GBits/s5.1 the clock should be 375 MHz.
- In **RXC capture mode at 1 GBits/s** 5.2 the clock should be 125 MHz or any bigger number. It is recommended to use a higher frequency than 125 MHx.
- At 100 MBits/s the clock should be 50 MHz or bigger.

When the IP is using RMII interface this clock port does not exist.

#### 6.3.3 AXI Streams Clocks

The IP has 2 AXI streams, one for receivnging packets from other FPGA modules and the another for sending packets to these modules. Each of these AXI interfaces can operate in a different clock domain. The names of IP's clock ports are m\_axis\_FROM\_PHY\_aclk and s\_axis\_TO\_PHY\_aclk.

## 7 IP Parameters and Configuration (RGMII PHY)

Figures 7 shows the GUI of the IP.

In the following we go through each of the configuration options.

## 7.1 PHY Type

Currently the following list of PHYs are supported and tested.

- Microchip KSZ9031RNX tested on Enclutra XU5 board.
- RealTek RTL8211E tested on Kintex Ultrascale board.
- Microchip VSC8541XMV tested on Digilent Nexys Video board.

Important facts is all of the above PHYs have a similar register address map. Basically, any other PHY with standard MDIO address map is supported too.

## 7.2 PHY Address

Important parameter specifying the address of the PHY.

## 7.3 Force 100MBits Link

if TRUE the IP will program the PHY after reset and forces it to operate at 100 MBits/s. Set this option to FALSE when you want to have your link running at 1 GBits/s.

## 7.4 Loopback Enable

If set to TRUE the IP will program the PHY and enables digital loopback mode.

### 7.5 Use RX clock to capture data

When TRUE the IP will use RXC input as the clock to capture the incoming data and valid lines. When FALSE the IP will be in direct sampling mode where it treats all of the signals equally. It samples all of them and then by looking at positive and negative edges of RXC it determines the correct value of data bits. This mode is good if you have limitations with FPGA pin assignment and RXC is not located on a pin which can be a used a local or global clock.

### 7.6 Set RX skew

If TRUE, after reset the IP will configure the PHY to delay each of the RX control and data lines with regard to RX clock so that they can be safely captured at FPGA side. This is suitable when the IOs you are using at FPGA side for receiving signals from the PHY are not in the High Performance (HP) IO banks and so they do not have the internal IDELAY elements.

#### rgmii\_to\_axi\_stream\_v1\_0 (1.0)

🚯 Documentation 🛛 📄 IP Location

| Show disabled ports                 | Component Name rgmii_to_axi  | _stream_0     |         |   |
|-------------------------------------|------------------------------|---------------|---------|---|
|                                     | Phy Type                     | KSZ9031RN     | x v     |   |
|                                     | Phy Addr (5 bits binary)     | "00011"       |         |   |
|                                     | Force 100MBits Link          | TRUE          | ~       |   |
|                                     | Loopback Enable              | FALSE         | ~       |   |
|                                     | Use RX clock to capture data | TRUE          | ~       |   |
|                                     | Set Rx Skew                  | FALSE         | ~       |   |
|                                     | Use Clock Manager            | FALSE         | ~       |   |
|                                     | РНҮ                          |               |         |   |
|                                     | Rxctl Pad Skew               |               | "0111"  | 0 |
|                                     | Rxd Pad Skew 0               |               | "0111"  | 0 |
|                                     | Rxd Pad Skew 1               |               | "0111"  | 0 |
|                                     | Rxd Pad Skew 2               |               | "0111"  | 0 |
|                                     | Rxd Pad Skew 3               |               | "0111"  | 0 |
| + s axis TO PHY                     | Txctl Pad Skew               |               | "0111"  | 0 |
| aclk_375MHz                         | Txd Pad Skew                 |               | "0111"  | 0 |
| - aclk_50MHz PHY RESET N -          | Rx Clk Pad Skew              |               | "01111" | 0 |
| aclk_250MHz PHY_MDC                 | Tx Clk Pad Skew              |               | "01111" | 0 |
| m axis FROM PHY aclk     PHY_MDIO - | Phy Resetn Duration          |               | 1000    | 8 |
| debug_dropped_packet_count[15:0]    | Period of reading PHY sta    | us registers: | 5000000 | 8 |
|                                     | Interfaces                   |               |         |   |
|                                     | Axi Master Enable            | ALSE 🗸        |         |   |
|                                     | Axi Slave Config Enable      | ALSE 🗸        |         |   |
|                                     | Axi Streams Enable           | rrue 🗸        |         |   |
|                                     | Axi Stream Width (Bits)      | 3 ~           |         |   |
|                                     | Drop Preamble Fsd            | rrue 🗸        |         |   |
|                                     | CRC                          |               |         |   |
|                                     | Rx Drop Bad Crc              | FALSE         | *       |   |
|                                     | Rx Enable Crc Check          | TRUE          | ~       |   |
|                                     | Tx Add Crc To Packet         | TRUE          | ~       |   |
|                                     | Tx Wait For Complete Pack    | tet TRUE      | ~       |   |

Figure 5: IP parameters configuration GUI. In this setup, IP is configured to force the PHY to 100MBits ethernet.

#### 7.7 Use Clock Manager

If TRUE the IP will instantiate a clock management tile on RX clock path. The IP will then receive the RX clock from PHY and first it passes it through a clock management tile where it creates a clock with equal phase to RX clock. The generated clock by clocking wizard will then be used for capturing the data.

#### 7.8 Skew Values

User can set the amount of skew which should be programmed into PHY for each of the following items. The value should be a binary.

- RX Control
- RX Data
- TX Control
- TX Data
- RX Clock
- TX Clock

Note that for RX Data lines, user can set the skew of each line separately and they may not be equal. For TX Data lines one skew will be set for all lines.

#### 7.9 PHY Reset Duration

Specifies how long should the IP keep the PHY in reset (in MDIO clock cycles).

#### 7.10 Period of Read PHY Status

The IP can read and report PHY registers continously. This value indicates how often should IP read and report register values. Reporting values can be through VIO or AXI slave registers.

#### 7.11 AXI Master Enable

In advanced version of the IP, it can directly put received Ethernet packets into destination DRAM memory or read Ethernet packets form DRAM memory and send them to the PHY. These data transfer will be done using IP's internal DMA engine.

### 7.12 AXI Slave Config Enable

Enables the AXI slave interface and allows the user to read IP registers through this interface and also perform MDIO read and write accesses.

## 7.13 AXI Streams Enable

Enables AXI stream interfaces of the IP. These are the main interfaces through which the IP receives and sends Ethernet packets. Sections 6.1.1 and 6.1.2 describe these interfaces in more detail.

## 7.14 AXI Stream Width (Bits)

Width of AXI stream TDATA interface. Typical value is 1 Bytes. It can be 2, 4 or 8 bytes as well.

### 7.15 Drop Preamble FSD

Typical behavior of the IP is to drop the preamble and FSD of the Ethernet packets it receives.

## 7.16 RX Drop Bad CRC

When TRUE IP drops the recieved ethernet packets which have incorrect CRC.

## 7.17 RX Enable CRC Check

When TRUE, enables the CRC calculation engine of the IP.

### 7.18 TX Add CRC to Packet

When TRUE for each ethernet packet that IP should send to PHY, the IP calculates the CRC and adds the CRC to tail of the packet.

## 7.19 TX Wait for Complete Packet

When TRUE the IP will wait until the complete TX packet arrives (from the upstream FPGA module) and then starts sending the packet over Ethernet interface. This is specially helpful if the FPGA module who produces the packets to be sent, does not create conitnous packets and data flow interrupts time to time.

## 7.20 IP Parameters and Configuration (RMII PHY)

Figures 6 shows the GUI of the IP when connecting to RMII PHY.

Description of the parameters is similar to RGMII mode.

| Phy Type                                                                                   | DP8384    | 8                     | ~        |   |
|--------------------------------------------------------------------------------------------|-----------|-----------------------|----------|---|
| hy Addr (5 bits binary)                                                                    | "00001"   |                       | 6        |   |
| Loopback Enable                                                                            | FALSE     |                       | ~        |   |
| Tx Add Preamble Fsd                                                                        | TRUE      |                       | 8        |   |
| РНҮ                                                                                        |           |                       |          |   |
| Phy Resetn Duration                                                                        |           |                       | 1000     | 6 |
| Period of reading PH                                                                       | IY status | registers             | 5000000  | 6 |
| Interfaces                                                                                 |           |                       |          |   |
| Axi Master Enable                                                                          | FALS      | se 🗸                  |          |   |
| Axi Slave Config Enal                                                                      | ble FALS  | se 🗸                  |          |   |
| Axi Streams Enable                                                                         | TRU       | E 🗸                   |          |   |
| Axi Stream Width (Bi                                                                       | ts) 8     | ~                     |          |   |
|                                                                                            |           |                       |          |   |
| Drop Preamble Fsd                                                                          | TRU       | E 🗸                   |          |   |
| Drop Preamble Fsd                                                                          | TRU       | E V                   |          |   |
| Drop Preamble Fsd                                                                          | TRU       | E 🗸                   |          |   |
| Drop Preamble Fsd<br>CRC<br>Rx Drop Bad Crc                                                | TRU       | E ✓<br>FALSE          | ~        |   |
| Drop Preamble Fsd<br>CRC<br>Rx Drop Bad Crc<br>Rx Enable Crc Check                         | TRU       | E V<br>FALSE<br>TRUE  | <b>~</b> |   |
| Drop Preamble Fsd<br>CRC<br>Rx Drop Bad Crc<br>Rx Enable Crc Check<br>Tx Add Crc To Packer | TRU       | FALSE<br>TRUE<br>TRUE | ~<br>~   |   |

Figure 6: IP parameters configuration GUI. In this setup, IP is configured to connect to a RMII PHY.

## 8 Registers

By default the AXI slave lite interface of the IP is disabled. User does not need any specific register access through AXI Lite interface to configure the IP.



Figure 7: Vivado block design of RXC capture design example. 1 GBits/s link speed.

## 9 Exmaple Designs

The package comes with various example designs. In Vivado block designs that we show for each of the examples, we have the following color coding:

- Clock signals are in light green
- Reset in dark green
- interface connections in red.

Note that the same design example is available for multiple boards.

#### 9.1 RXC capture

Figure 9.1 shows the block design for this example.

You can create this design example with each of these two tcl scripts:

- create\_example\_post\_route\_rxc\_capture\_1GBits.tcl creates the example design for link speed of 1 GBits/s.
- create\_example\_post\_route\_rxc\_capture\_100MBits.tcl creates the example design for link speed of 100 MBits/s.
- create\_example\_rxc\_capture\_100mbits\_rmii\_artix7.tcl creates example design to connect to RMII PHY on Arty A7 Artix board.

Figure 9.1 shows the block design. RGMII to AXI stream IP is instantiated and is connected to outside world through RGMII interface and MDIO signals. An Ethernet packet generator is also instantiated. It produces Ethernet packets to be sent over the IP to the network. Ethernet packet generator can produce example ARP packets. Section 9.3 provides more details. A VIO controls the reset of the system and also start of packet generation. A system ILA monitors the AXI stream interface of the IP.

In Figure 9.1 the IP is set to operate at 1 GBits/s. Clocks for AXI interfaces are being driven by a 160 MHz clock source. It is recommended that the clock for AXI interfaces be higher than 125 MHz. A 50 MHz clock is used for MDIO connectivity. A 250 MHz clock is used for both TX and RX paths inside the IP. As we are using the IP in RXC capture mode, we do not need a 375 MHz clock.



Figure 8: Vivado block design of RXC capture design example. 100 MBits/s link speed.

| Phy Type                     | KSZ9031RNX | ~ |
|------------------------------|------------|---|
| Phy Addr (5 bits binary)     | "00011"    | 0 |
| Force 100MBits Link          | FALSE      | ~ |
| Loopback Enable              | FALSE      | ~ |
| Use RX clock to capture data | TRUE       | ~ |
| Set Rx Skew                  | TRUE       | ~ |
| Use Clock Manager            | FALSE      | ~ |

Figure 9: IP configuration 1 GBits/s link.

Figure 8 shows a similar example. This time the IP is in 100 MBits mode. The entire design uses a 50 MHz clock.

Figure 9 shows IP configuration in this design example when 1 GBits mode is active. As can be seen, we ask the IP to program the PHY and configure the skew registers. Note that enabling Set RX Skew option makes the PHY to program the skew registers for both of RX and TX. Section 9.4 provides further description of skew registers.

Figure 10 shows the same configs when IP should operate at 100 MBits.

Figure 11 shows VIO setup for our example. There exist two VIOs in the design. One is responsible for controlling the reset (probe0) and generation of packets (probe1).

Figure 12 shows captured ILA waveforms when a new packet has arrived. As can be seen, ILA captures the signals of both incoming and outgoing AXI streams. It also captures total number of packets arrived and total number of faulty packets arrived.

Figure 13 shows captured ILA waveforms in RMII PHY design example when a packet is being trasmitted to network.

Figure 14 shows a snapshot of Wireshark software running on the PC. As can be seen whireshark has captured the packets that our packet generator IP on the FPGA produced.

### 9.2 Enabling Loopback Mode

Remember, you can always put the PHY into Digital loopback mode easily. All you need to do is the put the config value for loopback to True in IP configuration GUI. This is usually useful

| Phy Type                               | KSZ9031RNX | ~ |
|----------------------------------------|------------|---|
| Phy <mark>Addr (</mark> 5 bits binary) | "00011"    | 0 |
| Force 100MBits Link                    | TRUE       | ¥ |
| Loopback Enable                        | FALSE      | ~ |
| Use RX clock to capture data           | TRUE       | ~ |
| Set Rx Skew                            | FALSE      | ~ |
| Use Clock Manager                      | FALSE      | ~ |

Figure 10: IP configuration 100 MBits/s link.

| hw_vio_1 hw_vio_2 x           |       |   |          |           |          |  |  |  |  |  |  |
|-------------------------------|-------|---|----------|-----------|----------|--|--|--|--|--|--|
| Q   ¥   €   +   -             |       |   |          |           |          |  |  |  |  |  |  |
| Name 🔨 1                      | Value |   | Activity | Direction | VIO      |  |  |  |  |  |  |
| ↓ design_1_i/vio_0_probe_out0 | [B] 1 | Ŧ |          | Output    | hw_vio_2 |  |  |  |  |  |  |
| ↓ design_1_i/vio_0_probe_out1 | [B] 0 | ۳ |          | Output    | hw_vio_2 |  |  |  |  |  |  |
|                               |       |   |          |           |          |  |  |  |  |  |  |
|                               |       |   |          |           |          |  |  |  |  |  |  |

Figure 11: VIO setup for controlling reset and generation of packets.

| Waveform - hw_ila_2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               |    |        |          |            |                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----|--------|----------|------------|----------------------------------------------|
| Q   +   −   &   ▶   ≫   ■   ⊵   Q   Q   ⊠   +                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 손 알 두 두 두 두 다 |    |        |          |            |                                              |
| ILA Status: Idle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |               |    |        | <b>*</b> |            |                                              |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Value         |    | 150    | 200      | 250        | 300                                          |
| 18 PHY_RESET_N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1             |    |        |          |            |                                              |
| > Vethernet_packet_coun_0_total_arrived_packets                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0000000a      |    |        | 000000a  |            | <u> </u>                                     |
| > Vertex et al. and the second sec | 0000000       |    |        |          | 0000000    |                                              |
| ✓ Slot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | -             |    |        |          |            |                                              |
| ✓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | _             |    |        |          |            |                                              |
| 🔓 slot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : TVALID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ISTATEO       | is | TATEO  | χ        | ISTATE     | <u>;                                    </u> |
| Islot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : TREADY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1             |    |        |          |            |                                              |
| 🔓 slot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : TLAST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0             |    |        |          |            |                                              |
| > 😻 slot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : TDATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0000033       |    | 000033 |          |            |                                              |
| 🖥 slot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : TUSER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0             |    |        |          |            |                                              |
| ✓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Inactive      |    |        |          | Inactive   |                                              |
| ✓                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | No Streams    |    |        |          | No Streams |                                              |
| 🐻 slot_1 : ethernet_packet_gene_0_m_axis : TVALID                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0             |    |        |          |            |                                              |
| Islot_1 : ethernet_packet_gene_0_m_axis : TREADY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1             |    |        |          |            |                                              |
| Islot_1 : ethernet_packet_gene_0_m_axis : TLAST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0             |    |        |          |            |                                              |
| > V slot_1 : ethernet_packet_gene_0_m_axis : TDATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 000000ff      |    |        |          | 000000ff   |                                              |
| Islot_1 : ethernet_packet_gene_0_m_axis : TUSER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0             |    |        |          |            |                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |    |        |          |            |                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |    |        |          |            |                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |    |        |          |            |                                              |

Figure 12: Captured ILA waveform of an arriving packet.

| Waveform - hw_ila_2                                     |            |                |  |      |             |         |            |  |  |  |  |
|---------------------------------------------------------|------------|----------------|--|------|-------------|---------|------------|--|--|--|--|
| Q   +   −   ♂   ▶   ≫   ■   ⊡   @   Q   ∷               | + I I ⊨ 1± | l ±r   +F   Fe |  |      |             |         |            |  |  |  |  |
| ILA Status: Idle                                        |            |                |  |      |             |         |            |  |  |  |  |
| Name                                                    | Value      |                |  |      |             |         |            |  |  |  |  |
| 16 PHY_RESET_N                                          | 1          |                |  |      |             |         |            |  |  |  |  |
| > 😽 ethernet_packet_coun_0_total_arrived_packets        | 6351       |                |  |      |             |         |            |  |  |  |  |
| > 😻 ethernet_packet_coun_0_total_faulty_packets         | 0000000    |                |  |      |             |         |            |  |  |  |  |
| > 👅 slot_0 : rgmii_to_axi_streaxis_FROM_PHY : Interface | _          |                |  |      |             |         |            |  |  |  |  |
| ✓                                                       | _          |                |  |      | Active      |         |            |  |  |  |  |
| ✓                                                       | _          |                |  |      | Stream Beat |         |            |  |  |  |  |
| 🖁 slot_1 : ethernet_packet_gene_0_m_axis : TVALI        | 0          |                |  |      |             |         |            |  |  |  |  |
| 🖁 slot_1 : ethernet_packene_0_m_axis : TREADY           | 1          |                |  |      |             |         |            |  |  |  |  |
| 🖁 slot_1 : ethernet_packet_gene_0_m_axis : TLAST        | 0          |                |  |      |             |         |            |  |  |  |  |
| > 💖 slot_1 : ethernet_packet_gene_0_m_axis : TDAT/      | 000000ff   | 000000f        |  | 33.3 | ( 🗶 🛛 🕴 🗖   | 0000000 | <u>;</u> ) |  |  |  |  |
| 🖁 slot_1 : ethernet_packet_gene_0_m_axis : TUSE         | 0          |                |  |      |             |         |            |  |  |  |  |
|                                                         |            |                |  |      |             |         |            |  |  |  |  |
|                                                         |            |                |  |      |             |         |            |  |  |  |  |

Figure 13: Captured ILA waveform of transmitting a packet (RMII mode).

|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        | *e           | np0s31      | f6                 |                        |                  |                      |             |                    |        | ^                  |              | пх     |
|------------|----------------|----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|------------------|----------------|--------|--------------|-------------|--------------------|------------------------|------------------|----------------------|-------------|--------------------|--------|--------------------|--------------|--------|
| File       | Edit           | View           | Go       | Cantu                                                                                                                                                                                 | re ∆n          | alvze            | Statis           | tics           | Telei  | hony         | Wirele      | s Tools            | Help                   |                  |                      |             |                    |        |                    | -            | - ~    |
| <u>1</u> e | Edit           | <u>r</u> icii  | <u> </u> |                                                                                                                                                                                       |                |                  | 0                | ~              | - Cicl |              | <u> </u>    |                    |                        | 0                |                      | -           |                    |        |                    |              |        |
|            |                | 3              | 9        | 011<br>011<br>011                                                                                                                                                                     | X              | C                | Ч                |                |        | <u>_/</u> _  | 1           | 2                  | ₩,                     | Q                | ₹ 1                  |             |                    |        |                    |              |        |
|            | oply a         | displa         | y filter | <ct< th=""><th>r -/&gt;</th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th>• +</th></ct<> | r -/>          |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              | • +    |
| No.        | T              | ime            | 00000    | Sour                                                                                                                                                                                  | ce             |                  | 20               |                |        | Desti        | ination     |                    | Protoco                | Leng             | th Info              | 10 0 1      | 0 40 T-            | 11 400 | . 400 4            | 70 0         | 0      |
|            | 10             | .0000          | 26944    |                                                                                                                                                                                       | Не⊢е_<br>Но⊑о  | ca:⊍e:<br>bb:bb: | 28<br>hh         |                |        | Broa         | dcast       |                    | ARP                    | 6                | i⊎ who n<br>⊛ who h  | 185 10.0.1  | 0.1? Ie<br>0.12 To | 11 192 | 2.168.1<br>2 168 1 | 78.2<br>78.2 | 3      |
|            | 3 4            | .7880          | 33033    | fe80                                                                                                                                                                                  | )::134         | 2:fba5           | :1f31            | :f1e9          | )      | ff02         | ::fb        |                    | MDNS                   | 20               | 3 Stand              | ard querv   | 0x0000             | PTR    | ipps.              | tcp.         | local. |
|            | 47             | .6988          | 07659    | 0.0                                                                                                                                                                                   | 0.0            |                  |                  |                |        | 255.         | 255.255     | .255               | DHCP                   | 33               | 8 DHCP               | Discover    | - Trans            | actio  | ID 0x              | 83c4         | 8b89 ( |
|            | 59             | .8061          | 03964    | LCF                                                                                                                                                                                   | HeFe_          | cd:0e:           | 28               |                |        | Broa         | dcast       |                    | ARP                    | 6                | 0 Who h              | nas 10.0.1  | 0.1? Te            | 11 192 | 2.168.1            | 78.2         | 3      |
|            | 6 1<br>7 1     | 3.638          | 889542   | 2 LCF(                                                                                                                                                                                | Не⊢е_          | op:pp:           | ממ               |                |        | Broa<br>ff02 | dcast       |                    | ARP<br>TCMDv6          | 12               | 00 Who h<br>00 Multi | nas 10.0.1  | 0.1? Ie<br>onor Ro | nort I | 2.168.1            | 18.2         | 3      |
|            | 11             | 0.007          | 000200   | ·                                                                                                                                                                                     |                |                  |                  |                |        | 1102         |             |                    | TOULAND                | 13               | o narti              | LOUGE LISE  | ener Ne            | porti  | icooaye            | ٧Z           |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
| 4          |                |                |          |                                                                                                                                                                                       | - / 40/        |                  |                  | hucha          |        |              | (400 b      |                    |                        | 0                | -04.50               |             |                    |        |                    |              | •      |
| ► Fr       | ame 5<br>herne | : 60 I<br>+ TT | Src      | ON W1r                                                                                                                                                                                | 6 (480<br>6 cd | 9 D1tS<br>∙⊖⊖∙28 | ), 60<br>(⊖8∙    | Dyte<br>6a:64  | s ca   | otured       | (480 D      | lts) on<br>Broadca | interface<br>t (ff.ff. | e enp⊍<br>∙ff∙ff | S31T6,<br>•ff•ff)    | 10 0        |                    |        |                    |              |        |
| Ad         | ldress         | Reso           | lutior   | ) Proto                                                                                                                                                                               | col (          | reques           | (eo.)            | 0a.04          | u      | 56.20)       | , DSC.      | Di Gauca           | st (11.11.             |                  | ,                    |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       | `              |                  | ,                |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
| 0000       | <i>ff</i> 4    | ** **          | ff ff    | ff of                                                                                                                                                                                 | 60 6           |                  |                  | 10 06          | 00.0   | 4            | -           | d (                |                        |                  |                      |             |                    |        |                    |              |        |
| 0000       | 08 0           | 0.06           | 04 00    | 01 e8                                                                                                                                                                                 | 6a 64          | ∔ ca ⊍<br>1 cd 0 | e 28 0<br>- 28 0 | 08 ⊎0<br>:0 a8 | h2 1   | 7            | · · · · · j | d(                 |                        |                  |                      |             |                    |        |                    |              |        |
| 0020       | 00 0           | 00 00          | 00 00    | 00 0a                                                                                                                                                                                 | 00 08          | a 01 0           | 0000             | 00 00          | 00 0   | 0            |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
| 0030       | 00 (           | 00 00          | 00 00    | 00 00                                                                                                                                                                                 | 00 00          | 00 00            | 9 00             |                |        |              | • • • • •   |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
|            |                |                |          |                                                                                                                                                                                       |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    |              |        |
| -          |                |                |          | -                                                                                                                                                                                     |                |                  |                  |                |        |              |             |                    |                        |                  |                      |             |                    |        |                    | -            |        |
|            | / w            | ireshai        | rk enn   | 0s31f6                                                                                                                                                                                | 20220          | 617000           | )912 I           | )27tf;         | a.pcai | ona          |             | Packe              | ts: 7 · Displ          | aved: 1          | 7 (100.0             | %) · Droppe | ed: 0 (0.0         | 0%)    | Profile:           | Defa         | ult :: |

Figure 14: Wireshark capturing ARP packets produced by our packet generator IP. (Arty A7 board, RMII PHY)

| Waveform - hw_ila_2                                         |                        |         |          |        |       |       |         |        |          |      |     |                  | ? _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------|------------------------|---------|----------|--------|-------|-------|---------|--------|----------|------|-----|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Q   +   -   &   >   =   B   Q   Q   X   -   H   H   =       | 27 [ 4] [ 6 ] 4] [ 6 ] |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| LA Status: Idle                                             |                        |         | 200      |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Name                                                        | Value                  | 1       | 200      | 250    | 300   | 1350  | 460     | 450    | 1500     | 550  | 600 | 1 <sup>650</sup> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 14 PHY_RESET_N                                              | 1                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| > 👽 ethernet_packet_coun_0_total_arrived_packets            | 00000000               |         |          |        |       |       | 0000    | 6606   |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| > W ethernet_packet_coun_0_total_faulty_packets             | 00000000               |         |          |        |       |       | 0       | 300000 |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Slot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : Interface  | -                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| > slot_0 : rgmi_to_axi_stream_0_m_axis_FROM_PHY : T Channel | -                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| & slot_0 : rgmii_to_axi_stream_0 _m_axis_FROM_PHY : TVALID  | ISTATEO                |         |          |        |       |       | ISTATED |        |          |      |     | İSTATE           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 🔓 slot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : TREADY   | 1                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| & slot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : TLAST    | 0                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| > V slot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : TDATA  | 00000000               |         |          | 000000 | 00    |       | X       |        | 000000ff |      |     | . C              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Islot_0 : rgmii_to_axi_stream_0_m_axis_FROM_PHY : TUSER     | 1                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| v slot_1 : ethernet_packet_gene_0_m_axis : Interface        | Active                 |         | Activ    | c      |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| slot_1 : ethernet_packet_gene_0_m_axis : T Channel          | Stream Beat            |         | Stream 8 | Beat   |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| lø slot_1 : ethernet_packet_gene_0_m_axis : TVAUD           | 1                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Islot_1 : ethernet_packet_gene_0_m_axis : TREADY            | 1                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| a slot_1 : ethernet_packet_gene_0_m_axis : TLAST            | 0                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| > 😻 slot_1 : ethernet_packet_gene_0_m_axis : TDATA          | 000000ff               | cococof |          | ab X   |       |       |         | 000    | abof f   |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Islot_1 : ethernet_packet_gene_0_m_axis : TUSER             | 0                      |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                             |                        |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                             |                        |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                             |                        |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                             |                        |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                             |                        |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                             |                        |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                             |                        |         |          |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                             |                        |         | - 437    |        |       |       |         |        |          |      |     |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                             |                        | - 45    | 2        | - 400  | - 350 | - 300 | - 250   | - 200  | -150     | -100 | -50 | 0                | 50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                             |                        |         |          |        |       |       |         |        |          |      |     |                  | and the second s |

Figure 15: Example ILA waveform capture, loopback is enabled.

when you have doubts about the connection between FPGA and PHY or its timing.

By enabling the loopback mode, and configuring system ILA to start capturing the data when Trigger signal to packet generator goes high, you will be able to see both the packet which goes from packet generator to RGMII to AXIS IP and then the packet that gets reflected back to FPGA by the PHY.

The two packets should be identical. Only the CRC should be added. Remember RGMII to AXIS adds the CRC of the packet to its tail itself.

An on board waveform capture using ILA when loopback mode is enabled is shown in Figure 9.2. As can be seen a packet starts getting trasmitted at clock cycle 200. At clock cycle 637, the looped back packet comes back. This is a total latency of around 850 micro-seconds for digital loopback for the RGMII to AXIS IP and the PHY together.

#### 9.3 Packet Generator

Packet generator is a Verilog module located inside verilog\_sim folder. It is fully synthesizable and can be used in Vivado designs. It contains a memory which holds the packets that user has defined.

Inside verilog\_sim folder there is a memory initialization file 01.mem. This file can be edited and any desired packet can be added.

Packet generator then starts putting out packets with any positive or negative edge of trigger signal.

#### 9.4 Programming Skew Registers

In 1 GBits/s mode, when enabled in the GUI, the IP can proram PHY's RX and TX skew registers itself right after reset. The amount of skew in RX data lines and clock can be defined separately for each line in the IP GUI. For TX, a same skew value will be applied to all TX data lines and a separate value will be applied to clock skew.

## 10 Tested Boards

This IP is tested on following boards:

| index | Board                | Board Device     |                      |  |  |
|-------|----------------------|------------------|----------------------|--|--|
| 1     | Enclustra XU5        | Zynq Ultrascale+ | Microchip KSZ9031RNX |  |  |
| 2     | Digilent Nexus Video | Artix7           | RealTek RTL8211E-VL  |  |  |
| 3     | Digilent Arty A7     | Artix7           | Texas Instruments    |  |  |

## 11 Revisions

- 1. Initial version created on 30th of April, 2021.
- 2. Update to IP documentation on 26th of May, 2021. Ports and interfaces, example designs added.
- 3. Update to IP docuemntation, added more examples, ila waveforms, block designs. June 12th, 2022.
- 4. IP now supports PHYs with RMII interface for 100MBits Ethernet. June 17th, 2022.