

# **AN 647: Single-Port Triple Speed Ethernet and On-Board PHY Chip Reference Design**



AN-647

# **Contents**

| 1. Single-Port Triple-Speed Ethernet and On-Board PHY Chip Reference Design | 3  |
|-----------------------------------------------------------------------------|----|
| 1.1. System Architecture                                                    | 3  |
| 1.1.1. Design Components                                                    | 6  |
| 1.2. Interface Signals                                                      | 10 |
| 1.3. Base Addresses and Configuration Registers                             | 11 |
| 1.3.1. Ethernet Packet Generator Configuration Registers                    | 11 |
| 1.3.2. Ethernet Packet Monitor Configuration Registers                      | 13 |
| 1.4. Running the Reference Designs                                          |    |
| 1.4.1. Hardware and Software Requirements                                   | 16 |
| 1.4.2. Internal MAC Loopback Test                                           | 16 |
| 1.4.3. Avalon-ST Reverse Loopback Test                                      | 17 |
| 1.4.4. Tcl Script                                                           | 18 |
| 2. Document Revision History                                                | 20 |



# **1. Single-Port Triple-Speed Ethernet and On-Board PHY** Chip Reference Design

The Single-Port Triple-Speed Ethernet and On-Board PHY Chip reference designs provide flexible test and demonstration platforms on which you can control, test, and monitor the Ethernet operations using system loopbacks.

The Single-Port Triple-Speed Ethernet and On-Board PHY Chip reference designs demonstrate Ethernet operations of the Altera<sup>®</sup> Triple-Speed Ethernet IP core with onboard Marvell 88E1111 PHY chips. In these reference designs, the Triple-Speed Ethernet IP core connects to the on-board PHY chip through either the Reduce Gigabit Media Independent Interface (RGMII) or the Serial Gigabit Media Independent Interface (SGMII).

The reference designs offer the following features:

- Minimal hardware requirement for a complete test.
- Implementation of one Triple-Speed Ethernet IP core instance supporting 10/100/1000-Mbps Ethernets operations with RGMII or SGMII with auto-negotiation.
- Support for programmable test parameters such as number of packets, packet length, source and destination MAC addresses, and payload-data type.
- Support for sequential random bursts test that enables the configuration of each burst for the number of packets, payload-data type, and payload size.
- Demonstration of Ethernet packets transmission and reception through internal loopback path at the maximum theoretical data rates without errors.
- Support for gathering throughput statistics.
- Support for System Console user interface.

# **1.1. System Architecture**

The reference designs demonstrate fully operational subsystems that integrate the Triple-Speed Ethernet IP core for Ethernet applications.

### Figure 1. **Reference Design with SGMII Interface—Arria 10 Devices**

The figure shows a high-level block diagram of the reference design implementing the SGMII interface with Arria 10 devices.







### Figure 2. Reference Design with SGMII Interface—Stratix V GX Devices

The figure shows a high-level block diagram of the reference design implementing the SGMII interface with Stratix V GX devices.



M = Avalon-MM Master Port

S = Avalon-MM Slave Port

src = Avalon-ST Source Port

sink = Avalon-ST Sink Port

Send Feedback

#### Reference Design with RGMII Interface—Arria V GX and Cyclone V GX Devices Figure 3.

The figure shows a high-level block diagram of the reference design implementing the RGMII interface with Arria V GX and Cyclone V GX devices.



- Avalon-MM Master Port М =
- Avalon-MM Slave Port S =
- Avalon-ST Source Port = src sink = Avalon-ST Sink Port

# **1.1.1. Design Components**

This topic describes each component of the Single-Port Triple-Speed Ethernet reference designs.



# Table 1. Components of the Single-Port Triple-Speed Ethernet Reference Designs

