# IGLOO2 FPGA PCIe HPMS HPDMA - Libero SoC v11.7 DG0585 Demo Guide ### **Contents** | 1 | Prefa | ce | | 2 | |---|-------|----------------|---------------------------------------------------|----| | | 1.1 | Purpos | se | 2 | | | 1.2 | Intende | ed Audience | 2 | | | 1.3 | Referer | nces | 2 | | 2 | PCle | Data P | Plane Demo Using HPMS HPDMA | 3 | | _ | 2.1 | | uction | | | | 2.2 | | n Requirements | | | | 2.3 | • | Design | | | | 2.0 | 2.3.1 | Introduction | | | | | 2.3.2 | Demo Design Features | 6 | | | | 2.3.3 | Demo Design Description | | | | | | 2.3.3.1 PC Memory to DDR Memory | | | | | | 2.3.3.2 DDR Memory to Fabric SRAM | | | | | | 2.3.3.4 Throughput Calculation | | | | 2.4 | Simulat | ting the Design | | | | 2.5 | | g Up the Demo Design | | | | | 2.5.1 | Programming the IGLOO2 Board | 10 | | | | 2.5.2 | Connecting IGLOO2 Evaluation Kit Board to Host PC | | | | | 2.5.3 | Drivers Installation | | | | | 2.5.4<br>2.5.5 | Installing PCIe_Demo Application GUI | | | | 2.6 | | Ision | | | _ | | | | | | 3 | Apper | ndix: IC | GLOO2 Evaluation Kit Board Setup for Laptop | 34 | | 4 | Apper | ndix: R | Register Details | 37 | | _ | | | | | | 5 | Revis | ion His | story | 38 | | 6 | Produ | ict Sup | pport | 39 | | | 6.1 | Custom | ner Service | 39 | | | 6.2 | | ner Technical Support Center | | | | 6.3 | Technic | ical Support | 39 | | | 6.4 | Website | te | 39 | | | 6.5 | | cting the Customer Technical Support Center | | | | | 6.5.1 | Email | 39 | | | | 6.5.2 | My Cases | | | | 0.0 | 6.5.3 | Outside the U.S. | | | | 6.6 | HARI | Fechnical Support | 40 | ### **Figures** | Figure 1. | Demo Design Files Top-Level Structure | 4 | |------------|------------------------------------------------------------------------------------|----| | Figure 2. | PCIe Data Plane Demo Block Diagram | 5 | | Figure 3. | Modelsim Transcript Messages | 8 | | Figure 4. | DMA Transactions between PCIe and LPDDR | 8 | | Figure 5. | DMA Transactions between LPDDR and LSRAM | 9 | | Figure 6. | FlashPro New Project | 10 | | Figure 7. | FlashPro Project Configuration | 1 | | Figure 8. | FlashPro Programming Passed | 12 | | Figure 9. | IGLOO2 Evaluation Kit Setup | 13 | | Figure 10. | Device Manager - PCIe Device Detection | 14 | | Figure 11. | Command Prompt | 15 | | Figure 12. | Jungo Driver Installation | 16 | | Figure 13. | Windows Security | 16 | | Figure 14. | GUI Installation | | | Figure 15. | Successful Installation of GUI | | | Figure 16. | Device Manager - PCIe Device Detection | 19 | | Figure 17. | PCIe Demo GUI | | | Figure 18. | PCIe Device Information | 2′ | | Figure 19. | Demo Controls | | | Figure 20. | PCIe Interrupt | 23 | | Figure 21. | PCIe Configuration Space | | | Figure 22. | DMA Operations | | | Figure 23. | Transfer Size Selection | | | Figure 24. | Burst Size Selection | | | Figure 25. | DMA Transaction - PC Memory to DDR | | | Figure 26. | PC Memory to DDR DMA Loop Transfer | | | Figure 27. | DDR to PC Memory DMA Loop Transfer | | | Figure 28. | LSRAM To DDR DMA Loop Transfer | | | Figure 29. | DDR to LSRAM DMA Loop Transfer | | | Figure 30. | Lining Up the IGLOO2 Evaluation Kit Board | | | Figure 31. | Inserting the IGLOO2 Evaluation Kit PCle Connector into the PCle Adapter Card Slot | | | Figure 32. | PCIe Adapter Card and IGLOO2 Evaluation Kit Connected to Laptop | 36 | ### **Tables** | Table 1. | Design Requirements | | |----------|-----------------------------------------------|----| | | IGLOO2 FPGA Evaluation Kit Jumper Settings | | | Table 3. | HP Workstation Z220 - CMT - Throughput Values | 33 | | Table 4. | Register Details 3 | 37 | #### 1 Preface #### 1.1 Purpose This demo is for IGLOO<sup>®</sup>2 field programmable gate array (FPGA) devices. It provides instructions on how to use the corresponding reference design. #### 1.2 Intended Audience This demo guide is intended for: - FPGA designers - · System-level designers #### 1.3 References See the following web page for a complete and up-to-date listing of IGLOO2 device documentation: http://www.microsemi.com/products/fpga-soc/fpga/igloo2-fpga The following documents are referred in this demo guide. - UG0448: IGLOO2 FPGA High Performance Memory Subsystem User Guide - UG0447: IGLOO2 and SmartFusion2 High Speed Serial Interfaces User Guide - DG0532: IGLOO2 FPGA PCIe Control Plane with Device Serial Number Demo Guide - DG0517: SmartFusion2 and IGLOO2 PCle Data Plane Demo using 2 Channel Fabric DMA Demo Guide - TU0509: Implementing PCIe Control Plane Design in IGLOO2 FPGA Tutorial ### 2 PCIe Data Plane Demo Using HPMS HPDMA #### 2.1 Introduction This demo describes the usage of the following embedded features of the IGLOO2 devices: - PCle controller - High-performance direct memory access (HPDMA) controller - Microcontroller subsystem double data rate (MDDR) controller The demo design uses all of these embedded features and few FPGA resources. This demo architecture is resource and power efficient, but does not demonstrate the highest performance of the PCIe link. The demo design also explains how to use the IGLOO2 FPGA embedded PCI Express feature as a data plane interface. The demo design accesses the PCIe end point (EP) available in the IGLOO2 device from a host PC, and initiates the DMA transactions using the PCIe interface. In this demo, the DMA transfers are performed using the IGLOO2 embedded high-performance memory subsystem (HPMS) HPDMA controller. A host PC PCIe\_Demo application is provided for setting up and initiating the DMA transactions between the IGLOO2 PCIe end point and host PC. The demo provides host PC device drivers for the IGLOO2 PCIe end point and also PCIe features are used as control plane. See the TU0509: Implementing PCIe Control Plane Design in IGLOO2 FPGA Tutorial for more information on PCIe control plane. Microsemi provides the following PCIe data plane demos for the IGLOO2 devices: - PCIe Data Plane Demo using HPMS HPDMA (current demo): This demo describes the medium throughput data transfer between the PCIe and MDDR. - DG0517: SmartFusion2 and IGLOO2 PCIe Data Plane Demo using 2 Channel Fabric DMA Demo Guide. This demo describes the high throughput data transfer between PCIe, MDDR, and a large SRAM (LSRAM). The high-speed serial interface available in the IGLOO2 devices provides a fully hardened PCIe endpoint implementation, and is compliant to the PCIe Base Specification Revision 2.0 and 1.1. For more information on high-speed serial interface, see the *UG0447: IGLOO2 and SmartFusion2 High Speed Serial Interfaces User Guide*. #### 2.2 Design Requirements Table 1 lists the design requirements for running the PCle data plane demo using HPMS HPDMA. Table 1 • Design Requirements | Design Requirements | Description | | | | |-------------------------------------------------------------------|---------------------------------|--|--|--| | Hardware Requirements | | | | | | IGLOO2 Evaluation Kit: | Rev C or later | | | | | Host PC or Laptop (8 GB RAM) | Windows 64-bit Operating System | | | | | Host PC with an available PCIe 2.0 compliant slot (×1 or greater) | - | | | | | Software Requirements | | | | | | Libero® System-on-Chip (SoC) | v11.7 | | | | | FlashPro Programming Software | v11.7 | | | | | PCIe Demo Application | _ | | | | #### 2.3 Demo Design #### 2.3.1 Introduction The demo design files are available for download from the following path in the Microsemi website: http://soc.microsemi.com/download/rsc/?f=m2gl\_dg0585\_hpms\_hpdma\_liberov11p7\_df The demo design files include: - Libero SoC project - Programming files - Drivers - Readme.txt file See the ${\tt Readme.txt}$ file for the complete directory structure. Figure 1 shows the top-level structure of the design files. Figure 1 • Demo Design Files Top-Level Structure Revision 3 Figure 2 shows the demo design. The PCIe\_Demo application from the host PC initiates the DMA transfers. The embedded PCIe core in the IGLOO2 device receives these commands and initiates the appropriate AHB transactions. The command decoder logic in the FPGA fabric decodes the AHB transaction commands and provides the inputs to CoreHPDMACtrl IP, which initializes the HPDMA controller to perform the DMA transactions between the low power DDR (LPDDR) memory (available on the IGLOO2 Evaluation Kit), the large static random access memory (LSRAM) (available on the IGLOO2 device), and the host PC. The counter logic implemented in the FPGA fabric calculates the throughput of each DMA transfer for displaying in the application GUI. The driver on the host PC creates a buffer and passes the physical address of that buffer to the IGLOO2 device. HPDMA uses this address to perform the DMA transfers to the host PC. The following options are available in the application for the DMA data transactions: - LPDDR to Host PC: In this DMA transfer, HPDMA reads the data from the external LPDDR memory through MDDR and writes to a host PC buffer using the fabric interface controller (FIC\_0) and PCIe. The DMA size can be 64 KB, 256 KB, or 1 MB. - Host PC to LPDDR: In this DMA transfer, HPDMA reads the data from the host PC buffer using FIC\_0 and PCle and writes to an external LPDDR memory using MDDR. The DMA size can be 64 KB, 256 KB, or 1 MB. - Fabric LSRAM to LPDDR: In this DMA transfer, HPDMA reads the data from fabric LSRAM using FIC\_0 and writes to the external LPDDR memory using MDDR. The DMA size can be 16 KB or 32 KB. - LPDDR to Fabric LSRAM: In this DMA transfer, HPDMA reads the data from the external LPDDR memory using MDDR and writes to the fabric LSRAM using FIC\_0. The DMA size can be 16 KB or 32 KB. Figure 2 • PCle Data Plane Demo Block Diagram In this demo, the IGLOO2 MDDR is configured for accessing the LPDDR memory in ×16 mode to access the LPDDR memory on the IGLOO2 Evaluation Kit board. The MDDR clock is configured to 160 MHz (320 Mbps DDR) with a 80 MHz DDR\_FIC clock for an aggregate memory bandwidth of 640 Mbps approximately. The PCIe AHB interface clock and fabric clocks are configured to run at 80 MHz. #### 2.3.2 Demo Design Features Following are the demo design features: - DMA data transfers between the host PC and external LPDDR memory using the HPDMA controller. - DMA data transfers between the external LPDDR memory and the IGLOO2 LSRAM using the HPDMA controller. - · Displays throughput for each DMA data transfer. - Continuous DMA transfers to observe the throughput variations. - Displays the PCle link enable/disable, negotiated link width, and the link speed. - Displays the position of DIP switches on the IGLOO2 Evaluation Kit board. - Displays the PCle Configuration Space Controlling LEDs on the board through the PCle\_Demo application. - · Read and write operations on scratch-pad register in the FPGA fabric. - Displays the interrupt counts by interrupting the host PC using the Push button on the IGLOO2 Evaluation Kit board. #### 2.3.3 Demo Design Description In this demo design, the PCIe link is configured to operate in Gen2 mode using one lane (×1) and a throughput of more than 400 Mbps can be achieved. The following four types of data transfers are supported and the sections describe the process of each data transfer: - PC Memory to DDR Memory - DDR Memory to Fabric SRAM - · Fabric SRAM to DDR Memory - · Throughput Calculation #### 2.3.3.1 PC Memory to DDR Memory A data transfer from PC memory to the LPDDR device happens in the following sequence: - 1. CoreHPDMA is setup over the PCle link based on the GUI settings. - CoreHPDMA sets up the HPMS HPDMA. - HPDMA initiates an AHB read transaction through the HPMS fabric interface (FIC) and to the PCIe AHB interface. - 4. The PCIe core sends a memory read (MRd) transaction layer packet (TLP) to the host PC. - 5. The host PC returns a completion with data (CpID) TLP to the PCIe link. - 6. This return data completes the AHB read initiated by HPDMA controller. - 7. This data is then written to the LPDDR memory using the MDDR subsystem. - 8. HPDMA repeats this process (from step 1 to 7) until the transfer size set in the host PC GUI is completed. For transfers that require more than one buffer descriptor size (64 KB size) of HPDMA, the fabric logic is implemented to reset the buffer descriptor and re-start the transfer process. This read operation is effective. However, it is not optimal for a PCIe link as the AHB bus of the HPMS does not support a split transaction. **Note:** For optimal data transfers from the host PC memory to DDR, use the AXI interface of the PCIe link and a fabric-based DMA controller. The AXI supports split transactions and allows the PCIe link to send a larger read request. While waiting for the read request, the AXI bus can move on to the next transaction. Multiple read requests can be initiated that allow the PCIe link to operate efficiently with read completion data returning. #### 2.3.3.2 DDR Memory to Fabric SRAM The FPGA design has a 32 KB fabric SRAM block. Data transfer from the LPDDR device to the fabric SRAM happens in the following sequence: - 1. CoreHPDMA is setup over the PCIe link based on the GUI settings. - 2. CoreHPDMA sets up the HPMS HPDMA. - 3. HPDMA initiates an AHB read transaction of the LPDDR using the DDR controller of the HPMS. - 4. The data is written to the fabric SRAM as an AHB write transaction through the FIC. - HPDMA repeats this process (from step 1 to 4) until the transfer size set in the host PC GUI is completed. #### 2.3.3.3 Fabric SRAM to DDR Memory A data transfer from the LPDDR device to PC memory happens in the following sequence: - 1. HPDMA is setup over the PCle link based on the GUI settings. - 2. HPDMA initiates an AHB read transaction through the HPMS FIC and to the fabric SRAM. - 3. The data is written to the LPDDR Memory through the MDDR subsystem. - 4. HPDMA repeats this process (from step 1 to 3) until the transfer size set in the host PC GUI is completed. #### 2.3.3.4 Throughput Calculation This demo implements a timer to measure the throughput of DMA transfers. The throughput measured includes all the overhead of AHB, PCIe, and HPDMA controller transactions. The procedure for measuring throughput is: - 1. Setup the CoreHPDMA controller for the complete transfer. - Start the timer and HPDMA controller, which initiates the data transfer for the requested number of bytes. - 3. Wait until the DMA transfer is completed. - 4. Record the number of clock cycles used for steps 2 and 3. To arrive at a realistic system performance, the throughput calculation takes into account all the overheads during a transfer. The throughput formula is as shown below: Throughput = Transfer Size (Bytes) / (Number of clock cycles taken for a transfer \* Clock Period) EQ 1 #### 2.4 Simulating the Design The design supports the BFM\_PCle simulation level to communicate with the serializer/de-serializer interface (SERDESIF) block using the master AXI/AHB bus interface. Although, the serial communication does not go through the SERDESIF block, the BFM\_PCle simulation scenario allows validating the fabric interface connections. The SERDESIF\_0\_user.bfm file under the <Libero project>/simulation folder has the BFM commands to trigger the DMA transactions. To run the simulation: - Double-click Simulate under Verify Pre-Synthesized Design in the Design Flow window of Libero project. - ModelSim runs the design for about 515 μs. The ModelSim Transcript window displays the BFM commands and the BFM simulation is completed without errors as shown in Figure 3. Figure 3 • Modelsim Transcript Messages ``` Debug: At Time 510355845 ps testbench.u_dram_16_IO.Control_Logic:WRITE: BAnk = 0, Col = 0038 At Time 510357408 ps testbench.u_dram_16_10.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Col = 036, Data = 6a69 # At Time 510358970 ps testbench.u_dram_16_IO.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Col = 037, Data = 6c6b # At Time 510360533 ps testbench.u_dram_16_I0.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Col = 038, Data = 6e6d # At Time 510362095 ps testbench.u_dram_16_I0.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Col = 039, Data = 706f # At Time 510363658 ps testbench.u_dram_16_I0.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Col = 03a, Data = 7271 At Time 510365220 ps testbench.u_dram 16_IO.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Col = 03b, Data = # At Time 510366783 ps testbench.u_dram_16_I0.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Col = 03c, Data = 7675 # At Time 510368345 ps testbench.u_dram_16_IO.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Col = 03d, Data = 7877 # At Time 510369908 ps testbench.u_dram_16_10.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Co1 = 03e, Data = 7a79 # At Time 510371470 ps testbench.u_dram_16_10.Write_FIFO_DM_Mask_Logic:WRITE: BAnk = 0, Row = 0000, Co1 = 03f, Data = 7c7b # Debug: At Time 511346470 ps testbench.u_dram_16_IO.Control_Logic:PRE: ADDR[10] = 0, BAnk = 00 testbench.u_dram_16_IO.Power_down_chk: at Time 511371470 ps Entering Power-Down Mode BFM:85:poll w 20008018 00000001 at 512228 ns BFM: Data Read 20008018 00000001 MASK:ffffffff at 512240.010000ns BFM:87:read w 20008014 at 512246 ns BFM:91:return # SFM: Data Read 20008014 000000c3 at 512258.760000ns SFM: Data Read 20008018 00000001 at 512265.010000ns SERDESIF_0 BFM Simulation Complete - 39 Instructions - NO ERRORS ...... ``` Figure 4 shows the **Waveform** window for the DMA transactions between PCIe and LPDDR. It shows the commands from the SERDES AHB master, command decoder signals, and data transfer on SERDES AHB slave and MDDR interfaces. Figure 4 • DMA Transactions between PCIe and LPDDR Figure 5 shows the **Waveform** window for the DMA transactions between LPDDR and LSRAM. It shows the commands from SERDES AHB master, command decoder signals, and data transfer on CoreLSRAM AHB and MDDR interfaces. Figure 5 • DMA Transactions between LPDDR and LSRAM ### 2.5 Setting Up the Demo Design The following steps describe how to setup the demo: - Connect the FlashPro4 Programmer to the J5 connector of the IGLOO2 FPGA Evaluation Kit board. - Connect the jumpers on the IGLOO2 FPGA Evaluation Kit board as shown in Table 2. CAUTION: Ensure that the power supply switch, SW7, is switched OFF while connecting the jumpers on the IGLOO2 FPGA Evaluation Kit. Table 2 • IGLOO2 FPGA Evaluation Kit Jumper Settings | Jumper | Pin (From) | Pin (To) | Comments | |--------|------------|----------|----------| | J22 | 1 | 2 | Default | | J23 | 1 | 2 | Default | | J24 | 1 | 2 | Default | | J8 | 1 | 2 | Default | | J3 | 1 | 2 | Default | 3. Connect the power supply to the J6 connector. #### 2.5.1 Programming the IGLOO2 Board The following steps describe how to program the demo design: - Download the demo design from: http://soc.microsemi.com/download/rsc/?f=m2gl\_dg0585\_hpms\_hpdma\_liberov11p7\_df - 2. Switch **ON** the power supply switch, **SW7**. - 3. Launch the FlashPro software. - 4. Click New Project. - 5. Enter the project name as PCle\_Data\_Plane in the New Project window. - 6. Click Browse and navigate to the location to save the project. - 7. Select a **Single Device** as the Programming mode. - 8. Click **OK** to save the project. Figure 6 • FlashPro New Project 9. Click Configure Device. Figure 7 • FlashPro Project Configuration - 11. Click Advanced as Mode and select PROGRAM as Action. - Click PROGRAM to start programming the device. Wait until the programmer status is changed to RUN PASSED. Figure 8 • FlashPro Programming Passed #### 2.5.2 Connecting IGLOO2 Evaluation Kit Board to Host PC The following steps describe how to connect the IGLOO2 Evaluation Kit board to the host PC: - After successful programming, power OFF the IGLOO2 Evaluation Kit board and shut down the host PC. - 2. Connect the CON1-PCle Edge Connector either to a host PC or laptop: - Connect the CON1-PCle Edge Connector to the host PC PCle Gen2 slot or Gen1 slot as applicable. This tutorial is designed to run on any PCle Gen2 compliant slot. If the host PC does not support the Gen2 compliant slot, the design switches to the Gen1 mode. - Connect the CON1-PCle Edge Connector to the laptop PCle slot using the express card adapter. If a laptop is used, the express card adapters support only Gen1 and the design works on Gen1 mode. **Note:** Host PC or laptop is powered OFF while inserting the PCle Edge Connector. If the system is not powered OFF, the PCle device detection and selection of Gen1 or Gen2 do not occur properly. Power OFF the host PC or laptop during PCle card insertion. Figure 9 shows the board setup for the host PC in which the IGLOO2 Evaluation Kit board is connected to the host PC PCIe slot. To connect the IGLOO2 Evaluation Kit board to the laptop using Express card adapter, see the "Appendix: IGLOO2 Evaluation Kit Board Setup for Laptop" on page 34". Figure 9 • IGLOO2 Evaluation Kit Setup 3. Switch **ON** the power supply switch, **SW7**. 4. Power On the host PC and check the **Device Manager** of the host PC for **PCIe Device**. Figure 10 shows the example **Device Manager** window. If the device is not detected, power cycle the IGLOO2 Evaluation Kit and click **scan for hardware changes** option in the **Device Manager** window. Figure 10 • Device Manager - PCle Device Detection **Note:** If the device is still not detected, check if the BIOS version in the host PC is the latest version, and PCI is enabled in the host PC BIOS. #### 2.5.3 Drivers Installation The PCIe demo uses a driver framework provided by Jungo WinDriverPro. The following steps describe how to install the PCIe drivers on the host PC: - Extract the PCIe\_Demo.rar from m2gl\_dg0585\_hpms\_hpdma\_liberov11p7\_df\Drivers\_64bitOS\PCle\_Demo.rar to C:\ drive. - 2. Run the batch file Jungo KP install.bat located at C:\ PCle\_Demo\DriverInstall\ Note: Installing these drivers require administration rights. 3. To run the batch file C:\PCIe\_Demo\DriverInstall\Jungo\_KP\_install.bat, open command prompt and select Run as administrator, as shown in Figure 11. Figure 11 • Command Prompt - Navigate to C:\ Drive and execute Jungo\_KP\_install.bat in command prompt and press Enter. A Windows Security dialog box is displayed, as shown in Figure 12. - 5. Click Install. Figure 12 • Jungo Driver Installation 6. If the Windows Security dialog box appears asking whether to install or not, click **Install this driver software anyway**, as shown in Figure 13. Figure 13 • Windows Security #### 2.5.4 Installing PCIe\_Demo Application GUI The PCIe\_Demo application is a simple graphic user interface that runs on the host PC to communicate with the IGLOO2 PCIe end point device. It provides PCIe link status, driver information, and demo controls. The PCIe\_Demo application invokes the PCIe driver installed on the host PC and provides commands to the driver according to the selection made. The following steps describe how to install the PCIe\_Demo application GUI: - Download the PCIe demo application at: http://soc.microsemi.com/download/rsc/?f=PCIe\_Demo\_GUI\_Installer - 2. Double-click setup.exe. Do not change the default options and click Next. Figure 14 • GUI Installation 3. Click **Next** to complete the installation. The **Installation Complete** window is displayed, as shown in Figure 15. Figure 15 • Successful Installation of GUI - 4. Shut down the host PC - 5. Power cycle the IGLOO2 Evaluation Kit board. - 6. Restart the host PC. #### 2.5.5 Running the Design - 1. Check the host PC **Device Manager** for the drivers. If the device is not detected, power cycle the IGLOO2 Evaluation Kit board and click **scan for hardware changes** in Device Manager. - 2. Ensure that the board is switched ON. Figure 16 • Device Manager - PCle Device Detection **Note:** If a warning symbol appears on the **DEVICE** or **WinDriver** icons in **Device Manager**, uninstall them and start from step 1 of Driver Installation. 3. Invoke the GUI from **All Programs > PCleDemo > PCle Demo GUI**. The GUI is displayed as shown in Figure 17. Figure 17 • PCle Demo GUI Click the Connect at the top right corner of the PCle\_Demo application. The application detects and displays the connected Kit, demo design, and PCle link. Figure 18 shows the example messages after the connection is established. Figure 18 • PCle Device Information 5. Click **Demo Controls** to display the LEDs options and DIP switch positions, as shown in Figure 19. Figure 19 • Demo Controls - 6. Click LED buttons to switch ON or OFF the LEDs on the board. - 7. Click Start LED ON/OFF Walk to blink the LEDs on the board. - 8. Click **Stop LED ON/OFF Walk** to stop the LEDs blinking. - 9. Change the DIP switch positions on the board and observe the same being reflected in the **Switch Module** of the PCIe\_Demo application. - 10. Click Enable Interrupt Session to enable the PCle interrupt. - 11. Press the **Push** button, SW4 on the IGLOO2 Evaluation Kit board. Observe the interrupt count on the **Interrupt Counter** field in PCIe\_Demo application, as shown in Figure 20 on page 23. Figure 20 • PCle Interrupt - 12. Click Clear/Disable Interrupts to clear and disable the PCIe interrupts. - 13. Click **Config Space** to view the details about the PCle configuration space. Figure 21 shows the PCle configuration space. Figure 21 • PCle Configuration Space 14. Click **PCIe R/W** to execute reads and writes to a 32-bit scratch-pad register using BAR1 space. Figure 22 shows the **PCIe R/W** panel. Figure 22 • DMA Operations - 15. Click **DMA Operations** to perform DMA operations. Four types of DMA transactions are possible: - PC Memory to DDR - DDR to PC Memory - DDR to Fabric LSRAM - Fabric LSRAM to DDR - 16. The transfer size can be selected from 64 KB to 1 MB for: - PC memory to DDR - DDR to PC memory The transfer size is provided in steps of HPDMA buffer descriptor size (64 KB). For more information on buffer description, see the "HPDMA" chapter in the *UG0448: IGLOO2 FPGA High Performance Memory Subsystem User Guide*. - 17. The transfer size can be selected from 16 KB to 32 KB for: - Fabric LSRAM to DDR - DDR to Fabric LSRAM Figure 23 • Transfer Size Selection 18. The Burst Size (TLP size) is fixed to 4 bytes as the HPDMA does not support burst, and the actual size of the PCIe packet is the width of a single AHB transfer, which is 4 bytes (32-bit AHB) as shown in Figure 24. Figure 24 • Burst Size Selection 19. Select the type of DMA transfer as PC Memory to DDR. Select any Transfer Size, and click Start Transfer after completion of the data transfer, the GUI displays the throughput in MBps as shown in Figure 25. Figure 25 • DMA Transaction - PC Memory to DDR Enter the Loop Count as 10 in the Loop Count box and click Loop Transfer to perform 10 sequential DMA transactions. The DMA throughput is displayed in MBps after the completion of data transfer. Figure 26 shows the throughput of DMA transactions from the host PC to DDR. The average throughput is logged and the log file is stored at C:\PCIe\_Demo\DriverInstall in the host PC. Figure 26 • PC Memory to DDR DMA Loop Transfer 21. Select the type of DMA transfer as **DDR to PC Memory**. Select any **Transfer Size** and click **Loop Transfer** as shown in Figure 27. Figure 27 • DDR to PC Memory DMA Loop Transfer 22. Select the type of DMA transfer as **DDR to Fabric SRAM**. Select any **Transfer Size** and click **Loop Transfer** as shown in Figure 28. Figure 28 • LSRAM To DDR DMA Loop Transfer 23. Select the type of DMA transfer as **Fabric SRAM to DDR**. Select any **Transfer Size** and click **Loop Transfer** as shown in Figure 29. Figure 29 • DDR to LSRAM DMA Loop Transfer - 24. The LEDs on the board can blink in parallel to the DMA operations by using the LED controls on the right side of the GUI. Select the **Enable the LED Blinking During Loop Transfer** check box to perform the LED blinking from host PC to DMA transfers. - 25. Click Exit to quit the demo. #### 2.6 Conclusion This demo shows how to implement a PCle data plane design using HPMS HPDMA. The data transfer occurs between the host PC IGLOO2 LSRAM, and IGLOO2 DDR memories. The throughput for data transfers depends on the host PC system configuration and the types of PCle slots used. Table 3 lists the throughput values observed in the HP Workstation Z220 - CMT. Table 3 • HP Workstation Z220 - CMT - Throughput Values | | | Throughput (Mega Bytes Per Second) | | | | |-----------------------|------------------------------------------------------------------------------|------------------------------------|------------------|--------------------|---------------| | DMA Transfer Type | DMA Transfer Size | Gen 1 | | Gen 2 | | | | | Single<br>Transfer | Loop<br>Transfer | Single<br>Transfer | Loop Transfer | | Host PC Memory to DDR | <ul><li>1 BD (64 KB)</li><li>4 BD (256 KB)</li><li>4 × 4 BD (1 MB)</li></ul> | 2.1 | 2.2 | 2.604 | 2.826 | | DDR to Host PC Memory | <ul><li>1 BD (64 KB)</li><li>4 BD (256 KB)</li><li>4 × 4 BD (1 MB)</li></ul> | 23.8 | 23.8 | 33 | 33 | | DDR to Fabric SRAM | • 16 KB<br>• 32 KB | 78 | 77.5 | 78 | 77.5 | | Fabric SRAM to DDR | • 16 KB<br>• 32 KB | 79 | 79 | 79 | 79 | ### 3 Appendix: IGLOO2 Evaluation Kit Board Setup for Laptop Figure 30 shows how to line up the IGLOO2 Evaluation Kit PCIe connector with the adapter card slot. Figure 30 • Lining Up the IGLOO2 Evaluation Kit Board Note: The notch (highlighted in red) does not go into the adapter card. Figure 31 shows the IGLOO2 Evaluation Kit PCIe connector inserted into the PCIe adapter card slot. Figure 31 • Inserting the IGLOO2 Evaluation Kit PCIe Connector into the PCIe Adapter Card Slot Figure 32 shows the PCIe adapter card and the IGLOO2 Evaluation Kit connected to the laptop. Figure 32 • PCIe Adapter Card and IGLOO2 Evaluation Kit Connected to Laptop ### 4 Appendix: Register Details Table 4 shows the registers used to interface with the HPDMA Controller. Table 4 • Register Details | Register Name | BAR Space | Register Address | Description | | | |--------------------------------------------------|-----------|------------------|-----------------------------------------------------------------|-------------------------------------------|--| | PC_BASE_ADDR | BAR 1 | 0x8028 | Host PC memory base address provided by the driver | | | | DMA_SIZE | BAR 1 | 0x8008 | Size of DMA transfer | | | | | BAR 1 | 0x800C | DMA direction | | | | | | | Direction | Register value | | | DMA DID | | | PCIe to DDR | 0x11AA1111 | | | DMA_DIR | | | DDR to PCIe | 0x11AA2222 | | | | | | LSRAM to DDR | 0x11AA3333 | | | | | | DDR to LSRAM | 0x11AA4444 | | | DMA_CLK_CYCLES | BAR 1 | 0x8014 | Number of clock cycles t transfer. | of clock cycles taken to complete the DMA | | | DMA_STATUS | BAR 1 | 0x8018 | 1 - DMA transfer completed<br>0 - DMA transfer is not completed | | | | RW_REG | BAR 1 | 0x0 | Scratch-pad register for PCIe R/W | | | | LED_CTRL[7:0] | BAR 0 | 0xA0 | LEDs control register | | | | SWITCH_STATUS[11:8] BAR 0 0x90 DIP switch status | | | | | | ### **5** Revision History The following table shows important changes made in this document for each revision. | Revision | Changes | Page | |-------------------------------|---------------------------------------------------------------------|------| | Revision 3<br>(March 2016) | Updated the document for Libero v11.7 software release (SAR 76924). | NA | | Revision 2<br>(October 2015) | Updated the document for Libero v11.6 software release (SAR 71500). | NA | | Revision 1<br>(February 2015) | Initial release | NA | #### 6 Product Support Microsemi SoC Products Group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, electronic mail, and worldwide sales offices. This appendix contains information about contacting Microsemi SoC Products Group and using these support services. #### 6.1 Customer Service Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization. From North America, call 800.262.1060 From the rest of the world, call 650.318.4460 Fax, from anywhere in the world, 408.643.6913 #### 6.2 Customer Technical Support Center Microsemi SoC Products Group staffs its Customer Technical Support Center with highly skilled engineers who can help answer your hardware, software, and design questions about Microsemi SoC Products. The Customer Technical Support Center spends a great deal of time creating application notes, answers to common design cycle questions, documentation of known issues, and various FAQs. So, before you contact us, please visit our online resources. It is very likely we have already answered your questions. #### 6.3 Technical Support For Microsemi SoC Products Support, visit http://www.microsemi.com/products/fpga-soc/design-support/fpga-soc-support. #### 6.4 Website You can browse a variety of technical and non-technical information on the Microsemi SoC Products Group home page, at http://www.microsemi.com/products/fpga-soc/fpga-and-soc. ## 6.5 Contacting the Customer Technical Support Center Highly skilled engineers staff the Technical Support Center. The Technical Support Center can be contacted by email or through the Microsemi SoC Products Group website. #### 6.5.1 Email You can communicate your technical questions to our email address and receive answers back by email, fax, or phone. Also, if you have design problems, you can email your design files to receive assistance. We constantly monitor the email account throughout the day. When sending your request to us, please be sure to include your full name, company name, and your contact information for efficient processing of your request. The technical support email address is soc\_tech@microsemi.com. #### 6.5.2 My Cases Microsemi SoC Products Group customers may submit and track technical cases online by going to My Cases. #### 6.5.3 Outside the U.S. Customers needing assistance outside the US time zones can either contact technical support via email (soc\_tech@microsemi.com) or contact a local sales office. Visit About Us for sales office listings and corporate contacts. #### 6.6 ITAR Technical Support For technical support on RH and RT FPGAs that are regulated by International Traffic in Arms Regulations (ITAR), contact us via soc\_tech@microsemi.com. Alternatively, within My Cases, select **Yes** in the ITAR drop-down list. For a complete list of ITAR-regulated Microsemi FPGAs, visit the ITAR web page. ### Microsemi Corporate 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 E-mail: sales.support@microsemi.com © 2016 Microsemi Corporation. All rights reserved. Microsemi and the Microsemi logo are trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners. Microsemi Corporation (Nasdaq: MSCC) offers a comprehensive portfolio of semiconductor and system solutions for communications, defense & security, aerospace 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. Microsemi is headquartered in Aliso Viejo, Calif, and has approximately 4,800 employees globally. Learn more at www.microsemi.com. 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.