



A.L.S.E 8, Passage Barrault 75013 PARIS France Tel : +33 1 84 16 32 32

www.alse-fr.com



| 1. REVISION HISTORY                    | 3  |
|----------------------------------------|----|
| 2. GENERAL INFORMATION                 | 4  |
| 2.1. IP CONFIGURATION.                 | 4  |
| 2.2. Possible configurations.          | 4  |
| 2.1. Delivery content.                 | 5  |
| 3. ARCHITECTURE                        | 6  |
| 3.1. MICROCHIP DESIGN COMPILATION      | 7  |
| 3.1.1. On Linux                        | 7  |
| 3.1.2. On Windows                      | 7  |
| 3.1.3. Project compilation             | 7  |
| 3.2. JTAG debugging                    | 7  |
| 3.3. LEDS AND BUTTONS                  | 8  |
| 3.4. Master Hardware Tester User Guide | 9  |
| 3.4.1. Intel Master Design             | 9  |
| 3.4.2. Xilinx Master Design            | 14 |
| 3.5. Pictures                          | 16 |
| 3. TECHNICAL SUPPORT                   | 18 |
|                                        |    |



# 1. **REVISION HISTORY**

The following table shows the revision history for this document and the associated IP.

| Version | Date       | Revision                                         |
|---------|------------|--------------------------------------------------|
| 1.0     | Nov 2023   | Initial Version (for Polarfire)                  |
| 1.1     | Feb 2024   | Add compilation instructions with Aurora netlist |
| 1.2     | April 2024 | Fixed minor type, details about CRC activation.  |

Table 1: Revision history



## 2. **GENERAL INFORMATION**

This document describes the content of ALSE Aurora 8B/10B loopback Reference Design for Polarfire. This design is built for the <u>Polarfire FPGA Evalutation Kit</u>.

Loopback is done over 1 lane, using the only SFP+ connector of the board. It is configured to work at 3.125 Gbits/s.

This Reference Design does re-transmit any frame received on its RX side to its TX side.

PDU (Data) frames as well as NFC and UFC Flow Control frames are supported.

With this design, we demonstrate the full compliance of our implementation with the Xilinx Aurora 8b/10b protocol, allowing interoperability with Xilinx FPGAs through Xilinx Aurora 8b/10b IP, as well as with Intel or Lattice boards using our own Aurora IP !

Here is the exact configuration of the IP in the Reference Design described below. Static parameters can be quickly modified to be adapted to your need !

 $\rightarrow$  Please let ALSE know if you would like to test our design in a different configuration on this board (CRC on, different speed, streaming mode...).

## 2.1. IP configuration

In the *current* version, the IP is configured as follow :

- Full-Duplex (of course compulsory for loopback design)
- ✓ 1 x transceiver lane at 3.125 Gbits/s through SFP+ connector.
- ✓ 32 bits (4 Bytes width) user Datapath.
- ✓ Framing interface.

Note : we have de-activated the CRC to demonstrate the highest bandwidth achieved.

For some applications, the user can enable the CRC feature to verify automatically the integrity of the data received. If framing mode, activating the CRC while using short frames has a significant impact on the bandwidth.

- User Flow Control in direct (Xilinx-IP style) mode.
- Native Flow Control in completion mode.
- Clock compensation sequence generation enabled.
- 125 MHz reference clock for transceivers.

## 2.2. Possible configurations

Here is the list of the **possible** configurations of our IP on this development kit:

- ✓ Full-Duplex and Simplex Tx/Rx Operations.
- ✓ Up to 6.6 Gbps (Gigabits per seconds) per lane.
- ✓ SFP+ or SMA connectors. Multiple lanes possible (max 2).
- 16 bits (2 Bytes width) and 32 bits (4 Bytes width) user datapath.
- Framing and Streaming interface.
- User Flow Control.
- ✓ Native Flow Control in immediate and completion mode.
- Additional CRC for PDU Frames (16bits or 32bits, depending chosen user Datapath)
- Per lane polarity inversion and skew compensation.



## 2.1. Delivery content

Here is the list of files available in the Reference Design delivery.

| aurora_8b10b                 | Reference folder                                                                                                               |  |  |  |  |  |  |  |  |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| La doc                       | IP related documentation                                                                                                       |  |  |  |  |  |  |  |  |
| La src*                      | VHDL source code and IP files (Xilinx and Microchip files)                                                                     |  |  |  |  |  |  |  |  |
| La boards                    | Reference design files for Intel and Xilinx boards                                                                             |  |  |  |  |  |  |  |  |
| L xilinx/Vivado_VC707        | Xilinx VC707 Master Reference Design files                                                                                     |  |  |  |  |  |  |  |  |
| La microchip/MPF300-EVAL-KIT | Polarfire loopback design top-level file                                                                                       |  |  |  |  |  |  |  |  |
| La common                    | Common source code                                                                                                             |  |  |  |  |  |  |  |  |
| La misc                      | Common source code as well                                                                                                     |  |  |  |  |  |  |  |  |
| La test_modules              | Validation modules (generator / checker for PDU, UFC and NFC streams)                                                          |  |  |  |  |  |  |  |  |
| └ <b>──</b> mc_aurora*       | Aurora controller sources, including transceivers instantiation.                                                               |  |  |  |  |  |  |  |  |
| La MPF300*                   | Microchip IPs TCL import files (TX PLL, transceivers, REF CLK BUFFERS) used in the transceiver wrapper                         |  |  |  |  |  |  |  |  |
| La xcvr_wrapper.vhd          | Transceiver wrapper VHDL entity                                                                                                |  |  |  |  |  |  |  |  |
| La mc_aurora_wrapper_*.vhd   | Netlist or RTL Aurora controller depending on delivery type.                                                                   |  |  |  |  |  |  |  |  |
| 🗅 mc_aurora_top.vhd          | Top wrapper, instantiating wrapper and transceiver.                                                                            |  |  |  |  |  |  |  |  |
| L fit                        | Synthesis files.                                                                                                               |  |  |  |  |  |  |  |  |
| La microsemi                 | Project files.                                                                                                                 |  |  |  |  |  |  |  |  |
| Len MPF300_EVAL_KIT*.ppd     | Binary (.ppd) file for Polarfire Evaluation Development Kit.<br>It is only present if it is not an IP delivery.                |  |  |  |  |  |  |  |  |
| Land Sh, .tcl, .sdc, .pdc    | Everything you need to create the full Reference Design,<br>using our IP, including timing constraints and pin<br>assignments. |  |  |  |  |  |  |  |  |
| La xilinx                    | Projects for Xilinx boards                                                                                                     |  |  |  |  |  |  |  |  |