| Component                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Phase-Locked Loop (PLL) Core      | <ul> <li>This IP core generates a 125-MHz PLL output clock (clk_125M).</li> <li>This output clock is the system-wide clock source for the Qsys system.</li> <li>All the components in these reference designs use the 125-MHz clock from the PLL core.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                               |
| JTAG to Avalon Master Bridge Core | <ul> <li>This IP core provides a connection between the System Console and Qsys system through the physical interfaces.</li> <li>The System Console can initiate Avalon Memory-Mapped (Avalon-MM) transactions by sending encoded streams of bytes through the bridge's physical interfaces.</li> </ul>                                                                                                                                                                                                                                                                                                                                                         |
| Triple-Speed Ethernet IP Core     | <ul> <li>This IP core provides an integrated Ethernet MAC, PCS, and PMA solution for Ethernet applications.</li> <li>The Triple Speed Ethernet IP core transmits Ethernet packets from Avalon Streaming (Avalon-ST) interface to a 1.25-Gbps serial transceiver interface and receives packets from the opposite direction.</li> </ul>                                                                                                                                                                                                                                                                                                                          |
| Ethernet Packet Generator         | This Qsys custom component generates Ethernet packets.<br>Refer to Ethernet Packet Generator on page 8 for more information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Ethernet Packet Monitor           | This Qsys custom component verifies the payload of all receive<br>packets, indicates the validity of the packets, and collects statistics<br>about each packet, such as the number of bytes received.<br>Refer to Ethernet Packet Monitor on page 9 for more information.                                                                                                                                                                                                                                                                                                                                                                                       |
| Error Adapter                     | <ul> <li>This Qsys custom component connects mismatched Avalon-ST source and sink interfaces.</li> <li>The adapter allows you to connect a data source to a data sink of differing byte sizes. For TX-to-RX Avalon-ST reverse loopback in these design examples, ff_tx_err is a 1-bit error signal and rx_err is a 6-bit error signal. The adapter ensures that the per-bit error information provided by ff_tx_err at the source interface connects correctly to the rx_err signal.</li> <li>The adapter connects matching error conditions that are handled by the source and the sink.</li> <li><i>Note:</i> Not applicable for Arria 10 designs.</li> </ul> |
| Avalon-ST Multiplexer             | <ul> <li>This Qsys custom component accepts data on its two Avalon-ST sink interfaces and multiplexes the data for transmission on its Avalon-ST source interface.</li> <li>One Avalon-ST sink interface connects to the source of the Ethernet Packet Generator for forward loopback while the other sink interface connects to the source of the Error Adapter for reverse loopback.</li> <li>The Avalon-ST source interface sends Ethernet packets to the Triple-Speed Ethernet IP Core.</li> <li>Note: Not applicable for Arria 10 designs.</li> </ul>                                                                                                      |
| Avalon-ST Splitter                | <ul> <li>This Qsys custom component accepts data on its Avalon-ST sink interface and splits the data for transmission on its two Avalon-ST source interfaces.</li> <li>The Avalon-ST sink interface receives Ethernet packets from the Triple-Speed Ethernet IP Core. One Avalon-ST source interface connects to the sink of the Ethernet Packet Generator for forward loopback while the other source interface connects to the sink of the Error Adapter for reverse loopback.</li> <li>Note: Not applicable for Arria 10 designs.</li> </ul>                                                                                                                 |



# 1.1.1.1. Ethernet Packet Generator

### Figure 4. **Ethernet Packet Generator Block Diagram**

This figure shows a high-level block diagram of the Ethernet Packet Generator module.



### Table 2. **Components of the Ethernet Packet Generator**

| Component                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Ethernet Packet Generation Block   | <ul> <li>The Ethernet packet generation block generates an Ethernet packet header, data payload and running sequence number for each packet.</li> <li>The Ethernet packet generation block sends the packets to the CRC Generator and the RAM-based Shift Register IP core.</li> </ul>                                                                                                                                                             |
| CRC Generator                      | <ul> <li>The CRC Generator calculates the CRC-32 checksum for the packet<br/>and the RAM-based shift register megafunction stores the packet<br/>until the checksum is available.</li> <li>After the generator merges the valid CRC-32 checksum with the<br/>packet stream, it sends the complete packet to the Avalon-ST<br/>source interface.</li> </ul>                                                                                         |
| Avalon-MM Registers                | <ul> <li>The Avalon-MM slave interface provides access to the Avalon-MM register interface. Using a Tcl script, you can configure the Avalon-MM configuration registers.</li> <li>The Avalon-MM status registers provide the status of the transmit operation and report the number of packets that were successfully transmitted.</li> <li>Refer to Ethernet Packet Generator Configuration Registers on page 11 for more information.</li> </ul> |
| Shift Register (RAM-based) IP Core | The Shift Register IP core implements a shift register with taps.<br>Refer to the <i>RAM-Based Shift Register IP Core User Guide</i> for more<br>information.                                                                                                                                                                                                                                                                                      |





### Figure 5. Ethernet Packet Generator Output Frame Format

The figure shows the format the Avalon-ST source interface streams Ethernet packets. The generated packets do not include the 7-byte preamble, 1-byte start frame delimiter (SFD) and 4-byte MAC-calculated Frame Check Sequence (FCS) fields.

