# DG0885 Demo Guide PolarFire FPGA USXGMII Design a **Microchip** company #### Microsemi Headquarters One Enterprise, Aliso Viejo, CA 92656 USA Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996 Email: sales.support@microsemi.com www.microsemi.com ©2019 Microsemi, a wholly owned subsidiary of Microchip Technology Inc. All rights reserved. Microsemi and the Microsemi logo are registered trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners. Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this document or to any products and services at any time without notice. #### **About Microsemi** Microsemi, a wholly owned subsidiary of Microchip Technology Inc. (Nasdaq: MCHP), offers a comprehensive portfolio of semiconductor and system solutions for aerospace & defense, communications, data center and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; enterprise storage and communication solutions, security technologies and scalable anti-tamper products; Ethernet solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Learn more at www.microsemi.com. # **Contents** | 1 | Revis | | story | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------|-----------------------------------------------|----| | 2 | Polar | Fire FF | PGA USXGMII Design | 5 | | | 2.1 | | Requirements | | | | 2.2 | | uisites | | | | 2.3 | | Design Architecture | | | | 2.0 | 2.3.1 | I/O Ports | | | | | 2.3.2 | Subsystem Components | 8 | | | | 2.3.3 | Clocking Structure | 12 | | | | 2.3.4 | Reset Structure | | | | | 2.3.5 | Resource Utilization | 13 | | 3 | Settir | ıg Up t | he Demo | 14 | | | 3.1 | | g Up the Hardware | | | | 3.2 Programming the PolarFire Device | | | | | | | 3.2.1 | Programming the Device Using FlashPro Express | | | | | 3.2.2 | Programming the Device Using Libero SoC | 17 | | 4 | Runn | ina the | Demo | 20 | | Training the Bonne control of the co | | | | | # **Figures** | Figure 1 | USXGMII Design Architecture | . 7 | |-----------|----------------------------------------------|-----| | Figure 2 | Mi-V Subsystem | | | Figure 3 | Mi-V Soft Processor - DRI - PF CCC Interface | | | Figure 4 | Clocking Structure | 12 | | Figure 5 | Board Setup | | | Figure 6 | FlashPro Express New Job | 15 | | Figure 7 | New Job Project from FlashPro Express Job | 16 | | Figure 8 | Programming the Device | | | Figure 9 | Run Passed | | | Figure 10 | Libero Design Flow | 17 | | Figure 11 | Design and Memory Initialization Option | | | Figure 12 | Selecting the Logical RAM Instance | 18 | | Figure 13 | Edit Fabric RAM Client | | | Figure 14 | Import Memory File | 19 | | Figure 15 | Apply Configuration | 19 | | Figure 16 | Generate Design Initialization Data | 19 | | Figure 17 | Initialization Data Generated | 19 | | Figure 18 | 10GBASE-T Advertisement | 2( | | Figure 19 | TeraTerm Configuration | 2 | | Figure 20 | UART Message - 1 | 2 | | Figure 21 | 10G Traffic Report | 2 | | Figure 22 | 5GBASE-T Advertisement | 22 | | Figure 23 | UART Message -2 | 22 | | Figure 24 | 5G Traffic Report | 22 | | Figure 25 | 2.5GBASE-T Advertisement | 23 | | Figure 26 | UART Message - 3 | 23 | | Figure 27 | 2.5G Traffic Report | 23 | | Figure 28 | 1000BASE-T Advertisement | 24 | | Figure 29 | UART Message - 4 | 24 | | Figure 30 | 1000BASE-T Traffic Report | 24 | # **Tables** | Table 1 | Design Requirements | 6 | |---------|--------------------------------------|----| | Table 2 | I/O Ports | | | Table 3 | Core10GMAC Registers | 9 | | Table 4 | CoreUSXGMII Registers | | | Table 5 | PHY Registers | | | Table 6 | USXGMII and Core10GMAC Clock Sources | 11 | | Table 7 | USXGMII Resource Utilization | 13 | | Table 8 | Jumper and Switch Settings | 14 | # 1 Revision History The revision history describes the changes that were implemented in the document. The changes are listed by revision, starting with the most current publication. ## **1.1** Revision **1.0** The first publication of this document. # 2 PolarFire FPGA USXGMII Design Microchip's PolarFire<sup>®</sup> FPGAs and Ethernet IPs enable quick development of Ethernet solutions. In the 10G Ethernet segment, the Universal Serial 10G Media Independent Interface (USXGMII) IP core from Microchip enables building 10GBASE-R solutions on PolarFire FPGAs, the IP is complaint with IEEE802.3ae. USXGMII provides the support for variable data rates of 10G, 5G, 2.5G, and 1G based on the corresponding data rate change at the downstream PHY. Implementing the solution on PolarFire FPGAs offer low-power advantages which include the low-power transceiver and FPGA fabric. The low-power advantage helps saving the power budget of the system. The USXGMII Ethernet solution is implemented using the CORE10GMAC soft IP media access control (MAC) core configured in XGMII mode, and CoreUSXGMII IP used to carry single network port over a single SERDES between MAC and PHY (Aquantia PHY AQR107). This document describes the Microchip PolarFire USXGMII design and how to run the demo using the PolarFire Video Kit, Microchip Daughter Card with Aquantia PHY (AQR107), and a USXGMII compliant network module. The PolarFire USXGMII demo design features: - 10G Ethernet MAC IP. - USXGMII IP that provides an XGMII interface with the MAC IP. - Transceiver connected to a PHY daughter card via FMC at the system side. - USXGMII Compliant network module at the line side. The PolarFire Video Kit (DVP-102-000512-001) features: - A 300K LE FPGA (MPF300T, FCG1152) - HDMI 1.4 transmitter (ADV7511) chipset and corresponding connector - · HDMI 2.0 with rail clamps, ReDrivers and corresponding connectors - Dual camera sensor featuring IMX334 Sony image sensor - Image sensor interface to support upto two MIPI CSI-2 cameras - DSI Interface - NVIDIA Jetson Interface (MIPI CSI-2 TX connector) - A High Pin Count (HPC) FMC connector to connect to high-speed interfaces (like 12G-SDI and USXGMII) For more information about this video kit, see https://www.microsemi.com/existing-parts/parts/150747. The demo design can be programmed using either of the following options: - Using the pre-generated .job file: To program the device using the .job file provided along with the demo design files, see Programming the Device Using FlashPro Express. - Using Libero SoC: To program the device using Libero SoC, see Programming the Device Using Libero SoC. ## 2.1 Demo Requirements The following table lists the resources required to run the USXGMII demo. Table 1 • Design Requirements | Description | | |-----------------------------------------------------------------------------------------------------------------------|--| | A host PC with USB port | | | | | | v12.2 | | | | | | DVP-102-000512-001 REV 1.0 | | | | | | -An Ethernet test module for 10 GbE USXGMII compliant traffic generation and error analysis -Chassis Model: SPT - N4U | | | For FPGA programming (Available with the PolarFire Video kit) | | | Two cables required for: -Connecting PHY daughter card and test module -Connecting Host PC to LAN | | | 12V, 5A (Available with the PolarFire Video kit) | | | | | | v12.2 | | | 4.69.9486 | | | TeraTerm or PuTTY | | | | | ## 2.2 Prerequisites Before you start: - Download the design files from: http://soc.microsemi.com/download/rsc/?f=mpf\_dg0885\_liberosoc\_df - 2. Download FlashPro Express from: https://soc.microsemi.com/portal/default.aspx?r=3&p=f=ProgramDebug\_v12\_2\_WIN - Download the test module software from: link? - 4. Download and install Libero SoC v12.2 from: https://www.microsemi.com/product-directory/design-resources/1750-libero-soc#downloads - 5. Download and install SoftConsole v6.1 from: https://www.microsemi.com/product-directory/design-tools/4879-softconsole#downloads ## 2.3 Demo Design Architecture The following figure shows the architecture of the demo design. Figure 1 • USXGMII Design Architecture The design loops back the XGMII traffic generated by the test module as per the following steps: - 1. The data generated by the test module passes through the Aquantia PHY(AQR107) and is received by the PolarFire transceiver inside the FPGA via FMC. - The PolarFire transceiver RX converts the serial data stream in to parallel data and clock, which is sent to the CoreUSXGMII RX interface. The data is downscaled at the CoreUSXGMII RX interface based on the data rate set during Auto-Negotiation. - CoreUSXGMII RX sends the data to the Ethernet MAC RX (Core10GMAC), which loops back the XGMII data and RX control signals using a FIFO logic implemented in RTL. - The looped back data passes through Core10GMAC TX, CoreUSXGMII TX (data upscaling), PF\_XCVR TX and the Aquantia PHY, and finally received by the test module. - 5. The received packets are analyzed for throughput rate and errors using the test module software. #### 2.3.1 I/O Ports The following table lists the important I/O ports of the USXGMII Libero hardware design. Table 2 • I/O Ports | Port Name | Direction | Description | |------------------------------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | TMS TRSTB TDI TCK TDO | Input<br>Input<br>Input<br>Input<br>Output | JTAG signals interfaced to the Mi-V soft processor for debugging. | | REF_CLK_PAD_P_0<br>REF_CLK_PAD_N_0 | Input | 148.5 MHz reference clock received from the on-board LVDS oscillator. This reference clock is used to generate clocks for the Fabric and DRI interface. | Table 2 • I/O Ports (continued) | Port Name | Direction | Description | |--------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | PHY_RSTN_OUT | Input | Active-high reset signal from external PHY. This signal indicates that the external PHY is powered-up. | | LANE0_RXD_P<br>LANE0_RXD_N | Input | Receive lane of the Transceiver to receive the serial data via FMC from the external PHY. These pads are connected to the receive pins of the FMC. | | LANE0_TXD_P<br>LANE0_TXD_N | Output | Transmit lane of the Transceiver to transmit the serial data via FMC to the external PHY. These pads are connected to the transmit pins Transceiver. | | REF_CLK_PAD_P<br>REF_CLK_PAD_N | Input | Reference clocks received from the external PHY card. | | SYSRESTN | Input | Active-low system reset. Asserted by pressing the on-board AL27 push-button. | | TX | Input | UART interface to the FPGA from the Host PC | | RX | Output | UART interface to the Host PC from the FPGA. | | PHY_MDIO | Input/Output | Management Data IO Interface for accessing the external PHY PHY registers. | | PHY_MDC | Output | Management Data IO clock fed to the external PHY. | | PHY_RST | Output | Active-high reset signal to the external PHY. | ### 2.3.2 Subsystem Components The following sections describe the subsystems used in the design. - CORE10GMAC - CoreUSXGMII - PF\_XCVR\_ERM - Mi-V Processor Subsystem - FIFO Logic - PF\_TX\_PLL - PF\_XCVR\_REF\_CLK - PF\_CCC #### 2.3.2.1 CORE10GMAC The CORE10GMAC IP is the 10-Gbps Ethernet MAC that transmits and receives the Ethernet packets. Core10GMAC is configured for XGMII mode with a core data width of 64 bits. Core data width is the width of the data path connected to the USXGMII IP. The system data width, that is, the width of the interface to the user logic, is configured as 64 bits. In this demo, the FiFo\_wrapper\_top module provides this interface. The TX and RX Pause features are disabled, and both the MAC TX FIFO depth and MAC RX FIFO depth are set to 256. The Core10GMAC IP is configured using Mi-V soft processor and is covered in-detail in the Mi-V subsystem section. For information about the features and registers of Core10GMAC, see **Libero SoC** - > **Catalog** -> **Core10GMAC Handbook**. #### 2.3.2.2 CoreUSXGMII The CoreUSXGMII IP provides an XGMII interface between MAC and transceiver, and adapts the Ethernet frames to/from MAC based on the Auto-Negotiated data rate using data downscaling or upscaling logic in the RX and TX interface. CoreUSXGMII is configured using the Mi-V soft processor. For information about the features and registers of CoreUSXGMII, see Libero SoC -> Catalog -> CoreUSXGMII Handbook. #### **2.3.2.3 PF XCVR ERM** The PF\_XCVR IP provides the 10GBASE-R physical interface for data transfers. PF\_XCVR is configured for 64b/66b encoding/decoding with scrambler/descrambler enabled with a PCS interface width of 64 bits to the COREUSXGMII. The PolarFire high-speed transceiver (PF\_XCVR) is a hard IP block and supports data rates from 250 Mbps to 12.5 Gbps. In this demo, PF\_XCVR is configured for the data rate of 10312.5 Mbps. It is configured with a CDR reference clock of 156.25 MHz with Lock to data selected as the CDR lock mode. #### 2.3.2.4 Mi-V Processor Subsystem The Mi-V processor subsystem configures Core10GMAC, CoreUSXGMII through AHB-APB bus interface, and also communicates with external AQR107 PHY through CoreGPIO which provides the MDIO clause 45 interface implemented in the firmware. Figure 2 • Mi-V Subsystem MIV\_RV32IMA\_L1\_AHB Configurator, set the Reset Vector Address to 0x80000000, as shown in the following figure. This is the address the processor will start executing from after a reset. The processor's main memory must be accessible to Mi-V AHB memory interface whose memory mapped address ranges from 0x80000000 to 0x8FFFFFFF. The Mi-V memory interface supports cached transactions, whereas Mi-V MMIO interface does not support them. Mi-V subsystem communicates to the IP block using the following interfaces: Core10GMAC: Mi-V (AHB master) -> CoreAHBlite (AHB master) -> CoreAHB\_to\_APB3 (APB master) -> Core10GMAC (APB slave). Registers configured by Mi-V subsystem are as follows. Table 3 • Core10GMAC Registers | Register | Address | Offset | Bit | Binary value | |------------------------------|---------|--------|--------------------|--------------| | MAC TX Config Register (0xA) | | 0x3 | cfg_sys_mac_tx_en | 1 | | | | 0x4 | sys_mac_tx_fcs_ins | 1 | Table 3 • Core10GMAC Registers | Register | Address | Offset | Bit | Binary value | |------------------------------|---------|--------|-------------------|--------------| | MAC RX Config Register (0xB) | | 0x0 | mac_rx_fcs_remove | 1 | | | | 0x3 | cfg_sys_mac_rx-en | 1 | CoreUSXGMII: Mi-V (AHB master) -> CoreAHBlite (AHB master) -> CoreAHB\_to\_APB3 (APB master) -> CoreUSXGMII (APB slave). Registers configured by Mi-V subsystem are listed in Table 4. Table 4 • CoreUSXGMII Registers | Register | Offset | Description | |---------------------|--------|-----------------------------------------------------------------------------------------------------------------------------| | USXGMII-CONTROL_REG | 0x0 | Control: Enables/Disables the USXGMII Auto negotiation function | | USXGMII_STATUS_REG | 0x4 | Status: Indicates the Link status along with Auto negotiation status | | USXGMII_AN_ADV | 0x8 | Auto Negotiation Advertise: configures the mode of operation and configures the speed selection | | USXGMII_AN_LP_ADV | 0xC | Auto Negotiation Link Partner Base Page Ability:<br>Read Only register indicates the link partners<br>USXGMII configuration | - CoreUARTAPB: Mi-V (AHB master) -> CoreAHBlite (AHB master) -> CoreAHB\_to\_APB3 (APB master) -> CoreUARTAPB (APB slave). Registers configured by Mi-V subsystem and the user requests are as follows. - Aquantia PHY (AQR107): Mi-V (AHB master) -> CoreAHBlite (AHB master) -> CoreAHB\_to\_APB3 (APB master) -> CoreGPIO (APB slave). Registers configured by Mi-V subsystem are as follows: Table 5 • PHY Registers<sup>1</sup> | Register | Offset | Description | |--------------|--------|------------------------------------------------| | PHY REGISTER | 0x4 | Enables / Disables / re-start Auto Negotiation | - For information about the features and registers of Aquantia PHY, see AQR107 Handbook. - PF\_SRAM: The PolarFire system controller initializes the LSRAM's with user application and releases the system reset. #### **2.3.2.5** FIFO Logic The FIFO interface logic loops back the CORE10GMAC RX data to TX data. FiFo\_wrapper\_Top is a user-defined RTL module, which uses the CoreFIFO IP to loop the MAC RX PACKET INTERFACE to the MAC TX PACKET INTERFACE. #### 2.3.2.6 PF TX PLL The PF\_TX\_PLL IP generates the bit clock required for the transceiver. The PolarFire transmit PLL (PF\_TX\_PLL) is a hard IP block that provides a bit clock and a reference clock to the transceiver block. The transmit PLL is configured with a reference clock of 156.25 MHz and generates an output clock of 10312.5 Mbps. #### 2.3.2.7 PF XCVR REF CLK PF\_XCVR\_REF\_CLK generates the fabric clock and the reference clock for the transceiver and the TX\_PLL. The transceiver reference clock (PF\_XCVR\_REF\_CLK) is a hard IP block that provides a reference clock (REF\_CLK) of 156.25 MHz to the transmit PLL and a fabric reference clock (FAB\_REF\_CLK) which is provided as input to the Clock Conditioning circuit (CCC) to generate the PCLK (for configuration) and I SYS CLK of CORE10GMAC. #### 2.3.2.8 PF\_CCC The PF\_CCC IP instances provide the required clock frequency for CoreUSXGMII, Core10GMAC, and FIFO logic. The PolarFire Clock Conditioning Circuitry (CCC) block sources an input clock of 148.5 MHz from the FAB\_REF\_CLK signal (output of PF\_XCVR\_REF\_CLK) and generates a 50 MHz clock at OUT0 and 156.25 at OUT1. The OUT0 port of CCC is used for the configuration and OUT1 is used for the user logic in the design. Mi-V soft processor receives speed information from configures the PF\_CCC instantiations via the DRI interface as shown in the following figure. Figure 3 • Mi-V Soft Processor - DRI - PF\_CCC Interface The following table shows the clock generated by PF\_CCC instantiations used for generating RX and TX clocks for USXGMII and Core10GMAC. Table 6 • USXGMII and Core10GMAC Clock Sources | PF_CCC Instance | Input Source | Output Clocks | |-------------------|--------------|-------------------------| | CCC XCVR Rx Ref 0 | XCVR RX CLK | USXGMII_core_rx_clk | | CCC_XCVK_RX_Rei_0 | XCVIN_NX_CLN | Core10GMAC_Icore_rx_clk | Table 6 • USXGMII and Core10GMAC Clock Sources (continued) | PF_CCC Instance | Input Source | Output Clocks | | |-----------------|--------------------|-------------------------|--| | PF CCC 0 | PF XCVR REF CLK 1 | USXGMII_core_tx_clk | | | 11_000_0 | TT_XOVIN_NEF_OLN_T | Core10GMAC_lcore_tx_clk | | For more information, see Clocking Structure. #### 2.3.2.9 PF\_INIT\_MONITOR The PF\_POWER\_INIT block ensures the device is powered up in a systematic way. The process of powering up the device includes three steps: - 1. Power-on reset - 2. Programmed device boot - 3. Design initialization During design initialization, the transceiver configuration is initialized using the data stored in the non-volatile memory. The output of the PF\_POWER\_INIT block is ANDed with the resets used in the design to reset entire logic. ### 2.3.3 Clocking Structure Figure 4 shows the clocking structure of the PolarFire USXGMII design. As shown below, the clocking structure consists of the following clock domains: - On-chip 160 MHz RC Oscillator: Drives PF XCVR ERM C0:XCVR CTRL CLK. - **PF\_XCVR\_REF\_CLK\_C0**: Generates reference clock required for the PF\_DRI\_C0 block. - PF\_XCVR\_REF\_CLK\_1: Generates reference clocks required for: - Driving Transceiver CDR reference clock used to derive the RX clocks for Transceiver, USXGMII, and Core10GMAC blocks. - Driving TX clocks for USXGMII and Core10GMAC blocks. Figure 4 • Clocking Structure #### 2.3.4 Reset Structure The Reset structure is implemented in the <code>Clock\_Reset\_Subsystem</code> SmartDesign file in the Libero design. This SmartDesign module generates the following reset signals: - FABRIC\_RESET\_N: To reset the Mi-V\_Subsystem. FABRIC\_RESET\_N is asserted when the SYSRESET\_N, PHY\_RST\_OUT, DEVICE\_INIT\_DONE, and PLL\_LOCK signals are asserted. PHY\_RST\_OUT is asserted when the external PHY is powered up. - XCVR\_PCS\_PMA\_RESET and PHY\_RST: To reset the PolarFire Transceiver (PF\_XCVR\_ERM) PMA and PCS. XCVR\_PCS\_PMA\_RESET and PHY\_RST are asserted when SYSRESETN and DEVICE\_INIT\_DONE signals are asserted. The Mi-V Subsystem generates the following reset signals after reset: - EXT\_RST: To reset FIFO, USXGMII blocks. - MAC\_RST: To reset Core10GMAC block using the CoreGPIO APB interface. #### 2.3.5 Resource Utilization Table 7 lists the resource utilization of the UXSGMII design on the MPF300T device. This report is derived after Place and Route. Table 7 • USXGMII Resource Utilization | Element | Used | Total | Percentage | |----------------|-------|--------|------------| | 4LUT | 28006 | 299544 | 9.35 | | DFF | 22730 | 299544 | 7.59 | | Logic Elements | 32744 | 299544 | 10.93 | ## 3 Setting Up the Demo This section describes steps to successfully set up the hardware and program the FPGA. Setting up the demo involves the following steps: - Setting Up the Hardware - · Programming the Device Using FlashPro Express ### 3.1 Setting Up the Hardware This section describes how to connect all of the components required to run the demo. - 1. Connect the test module device to a LAN using the Cat 6 cable. - 2. Connect the Host PC to the same LAN using the Cat 6 cable. - 3. Connect the host PC and the video kit through J12 of the video kit using the USB mini cable. - 4. Insert the Aquantia PHY daughter card on the FMC connector of video kit. - 5. Connect the Aquantia PHY daughter card and the test module using the Cat 6 cable. At the test module side use the 10Gbe variable data rate port (for example port 9). - 6. Connect the power supply cable to **J20** of the video kit. - 7. Ensure that the following jumper settings are set on the video kit. Table 8 • Jumper and Switch Settings | Jumper | Default Position | Functionality SPI Slave and Master mode selection. By default, SPI master. | | |--------|-----------------------------|-----------------------------------------------------------------------------|--| | J15 | Open | | | | J17 | Open | 100K PD for TRSTn. By default,1K PD is connected. | | | J19 | Pin 1&2 | Default: XCVR_VREF is connected to GND. | | | J28 | Pin 1&2 | Default: Programming through the FTDI. | | | J24 | Pin 2&4 | Default: VDDAUX4 voltage is set to 3V3. | | | J25 | Pin 5&6 | Default: Bank4 voltage is set to 1V8. | | | J36 | Pin 1&2 | Default: Board power up through the SW4. | | | SW4 | OFF (Pin 2-3,5-6 Positions) | Power ON\OFF switch. | | | SW6 | OFF | User slide switch. Default position: OFF. | | | J20 | 12 Volts Input | 12V input to the board. | | - 8. Power-up the Host PC and test module. - Power-up the video kit using the SW4 slide switch. The PolarFire USXGMII hardware is set up as shown in Figure 5. See the following section to program the PolarFire device. Figure 5 • Board Setup ### 3.2 Programming the PolarFire Device The PolarFire device can be programmed using any of the following methods: - Programming the Device Using FlashPro Express - Programming the Device Using Libero SoC ### 3.2.1 Programming the Device Using FlashPro Express This section describes how to program the PolarFire device with the job file using Flashpro Express. The job file can be downloaded using the following link: http://soc.microsemi.com/download/rsc/?f=mpf\_dg0885\_liberosoc\_jb Follow these steps: - 1. On the host PC, start the FlashPro Express software from its installation directory. - Select New or New Job Project from FlashPro Express Job from Project menu to create a new job project, as shown in Figure 6. Figure 6 • FlashPro Express New Job - 3. Enter the following in the New Job Project from FlashPro Express Job dialog box: - Programming job file: Click Browse and navigate to the location where the job file is located and select the file. The default location is: - <\$Download\_Directory>\mpf\_dg0885\_liberosoc\_jb\Programming\_job - FlashPro Express job project location: Select Browse and navigate to the location where you want to save the project. Figure 7 • New Job Project from FlashPro Express Job - 4. Click **OK**. The required programming JOB file is selected and ready to be programmed in the device. - The FlashPro Express window appears as shown in Figure 8. Confirm that a programmer number appears in the Programmer field. If it does not, confirm the board connections and click Refresh/Rescan Programmers. Figure 8 • Programming the Device Click RUN to program the device. When the device is programmed successfully, a RUN PASSED status is displayed as shown in Figure 9. See Running the Demo. Figure 9 • Run Passed #### 3.2.2 Programming the Device Using Libero SoC The design files include the Libero SoC project for USXGMII. The PolarFire device can be programmed using Libero SoC. The Libero SoC project is completely built and run from Synthesis, Place and Route, Timing Verification, FPGA Array Data Generation, Design and Memory Initialization, Bitstream Generation, FPGA Programming. The Libero design flow is shown in the following figure. Figure 10 • Libero Design Flow To program the PolarFire device, the USXGMII project must be opened in Libero SoC and the following steps must be re-run: - Design and Memory Initialization: In this step, the following options are selected: - Storage type (sNVM, µPROM, or SPI Flash) for the initialization client to initialize the designated fabric RAM block. - Generating the initialization client by selecting the user application file (.hex). - Bitstream Generation: In this step, the STAPL file is generated for the PolarFire device. - FPGA Programming: In this step, the PolarFire device is programmed using the STAPL file. Follow these steps: - 1. Launch Libero SoC. - 2. Open the USXGMII project by selecting the USXGMII\_Demo.prjx file from following location: <\$Design\_Files\_Directory>:\mpf\_dg0885\_liberosoc\_df\Solution\Libero\_Project - 3. Select the Design Initialization Data and Memories as shown in Figure 11. Figure 11 • Design and Memory Initialization Option 4. Select the logical RAM instance as shown in Figure 12. Figure 12 • Selecting the Logical RAM Instance Select the storage type and select the Import option to import user application file (Figure 13). Figure 13 • Edit Fabric RAM Client 6. Select the application file as shown in Figure 14. Figure 14 • Import Memory File 7. Apply the configuration as shown in Figure 15. Figure 15 • Apply Configuration 8. Select the Generate Design Initialization Data option as Figure 16. Figure 16 • Generate Design Initialization Data The design initialization data is generated as shown in Figure 17. Figure 17 • Initialization Data Generated - 9. Select the Generate Bitstream option to the generate bitstream for the PolarFire device - 10. Select the Run PROGRAM Action to program the PolarFire device. This concludes the programming of the PolarFire device. # 4 Running the Demo This section describes steps to successfully run the demo and observe the Ethernet packets transmitted and received by the Ethernet test module. The following points describe the overview of the demo: - The test module initiates the Ethernet traffic on the line. At the system side, the FPGA configures the AQR107 PHY. Then, AN packets are passed to CoreUSXGMII via AQR107 PHY and the auto negotiation is completed at the system side. - The Ethernet traffic is received at USXGMII through XCVR lane which is connected to AQR107 PHY on 10G daughter board. Ethernet Packets are looped back at the USER FIFO located at CORE10GMAC system interface. - The test module receives the packets from AQR107 PHY through Cat6 cable and checks for CRC errors. It displays the number of packets transmitted, received, errors received and the line throughput. Note: Before running the demo: - Ensure that the demo hardware is set up as described in Setting Up the Demo. - The user must know how to launch the test module software on the Host PC, discover the test module, and use the test module software. Follow these steps to run the USXGMII demo: . Configure the test module for 10GBASE-T advertisement using the test module software. Figure 18 • 10GBASE-T Advertisement 2. Launch TeraTerm with the 3rd FlashPro5 Port and 115200 Baud rate. Figure 19 • TeraTerm Configuration - Reset the design or power cycle the video board. - Observe the UART messages for the completion of PHY initialization, AN enabled between the external PHY and USXGMII, MAC configuration, and the 10G clock configured message. Figure 20 • UART Message - 1 5. Observe the 10G traffic transmitted and received by the test module. Figure 21 • 10G Traffic Report 6. Configure the test module for 5GBASE-T advertisement. Figure 22 • 5GBASE-T Advertisement 7. Observe the clocks configured message for 5G data rate on the TeraTerm. Figure 23 • UART Message -2 8. Observe the 5G traffic transmitted and received by the test module. Figure 24 • 5G Traffic Report 9. Configure the test module for 2.5BASE-T advertisement. Figure 25 • 2.5GBASE-T Advertisement 10. Observe the clocks configured message for 2.5G data rate on the TeraTerm. Figure 26 • UART Message - 3 11. Observe the 2.5G traffic transmitted and received by the test module. Figure 27 • 2.5G Traffic Report 12. Configure the test module for 1000BASE-T advertisement. Figure 28 • 1000BASE-T Advertisement 13. Observe the clocks configured message for 1000BASE-T data rate on the TeraTerm. Figure 29 • UART Message - 4 14. Observe the 1000BASE-T traffic transmitted and received by the test module. Figure 30 • 1000BASE-T Traffic Report This concludes the demo.