Figure 1: IP package contents

\*Note : Folders and files that appear in bold are present only in a IP delivery.

In an Example Design delivery, only the Xilinx side source code is available, the Microchip design is already compiled in a .ppd and ready to be programmed.



## 3. ARCHITECTURE

This chapter describes the architecture of the Reference Design provided with the Aurora 8b/10b IP Core.



Figure 2: Reference Design architecture

#### Generator / Checker :

The Generator & Checker modules use LFSRs to generate pseudo random sequences for PDU, UFC and NFC control signals. Since the sizes of the LFSRs are not the same for all signals, most of the use cases are tested by this method.

The Data bytes are incremented ("counter") as they are valid (using the byte enables), so the checker can easily verify the absence of duplicated or lost bytes.

Checking, Generation of results and various Control signals are managed through JTAG using an Intel tool named "In-System Sources & Probes" (see later).

#### **RTL Loopback :**

The loopback function in the Polarfire Reference Design does re-send PDU and UFC Data as they are received.

For PDU, a FIFO stores the incoming data from the RX interface and writes these data to the TX interface.

UFC Data are checked using the UFC checker module. As long as UFC frames are correct, new UFC requests are generated on the TX interface. If an error is detected, no request is sent so that the checker at the Intel side will detect the error.

NFC requests are generated in order to avoid overflow on the PDU datapath by looking at the FIFO level. NFC requests are also re-sent as they are received.



## 3.1. Microchip Design compilation