|                                                                                       | 7 bytes                  | PREAMBLE                 | <br> <br>                               |                           |
|---------------------------------------------------------------------------------------|--------------------------|--------------------------|-----------------------------------------|---------------------------|
|                                                                                       | 1 byte                   | START FRAME DELIMITER    | 1<br> <br>                              |                           |
|                                                                                       | 6 bytes                  | DESTINATION ADDRESS      |                                         |                           |
|                                                                                       | 6 bytes                  | SOURCE ADDRESS           |                                         |                           |
| Frame / 2 bytes<br>2 bytes<br>2 bytes<br>0 - 1,494 or 9,576 byt<br>4 bytes<br>4 bytes | 2 bytes                  | LENGTH/TYPE              |                                         | Packet Generated by       |
|                                                                                       | 2 bytes                  | SEQUENCE NUMBER          |                                         | Ethernet Packet Generator |
|                                                                                       | 0 - 1,494 or 9,576 bytes | PAYLOAD DATA             | Payload                                 |                           |
|                                                                                       | 4 bytes                  | CRC-32                   | )                                       |                           |
|                                                                                       | 4 bytes                  | MAC FRAME CHECK SEQUENCE | 1 · · · · · · · · · · · · · · · · · · · |                           |

## **Related Information**

RAM-Based Shift Register (ALTSHIFT\_TAPS) IP Core User Guide

# 1.1.1.2. Ethernet Packet Monitor

### Figure 6. Ethernet Packet Monitor Block Diagram

This figure shows a high-level block diagram of the Ethernet Packet Monitor module.





| Component           | Description                                                                                                                                                                                                                                                                                            |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CRC Checker         | <ul> <li>The Avalon-ST sink interface accepts Ethernet packets and sends<br/>the packets to the CRC Checker.</li> <li>The CRC Checker computes the CRC-32 checksum of the receive<br/>packet and verifies it against the CRC-32 checksum field in the<br/>packet.</li> </ul>                           |
|                     | • The checker then outputs a status signal that identifies whether the packet received is good or corrupted, and updates the statistics counters accordingly.                                                                                                                                          |
| Avalon-MM Registers | The Avalon-MM slave interface provides access to the Avalon-MM register interface.                                                                                                                                                                                                                     |
|                     | <ul> <li>Using a Tcl script, you can configure the Avalon-MM configuration<br/>registers to specify the number of packets the monitor expects to<br/>receive.</li> </ul>                                                                                                                               |
|                     | • The Avalon-MM status registers provide the status of the receive operation and report the number of good and bad packets received, the number of bytes received, and the number of clock cycles. This information is used to calculate the performance and throughput rate of the reference designs. |
|                     | Refer to Ethernet Packet Monitor Configuration Registers on page 13 for more information.                                                                                                                                                                                                              |

### Table 3. **Components of the Ethernet Packet Monitor**

# **1.2. Interface Signals**

The top-level signals of the reference designs show the behavior of the specific operations.

**Clock and Reset Signals** 

#### **RGMII Clock and Reset Signals** Table 4.

| Signal                                                              | Description                                                                                          |  |  |
|---------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|--|
| clk_clk                                                             | Reference design clock. The clock is derived from the PLL.                                           |  |  |
| triple_speed_ethernet_0_pcs_mac_rx_clock_conn ection_clk            | RGMII receive clock. The clock is sourced from the on-board PHY chip.                                |  |  |
| <pre>triple_speed_ethernet_0_pcs_mac_tx_clock_conn ection_clk</pre> | RGMII transmit clock. The clock is sourced from the clock multiplexer which is sourced from the PLL. |  |  |
| reset_reset_n                                                       | Single reset signal for all logic in the reference design.                                           |  |  |

#### Table 5. **SGMII Clock and Reset Signals**

| Signal                                                               | Description                                                                                                                     |  |  |
|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|
| clk_clk                                                              | Reference design clock. The clock is derived from the PLL.                                                                      |  |  |
| <pre>triple_speed_ethernet_0_pcs_ref_clk_clock_con nection_clk</pre> | Reference clock for the transceiver. The clock is sourced from the 125-MHz oscillator.                                          |  |  |
| reset_reset_n                                                        | Single reset signal for all logic in the reference design.<br>Connect this reset signal to the RESET push button<br>(USER_PB0). |  |  |



# **Triple-Speed Ethernet Component Signals**

## Table 6.RGMII Reference Design Signals

