# **Example of FPGA-based Aurora communication** PN118 | Posted on November 11, 2024 | Updated on May 7, 2025 Victor HERRMANN Development Engineer imperix • in #### **Table of Contents** - What is Aurora? - Aurora 8B/10B loopback example - Vivado project - MATLAB model - Experimental results - Step-by-step procedure to create the Aurora 8B/10B loopback example - Aurora 64B/66B loopback example - Going further The SFP ports on imperix controllers are typically used for interconnecting devices in a <u>RealSync network</u>. However, when customizing the FPGA firmware, imperix designed the system to allow these SFP ports to be repurposed for other communication protocols. Aurora 8B/10B or Aurora 64B/66B can be used to communicate with hardware-in-the-loop (HIL) simulators that support the Aurora protocol, such as <u>OPAL-RT</u>, <u>TYPHOON HIL</u>, <u>SPEEDGOAT</u> and <u>RTDS</u>. This note provides an example of loopback communication using the Aurora 8B/10B protocol over a fiber optic link. It provides a step-by-step guide demonstrating how the Aurora 8B/10B protocol can be seamlessly integrated into the imperix controller FPGA. An example of Aurora 64B/66B is also provided. An example of SFP communication with a hardware-in-the-loop (HIL) simulator is available on the page <u>SFP communication with an RTDS MMC simulator</u>. Required hardware to follow this example: 1x imperix controller with SFP ports (B-Box RCP, B-Board PRO or TPI8032) • 1x 10G SFP cable #### Required software: - Xilinx Vivado 2022.1 or later. Installation guide available <u>here</u>. - FPGA sandbox template 3.10 or later. Available on the <u>FPGA download</u> page. - C++ or ACG SDK version 2024.3 or later. Available on the <u>SDK download</u> page. Hardware used in this Aurora 8B/10B example: a B-Board with a loopback connection between SFP 0 and SFP 1 FPGA-based Aurora communication is available for SDK version 2024.3 or later. Latest SDK version is available on the <u>download page</u>. To find all FPGA-related notes, please visit FPGA development homepage. ### What is Aurora? Aurora is a serial link layer communication protocol developed by Xilinx/AMD. The protocol is open and provides lightweight, high-speed point-to-point communication between devices. Implementing Aurora communication is particularly useful for establishing high-throughput, low-latency communication with other power controllers or HIL simulators. The protocol is available in two versions: Aurora 8B/10B and Aurora 64/66B. Aurora 8B/10B provides lower latency while Aurora 64B/66B provides higher bandwidth. ## Aurora 8B/10B loopback example For demonstration purposes, a loopback connection is established between two ports on the same controller, as shown in the diagram below: Diagram of the architecture of the system implemented in the loopback example - SBI and SBO blocks are used to move data between the CPU and the FPGA. - FIFOs are used to move data between the IXIP clock domain (250 MHz) and the Aurora communication clock domain (78.125 MHz in this example). - Aurora 8B10B IPs encode/decode data. - TX/RX serial links are connected to physical SFP ports to transmit data over the optical fiber. ## Vivado project The Vivado block design of the Aurora 8B/10B loopback example is provided below. Click here to open as PDF The following zip file contains scripts to automatically generate this design. <u>create\_aurora\_8b10b\_exampleDownload</u> **Aurora\_8b10b\_example\_gen\_scripts.zip** To generate the design using the script, please do the following: - Download the FPGA sandbox template 3.10 or later, available on the FPGA download page - Unzip it and save the content somewhere on the PC - Rename the folder to something more explicit | Name | Date modified | Туре | Size | |--------------------------------|------------------|------------------|----------| | Aurora_8b10b_example | 06/11/2024 09:08 | File folder | | | FPGA_Sandbox_template_3.10.zip | 05/11/2024 16:31 | Compressed (zipp | 9'753 KB | - Download Aurora\_8b10b\_example\_gen\_scripts.zip using the button above - Unzip it and copy the content to the scripts folder of the FPGA sandbox template Set the vivado\_path variable to match the Vivado version installed on the PC • Double-click on create\_aurora\_8b10b\_example.bat Windows Defender SmartScreen may display a warning pop-up. Simply click More info, then *Run anyway*. ``` C:\Windows\system32\cmd.e: \times + \times Please enter a project name. Project names must start with a letter (A-Z, a-z) and must contain only alphanumeric characters (A-Z, a-z, 0-9) and underscores (_) Project name: Aurora_8b10b_loopback ``` The Vivado Aurora 8B/10B project will be created and configured. The step-by-step section below explains how to recreate it manually. ## **MATLAB** model The model below is used to test the design. It generates a sinusoidal waveform and sends it to the FPGA using SBI 0 and 1. It reads the received on SBO 2 and 3. <u>Probe variables</u> are used to observe the sent and received signals on Cockpit. <u>Download SFP\_communication\_loopback.slx</u> # **Experimental results** Observing the signals on <u>Cockpit</u> validates that the data sent on port SFP 0 using Aurora 8B/10B is properly received on port SFP 1. Thanks to the Aurora 8B/10B low latency, there is a delay of 2 control task periods between sending and receiving data. Using the Integrated Logic Analyzer (ILA) in Vivado, the propagation delays of the data in the FPGA can be measured. With a lane rate of **3.125 Gbps**, the total measured delay is **560 ns**. It consists in: - 84 ns for the TX FIFO data - 424 ns for the Aurora communication - 52 ns for the RX FIFO Propagation delay of the data in the FPGA. The acquisition was done with a clock of 250 MHz. # Step-by-step procedure to create the Aurora 8B/10B loopback example #### Instantiating the Aurora 8B/10B IP The first step is to instantiate 2 Aurora IPs. The Aurora 8B/10B IP is available for free from the Vivado IP Catalog. #### Configuring the Aurora 8B/10B IP The screenshots below show the settings used in this example. The two following parameters must be set to specific values to work on imperix hardware: - GT Reflck must be set to 250 MHz, because the clock is generated outside of the FPGA - "include Shared Logic in example design" must be checked, because the Shared Logic is already instantiated inside imperix firmware The other Core Options settings can be modified freely. Below are the settings used in this example: - A lane width of 4 Bytes was chosen to be easily interfaced to the AXI-Stream interface. - The default line rate of 3.125 Gbps was kept. This will result in a data clock of line\_rate \* 0.8 / lane\_width\_in\_bits = (3.125 Gbps \* 0.8) / (32 bits) = 78.125 MHz - In this example, making packets is unnecessary, so the interface is set to **streaming mode**. Other Core Options settings are not detailed in this note and are left as defaults. #### Configuring the imperix IP The second step is to configure the imperix firmware IP to make the SFP ports available from the sandbox. In this example, SFP 0 and 1 are used. SFP settings of the imperix IP This makes the following ports visible on the imperix IP. - TX and RX signals are the differential serial signals connected between the transceiver and the physical SFP ports. - The GT interface gives access to the shared logic instantiated in the imperix IP. #### Connecting the clocks of the Aurora 8B/10B IP The Aurora IP provides a **tx\_out\_clk** (78.125 MHz in this example), which is used as the user\_clock. A <u>BUFG buffer</u> is required between tx\_out\_clk and the clock inputs. The init clocks and DRP clocks are connected to **clk\_50\_mhz** provided by the imperix firmware IP. To learn more about the different clocks, please refer to the <u>Aurora 8B10B IP</u> and the <u>GTX transceiver</u> user guides. Aurora IP clock connections #### Connecting the data interfaces of the Aurora 8B/10B IP The *AXI-Stream interface* module (ix\_axis\_interface) is used to exchange data with the Aurora IPs. As the AXI-Stream interface module and the Aurora IPs are not in the same clock domain, <u>AXI4-Stream Data FIFO</u> with independent clocks are used to manage the clock domain crossing. The figure below shows how the FIFOs are connected in the system. To learn more about the AXI-Stream interface module, please refer to the <u>getting</u> <u>started</u> page. The following signals, connected to the *shared logic* of Aurora, must be connected between the GT interface of the imperix firmware IP and each Aurora IP: - gt0\_qplllock - gt0\_qpllrefclklost - gt\_qpllclk\_quad1 - gt\_qpllrefclk\_quad1 - gt\_refclk1 #### Connecting the TX/RX signals of the Aurora 8B/10B IP Finally, the **rxn**, **rxp**, **txn**, and **txp** signals of each Aurora IP must be connected to the corresponding pins of the imperix firmware IP to map each Aurora IP to a physical SFP port on the board. Finally, the bitstream can be generated and loaded in an imperix controller, as explained on the <u>getting started</u> page. ## Aurora 64B/66B loopback example In a similar manner to the Aurora 8B/10B example, it is possible to configure an Aurora 64B/66B communication on SFP ports. This section details the steps to adapt the Aurora 8B/10B example described in the previous section to use an Aurora 64B/66B communication. The Vivado block design of the Aurora 64B/66B loopback example is shown below. Click here to open as PDF The following zip file contains scripts to automatically generate this design. #### aurora\_64b66b\_exampleDownload aurora\_64b66b\_example.zip To use the script, please follow the <u>same instructions</u> as for the 8B/10B example. Since this example has the same behavior as the 8B/10B example, it is possible to reuse the <u>MATLAB model</u> above to test the design. #### Instantiating the Aurora 64B/66B IPs The two Aurora 8B/10B IPs are replaced by Aurora 64B/66B IPs. The connections of the following signals are the same as for the Aurora 8B/10B IP: - The init and DRP clocks are connected to clk\_50\_mhz, which is provided by the imperix firmware IP. - The shared logic signals (refclk1\_in, gt\_qpllclk\_quad1,gt\_qpllrefclk\_quad1) are connected to the GT interface of the imperix firmware IP. - The rxn, rxp, txn and txp signals are connected to the imperix firmware IP. The configuration of the Aurora 64B/66B IP follows the same rules as the Aurora 8B/10B IP: - GT Reflck must be set to 250 MHz as the clock is generated outside the FPGA. - "Include Shared Logic in example design" must be checked, because the shared logic is already instantiated inside the imperix firmware. - The other settings can be changed freely. #### Connecting the Aurora 64B/66B IP clocks A **Clocking Wizard** is instantiated for each Aurora 64B/66B IP to generate the user clock and the sync clock from the tx\_out clock. The **Clocking Wizard** is configured as follows: - The primitive is set to **MMCM**. - The **input frequency** is set to the tx\_out\_clk frequency of the Aurora 64B/66B IP. This frequency can be calculated from the line rate: tx\_out\_clk\_freq = line\_rate / 32. With a line rate of 5 Gbps we get a tx\_out\_clk of 156.25 MHz. - The source is set to Global buffer. - The **frequency of output 1** is set to half the frequency of **tx\_out\_clk**, in this example **78.125 MHz**. - The **frequency of output 2** is set to the same frequency as **tx\_out\_clk**, in this example **156.25 MHz**. - The drive buffer for both outputs is set to BUFG . The **Clocking Wizards** are connected to the Aurora 64B/66B IP as follows: - The **input** of the Clocking Wizard is connected to **tx\_out\_clk** on the Aurora 64B/66B IP. - Output 1 of the Clocking Wizard is connected to user\_clk on the Aurora 64B/66B IP. - Output 2 of the Clocking Wizard is connected to sync\_clk on the Aurora 64B/66B IP. #### Connecting the Aurora 64B/66B IP reset signals Unlike the Aurora 8B/10B IP, the Aurora 64B/66B must be properly reset during initialisation to function properly. In this example, the reset is handled by the Processor System Reset IP provided by Xilinx/AMD. The IP is used with default settings and connected as follows: The slowest\_syn\_clk input of the Processor System Reset IP is connected to the init\_clk of the Aurora 64B/66B IP. - The ext\_reset\_in, aux\_reset\_in and dcm\_locked inputs are connected to a constant set to 1. - The **pma\_init** signal of the Aurora 64B/66B IP is connected to the **bus\_struct\_reset**. - The **reset\_pb** signal of the Aurora 64B/66B IP is connected to the **peripheral\_reset**. #### Connecting the data interfaces of the Aurora 64B/66B IP Since the Aurora 64B/66B provides a 64-bit data interface, 64-bit FIFOs are used and the data from the AXI stream interface is padded with 32 additional zeros to comply with the FIFOs' width. Additional zeros are then removed in the incoming stream before being fed back to the AXI stream interface. Finally, the bitstream can be generated and used in the same way as in the Aurora 8B/10B example. ## **Going further** The page <u>high-level synthesis for FPGA</u> developments shows how automated code generation tools such as <u>Model Composer</u> and <u>Vitis HLS</u> can be used to facilitate the development of FPGA modules. Like the Aurora 8B/10B IP, they use AXI4-Streams to move data around. The <u>FPGA development on imperix controllers</u> summarizes all the other FPGA-related pages.