This part describes the steps to re-create the Libero Reference Design project using the scripts located in the *fit/* folder. This is only available for IP delivery (and not with Example Design deliveries).

Libero 2023.2 or above should be installed and accessible in you \$PATH variable.

Depending on your OS :

- Linux, execute the steps below.
- Windows, go to <u>3.1.3</u>.

#### 3.1.1. Under Linux

Open a terminal in the **fit/microsemi/polarfire/** directory.

Run the following command :

#### \$ ./gen\_project.sh MPF300\_EVAL\_KIT\_loopback

This command calls Libero in batch mode through the three TCL scripts located in this folder :

- **gen\_project.tcl** : download the required Libero IPs, create the Libero project and add the Reference Design sources. It includes the timing constraint (.sdc) and pin assignments (.pdc) files as well. It imports and creates all the Microchip IPs required in the design (including transceivers IPs).
- **import\_aurora\_xcvr.tcl** : Links the transceiver wrapper file to the project.
- **build\_prj.tcl** : Builds the project hierarchy, applies constraints files previously added, and sets the project top-level.

The script has several options but the one presented above in **the only one working with a netlist format delivery**.

#### **3.1.2. Under Windows**

Open a terminal (<u>not</u> a power shell) in the **fit\microsemi\polarfire\** directory.

make sure **libero.exe is in your path** and that you can invoke it directly in the terminal.

Run the following command :

#### \$ gen\_project.bat MPF300\_EVAL\_KIT\_loopback

This command invokes Libero and runs the same three TCL scripts as described above (for Linux). The script has several options but the one presented above in **the only one working with a netlist format delivery**.

#### 3.1.3. Project compilation

Steps above created the **MPF300\_EVAL\_KIT\_loopback.prjx project** file that you can now open in Libero.

In the *Design Flow* window, run *Generate Bitstream* to run the full Libero flow.

By clicking on Manage Constraints, you can check that our constraints are correct and applied.

In the report window you can check that the compilation is successful and that the resource usage corresponds to what described in the Aurora IP User Guide (depending on your configuration).

You can now program you Polarfire board with the loopback design and test its interoperability with a Xilinx or an Intel master design !

It is possible to change the link speed of the design by modifying the configuration of the **PF\_XCVR\_ERM** and **PF\_TX\_PLL** Microchip IPs used in the design. In the *Components* window click on the corresponding IPs to see current configuration.

See Microchip transceiver documentations to get more information on how to configure the transceivers !



- INTEL ONLY

- INTEL ONLY

## 3.2. JTAG debugging

The main difference with the simulation is that the hardware implemented version uses JTAG accessible control modules in order to control and monitor the tester/checker.

These modules are accessible through :

- "In-System Sources and Probes", a tool available from Intel Quartus Prime. Open the file "insys\_src\_prb.spf" in Quartus to control the design.
- "Virtual Input/Output" a tool from Xilinx/AMD Vivado.
  Open the file "debug\_nets.ltx" in Vivado to control the design.

JTAG allows real-time modification of :

- Enable / Disable PDU generation.
- Enable / Disable NFC generation.
- Enable / Disable UFC generation.
- NFC immediate or completion mode.
- ◆ PDU pause (some cycles with valid='0') or contiguous (all cycles valid).
- PDU endless (no End Of Packet generated).
- Counters and link Reset.

JTAG can also monitor these values :

- Number of PDU frames sent / received.
- Number of UFC frames sent / received.
- Number of NFC requests (pause cycles) sent / received.
- Number of Errors in PDU frames received.
- Number of Errors in UFC frames received.
- PDU bit rate on TX interface (use byte enable to count valid bytes).
  INTEL ONLY
- PDU bit rate on RX interface (use byte enable to count valid bytes).
   INTEL ONLY
- Transceiver reference clock frequencies for Intel FPGA.

## 3.3. LEDS and buttons

The Polarfire loopback design uses the few control LEDs available to output basic debug information. Debugging and verification is performed from the Master board using the JTAG debug tools presented above.

- > LED4 (F22) : Link-up information : led is OFF when link is up!
- > LED5 (B26) : Heartbeat signal, should blink if design is alive.
- > LED6 (C26) : User push-button SWITCH10 (B19) is directly wired to this led.
- > LED7 (D25) : POR signal, should be ON when reset is inactive.
- LED8 (C27) : Is transceiver **RX recovery clock alive**? **OFF** when true.
- ▶ LED9 to 11 : wired to '1' to check LED polarity. Always ON.

Master boards usually also have some LEDs displaying link up and reset information despite of JTAG tools availability for fast debug. To be checked in the Reference Design top level !



## 3.4. Master Hardware Tester User Guide

Here we help you to setup the experiment using a Polarfire dev kit and an Intel/Xilinx master board. Follow the next step to generate an **Intel** master design or 3.3.2 to generate a **Xilinx** master design.

### 3.4.1. Intel Master Design

The following pages will guide you through the ALSE's Aurora 8b10b Hardware Tester Reference design for clients having purchased the ALSE Aurora 8B/10P IP for Intel FPGAs.

Here are the **<u>steps</u>** to follow :

- Open the provided ALSE Quartus project, located typically in ./fit/altera/board\_name/
- Check (and adjust if the delivered source files allow it) the Aurora IP configuration defined in the Top Level <u>VHDL generics</u> :
  - Device Family
  - Number of XCVR Lanes
  - Lane Width (16 or 32)
  - Streaming / Framing Mode
  - CRC Enabled (if using Framing)
  - Duplex or Simplex Tx/Rx Mode

- etc ...

| 17 entity avdb_x1_top | _streaming i | s              |                                                                                                                |
|-----------------------|--------------|----------------|----------------------------------------------------------------------------------------------------------------|
| 18                    |              |                |                                                                                                                |
| 19                    |              |                |                                                                                                                |
| 20 generic (          |              |                |                                                                                                                |
| 21 device family      | : string     | := "CycloneV"; | Altera Device Family                                                                                           |
| 22 nb lanes           | : integer    | := 1;          | Number of XCVR lanes                                                                                           |
| 23 lane width         | : integer    | := 32;         | 16 or 32                                                                                                       |
| 24 streaming mode     | : std logic  | := '1';        | Streaming Mode if '1', Framing if '0'                                                                          |
| 25 crc enable         | : std logic  | := '0';        | CRC Enabled if '1', Disabled if '0'                                                                            |
| 26 simplex tx         | : std logic  | := '0';        | Simplex Tx only if '1'                                                                                         |
| 27 ext clk freq       | : positive   | := 50e6        | Ext Clock Frequency                                                                                            |
| 28 );                 |              |                | The second s |

- Check the pinout assignments in the project (through the Pin Planner, or directly in the QSF) The Hardware Tester Reference design uses typically the following pins :
  - an external free-running clock (board quartz) called *ext\_clk*. This clock frequency should match the *ext\_clk\_freq* VHDL generic (example : ext\_clk\_freq = 50e6 if the *ext\_clk* pin runs @ 50MHz)
  - the XCVR Tx/Rx pins (number depends on the *nb\_lanes* generic) and the XCVR Reference Clock. These pins might be associated with an SFP(+) cage, QSFP(+) connector, or to a specific Board implementation.
- If using the <u>encrypted</u> version of the IP, check that you have the license installed correctly : in Quartus, go to the Tools > License Setup... menu, and check that the ALSE (7D3A Vendor ID) **0030** Product (this is the Aurora 8b10b IP) appears in the list, with a valid expiration date.

| License Setup                       | Licensed AMPP/Mer | Core functions |
|-------------------------------------|-------------------|----------------|
| Preferred Text Editor<br>Processing | Vendor            | Product        |
| Tooltip Settings                    | ALSE (7D3A)       | 002B           |
| ✓ Messages                          | ALSE (7D3A)       | 002C           |
| Colors                              | ALSE (7D3A)       | 002D           |
| Fonts                               | ALSE (7D3A)       | 002F           |
|                                     | ALSE (7D3A)       | 0030           |
|                                     | ALSE (7D3A)       | 0031           |
|                                     | ALSE (7D3A)       | 0032           |



- Once this is OK, compile the project (**CTRL+L** in Quartus). The project should compile without any error, and no timing violation should be reported.
- Prepare your hardware XCVR connections/cables. Connect it to the Polarfire Dev kit implementing the simple loopback on PU/UFC/NFC packets design.
- <u>Power</u> on your board(s), plug the JTAG (USB Blaster typically), and program the board with the generated bitstreams (.SOF file for Intel). **Polarfire should be programmed as well with ALSE loopback bitstream !**
- Back in Quartus, open the provided *Tools > In-System Sources and Probes Editor* file : *File > Open*, and select the ./*fit/altera/<u>board\_name</u>/insys\_src\_prb.spf* file. A window like the one below will appear.

Note : if the Aurora Streaming IP is used, the UFCC and NFCC instances will not be present.

| Instan    | ce Manage  | er: 📑      | 10 II (               | Ready to acc       | quire           |                                         |                                |                 |                 |                           |             |  |  |  |
|-----------|------------|------------|-----------------------|--------------------|-----------------|-----------------------------------------|--------------------------------|-----------------|-----------------|---------------------------|-------------|--|--|--|
| Probe     | read inte  | rval       |                       |                    |                 |                                         | Event log                      |                 |                 |                           |             |  |  |  |
| Cur       | rent inten | /al: 0 sam | ples per second       |                    |                 |                                         | Maximum s                      | ize: 8          |                 |                           |             |  |  |  |
| ~         | A          |            |                       |                    |                 |                                         | 🗖 Cauca di                     |                 | ~               | -                         |             |  |  |  |
| 0         | Automat    | IC         |                       |                    |                 |                                         | L Save u                       | ata to event to | g               |                           |             |  |  |  |
| 0         | Manual     | 1          |                       | 5                  | ¥               |                                         | Write source d                 | lata: Continu   | uously 👻        | <u>=</u> †                |             |  |  |  |
|           | Index      | Insta      | nce ID                | Status             | Sources: 7      | Probes: 385                             |                                |                 |                 |                           | Name        |  |  |  |
| đ         | 0          | PDUC       | Unexpecte             | d JTAG commun.     | 0               | 96                                      | alt_aurora_tester:i_alt_aurora | a_tester altsou | rce_probe:\bl   | k_pdu:i_altsource_probe   | 2           |  |  |  |
|           | 1          | UFCC       | Unexpecte             | d JTAG commun.     | 0               | 96                                      | alt_aurora_tester:i_alt_aurora | _tester altsou  | irce_probe:\ge  | en_ufc_on:blk_ufc:i_altsc | ource_probe |  |  |  |
| đ         | 2          | NFCC       | Unexpecte             | d JTAG commun.     | 0               | 64                                      | alt aurora tester:i alt aurora | a_tester altsou | rce_probe:\ge   | en nfc_on:blk_nfc:i_altsc | ource_probe |  |  |  |
|           | 3          | RSTn       | Unexpecte             | d JTAG commun.     | 1               | 0                                       | alt aurora tester:i alt aurora | a tester altsou | rce probe:\bl   | k jtag:i altsource probe  | rst         |  |  |  |
| đ         | 4          | CTRL       | Unexpecte             | d JTAG commun.     | 6               | 1                                       | alt aurora tester:i alt aurora | a tester altsou | irce probe:\bli | k jtag:i altsource probe  | ena         |  |  |  |
| *         | 5          | RATE       | Unexpecte             | d JTAG commun.     | 0               | 128                                     | alt_aurora_tester:i_alt_aurora |                 | irce_probe:\bl  | k_rate:i_altsource_probe  | 2           |  |  |  |
|           |            |            |                       |                    |                 |                                         |                                |                 |                 |                           |             |  |  |  |
| at o P    | 000        |            |                       |                    |                 |                                         |                                |                 | 0               | 7                         | 6           |  |  |  |
| Index     | Type       | Allas      | TT alt surgers tester | ri alt aurora tar  | Nam             | e<br>alle adminate a                    | hulaman ant[05, 64]            | Data            | 1-0             | -7                        | -P          |  |  |  |
| [9504     | 44.2       |            | alt_aurora_tester     | r:i_alt_aurora_tes | ter[pdu_chk.\t  | olk_pdu:i_pdu_ci                        | hkjenor_cht[95.64]             | 0               | -               |                           |             |  |  |  |
| 2[21 0]   | 4.         |            | E alt_aurora_tester   | r:i_all_aurora_tes | teripdu_crik.\r | adadu aanihik adul adu aanifama anif1 0 |                                |                 |                 |                           |             |  |  |  |
| -[310]    | 44         |            | tester                | n_all_aurora_les   | teripau_gen.ti  | ork_pau.i_pau_g                         | enfiname_cnu[310]              | 0               |                 |                           |             |  |  |  |
| 据 1 U     | IFCC       |            |                       |                    |                 |                                         |                                |                 |                 |                           |             |  |  |  |
| Index     | Туре       | Alias      | <u>.</u>              |                    | Nam             | e                                       |                                | Data            | 1-8             | -/                        | -p          |  |  |  |
| [9564     | **         |            | H alt_aurora_tester   | r:I_alt_aurora_tes | ter/ufc_chk:\g  | en_ufc_on:blk_u                         | fc:i_ufc_chk[error_cnt[9564]   | 0               |                 |                           |             |  |  |  |
| [6332     | **         |            | alt_aurora_tester     | r:I_alt_aurora_tes | ter/ufc_chk:\g  | en_ufc_on:blk_u                         | tc:i_utc_chk[frame_cnt[6332]   | 0               |                 |                           |             |  |  |  |
| 2[310]    | **         |            | ⊞ alt_aurora_tester   | r:I_alt_aurora_tes | ter ufc_gen:\g  | en_ufc_on:blk_u                         | fc:I_ufc_gen[frame_cnt[310]    | 0               |                 |                           |             |  |  |  |
| 者 2 N     | IFCC       |            |                       |                    |                 |                                         |                                |                 |                 |                           |             |  |  |  |
| Index     | Туре       | Alias      | _                     |                    | Nam             | e                                       |                                | Data            | -8              | -7                        | -р          |  |  |  |
| [6332     | **         |            | ⊞ alt_aurora_tester   | r:i_alt_aurora_tes | ter nfc_chk:\g  | en_nfc_on:blk_n                         | fc:i_nfc_chk wait_cnt[6332]    | 0               |                 |                           |             |  |  |  |
| °[310]    | <b>本</b> 公 |            | ⊞ alt_aurora_tester   | r:i_alt_aurora_tes | ter nfc_gen:\g  | en_nfc_on:blk_n                         | fc:i_nfc_gen wait_cnt[310]     | 0               |                 |                           |             |  |  |  |
| 👬 3 R     | STn        |            |                       |                    |                 |                                         |                                |                 |                 |                           |             |  |  |  |
| Index     | Туре       | Alias      | Name                  | Data               | -8              |                                         | -7                             | -p              |                 | -5                        |             |  |  |  |
| SO        |            |            | aurora_reset_n        | 0                  |                 |                                         | 76                             |                 |                 | 100                       |             |  |  |  |
| a 4 C     | TRL        |            |                       |                    |                 |                                         |                                |                 |                 |                           |             |  |  |  |
| Index     | Туре       | Alias      | Nan                   | ne                 | Data            | 8                                       | -7                             |                 | -6              | -5                        |             |  |  |  |
| PO        | **         |            | alt aurora top:i au   | rora top link up   | 0               |                                         |                                |                 |                 |                           |             |  |  |  |
| <b>S5</b> |            |            | pdu_endless           |                    | 0               |                                         |                                |                 |                 |                           |             |  |  |  |
| <b>S4</b> |            |            | pdu_underflow         |                    | 0               |                                         |                                |                 |                 |                           |             |  |  |  |
| \$3       |            |            | nfc_immediate         |                    | 0               |                                         |                                |                 |                 |                           |             |  |  |  |
| S2        |            |            | nfc_enabled           |                    | 0               |                                         |                                |                 |                 |                           |             |  |  |  |
| <b>S1</b> |            |            | ufc_enabled           |                    | 0               |                                         |                                |                 |                 |                           |             |  |  |  |
| SO        |            |            | pdu_enabled           |                    | 0               |                                         |                                |                 |                 |                           |             |  |  |  |



- First, Check in the JTAG configuration window that the correct JTAG cable is selected.
- Select the *CTRL* instance, and click on *Continuously Read Probe Data*.

| Instance Manag  | ger: 📑 📴 I          | Ready to ac               | quire      |             |                                                                                             |
|-----------------|---------------------|---------------------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Probe read inte | erval Con           | tinuously Read Probe Data |            | Event log   | L                                                                                           |
| Current inte    | rval: 0 samples per | second                    |            | Maxim       | um size: 8 💌                                                                                |
| O Automa        | itic                |                           |            | 🖸 Sa        | ive data to event log                                                                       |
| 🔿 Manual        | 1                   | s *                       |            | Write sou   | rrce data: Continuously 🔹 🗐                                                                 |
| Index           | Instance ID         | Status                    | Sources: 7 | Probes: 385 | Name                                                                                        |
| # 0             | PDUC                | Not running               | 0          | 96          | alt_aurora_tester:i_alt_aurora_tester altsource_probe:\blk_pdu:i_altsource_probe            |
| at 1            | UFCC                | Not running               | 0          | 96          | alt_aurora_tester:i_alt_aurora_tester altsource_probe:\gen_ufc_on:blk_ufc:i_altsource_probe |
| at 2            | NFCC                | Not running               | 0          | 64          | alt_aurora_tester:i_alt_aurora_tester altsource_probe:\gen_nfc_on:blk_nfc:i_altsource_probe |
| at 3            | RSTn                | Not running               | 1          | 0           | alt_aurora_tester:i_alt_aurora_tester altsource_probe:\blk_jtag:i_altsource_probe_rst       |
| <b>R</b> 4      | CTRL                | Not running               | б          | 1           | alt_aurora_tester:i_alt_aurora_tester altsource_probe:\blk_jtag;i_altsource_probe_ena       |
|                 | DATE                | Netrunning                | 0          | 100         | alt aurora testeri alt aurora testerialteaurea proba\bik ratei alteaurea proba              |

You will see '0's being read for all bits of the CTRL instance, including for the link\_up bit.

To start the test, you must first release the Aurora Tester (and IP) active\_low reset, which is asserted by default ('0') at FPGA start-up. This can be done by clicking on the '0' value of the *Data* Column of the RSTn instance, making the '0' value change into a '1' => the reset is removed (de-asserted).

| <b>a</b> : | 3 RS | Tn |
|------------|------|----|
|------------|------|----|

| Index | Туре | Alias | Name           | Data | -8 | -7 | -6 |
|-------|------|-------|----------------|------|----|----|----|
| SO    |      |       | aurora_reset_n | 0    |    |    |    |

The **link\_up bit of the CTRL instance should be now on** ('1'), signifying that the Aurora link is up through the full setup (board-to-board, or Hardware Loopback through a connector).

<u>Note</u> : If link is not up, check the pinout assignments and the XCVR Ref Clock frequency. Check also that the Slave board (if any) runs at the same link rate than the Intel board. If any error is found, correct it and recompile.

If the link is still down, a SignalTap core is embedded in the FPGA to help you debug some of the signals that may help you understand why. Please contact ALSE to help you.

• <u>To start testing PDU frames</u>, first enable <u>Continuous Read</u> also on the PDUC instance. Then, in the *CTRL* instance, assert ('1') pdu\_enabled (bit S0).

| a u ru    | UC   |       |                                   |                |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
|-----------|------|-------|-----------------------------------|----------------|-------------------------------------------------|-----------|----|----------|-----------|---------|-----------|----|-----------|--------|-------|-----------|--------|-----------|-----------|-----------|
| Index     | Туре | Alias |                                   |                | Name                                            | Data      | -8 |          | 7         | -p      |           | -5 | -         | 4      | -3    |           | -7     |           | -1        | 0         |
| 9564      | **   |       | . B. alt_aurora_tester:i_alt_auro | ra_tester pdu  | _chk: blk_pdu:i_pdu_chk error_cnt[95.64]        | 0         | -  |          |           |         |           |    |           | 0      |       |           |        |           |           |           |
| 6332      | **   |       | ⊞ alt_aurora_testeri_alt_auro     | ra_tester pdu  | _chk:blk_pdu:i_pdu_chk frame_cnt[6332]          | 557935532 | 54 | 47020963 | 548579738 | $-\chi$ | 550137756 |    | 551700133 | 553257 | 709   | 554816262 | $\sim$ | 556373733 | $\supset$ | 557935532 |
| [310]     | **   |       | . elt_aurora_tester:i_alt_auro    | ra_tester pdu  | _gen; blk_pdu:i_pdu_gen[frame_cnt[310]          | 557935538 | 54 | 47020965 | 548579744 | X       | 550137762 | X  | 551700140 | 553257 | 711 ) | 554816263 | X      | 556373741 | X         | 557935538 |
| at 1 UFCC |      |       |                                   |                |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| Index     | Туре | Alias |                                   |                | Name                                            | Data      | -8 | -1       | 7         | -p      |           | -5 | -         | 4      | -3    |           | -7     |           | -1        | 0,        |
| 9564      | **   |       | ⊞ alt_aurora_tester:i_alt_auro    | ra_tester ufc_ | chk:\gen_ufc_on:blk_ufc:i_ufc_chk]error_cnt[95  | 64] 0     |    |          |           | ~~~     |           |    |           |        | 0     |           |        |           |           |           |
| 6332      | *2   |       | ⊞ alt_aurora_tester:i_alt_auro    | ra_tester ufc_ | chk:\gen_ufc_on:blk_ufc:I_ufc_chk frame_cnt[63. | .32] 0    |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| [310]     | *:   |       | alt_aurora_tester:i_alt_auro      | .0] 0          |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| 2 NF      | сс   |       |                                   |                |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| Index     | Туре | Alias | Name                              |                |                                                 |           | -8 | -        | 7         | -p      |           | -5 | 7         | 4      | -3    |           | -2     |           | -1        | 0,        |
| 6332      | **   |       | ⊞ alt_aurora_testeri_alt_auro     | ra_tester nfc_ | chk:\gen_nfc_on:blk_nfc:i_nfc_chk wait_cnt[633  | 2] 0      |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| [310]     | \$2  |       | ⊞ alt_aurora_tester:i_alt_auro    | ra_tester nfc_ | gen:\gen_nfc_on:blk_nfc:i_nfc_gen wait_cnt[310  | 0 [0      |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| 1 3 RS    | Tn   |       |                                   |                |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| Index     | Туре | Alias | Name Dat                          | a ,-8          | -7                                              | -6        |    | -5       |           |         | -4        |    | -3        |        |       | -2        |        | -1        |           | 0         |
| 50        |      |       | aurora_reset_n 1                  |                |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| 14 CT     | RL   |       |                                   |                |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| Index     | Туре | Alias | Name                              | 1              | Data -8                                         |           | -7 |          |           |         | -p        |    |           |        |       | -5        |        |           |           | -4        |
| PO        | **   |       | alt_aurora_top:i_aurora_top lin   | nk_up          | 1                                               |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| \$5       |      |       | pdu_endless                       |                | 0                                               |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| S4        |      |       | pdu_underflow                     |                |                                                 |           |    |          |           | _       |           |    |           |        |       |           |        |           |           |           |
| 53        |      |       | nfc_immediate 0                   |                |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| S2        |      |       | nfc_enabled 0                     |                |                                                 |           |    |          |           | _       |           | _  |           |        |       |           | _      |           | _         |           |
| S1        |      |       | ufc enabled                       | 0              |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |
| 50        |      |       | ndu enabled                       |                |                                                 |           |    |          |           |         |           |    |           |        |       |           |        |           |           |           |

You should see in the PDUC instance both PDU\_GEN / PDU\_CHK Frame Counters increase quickly, and the PDU\_CHK Errors Counter stay at 0, meaning PDU Frames are sent/received without any error.



- PDU tests can be adjusted by enabling :
  - the **pdu\_underflow** bit (*CTRL* instance, bit S4) : if asserted, the PDU Frame generator insert dead cycles (no tx\_pdu\_vld asserted) at random clock cycles, thus decreasing a bit the PDU Bandwidth.
  - the **pdu\_endless** bit (*CTRL* instance, bit S5) : if asserted, the PDU Frame generator creates a frame without EOP (Endless "infinite" frame) : the Frame Counter will stay to its current value, as long as this bit is asserted.
- PDU tests can also be driven by a **<u>Fixed mode</u>** : this mode generates known PDU Frames sizes, with sizes and interframe gaps adjustable dynamically.

The data generated are again incremented ("counter") values.

To use this mode :

- First stop the PDU Stream (pdu\_enabled = '0').
- Then, set the **pdu\_fixed\_size\_on** bit (PDUF instance, bit S0)
- Set the maximum/minimum frame sizes : pdu\_fixed\_size\_max and pdu\_fixed\_size\_min (should be at least 4 minimum).
- Set the frame size increment : **pdu\_fixed\_size\_incr** (0 means frame size is always the same, max at start-up, 1 means after each frame finished, the next frame has a size +1, etc ...)
- Set the Inter-Frame gap, in clock cycles : **pdu\_fixed\_size\_ifgap** : should be at least 1

#### Optionally :

- Set the frame cut size : **pdu\_fixed\_size\_cut\_size** : this is the number of data valid after which a gap will be inserted in the data\_valid (in order to avoid PDU Frames being a continuous burst).
- Set the frame cut gap : pdu\_fixed\_size\_cut\_gap defines the number of clock cycles of the "cut".
- **Enable** the PDU Stream again (pdu\_enabled = '1')
- <u>To start testing UFC frames</u>, first enable <u>Continuous Read</u> also on the UFCC instance. Note : this is only possible in <u>Framing</u> mode.
- Then, in the *CTRL* instance, assert ('1') **ufc\_enabled** (bit S1).

| 8 0 PE     | UC         |       |                     |                       |                  |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
|------------|------------|-------|---------------------|-----------------------|------------------|---------------|-----------------------------|------------|----|-----------|----|------------|----|------------|-----|------------|------|--------|----|------------|-----|------------|----------|------------|----|
| Index      | Туре       | Alias |                     |                       | Name             |               |                             | Data       | -8 |           | -7 |            | -p |            | -5  |            | 4    |        | -3 |            | -7  |            | -1       |            | 0  |
| [6332]     | **         |       | ⊞ alt_aurora_test   | er:i_alt_aurora_teste | er pdu_chk:\blk_ | pdu:i_pdu_ch  | k frame_cnt[6332]           | 2110351207 | 20 | 099702547 | X  | 2101226549 | 1  | 2102742558 | _X_ | 2104267314 | 2105 | 787704 | _X | 2107309920 | _X_ | 2108830204 | Χ        | 2110351207 |    |
| P[310]     | *2         |       | ⊞ alt_aurora_test   | er:i_alt_aurora_test  | er pdu_gen:\blk_ | pdu:i_pdu_ge  | n[frame_cnt[310]            | 2110351215 | 20 | 099702551 | X  | 2101226555 | X_ | 2102742560 |     | 2104267323 | 2105 | 787712 |    | 2107309924 |     | 2108830207 | X        | 2110351215 |    |
| R 1 UF     | CC         |       |                     |                       |                  |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| Index      | Туре       | Alias | 1                   |                       | Name             |               |                             | Data       | -8 |           | -7 |            | -p |            | -5  | -          | 1    |        | -3 |            | -2  |            | -1       |            | 0, |
| [9564]     | **         |       | ⊞ alt_aurora_test   | er:i_alt_aurora_teste | er ufc_chk:\gen_ | ufc_on blk_uf | ::I_ufc_chk error_cnt[9564] | 0          |    |           |    |            |    |            |     | (          | 1    |        |    |            |     |            |          |            |    |
| [6332]     | **         |       | ⊞ alt_aurora_test   | er:i_alt_aurora_teste | er ufc_chk:\gen_ | ufc_on_blk_uf | ::i_ufc_chk frame_cnt[6332] | 23886246   | 2  | 3433757   | X  | 23498440   | X  | 23562866   | )_  | 23627649   | 2369 | 92387  | X  | 23756937   | X   | 23821641   | <u>)</u> | 23886246   | _  |
| [310]      | **         |       | ⊞ alt_aurora_test   | er:i_alt_aurora_teste | er ufc_gen:\gen_ | ufc_on_blk_uf | c:i_ufc_gen frame_cnt[310]  | 23886246   | 2  | 3433757   | X  | 23498440   | X  | 23562866   | X   | 23627649   | 2369 | 92387  | X  | 23756938   | X   | 23821641   | X        | 23886246   |    |
| 2 2 NF     | cc         |       |                     |                       |                  |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| Index      | Type       | Alias |                     |                       | Name             |               |                             | Data       | -8 |           | -7 |            | -6 |            | -5  |            | 1    |        | -3 |            | -2  |            | -1       |            | 0, |
| [6332]     | **         |       | ⊕ alt aurora teste  | er:i alt aurora teste | erinfc chk:\gen  | nfc on:blk nf | ci nfc chk/wait cnt[6332]   | 0          |    |           |    |            |    |            | _   |            |      |        |    |            |     |            | -        |            |    |
| P[310]     | **         |       | alt_aurora_test     | er:i_alt_aurora_teste | er nfc_gen:\gen_ | nfc_on:blk_nf | c:i_nfc_gen wait_cnt[310]   | 0          |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| 3 RS       | Tn         |       |                     |                       |                  |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| Index      | Туре       | Alias | Name                | Data                  | -8               |               | -7                          | -p         |    | -5        |    |            |    | -4         |     | -3         |      |        | -2 |            |     | -1         |          |            | 0  |
| <b>SO</b>  |            |       | aurora_reset_n      | 1                     |                  |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| a 4 CT     | RL         |       |                     |                       |                  |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| Index      | Туре       | Alias | Na                  | me                    | Data             | -8            |                             |            | -7 |           |    |            |    | -p         |     |            |      |        |    | -5         |     |            |          |            | -4 |
| PO         | <b>*</b> 2 |       | alt_aurora_top:i_ar | urora_top link_up     | 1                |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| <b>S</b> 5 |            |       | pdu_endless         |                       | 0                |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| <b>S4</b>  |            |       | pdu_underflow       |                       | 0                |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| 53         |            |       | nfc_immediate       |                       | 0                |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| S2         |            |       | nfc_enabled         |                       | 0                |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            |    |
| 51         |            |       | ufc_enabled         |                       | 1                |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            | _  |
| <b>SO</b>  |            |       | pdu_enabled         |                       | 1                |               |                             |            |    |           |    |            |    |            |     |            |      |        |    |            |     |            |          |            | _  |

As for PDU, you should see in the UFCC instance both UFC\_GEN / UFC\_CHK Frame Counters increase quickly, and the UFC\_CHK Errors Counter stay at 0, meaning UFC Frames are sent/received without any error.

Note that you can enable both PDU and UFC testing at the same time.



- <u>To start testing NFC frames</u>, first enable <u>Continuous Read</u> also on the NFCC instance. Note : this is only possible in <u>Framing</u> mode.
- Then, in the *CTRL* instance, assert ('1') **nfc\_enabled** (bit S2).

| 2 0 PI     | DUC        |       |                                                                                             |                    |                    |                                           |            |            |              |             |                |            |            |             |            |
|------------|------------|-------|---------------------------------------------------------------------------------------------|--------------------|--------------------|-------------------------------------------|------------|------------|--------------|-------------|----------------|------------|------------|-------------|------------|
| Index      | Туре       | Alias |                                                                                             |                    | Name               |                                           | Data       | -8         | -7           | -β          | -5 -4          | -β         |            | -2 -        | 1 0,       |
| [9564]     | **         |       | ⊞ alt_aurora_teste                                                                          | r:i_alt_aurora_tes | ster pdu_chk:\blk  | pdu:i_pdu_chk error_cnt[9564]             | 0          |            |              |             | 0              |            |            |             |            |
| [6332]     | **         |       | ⊞ alt_aurora_teste                                                                          | r:i_alt_aurora_tes | ster/pdu_chk:\blk  | pdu:i_pdu_chk frame_cnt[6332]             | 4249085462 | 4241935252 | ( 4242954969 | 4243978109  | ( 4244996251 ) | 4246019879 | 4247039957 | 4248060827  | 4249085462 |
| P[310]     | 奉之         |       | ⊞ alt_aurora_teste                                                                          | r:i_alt_aurora_tes | ster pdu_gen:\blk  | _pdu:i_pdu_gen frame_cnt[310]             | 4249085464 | 4241935258 | ( 4242954969 | 4243978110  | ( 4244996256 ) | 4246019887 | 4247039963 | 4248060831  | 4249085464 |
| at 1 U     | FCC        |       |                                                                                             |                    |                    |                                           |            |            |              |             |                |            |            |             |            |
| Index      | Туре       | Alias |                                                                                             |                    | Name               |                                           | Data       | -8         | -7           | -p          | -5 -4          | -3         |            | -7 -        | 1 0,       |
| [9564]     | **         |       |                                                                                             | r:i_alt_aurora_tes | ster ufc_chk:\gen_ | ufc_on:blk_ufc:i_ufc_chk error_cnt[95.64] | 0          |            |              |             | 0              |            |            |             |            |
| [6332]     | **         |       | alt_aurora_teste                                                                            | r:i_alt_aurora_tes | ster ufc_chk:\gen  | ufc_on:blk_ufc:i_ufc_chk frame_cnt[6332]  | 511351232  | 510899273  | 510963880    | 511028295   | ( 511093036 )  | 511157507  | 511222066  | ( 511286549 | 511351232  |
| P[310]     | **         |       | 🗄 alt_aurora_teste                                                                          | r:I_alt_aurora_tes | ster ufc_gen:\gen  | ufc_on:blk_ufc:I_ufc_gen[frame_cnt[31.0]  | 511351233  | 510899273  | 510963881    | 511028295   | 511093036      | 511157508  | 511222066  | 511286549   | 511351233  |
| 8 2 N      | FCC        |       |                                                                                             |                    |                    |                                           |            |            |              |             |                |            |            |             |            |
| Index      | Туре       | Alias |                                                                                             | Name               |                    |                                           | Data       | -8         | -7           | -р          | -5 -4          | -3         |            | -2 -        | 1 0,       |
| [6332]     | **         |       | ⊕ alt_aurora_tester:i_alt_aurora_tester nfc_chk:\gen_nfc_onblk_nfc:i_nfc_chk walt_cnt[63.32 |                    |                    |                                           | 159713520  | 158966520  | 159072810    | ( 159179648 | ( 159286332 )  | 159393382  | 159499696  | ( 159606399 | 159713520  |
| P[310]     | **         |       | 🗄 alt_aurora_teste                                                                          | r:i_alt_aurora_tes | sterinfc_gen:\gen  | nfc_orblk_nfc:i_nfc_genjwait_cnt[310]     | 159713520  | 158966520  | 159072810    | 159179648   | X 159286333 X  | 159393382  | 159499696  | ( 159606399 | 159713520  |
| R 3 R      | STn        |       |                                                                                             |                    |                    |                                           |            |            |              |             |                |            |            |             |            |
| Index      | Туре       | Alias | Name                                                                                        | Data               | -8                 | -7                                        | -p         | -5         |              | -4          | -3             |            | -2         | -1          | 0,         |
| 50         |            |       | aurora_reset_n                                                                              | 1                  |                    |                                           |            |            |              |             |                |            |            |             |            |
| R 4 C      | TRL        |       |                                                                                             |                    |                    |                                           |            |            |              |             |                |            |            |             |            |
| Index      | Туре       | Alias | Nar                                                                                         | ne                 | Data               | -8                                        |            | -7         |              | -p          |                |            | -5         |             | -4,        |
| PO         | <b>*</b> * |       | alt_aurora_top:i_au                                                                         | irora_top[link_up  | 1                  |                                           |            |            |              |             |                |            |            |             |            |
| <b>S</b> 5 |            |       | pdu_endless                                                                                 |                    | 0                  |                                           |            |            |              |             |                |            |            |             |            |
| <b>S4</b>  |            |       | pdu_underflow 0                                                                             |                    |                    |                                           |            |            |              |             |                |            |            |             |            |
| 53         |            |       | nfc immediate 0                                                                             |                    |                    |                                           |            |            |              |             |                |            |            |             |            |
| <b>S2</b>  |            |       | nfc_enabled                                                                                 |                    | 1                  |                                           |            |            |              |             |                |            |            |             |            |
| S1         |            |       | ufc_enabled 1                                                                               |                    |                    |                                           |            |            |              |             |                |            |            |             |            |
| 50         |            |       | pdu enabled                                                                                 |                    | 1                  |                                           |            |            |              |             |                |            |            |             |            |

You should see in the NFCC instance both NFC\_GEN / NFC\_CHK <u>Wait</u> Counters increase quickly with the same value, meaning NFC Frames are sent/received, without any error. Note that you can <u>enable all PDU, UFC, and NFC testing at the same time</u>.

- NFC tests can be adjusted by enabling the **nfc\_immediate** bit (*CTRL* instance, bit S3) : if asserted, the NFC Frames are sent in Immediate mode, otherwise ('0', default), the NFC <u>Completion</u> mode is used.
- Finally, the *In-System Sources and Probes Editor* contains a **RATE** instance, allowing to observe in real-time the PDU Bandwidth exactly Transmitted (Tx) and Received (Rx), in MB/s (MegaBytes/second).
  You can perform a <u>Continuous Read</u> also on this instance, during PDU/UFC/NFC testing.

| R 5 RATE |      |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                     |          |    |      |       |      |     |    |        |
|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|----------|----|------|-------|------|-----|----|--------|
| Index    | Туре | Alias | Name 👝                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                     | Data     | -8 | -7   | -β    | -5   | -4  | -3 | -2     |
| 12796    | **   |       | alt_aurora_tester:i_alt_aurora_tester rate_count:\blk_rate:blk_rxbitratei                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | rate_count_rxbit cycle_count[12796] | 221      |    |      |       |      | 221 |    |        |
| [9564    | **   |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | rate_count_txbit[cycle_count[9564]  | 221      |    |      |       | 1025 | 221 |    |        |
| [6332    | **   |       | alt_aurora_tester:i_alt_aurora_tester rate_count:\blk_rate:i_rate_count_p                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | clk cycle_count[6332]               | 78124828 |    | 781. | 24900 | X    |     | 78 | 124828 |
| P[310]   | **   |       | It_aurora_tester:i_alt_aurora_tester/rate_count:\blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rate_count_blk_rate:i_rat | clk[cycle_count[310]                | 78124828 |    | 781  | 24900 | X    |     | 78 | 124828 |



### **3.4.2.** Xilinx Master Design

The Xilinx Master Design offers the same features as Intel design.

The same steps should be followed to generate the design.

Here we list only the differences. Refer to previous chapter for more detailed information.

- Open the provided ALSE Xilinx project, located typically in ./fit/xilinx/board\_name/. It is intended for Vivado 2020.2 and could require some IP update with newer version.
- Check (and adjust if the delivered source files allow it) the Aurora IP configuration defined in the Top Level <u>VHDL generics</u> :
  - Number of Transceivers Lanes
  - Lane Width (16 or 32)
  - Streaming / Framing Mode
  - CRC Enabled (if using Framing)

#### The default configuration should indeed match the Polarfire settings !

- Check the pinout assignments in the project (directly in the .xdc file). The Hardware Tester Reference design uses typically the following pins :
  - An external free-running clock (board quartz) called *ext\_clk* used to generate a POR and a 100 MHz system with a PLL.
  - The XCVR (Transceiver) Tx/Rx pins (number depends on the *nb\_lanes* generic) and the XCVR Reference Clock.
     These pins might be associated to an SFP(+) cage, QSFP(+) connector, or to a specific Board implementation.
  - User LEDs used to display basic debug information (link-up, reset...)
- Compile the project !
- Prepare your hardware Connections and Cables.
  Connect them to the Polarfire development kit.
  Verify that the Polarfire kit is programmed with the simple loopback on PU/UFC/NFC packets.
- Verify that the programming cable is correctly connected.
- <u>Power On</u> your boards, and if needed program the Master board with the adhoc bitstream (.BIT file for Xilinx). Reminder : the **Polarfire should be programmed as well with ALSE loopback bitstream !**



• Once your board is programmed you should see the VIO entity in the Vivado Hardware Manager. Here is the list of the source and probe connection.

For more information on a specific signal, refer to the Intel section !

| Direction | Index | Size | Signal Name                           |  |  |  |  |
|-----------|-------|------|---------------------------------------|--|--|--|--|
| OUT       | 0     | 1    | pdu_tx_ena                            |  |  |  |  |
| OUT       | 1     | 1    | pdu_underflow                         |  |  |  |  |
| OUT       | 2     | 1    | nfc_tx_ena                            |  |  |  |  |
| OUT       | 3     | 1    | ufc_tx_ena                            |  |  |  |  |
| OUT       | 4     | 1    | pdu_fixed_size_on                     |  |  |  |  |
| OUT       | 5     | 32   | pdu_endless_mode (bit 0 only is used) |  |  |  |  |
| IN        | 0     | 32   | pdu_rx_frame_cnt                      |  |  |  |  |
| IN        | 1     | 32   | pdu_rx_error_cnt                      |  |  |  |  |
| IN        | 2     | 32   | ufc_rx_frame_cnt                      |  |  |  |  |
| IN        | 3     | 32   | ufc_rx_error_cnt                      |  |  |  |  |
| IN        | 4     | 32   | pdu_tx_frame_size                     |  |  |  |  |
| IN        | 5     | 32   | pdu_tx_frame_cnt                      |  |  |  |  |
| INOUT     | 6     | 32   | pdu_fixed_size_max                    |  |  |  |  |
| INOUT     | 7     | 32   | pdue_fixed_size_min                   |  |  |  |  |
| INOUT     | 8     | 32   | pdu_fixed_size_incr                   |  |  |  |  |
| INOUT     | 9     | 32   | pdu_fixed_size_ifgap                  |  |  |  |  |
| INOUT     | 10    | 32   | pdu_fixed_cut_size                    |  |  |  |  |
| INOUT     | 11    | 32   | pdu_fixed_cut_gap                     |  |  |  |  |

Table : Xilinx sources and probes



## 3.5. Pictures

The picture below shows boards interconnect in a **x1 configuration** (using SFP+ connectors + optical fiber cable), between the ReflexCES **CycloneV-based Clovis board** (also known as the ALSE "AVDB" Board), on the bottom of the picture, and the Microsemi **Polarfire MPF300 evaluation development kit (MPF300-EVAL-KIT)** (on the top).



Figure 3 : x1 lane hardware test bench overview



The picture below shows the state of the **Polarfire MPF300 Development kit** board once programmed and not connected to any master board.



Figure 4 : Polarfire MPF300 Development Kit



# 3. TECHNICAL SUPPORT

For any type question about this IP, please contact ALSE Technical Support by **E-mail** at <u>support@alse-fr.com</u> or at a specific E-mail address that you may have received.

If a telephone contact is desired, our R&D office can be reached at +33 1 84 16 32 32, during office hours, CET.

You will be either answered directly or directed to an engineer available and competent, depending on the type of question or support.

ALSE provides a warranty defined In the IP Licensing Agreement, which is strictly limited to making the best efforts in fixing any design error that would prevent the normal use of the IP or induce an incorrect behavior of the IP, as long as the IP is used in a correct and valid context. This warranty will be void if any modification is made to the code by the customer.

This IP can only be purchased and used after signing the *ALSE IP License Agreement*.

-=000=-