| Signal                                                            | Description                                                                         |
|-------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| <pre>triple_speed_ethernet_0_mac_rgmii_connection_ rgmii_in</pre> | RGMII receive data bus. Connect this bus to the on-board PHY chip.                  |
| triple_speed_ethernet_0_mac_rgmii_connection_<br>rx_control       | RGMII receive control output signal. Connect this signal to the on-board PHY chip.  |
| triple_speed_ethernet_0_mac_rgmii_connection_<br>rgmii_out        | RGMII transmit data bus. Connect this bus to the on-board PHY chip.                 |
| triple_speed_ethernet_0_mac_rgmii_connection_<br>tx_control       | RGMII transmit control output signal. Connect this signal to the on-board PHY chip. |

# Table 7.SGMII Reference Design Signals

| Signal                                           | Description                                                                    |
|--------------------------------------------------|--------------------------------------------------------------------------------|
| triple_speed_ethernet_0_serial_connection_rxp _0 | SGMII receive serial data bus. Connect this bus to the on-<br>board PHY chip.  |
| triple_speed_ethernet_0_serial_connection_txp _0 | SGMII transmit serial data bus. Connect this bus to the on-<br>board PHY chip. |

# **1.3. Base Addresses and Configuration Registers**

To access the configuration registers of the reference design components, use the base address of the component and the register offset.

## Table 8. Base Addresses of Reference Design Components

| Base Address | Name                    | Description                                                         |
|--------------|-------------------------|---------------------------------------------------------------------|
| 0x0000000    | triple_speed_ethernet_0 | Triple-Speed Ethernet                                               |
| 0x00000400   | st_mux_2_to_1_0         | Avalon-ST Multiplexer<br>Note: Not applicable for Arria 10 designs. |
| 0x0000800    | eth_mon_0               | Ethernet Packet Monitor                                             |
| 0x00000C00   | eth_gen_0               | Ethernet Packet Generator                                           |

# **1.3.1. Ethernet Packet Generator Configuration Registers**

### Table 9. Ethernet Packet Generator Configuration Registers

| Byte Offset | Register           | Bit Number | Bit Name   | R/W | H/W Reset | Description                                                                       |
|-------------|--------------------|------------|------------|-----|-----------|-----------------------------------------------------------------------------------|
| 0x00        | number_packet      | 31:0       | -          | RW  | 0x00      | Specifies the total number of packets to be generated.                            |
| 0x04        | config_settin<br>g | 0          | LENGTH_SEL | RW  | 0x00      | 0: Fixed packet length<br>1: Random packet length                                 |
|             |                    | 14:1       | PKT_LENGTH | RW  | 0x00      | Specifies the fixed packet<br>length.<br>Valid values are between<br>24 to 9,600. |
| continued   |                    |            |            |     |           |                                                                                   |



| Byte Offset | Register              | Bit Number | Bit Name    | R/W | H/W Reset | Description                                                                                                                                                                                                                                                                                                                                                     |
|-------------|-----------------------|------------|-------------|-----|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |                       |            |             |     |           | Applicable only when you set bit 0 of this register to 0.                                                                                                                                                                                                                                                                                                       |
|             |                       | 15         | PATTERN_SEL | RW  | 0x00      | Specifies the data pattern<br>for the random packet<br>length.<br>0: Incremental—data<br>starts from zero and<br>increments by 1 in<br>subsequent bytes.<br>1: Random.                                                                                                                                                                                          |
|             |                       | 31:16      | -           | -   | -         | Reserved.                                                                                                                                                                                                                                                                                                                                                       |
| 0x08        | operation             | 0          | START       | RW  | 0x00      | Set this bit to 1 to trigger<br>packet generation. This bit<br>clears as soon as packet<br>generation starts.                                                                                                                                                                                                                                                   |
|             |                       | 1          | STOP        | RW  | 0x00      | Set this bit to 1 to stop<br>packet generation. The<br>generator completes the<br>current packet before<br>termination packet<br>generation.                                                                                                                                                                                                                    |
|             |                       | 2          | TX_DONE     | RO  | 0x00      | A value of 1 indicates that<br>the packet generator<br>completes generating the<br>total number of packets<br>specified in the<br>number_packet register.<br>This bit clears each time<br>packet generation triggers.                                                                                                                                           |
|             |                       | 31:3       | -           | -   | -         | Reserved.                                                                                                                                                                                                                                                                                                                                                       |
| 0x10        | source_addr0          | 31:0       | -           | RW  | 0x00      | 6-byte MAC address.                                                                                                                                                                                                                                                                                                                                             |
| 0x14        | source addr1          | 31:0       | -           | RW  | 0x00      | <ul> <li>source_addr0/<br/>destination_addr0</li> </ul>                                                                                                                                                                                                                                                                                                         |
| 0x18        | destination_a<br>ddr0 | 31:0       | -           | RW  | 0x00      | <ul><li>= last four bytes of the address</li><li>Bits 0 to 15 of</li></ul>                                                                                                                                                                                                                                                                                      |
| 0x1C        | destination_a<br>ddr1 | 31:0       | _           | RW  | 0x00      | <pre>source_addr1/<br/>destination_addr1<br/>= first two bytes of the<br/>address<br/>• Bits 16 to 31 of<br/>source_addr1/<br/>destination_addr1<br/>= unused<br/>For example, if the source<br/>MAC address is<br/>00-1C-23-17-4A-CB, you<br/>get the following<br/>assignments:<br/>• source_addr0 =<br/>0x17231C00<br/>• source_addr1 =<br/>0x0000CB4A</pre> |



| Byte Offset | Register            | Bit Number | Bit Name | R/W | H/W Reset | Description                                                                                                                                                                       |
|-------------|---------------------|------------|----------|-----|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x24        | packet_tx_cou<br>nt | 31:0       | _        | -   | -         | Keeps track of the number<br>of packets the generator<br>successfully transmits. This<br>register clears each time<br>packet generation triggers.                                 |
| 0x30        | rand_seed0          | 31:0       | _        | RW  | 0x00      | The lower 32 bits of the<br>random seed.<br>Occupies bits 31:0 of the<br>PBRS generator when you<br>set the data pattern to<br>random (bit 15 of the<br>configuration register).  |
| 0x34        | rand_seed1          | 31:0       | _        | RW  | 0x00      | The middle 32 bits of the random seed.<br>Occupies bits 63:32 of the PBRS generator when you set the data pattern to random (bit 15 of the configuration register).               |
| 0x38        | rand_seed2          | 31:0       | _        | RW  | 0x00      | The upper 32 bits of the<br>random seed.<br>Occupies bits 91:64 of the<br>PBRS generator when you<br>set the data pattern to<br>random (bit 15 of the<br>configuration register). |

# **1.3.2. Ethernet Packet Monitor Configuration Registers**

# Table 10. Ethernet Packet Monitor Configuration Registers

| Byte Offset | Register             | Bit Number | Bit Name | R/W      | H/W Reset | Description                                                                                                                                                                                                                                                                                  |
|-------------|----------------------|------------|----------|----------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00        | number_packet        | 31:0       | -        | RO       | 0×00      | Total number of packets the monitor expects to receive.                                                                                                                                                                                                                                      |
| 0x04        | packet_rx_ok         | 31:0       | _        | RO       | 0x00      | Total number of good packets received.                                                                                                                                                                                                                                                       |
| 0x08        | packet_rx_err<br>or  | 31:0       | -        | RO       | 0x00      | Total number of packets received with error.                                                                                                                                                                                                                                                 |
| 0x0C        | byte_rx_count<br>_0  | 31:0       | _        | RO       | 0x00      | 64-bit counter that keeps track of the total number of bytes received.                                                                                                                                                                                                                       |
| 0x10        | byte_rx_count<br>_1  | 31:0       | _        | RO       | 0x00      | <ul> <li>bytesreceived.</li> <li>byte_rx_count_0<br/>represents the lower 32<br/>bits.</li> <li>byte_rx_count_1<br/>represents the upper 32<br/>bits.</li> <li>Read byte_rx_count_0<br/>followed by<br/>byte_rx_count_1 in the<br/>subsequent cycle to get an<br/>accurate count.</li> </ul> |
| 0x14        | cycle_rx_coun<br>t_0 | 31:0       | -        | RO       | 0x00      | 64-bit counter that keeps track of the total number of cycles the monitor takes                                                                                                                                                                                                              |
|             |                      | <u> </u>   |          | <u> </u> | I         | continued                                                                                                                                                                                                                                                                                    |



| Byte Offset | Register              | Bit Number | Bit Name | R/W | H/W Reset | Description                                                                                                                                  |
|-------------|-----------------------|------------|----------|-----|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 0x18        | cycle_rx_coun<br>t_1  | 31:0       |          |     |           | <ul> <li>to receive all packets</li> <li>cycle_rx_count_0<br/>represents the lower 32<br/>bits.</li> </ul>                                   |
|             |                       |            | -        | RO  | 0x00      | <ul> <li>cycle_rx_count_1<br/>represents the upper 32<br/>bits.</li> </ul>                                                                   |
|             |                       |            |          |     |           | Read byte_rx_count_0<br>followed by<br>byte_rx_count_1 in the<br>subsequent cycle to get an<br>accurate count.                               |
| 0x1C        | rx_control_st<br>atus | 0          | START    | RW  | 0×00      | Set this bit to 1 to start<br>packet reception. This bit<br>clears when packet<br>reception starts.                                          |
|             |                       | 1          | STOP     | RW  | 0×00      | Set this bit to 1 to stop<br>packet reception. This bit<br>clears each time packet<br>reception starts.                                      |
|             |                       | 2          | RX_DONE  | RO  | 0x00      | A value of 1 indicates that<br>the packet monitor has<br>received the total number<br>of packets specified in the<br>number_packet register. |
|             |                       | 3          | CRCBAD   | RO  | 0×00      | A value of 1 indicates CRC error in the current packet received by the monitor.                                                              |
|             |                       | 9:4        | RX_ERR   | RO  | 0x00      | Receive error status.<br>The rx_err[] signal of<br>the Triple-Speed Ethernet<br>IP core maps to this<br>register.                            |
|             |                       | 31:10      | -        | -   | -         | Reserved.                                                                                                                                    |

# **1.4. Running the Reference Designs**

When the board is set up and the FPGA is configured, you can start running the design tests.

To run the tests, download and unzip the reference design files to your local directory.

# Table 11.Reference Design Files

This table lists the reference design files.

| Components            | File          | Description                                                                                                   |
|-----------------------|---------------|---------------------------------------------------------------------------------------------------------------|
| Top Level Design File | top.v         | Top-level entity file of the reference design for verification in the hardware.                               |
|                       | top_out.sdc   | Intel <sup>®</sup> Quartus <sup>®</sup> Prime SDC constraint file for use with the TimeQuest timing analyzer. |
|                       | qsys_top.qsys | Qsys file of the reference design.                                                                            |
|                       | pll.v         | The IP-generated PLL file.                                                                                    |
|                       | -             | continued.                                                                                                    |





| Components                            | File                             | Description                                                                                                                                        |  |  |
|---------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Ethernet Generator                    | eth_gen_hw.tcl                   | Qsys custom component which generates Ethernet packets.                                                                                            |  |  |
|                                       | eth_gen.v                        | The top level file of the Ethernet Packet Generator.                                                                                               |  |  |
|                                       | prbs23.v                         | Module to generate Pseudo-Random Bit Sequence 23 data.                                                                                             |  |  |
|                                       | shiftreg_data.v                  | RAM-based shift register to delay transmit packe<br>payload sending to Triple-Speed Ethernet TX FIF(<br>interface for CRC checksum merging at EOP. |  |  |
|                                       | shiftreg_ctrl.v                  | RAM-based shift register to store and delay control signals.                                                                                       |  |  |
|                                       | crcgen_dat32.v                   | Module to generate checksum CRC32.                                                                                                                 |  |  |
| Ethernet Monitor                      | eth_mon_hw.cl                    | Qsys custom component which verifies the payload of all receive packets.                                                                           |  |  |
|                                       | eth_mon.v                        | Top level file of the Ethernet Packet Monitor.                                                                                                     |  |  |
|                                       | crcchk_dat32.v                   | Module to verify the data payload of the received packets.                                                                                         |  |  |
| CRC Generator/Checke                  | crc32.sdc                        | Intel Quartus Prime SDC constraint file for use with the TimeQuest timing analyzer.                                                                |  |  |
|                                       | crc32_chk.v                      | Top level file of the CRC 32 checker.                                                                                                              |  |  |
|                                       | crc32_gen.v                      | Top level file of the CRC 32 generator.                                                                                                            |  |  |
|                                       | avalon_st_to_crc_if_bridg<br>e.v | Module to convert the Avalon-ST signal to the CRC 32 calculator input signal.                                                                      |  |  |
|                                       | byte_endian_converter.v          | Module to convert the input data byte to big or little endian.                                                                                     |  |  |
|                                       | crc32_calculator.v               | Module to calculate the crc32 checksum for the incoming data.                                                                                      |  |  |
|                                       | crc_checksum_aligner.v           | Module to align the checksum with crc_valid signal.                                                                                                |  |  |
|                                       | crc_comparator                   | Module to compare the checksum of the receiving packet with the Ethernet CRC 32 residue value.                                                     |  |  |
| Avalon-St Multiplexer                 | st_mux_2_to_1_hw.tcl             | The Qsys custom component accepts data on its                                                                                                      |  |  |
| (not applicable for Arria 10 designs) | st_mux_2_to_1.v                  | <ul> <li>two Avalon-ST sink interfaces, and multiplexes<br/>the data for transmission on its Avalon-St source<br/>interface.</li> </ul>            |  |  |
|                                       | st_mux.v                         | LPM_MUX IP core file.                                                                                                                              |  |  |
| Avalon St-Splitter                    | aso_splitter_hw.tcl              | The Qsys custom component accepts data on its                                                                                                      |  |  |
| (not applicable for Arria 10 designs) | aso_splitter.v                   | Avalon-ST sink interface and splits the data for<br>transmission on its two Avalon-ST source<br>interfaces.                                        |  |  |
| Error Adaptor                         | error_adapter2_hw.tcl            | The Qsys custom component connects                                                                                                                 |  |  |
| (not applicable for Arria 10 designs) | error_adapter2.tcl               | mismatched Avalon-ST source and sink interfaces.                                                                                                   |  |  |
|                                       |                                  | 1                                                                                                                                                  |  |  |

# **Related Information**

• TSE Single Port RGMII Arria V GX Click to download the design file.



- TSE Single Port RGMII Cyclone V GX Click to download the design file.
- TSE Single Port SGMII Stratix V GX Click to download the design file.
- TSE Single Port SGMII Stratix IV GX Click to download the design file.

# 1.4.1. Hardware and Software Requirements

The reference designs require the following hardware and software:

- Arria 10 GX, Arria V GX, or Stratix V GX, or Stratix IV GX FPGA Development Kit •
- USB-Blaster or ByteBlaster download cable •
- External Ethernet packet generator (only for Avalon-ST reverse loopback test) •
- Ethernet cable assembly (only for Avalon-ST reverse loopback test)
- Intel Quartus Prime version 15.0 or later
  - USB-Blaster or ByteBlaster driver
  - Qsys system
  - System Console

# **Related Information**

Analyzing and Debugging Designs with the System Console Provides more information about analyzing and debugging designs.

# 1.4.2. Internal MAC Loopback Test

Complete the tasks to run the internal MAC loopback test.

Set up the development board.

- 1. Connect the programming cable to the JTAG connection port.
- 2. Connect the board to the power supply input.

To run the internal MAC loopback test:

- 1. Set up the System Console.
  - a. Open Qsys.
  - b. On the Tools menu, click System Console.

The System Console is a debugging tool that provides you with Tcl scripts to perform low-level hardware debugging and run tests on your reference designs. The console communicates to the hardware components instantiated into your Qsys system reference designs through the JTAG to Avalon Master Bridge.

- 2. Open the config.tcl script and set LOOP\_ENA to 1 to enable the MAC loopback mode.
- 3. Type the following command to start the MAC and PHY configurations in the System Console:

source config.tcl





For more information, refer to Configuration Script on page 18.

The System Console displays the copper link connection status and the PHY's operating speed and mode. Verify that the console displays the correct configurations

4. Open and edit the eth\_gen\_start.tcl script.

For more information, refer to Ethernet Packet Generator Script on page 18.

5. Type the following command to start generating Ethernet packets:

source eth\_gen\_start.tcl

The Ethernet Packet Monitor automatically starts when you start the Ethernet Packet Generator.

- When the monitor receives all the Ethernet packets, the System Console displays the loopback test result.
- If the monitor receives packets with error, the console displays the total number of packets received with error and the type of error for each packet.
- 6. Type the following command to view the MAC statistic counters:

source tse\_stat\_read.tcl

# 1.4.3. Avalon-ST Reverse Loopback Test

Complete the tasks to run the Avalon-ST reverse loopback test.

Set up the development board. The Avalon-ST reverse loopback test requires an external Ethernet packet generator.

- 1. Using the Ethernet cable assembly, connect the external generator to the RJ-45 port of the FPGA development board.
- 2. Connect the programming cable to the JTAG connection port.
- 3. Connect the board to the power supply input (J4).

To run the internal MAC loopback test:

- 1. Set up the System Console.
  - a. Open Qsys.
  - b. On the Tools menu, click System Console.

The System Console is a debugging tool that provides you with Tcl scripts to perform low-level hardware debugging and run tests on your reference designs. The console communicates to the hardware components instantiated into your Qsys system reference designs through the JTAG to Avalon Master Bridge.

 Open the config.tcl script and set LOOP\_ENA to 0 to disable the MAC loopback mode.

For more information, refer to Configuration Script on page 18.

3. Type the following command to start the MAC and PHY configurations in the System Console:

source config.tcl





The System Console displays the copper link connection status and the PHY's operating speed and mode. Verify that the console displays the correct configurations

- 4. Start sending Ethernet packets from the external packet generator to the FPGA development board and verify that the packets are correctly looped back to the external packet generator.
- 5. Type the following command to view the MAC statistic counters:

source tse stat read.tcl

# 1.4.4. Tcl Script

You can use any text editor to edit the Tcl scripts inside the sc\_tcl folder of the reference designs.

Altera recommends that you do not modify the tse\_mac\_config.tcl, Note: tse\_marvel\_phy.tcl, eth\_gen\_mon.tcl, and tse\_stat\_read.tcl scripts inside the sc tcl folder.

# 1.4.4.1. Configuration Script

The config.tcl configuration script contains the parameters to configure the MAC, PCS, and Marvell PHY registers in the reference designs.

You can configure the following settings in the Tcl script:

- MAC configuration setting to configure the MAC registers. •
- PCS configuration setting to configure the PCS registers.
- Marvell PHY configuration setting to configure the on-board PHY chip registers.

| Parameter         | Description                                                 |
|-------------------|-------------------------------------------------------------|
| PHY_ENABLE        | To enable or disable the on-board PHY chip.                 |
| PHY_ETH_SPEED     | To select the PHY's operating speed.                        |
| PHY_ENABLE_AN     | To enable or disable auto-negotiation on the PHY.           |
| PHY_COPPER_DUPLEX | To select the PHY's operating mode.Statistic Counter Script |
| PHY_LOOPBACK      | To enable or disable the on-board PHY serial loopback.      |

The tse\_stat\_read.tcl script reads the values of the MAC statistic counters after you execute the reference designs.

# **Related Information**

# Configuration Register Space

Provides more information about Triple-Speed Ethernet configuration registers and statistic counters.

# 1.4.4.2. Ethernet Packet Generator Script

The eth gen start.tcl configuration script contains the parameters to configure the Ethernet Packet Generator registers in the reference designs.





You can use any text editor to configure the following registers in eth\_gen\_start.tcl script.

# Table 12. Ethernet Packet Generator Script Parameters

| number_packet    | To set the total number of packets to be generated by the packet generator.                                               |
|------------------|---------------------------------------------------------------------------------------------------------------------------|
| eth_gen          | To enable or disable the packet generator.                                                                                |
| length_sel       | To select fixed or random packet length.                                                                                  |
| pkt_length       | To set the fixed packet length. The packet length can be a value between 24 to 9,600 bytes.                               |
| pattern_sel      | To select the data pattern for the random packet length.                                                                  |
| rand_seed        | To set the initial random seed for the PRBS generator. This parameter is only valid when you select random packet length. |
| source_addr      | To set the source MAC address.                                                                                            |
| destination_addr | To set the destination MAC address.                                                                                       |

# 1.4.4.2.1. JTAG Connection Port for Altera Devices

The JTAG connection port varies for different Altera devices.

## Table 13. JTAG Connection Port for Altera Devices

| Device        | JTAG Connection Port |
|---------------|----------------------|
| Arria 10 GX   | 33                   |
| Arria V GX    | J14                  |
| Stratix V GX  | 37                   |
| Stratix IV GX | 37                   |

Send Feedback

# intel

# **2. Document Revision History**

| Date          | Version    | Changes                                                                                                                                            |
|---------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| December 2015 | 2015.12.14 | <ul><li>Added information about Arria 10 reference design.</li><li>Removed information about the obsoleted Arria II GX reference design.</li></ul> |
| December 2012 | 2012.12.03 | Added device support and restructured reference design topic.                                                                                      |
| Sept 2011     | 2011.09.23 | Updated the link to the design example download page.                                                                                              |
| June 2011     | 2011.06.17 | Initial release.                                                                                                                                   |

Intel Corporation. All rights reserved. Intel, the Intel logo, and other Intel marks are trademarks of Intel Corporation or its subsidiaries. Intel warrants performance of its FPGA and semiconductor products to current specifications in accordance with Intel's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Intel assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Intel. Intel customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. \*Other names and brands may be claimed as the property of others.