

# Golden System Reference Design and Demo User Guide for Lattice Avant-E Devices Lattice Propel 2024.1 Lattice Radiant 2024.1.1

**Reference Design** 

FPGA-RD-02296-1.0



#### **Disclaimers**

Lattice makes no warranty, representation, or guarantee regarding the accuracy of information contained in this document or the suitability of its products for any particular purpose. All information herein is provided AS IS, with all faults, and all associated risk is the responsibility entirely of the Buyer. The information provided herein is for informational purposes only and may contain technical inaccuracies or omissions, and may be otherwise rendered inaccurate for many reasons, and Lattice assumes no obligation to update or otherwise correct or revise this information. Products sold by Lattice have been subject to limited testing and it is the Buyer's responsibility to independently determine the suitability of any products and to test and verify the same. LATTICE PRODUCTS AND SERVICES ARE NOT DESIGNED, MANUFACTURED, OR TESTED FOR USE IN LIFE OR SAFETY CRITICAL SYSTEMS, HAZARDOUS ENVIRONMENTS, OR ANY OTHER ENVIRONMENTS REQUIRING FAIL-SAFE PERFORMANCE, INCLUDING ANY APPLICATION IN WHICH THE FAILURE OF THE PRODUCT OR SERVICE COULD LEAD TO DEATH, PERSONAL INJURY, SEVERE PROPERTY DAMAGE OR ENVIRONMENTAL HARM (COLLECTIVELY, "HIGH-RISK USES"). FURTHER, BUYER MUST TAKE PRUDENT STEPS TO PROTECT AGAINST PRODUCT AND SERVICE FAILURES, INCLUDING PROVIDING APPROPRIATE REDUNDANCIES, FAIL-SAFE FEATURES, AND/OR SHUT-DOWN MECHANISMS. LATTICE EXPRESSLY DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY OF FITNESS OF THE PRODUCTS OR SERVICES FOR HIGH-RISK USES. The information provided in this document is proprietary to Lattice Semiconductor, and Lattice reserves the right to make any changes to the information in this document or to any products at any time without notice.

#### **Inclusive Language**

This document was created consistent with Lattice Semiconductor's inclusive language policy. In some cases, the language in underlying tools and other items may not yet have been updated. Please refer to Lattice's inclusive language FAQ 6878 for a cross reference of terms. Note in some cases such as register names and state names it has been necessary to continue to utilize older terminology for compatibility.



## **Contents**

| Contents                                                                                    |    |
|---------------------------------------------------------------------------------------------|----|
| Abbreviations in This Document                                                              | 9  |
| 1. Introduction                                                                             | 10 |
| 1.1. Overview of the System                                                                 | 10 |
| 1.2. Quick Facts                                                                            | 10 |
| 1.3. Features                                                                               | 10 |
| 1.4. Licensing and Ordering Information                                                     | 11 |
| 1.4.1. License Requirements                                                                 | 11 |
| 1.4.2. Ordering Part Number                                                                 | 11 |
| 1.5. Naming Conventions                                                                     | 12 |
| 1.5.1. Nomenclature                                                                         | 11 |
| 1.5.2. Signal Names                                                                         | 11 |
| 2. Functional Description                                                                   | 12 |
| 2.1. System Architecture Overview                                                           | 12 |
| 2.1.1. Avant-AT-E                                                                           | 12 |
| 2.2. Clocking                                                                               | 13 |
| 2.2.1. Clocking Overview for Avant-AT-E                                                     |    |
| 2.3. Reset Scheme                                                                           |    |
| 2.4. IP Configurations                                                                      | 14 |
| 2.4.1. RISC-V RX CPU Core                                                                   | 14 |
| 2.4.2. LPDDR4 Memory Controller                                                             | 17 |
| 2.4.3. QSPI Flash Controller                                                                | 18 |
| 2.4.4. Tri-Speed Ethernet MAC                                                               | 18 |
| 2.4.5. Scatter-Gather DMA                                                                   | 19 |
| 2.4.6. UART                                                                                 | 20 |
| 2.4.7. GPIO                                                                                 | 20 |
| 2.4.8. Multi-Boot Configuration Module                                                      | 21 |
| 2.4.9. System Memory                                                                        | 21 |
| 2.5. System Level Interfaces                                                                | 27 |
| 2.6. SoC Memory/Address Map                                                                 | 27 |
| 2.7. Functional Operation                                                                   | 23 |
| 3. Signal Description                                                                       | 24 |
| 4. Software Components                                                                      |    |
| 4.1. Primary and Golden Bootloader                                                          | 25 |
| 4.2. Primary and Golden Application                                                         | 25 |
| 5. Design Constraints                                                                       |    |
| 5.1. I/O Constraints                                                                        | 26 |
| 6. Resource Utilization                                                                     | 31 |
| 7. Demo User Guide                                                                          | 32 |
| 7.1. Boot-Up Sequence                                                                       | 32 |
| 7.2. Prerequisites                                                                          | 34 |
| 7.2.1. Software Requirements                                                                | 34 |
| 7.2.2. Avant-AT-E Requirements                                                              | 34 |
| 7.3. Implementing the GHRD/GSRD Demo                                                        | 36 |
| 7.3.1. Setting up the UART Terminal                                                         |    |
| 7.3.2. Setting up the Non-Volatile Memory Register                                          |    |
| 7.3.3. Programming the Standalone Golden or Primary GSRD Bitstream and Application Software |    |
| 7.3.4. Programming the Golden, Primary Software and MCS file                                |    |
| 8. Compiling the Reference Design                                                           |    |
| 8.1. Building the Bootloader and FreeRTOS Binary Files Using Lattice Propel SDK             |    |
| 8.2. Validating and Generating the GSRD Design using Propel Builder                         |    |
| 8.3. Synthesizing the RTL Files and Generating the Bitstream using Lattice Radiant          |    |
| ·                                                                                           |    |



| 8.4.   | Generating the Multi-Boot MCS File                       | 85 |
|--------|----------------------------------------------------------|----|
|        | ustomizing the IP in the GSRD Design                     |    |
|        | Changing QSPI Flash Controller User Interface Parameters |    |
|        | ences                                                    |    |
| Techni | ical Support Assistance                                  | 95 |
|        | on History                                               |    |



## **Figures**

| Figure 2.1. GHRD Architecture on Avant-AT-E                                                  |    |
|----------------------------------------------------------------------------------------------|----|
| Figure 2.2. Clocking Structure for Avant-AT-E GSRD                                           | 13 |
| Figure 2.3. Reset Structure for Avant-AT-E GSRD                                              | 14 |
| Figure 2.4. CPU Configuration - General                                                      | 15 |
| Figure 2.5. CPU Configuration - Debug                                                        | 15 |
| Figure 2.6. CPU Configuration - Buses                                                        | 16 |
| Figure 2.7. CPU Configuration - Interrupt                                                    | 16 |
| Figure 2.8. CPU Configuration - UART                                                         | 17 |
| Figure 2.9. LPDDR4 MC Configuration                                                          | 17 |
| Figure 2.10. QSPI Flash Controller Configuration                                             | 18 |
| Figure 2.11. TSE MAC Configuration                                                           | 19 |
| Figure 2.12. SGDMA Configuration                                                             | 19 |
| Figure 2.13. UART Configuration                                                              | 20 |
| Figure 2.14. GPIO Configuration                                                              | 20 |
| Figure 2.15. Multi-Boot Configuration                                                        |    |
| Figure 2.16. System Memory Configuration                                                     | 21 |
| Figure 6.1. GSRD Resource Utilization on Avant-AT-E70                                        | 31 |
| Figure 7.1. GSRD Boot-Up Sequence                                                            | 33 |
| Figure 7.2 .Avant-AT-E70 Evaluation Board                                                    | 34 |
| Figure 7.3.Ethernet PHY FMC Card                                                             | 35 |
| Figure 7.4. Connections and Buttons needed for Demonstration                                 | 35 |
| Figure 7.5. UART Terminal Icon on Propel SDK Window                                          | 36 |
| Figure 7.6. UART Launch Terminal Window                                                      | 37 |
| Figure 7.7. Device Manager Window on PC                                                      | 37 |
| Figure 7.8. Launch Radiant Programmer from Windows Start                                     | 38 |
| Figure 7.9. Radiant Programmer Start Window                                                  | 38 |
| Figure 7.10. Radiant Programmer .xcf Window                                                  | 38 |
| Figure 7.11. Scan Device Icon on Radiant Programmer                                          | 39 |
| Figure 7.12. Select Device for Programming                                                   | 39 |
| Figure 7.13. Device Selected for Programmer                                                  |    |
| Figure 7.14. Select the Target Memory for Programming                                        | 39 |
| Figure 7.15. Device Properties to Erase the SPI Flash                                        | 40 |
| Figure 7.16. Program Button to Program the SPI Flash                                         | 40 |
| Figure 7.17. Erase Only Operation for CRAM Programming                                       | 41 |
| Figure 7.18. One-Time Programmable Control NV Register1                                      |    |
| Figure 7.19. Settings to Select Chip Value                                                   | 42 |
| Figure 7.20. Device Properties to Program the SPI Flash                                      | 42 |
| Figure 7.21. Cable Settings for device programming                                           |    |
| Figure 7.22. Radiant Programmer Console Output after Programming the SPI Flash               |    |
| Figure 7.23. Device Properties to Program the FPGA Bitstream in CRAM                         |    |
| Figure 7.24. Radiant Programmer Console Output after Bitstream is Programmed                 |    |
| Figure 7.25. SW1 Reset Button                                                                |    |
| Figure 7.26. Golden GSRD - Output on UART Terminal for Bootloader and FreeRTOS Start         |    |
| Figure 7.27. Golden GSRD - Output on UART Terminal for FreeRTOS Running                      |    |
| Figure 7.28. Primary GSRD Bootloader – Output on UART Terminal                               |    |
| Figure 7.29. Primary GSRD FreeRTOS – Output on UART Terminal                                 |    |
| Figure 7.30.Device Properties window to setup MCS programming file                           |    |
| Figure 7.31. UART Terminal Output after Power-Cycling Board with MCS and Binaries Programmed |    |
| Figure 7.32. Switches to Golden GSRD upon SW2 PROGRAMN Button                                |    |
| Figure 7.33. Device Properties settings to program the Golden Application                    |    |
| Figure 7.34. Radiant Programmer Console Output After Programming                             |    |
| Figure 7.35. Primary GSRD – UART Output after SW1 Reset where CRC Matched                    | 54 |



| Figure 7.36. UART Output Switching to Golden GSRD where CRC Mis-matched Intentionally | 55 |
|---------------------------------------------------------------------------------------|----|
| Figure 7.37. Device Properties for Programming Golden App Binary with CRC             | 56 |
| Figure 7.38. Radiant Programmer Console Output After Successful Programming           | 56 |
| Figure 7.39. Device Properties Window for Primary App Binary without CRC              | 57 |
| Figure 7.40. Radiant Programmer Console Output After Successful Programming           |    |
| Figure 7.41. Primary GSRD without CRC Fails – UART Terminal                           |    |
| Figure 7.42. Automatically Jumps to Boot-up Golden GSRD                               | 59 |
| Figure 7.43. UART Terminal Output - After Pressing SW2 PROGRAMN Button                | 60 |
| Figure 8.1. Propel Builder Launcher                                                   | 61 |
| Figure 8.2. Provide Name for Workspace Directory                                      | 61 |
| Figure 8.3. Creating Lattice SoC Design Project                                       | 62 |
| Figure 8.4. SoC Project Window                                                        | 62 |
| Figure 8.5. Launched SoC in Propel Builder                                            | 63 |
| Figure 8.6. Validate Design in Propel Builder                                         | 63 |
| Figure 8.7. TCL Console Output after Validating Design                                |    |
| Figure 8.8. Generate in Propel Builder                                                |    |
| Figure 8.9. TCL Console Output after Generating Design                                |    |
| Figure 8.10. sys_env.xml File Created                                                 |    |
| Figure 8.11. Creating Lattice C/C++ Project for Bootloader                            |    |
| Figure 8.12. Bootloader C/C++ Selection                                               |    |
| Figure 8.13. C/C++ Lattice Toolchain Setting                                          |    |
| Figure 8.14. Bootloader C Project Created                                             |    |
| Figure 8.15. Creating C/C++ Project for FreeRTOS                                      |    |
| Figure 8.16. FreeRTOS C/C++ Selection                                                 |    |
| Figure 8.17. FreeRTOS Project Created                                                 |    |
| Figure 8.18. Copy the CRC and NoCRC Add files                                         |    |
| Figure 8.19. Paste in FreeRTOS C project                                              |    |
| Figure 8.20. Copied Text Files                                                        |    |
| Figure 8.21. Updated Primary Address                                                  |    |
| Figure 8.22. Enable fw_softreset() Function                                           |    |
| Figure 8.23. Update crc_add_debug.txt                                                 |    |
| Figure 8.24. Update noncrc_add.txt                                                    |    |
| Figure 8.25. Open Linker.Ld File                                                      |    |
| Figure 8.26. Update Linker.ld File                                                    |    |
| Figure 8.27. Workspace                                                                |    |
| Figure 8.28. Build Bootloader Project                                                 |    |
| Figure 8.29. Bootloader Build Project Console Output                                  |    |
| Figure 8.30. Bootloader Binary Created                                                |    |
| Figure 8.31. Properties                                                               |    |
| Figure 8.32. Select Release as Configuration                                          |    |
| · ·                                                                                   |    |
| Figure 8.33. Set Release as Active Configuration                                      |    |
| Figure 8.34. Adding Post Build Step for FreeRTOS Application CRC Binary Append        |    |
| Figure 8.35. Build c_primary_app C/C++ Project                                        |    |
| Figure 8.36. FreeRTOS App Build Project Console Output                                |    |
| Figure 8.37. FreeRTOS App Binaries Created with CRC and without CRC                   |    |
| Figure 8.38. Open Propel Builder                                                      |    |
| Figure 8.39. Propel Builder SoC Project                                               |    |
| Figure 8.40. System Memory Highlighted                                                |    |
| Figure 8.41. System Memory IP Configuration                                           |    |
| Figure 8.42. Initialize System Memory with c_primary_bootloader.mem                   |    |
| Figure 8.43. Click Generate                                                           |    |
| Figure 8.44.Bootloader file updated in System Memory                                  |    |
| Figure 8.45. Click Finish                                                             |    |
| Figure 8.46. Run Radiant Icon                                                         | 80 |
|                                                                                       |    |



| Figure 8.47. Lattice Radiant 2024.1.1 Window                     | 81 |
|------------------------------------------------------------------|----|
| Figure 8.48. Constraint Files Folder                             | 81 |
| Figure 8.49. Add Existing Pre-Synthesis Constraint               | 81 |
| Figure 8.50. Select clock_constraint.sdc File                    | 82 |
| Figure 8.51. Select soc_board_constraint.pdc File                | 82 |
| Figure 8.52. Pre and Post-Synthesis Constraint Files Added       | 83 |
| Figure 8.53. Update the Strategy                                 | 83 |
| Figure 8.54. Strategy used for Avant GSRD Testing                | 84 |
| Figure 8.55. Generating the Bit File                             | 84 |
| Figure 8.56. Successful Radiant Flow and Bitstream Generation    | 84 |
| Figure 8.57. Launch Radiant Programmer from Windows Start        | 85 |
| Figure 8.58. Radiant Programmer Getting Started Window           | 85 |
| Figure 8.59. Error if No HW Board is Connected                   | 85 |
| Figure 8.60. Open Deployment Tool from Radiant Programmer        | 86 |
| Figure 8.61. Deployment Tool Start Window                        | 86 |
| Figure 8.62. Options for Creating New Deployment                 | 86 |
| Figure 8.63. External Memory Step 1 of 4: Select Input Files     | 87 |
| Figure 8.64. External Memory Step 2 of 4: Select Options         | 87 |
| Figure 8.65. External Memory Step 2 of 4: Multi-Boot             | 88 |
| Figure 8.66. External Memory Step 3 of 4: Select Output File(s)  | 88 |
| Figure 8.67. External Memory Step 4 of 4: General Development    | 89 |
| Figure 8.68. MCS File Generated Successfully                     | 89 |
| Figure 9.1. IP Block                                             | 90 |
| Figure 9.2. Customize IP                                         | 90 |
| Figure 9.3. TCL Console Output After Desired Customization       | 91 |
| Figure 9.4. Validate Design again is any IP is updated           |    |
| Figure 9.5. Generate again is any IP is updated                  | 91 |
| Figure 9.6. New sys_env.xml File Generated                       | 91 |
| Figure 9.7. Update Lattice C/C++ Project                         | 91 |
| Figure 9.8. Update System Dialog Window                          | 92 |
| Figure 9.9. New IP version Details                               | 92 |
| Figure 9.10. Generate BSP and Toolchain Parameters               | 93 |
| Figure 9.11. Confirm the Changes                                 | 93 |
| Figure 9.12. Confirm the Configuration Changes in sys_platform.h | 93 |



## **Tables**

| Table 1.2. IP Licenses       11         Table 2.1. IP Versions       12         Table 2.2. Reset Scheme       14 | ummary of the System |
|------------------------------------------------------------------------------------------------------------------|----------------------|
|                                                                                                                  | Licenses             |
| Table 2.2. Reset Scheme14                                                                                        | Versions             |
|                                                                                                                  | eset Scheme          |
| Table 2.3. System Level Interfaces22                                                                             |                      |
| Table 2.4. Address Map of GHRD22                                                                                 |                      |
| Table 3.1. Top-level I/O                                                                                         |                      |
| Table 6.1. GSRD Total Resource Utilization31                                                                     |                      |
| Table 7.1. Executable Files for Winbond Flash                                                                    |                      |



## **Abbreviations in This Document**

A list of abbreviations used in this document.

| Abbreviation      | Definition                                   |  |
|-------------------|----------------------------------------------|--|
| AHBL              | Advanced High-performance Bus-Lite           |  |
| AXI               | Advanced eXtensible Interface                |  |
| APB               | Advanced Peripheral Bus                      |  |
| API               | Application Programming Interface            |  |
| AXI4-Lite         | Advanced eXtensible Interface-Lite           |  |
| GPIO              | General Purpose Input/Output                 |  |
| CPU               | Central Processing Unit                      |  |
| DDR               | Double Data Rate                             |  |
| FIFO              | First-In-First-Out                           |  |
| FMC               | FPGA Mezzanine Card                          |  |
| ISR               | Interrupt Service Routines                   |  |
| LMMI              | Lattice Memory Mapped Interface              |  |
| LPDDR4            | Low Power Double Data Rate Generation 4      |  |
| MPMC              | Multi-Port Memory Controller                 |  |
| QSPI              | Quad Serial Peripheral Interface             |  |
| RISC-V            | Reduced Instruction Set Computer-V           |  |
| RTL               | Register Transfer Level                      |  |
| SFP               | Small Form-Factor Pluggable                  |  |
| SGDMA             | Scatter-Gather Direct Memory Access          |  |
| SGMII PCS and GbE | Serial Gigabit Media Independent Interface   |  |
| SoC               | System on Chip                               |  |
| TSE MAC           | Tri - Speed Ethernet Media Access Controller |  |
| UART              | Universal Asynchronous Receiver-Transmitter  |  |



## 1. Introduction

## 1.1. Overview of the System

The Lattice FPGA-based GSRD SoC design presented herein is aimed at providing a versatile and efficient platform for embedded applications requiring high-performance computing, memory access, data transfer capabilities, and network communication. By integrating various components onto a single FPGA chip, this design offers flexibility, scalability, and cost-effectiveness for a wide range of applications.

The Lattice Golden Hardware Reference Design (GHRD) is a System-on-Chip (SoC) that can be used as a baseline design to create FPGA applications as per the user requirements. It is a RISC-V based design that interacts with various Lattice Soft-IPs and peripherals such as GPIO, UART, I2C, Timer, Tri-Speed Ethernet MAC (TSE MAC), QSPI Flash Controller, Scatter-Gather DMA (SGDMA) and LPDDR4 Memory Controller. All these building blocks are connected via industry standard protocols such as AXI4-Full, AXI-Steam for data transfers and AXI4-Lite, APB for control.

The Lattice Golden Software Reference Design (GSRD) is a comprehensive embedded system which incorporates drivers and relevant firmware needed to operate various design components. Free-RTOS and First Stage Bootloader (FSBL) is built on RISC-V RX CPU Core. The primary function of FSBL is to initialize the hardware blocks in the design using the respective IP drivers and ensure the integrity of the firmware by performing CRC check.

GHRD and GSRD are integrated together to establish a complete system for which relevant binaries and executables are generated by Lattice SW tools such as Propel SDK, Propel Builder and Radiant to program the FPGA Hardware.

As a part of multi-boot demo, the executables folder comprises of compatible binaries and executable images, i.e., FPGA Bitstream (.bit) and Firmware Binary (.bin) for both Primary and Golden GSRD projects. The only difference is that the Primary bitstream contains the code for multi-boot enablement and Golden bitstream does not enable multi-boot.

The GSRD for the Avant-AT-E device is developed and tested with the following Lattice Propel™ and Lattice Radiant™ software versions.

## 1.2. Quick Facts

Table 1.1. Summary of the System

| SaC Barrinamanta    | Supported FPGA Family    | Lattice Avant™-AT-E                                               |  |
|---------------------|--------------------------|-------------------------------------------------------------------|--|
| SoC Requirements    | SoC Version              | 1.0                                                               |  |
| EDGA Davisa(s)      | Targeted Devices         | LAV-AT-E70                                                        |  |
| FPGA Device(s)      | Supported User Interface | AXI4-Full, AXI4-Lite, AXI-Stream, APB                             |  |
| Design Tool Support | Lattice Implementation   | Lattice Propel Software 2024.1  Lattice Radiant Software 2024.1.1 |  |
|                     | Synthesis                | Synopsys® Synplify Pro®                                           |  |

### 1.3. Features

The key features of the system include:

- FPGA device supported in this document is Lattice Avant-AT-E
- RISC-V RX CPU Core, SGDMA, TSE MAC, LPDDR4, and QSPI Flash Controller over AXI4 Interface
- Low-speed peripherals like GPIO and UART
- Bootloader, Primary and Golden FreeRTOS Application
- Application Firmware's CRC check by function implemented in RISC-V RX bootloader code
- FPGA bitstream CRC check done by FPGA Configuration Engine
- Manual and Automatic Multi-Boot capability
- FreeRTOS Application Software is run on LPDDR4 MC
- 256-bit AXI4 LPDDR4 data width to support 32-bit data to DDR at 800 MHz operating frequency



- AXI4/AXI4-Lite Peripherals at 140 MHz and APB Peripherals at 100 MHz
- 1 Gbps Ethernet throughput through RGMII support at 125 MHz

## **Licensing and Ordering Information**

The following IP licenses are required to enable full use of top-level design.

### 1.4.1. License Requirements

### Table 1.2. IP Licenses

|                    | QSPI Flash Controller  | LSC_IP_SC_HT_qspi_fc_avt       |
|--------------------|------------------------|--------------------------------|
|                    | Tri-Speed Ethernet MAC | LSC_IP_SC_HT_tse_mac_avt       |
| Lattice Avant-AT-E | Scatter-Gather DMA     | LSC_IP_SC_HT_sgdma_ave         |
|                    | SGMII GbE and PCS      | LSC_IP_SC_HT_sgmii_ave         |
|                    | LPDDR4 MC              | LSC_IP_SC_HT_mc_lp4_avt        |
| Common             | AXI4 Interconnect      | LSC_IP_SC_HT_axi4_interconnect |
| Common             | AXI to APB Bridge      | LSC_IP_SC_HT_axi2apb           |

### 1.4.2. Ordering Part Number

The GSRD System does not require an ordering part number.

#### **Naming Conventions** 1.5.

### 1.5.1. Nomenclature

The nomenclature used in this document is based on Verilog HDL.

### 1.5.2. Signal Names

Signal names that end with:

- \_n are active low (asserted when value if logic 0)
- \_i are input signals
- \_o are output signals
- \_io are bi-directional input/output signals



## 2. Functional Description

The GSRD/GHRD SoC architecture comprises of a RISC-V CPU core, LPDDR4 Memory Controller, SGDMA controller, QSPI Flash Controller, and a 1 Gbps TSE MAC, interconnected through a combination of high-speed and low-speed bus fabrics such as AXI4 Interconnect and APB Interconnect. This architecture enables seamless communication and data exchange between the components, facilitating efficient operation and system performance.

## 2.1. System Architecture Overview

## 2.1.1. Avant-AT-E



Figure 2.1. GHRD Architecture on Avant-AT-E

The design includes the following components:

Table 2.1. IP Versions

| Soft-IP                  | IP Version |
|--------------------------|------------|
| RISC-V RX Processor      | v2.4.0     |
| LPDDR4 Memory Controller | v2.2.1     |
| System Memory            | v.2.2.0    |
| QSPI Flash Controller    | v1.2.0     |
| General Purpose I/O GPIO | v1.6.2     |
| UART                     | v1.3.0     |
| AXI4 Interconnect        | v2.0.1     |
| APB Interconnect         | v1.2.1     |
| AXI to APB Bridge        | v1.2.0     |
| Tri-Speed Ethernet MAC   | v1.6.0     |
| SGDMA                    | v2.2.0     |
| AXI4 Register Slice      | v1.0.0     |
| Multi-Boot Configuration | V1.0.0     |
| PLL                      | v1.9.0     |
| OSC                      | V2.1.0     |

FPGA-RD-02296-1.0



Each component in the block diagram is instantiated using the IP in Propel Builder. The IP features and parameters are described in the IP Configurations section.

The signals in each interface are described in the Signal Description section.

## 2.2. Clocking

This section describes the reference design clocking scheme. There are some minor differences between the clocking scheme and the Lattice Avant-AT-E device. Refer to the Clocking Overview for Avant-AT-E section.

## 2.2.1. Clocking Overview for Avant-AT-E

There are five clocks in GSRD Avant-AT-E Architecture listed as follows:

- External PLL Reference Clock for LPDDR4 is 100 MHz
- External Reference Clock for TSE MAC is 125 MHz
- On-Chip Oscillator Clock is 10 MHz for TSE MAC MDIO Interface
- External Oscillator Clock is 125 MHz as Input Reference Clock to the PLL
- RISC-V Low Frequency Realtime Clock derived from FPGA PLL is 16.384 MHz
- Internal System Clock derived from FPGA PLL is 125 MHz
- All AXI Peripherals are operating at 140 MHz
- All APB Peripherals are operating at 100 MHz



Figure 2.2. Clocking Structure for Avant-AT-E GSRD



## 2.3. Reset Scheme

There are two resets in the entire design:

- External Asynchronous Reset which is controlled by a push button
- Synchronous Reset for entire system is generated from RISC-V

#### Table 2.2. Reset Scheme

| Reset Signal  | Source                     | Destination                         | Description                                                                                                                        |
|---------------|----------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| rstn_i        | Board Pushbutton           | PLL reset input and<br>Synchronizer | Reset the PLL                                                                                                                      |
| cpu_rstn_i    | PLL Lock and synced rstn_i | RISC-V RX reset input               | Release RISC-V RX from reset pin, synchronizer and PLL lock                                                                        |
| system_rstn_o | RISC-V RX output           | All components in system            | RISC-V RX output reset provides reset to all components in the design. This also triggers the reset during CPU OCD debugging mode. |



Figure 2.3. Reset Structure for Avant-AT-E GSRD

## 2.4. IP Configurations

The reference design is created using Lattice Propel Builder. The top-level HDL file is generated by Propel Builder and is used as the top module for the design. The design parameterization is performed by configuring the IP in Propel Builder. This section describes the following IPs and their configuration.

### 2.4.1. RISC-V RX CPU Core

For more information about the IP core including register map information, refer to RISC-V RX CPU IP Core User Guide (FPGA-IPUG-02241). The RISC-V RX CPU IP has AXI-based instruction and data ports. The instruction ports are connected to the memory that contains the bootloader software or the FreeRTOS application software for CPU execution. The data port is connected to the memory and peripherals for control.





Figure 2.4. CPU Configuration - General



Figure 2.5. CPU Configuration - Debug





Figure 2.6. CPU Configuration - Buses



Figure 2.7. CPU Configuration - Interrupt





Figure 2.8. CPU Configuration - UART

### 2.4.2. LPDDR4 Memory Controller

For more information about the IP core including register map information, refer to Memory Controller IP Core for Avant Devices (FPGA-IPUG-02208).

The LPDDR4 Memory Controller IP enables access to the external LPDDR4 memory modules. The memory can be used to store CPU software code and data.



Figure 2.9. LPDDR4 MC Configuration



#### 2.4.3. QSPI Flash Controller

For more information about the IP core including register map information, refer to QSPI Flash Controller IP User Guide (FPGA-IPUG-02248).

The QSPI Flash Controller is a four tri-state data line serial interface that is commonly used to store, program, erase and read SPI Flash memories. QSPI enhances the throughput of a standard SPI by four times since four bits are transferred every cycle. In GSRD, the QSPI is used to store the application software and bitstreams for both Primary and Golden systems.



Figure 2.10. QSPI Flash Controller Configuration

#### 2.4.4. Tri-Speed Ethernet MAC

For more information about the IP core including register map information, refer to Tri-Speed Ethernet MAC IP User Guide (FPGA-IPUG-02084).

The TSEMAC IP core is a 10/100/1000 Mbps network interface as per the IEEE 802.3 standard. It is complex core containing all the necessary logic, interfacing and clocking infrastructure to allow integrating an external industry-standard Ethernet PHY with an internal processor, with minimal overhead. The GSRD requires the Gigabit MAC to support 1 Gbps data-rates. The MIIM interface is used to control the external PHY control and status registers.





Figure 2.11. TSE MAC Configuration

#### 2.4.5. Scatter-Gather DMA

For more information about the IP core including register map information, refer to SGDMA Controller IP Core (FPGA-IPUG-02131).

The SGDMA Controller IP core is to access the main memory independent of the CPU processor. It offloads processor intervention. The processor initiates transfer to SGDMA Controller and receives interrupts on completion of the transfer by the DMA engine. The core implements a configurable, AXI4-compliant DMA controller with scatter-gather capability. It also implements the AXI4-Stream interface to support stream data from TSE MAC module. The AXI4-Lite CSR interface is used to configure the control and status registers by the RISC-V CPU.



Figure 2.12. SGDMA Configuration



#### 2.4.6. UART

For more information about the IP core including register map information, refer to UART IP User Guide (FPGA-IPUG-02105).

The Universal Asynchronous Receiver/Transmitted (UART) Transceiver IP core performs serial-to-parallel conversion of data characters received from a peripheral UART device and parallel-to-serial conversion of data characters received from the host locater insider the FPGA through an APB interface.



Figure 2.13. UART Configuration

### 2.4.7. GPIO

For more information about the IP core including register map information, refer to GPIO IP Core (FPGA-IPUG-02076). The General Purpose Input/Output (GPIO) peripheral IP provides dedicated memory-mapped interface to configure the GPIO ports as well as the number of input and output ports.



Figure 2.14. GPIO Configuration



## 2.4.8. Multi-Boot Configuration Module

The Multi-Boot Configuration is used to trigger an internal FPGA REFRESH/PROGRAMN command to LMMI logic. This core IP implements an APB endpoint which decodes the RISC-V CPU command data. The LMMI host FSM inside is used to execute the soft reset to load the next or alternate bitstream and application software data onto the FPGA.



Figure 2.15. Multi-Boot Configuration

### 2.4.9. System Memory

For more information about the IP core including register map information, refer to System Memory Module (FPGA-IPUG-02073).

The System Memory implements EBR, LRAM, or Distributed Memory in either single port or dual port AHBL or AXI4 subordinate. In GSRD, an EBR and single AXI4 port is used. The system memory in this design is used to store the bootloader.



Figure 2.16. System Memory Configuration



## 2.5. System Level Interfaces

## **Table 2.3. System Level Interfaces**

| Top-Level Interface Name               | Supported<br>Protocol | Description                                           |
|----------------------------------------|-----------------------|-------------------------------------------------------|
| Advanced eXtensible Interface 4        | AXI4                  | Used for Data/Control Interfaces on all IPs           |
| Advanced eXtensible Interface 4 - Lite | AXI4-Lite             | Used as Control Interface for SGDMA                   |
| Advanced Peripheral Interface          | APB                   | Used as Control Interface for low-speed and LPDDR4 MC |
| Serial Peripheral Interface            | SPI/QSPI              | Used for communication with external SPI Flash        |
| Dual Data Rate                         | LPDDR4                | Used for communication with external LPDDR4           |
| 1G Ethernet                            | RGMII                 | Used for communication with external FMC              |

## 2.6. SoC Memory/Address Map

## Table 2.4. Address Map of GHRD

| Base Address | End Address | Size (kB/MB/1 GB) | Block                    |
|--------------|-------------|-------------------|--------------------------|
| 0x0000000    | 0x0003FFFF  | 256 kB            | CPU Instruction/Data RAM |
| 0xF2000000   | 0xF20FFFFF  | 1 MB              | CLINT (CPU)              |
| 0xFC000000   | 0xFC3FFFFF  | 4 MB              | PLIC (CPU)               |
| 0xF0000000   | 0xF00003FF  | _                 | Reserved_Space1 (CPU)    |
| 0xF0000400   | 0xF1FFFFFF  | _                 | Reserved_Space2 (CPU)    |
| 0xFC400000   | 0xFFFFFFF   | _                 | Reserved_Space3 (CPU)    |
| 0x40000000   | 0x40000FFF  | 4 kB              | GPIO                     |
| 0x40092000   | 0x40092FFF  | 4 kB              | LPDDR4 APB               |
| 0x80000000   | 0xBFFFFFF   | 1 GB              | LPDDR4 AXI               |
| 0x40097000   | 0x40097FFF  | 4 kB              | Multi-Boot Config APB    |
| 0x40300000   | 0x4030FFFF  | 64 kB             | QSPI Flash Controller    |
| 0x40098000   | 0x40099FFF  | 4 kB              | SGDMA                    |
| 0x00000000   | 0x0001FFFF  | 128 kB            | System Memory            |
| 0x40001000   | 0x40004FFF  | 16 kB             | TSE MAC                  |
| 0x40090000   | 0x40090FFF  | 4 kB              | UART                     |
| 0x40099000   | 0x40099FFF  | 4 kB              | Watch Dog Timer          |



## 2.7. Functional Operation

The GSRD system comprises of two SoCs (System on Chip) such as Primary and Golden. Each SoC is linked with its respective First-Stage Bootloader (FSBL) and a FreeRTOS Application Software. These SoCs are built using Lattice Propel SDK, Lattice Propel Builder, and Lattice Radiant software tools. The FPGA image comprises of the entire system and is generated by the Radiant tool in the (.bit) bitstream format. The bootloader code is stored inside the system memory and is part of the bitstream. The bitstream and the FreeRTOS application software are stored into the external SPI Flash (Winbond).

During power-on, the Primary FPGA image is loaded into the device CRAM by the Config Engine. Before the device is completely programmed with the bitstream, the config engine checks the CRC (Cyclic Redundancy Check) for the bitstream to be loaded onto the FPGA. Once the FPGA is configured, DONE LED on the board glows green. Immediately, the RISC-V starts executing the bootloader software stored inside system memory and initialize all the soft-IP modules and peripherals to establish a base for communication and data transfers. This process includes configuring the IPs for the desired system operation. After all the IP configuration is complete, RISC-V initiates trigger the QSPI Flash controller to copy the FreeRTOS application software from external SPI Flash into the external LPDDR4 for software execution. Once the application software is copied, the RISC-V checks the CRC on entire copied application software. If the CRC check fails, RISC-V initiates a soft reset/refresh by instructing the multi-boot configuration module to start the PROGRAMN sequence. The PROGRAMN sequence loads the next bitstream into the FPGA which in this case would be the Golden FPGA and FW images, and the same process follows. Once CRC check passes for either Primary or Golden, the RISC-V jumps to the application instruction and starts the FreeRTOS FW execution.



## 3. Signal Description

Table 3.1 shows the input/output interface signals for the top-level module.

Table 3.1. Top-level I/O

| Signal Name     | I/O Type     | I/O Width | Description                                                                                     |  |
|-----------------|--------------|-----------|-------------------------------------------------------------------------------------------------|--|
| clk_125MHz      | Input        | 1         | Reference clock input for internal PLL and TSE MAC/SGMII                                        |  |
| pll_refclk_i    | Input        | 1         | Reference clock input for LPDDR4 MC internal PLL                                                |  |
| rstn_i          | Input        | 1         | Active low reset input for reference design. Activate by pressing SW1 push button on the board. |  |
| GPIO            |              |           |                                                                                                 |  |
| s0_gpio         | Input/Output | 8         | General Purpose I/O signals connect to LED on board                                             |  |
| UART            |              |           |                                                                                                 |  |
| s1_uart_txd_o   | Output       | 1         | UART transmit output. Connects to the board TXD signal.                                         |  |
| s1_uart_rxd_i   | Input        | 1         | UART receive input. Connects to the board RXD signal.                                           |  |
| QSPI Flash      |              |           |                                                                                                 |  |
| SPI_CLK         | Output       | 1         | Serial clock to SPI Flash                                                                       |  |
| SPI_CSS         | Output       | 1         | SPI Flash chip select                                                                           |  |
| SPI_MOSI        | Input/Output | 1         | Serial data between FPGA and external SPI Flash                                                 |  |
| SPI_MISO        | Input/Output | 1         | Serial data between FPGA and external SPI Flash                                                 |  |
| SPI_D2          | Input/Output | 1         | Serial data between FPGA and external SPI Flash                                                 |  |
| SPI_D3          | Input/Output | 1         | Serial data between FPGA and external SPI Flash                                                 |  |
| LPDDR4 MC       |              |           |                                                                                                 |  |
| ddr_ca_o        | Output       | 6         | LPDDR4 command/address                                                                          |  |
| ddr_ck_o        | Output       | 1         | LPDDR4 clock                                                                                    |  |
| ddr_cke_o       | Output       | 1         | LPDDR4 clock enable                                                                             |  |
| ddr_cs_o        | Output       | 1         | LPDDR4 chip select                                                                              |  |
| ddr_dmi_io      | Input/Output | 4         | LPDDR4 data mask                                                                                |  |
| ddr_dq_io       | Input/Output | 32        | LPDDR4 Data                                                                                     |  |
| ddr_dqs_io      | Input/Output | 4         | LPDDR4 data strobe                                                                              |  |
| ddr_reset_n_o   | Output       | 1         | External Memory chip reset signal                                                               |  |
| init_done_o     | Output       | 1         | Connects to LED for status check                                                                |  |
| irq_o           | Output       | 1         | Connects to LED for status check                                                                |  |
| pll_lock_o      | Output       | 1         | Connects to LED for status check                                                                |  |
| sclk_o          | Output       | 1         | Connects to LED for status check                                                                |  |
| trn_err_o       | Output       | 1         | Connects to LED for status check                                                                |  |
| RGMII Interface |              |           |                                                                                                 |  |
| rgmii_rxc_i     | Input        | 1         | RGMII Receive Clock from external PHY                                                           |  |
| rgmii_rxctl_i   | Input        | 1         | RGMII Receive Control signal from external PHY                                                  |  |
| rgmii_rxd_i     | Input        | 4         | 4-bit RGMII Receive Data from external PHY                                                      |  |
| rgmii_txc_o     | Output       | 1         | RGMII Transmit Clock to external PHY                                                            |  |
| rgmii_txctl_o   | Output       | 1         | RGMII Transmit Control signal to external PHY                                                   |  |
| rgmii_txd_o     | Output       | 4         | 4-bit RGMII Transmit Data to external PHY                                                       |  |
| rgmii_mdio_o    | Output       | 1         | RGMII Transmit Control signal to external PHY                                                   |  |
| rgmii_mdc_o     | Output       | 1         | RGMII Transmit Control signal to external PHY                                                   |  |
| phy_resetn_o    | Output       | 1         | Hard reset generated from FPGA to reset the external PHY                                        |  |
| Multi-Boot      |              |           | · · · · · ·                                                                                     |  |
| config_active_o | Output       | 1         | Connects to LED to check Multi-Boot Configuration Block                                         |  |



## 4. Software Components

The GSRD (Golden System Reference Design) is enabled by RISC-V core based FreeRTOS and Lattice FPGA IP modules. Lattice developed BSP (Board Support Package) drivers in C language act as intermediaries, facilitating communication between the hardware elements on the FPGA and FreeRTOS software. During boot up, these drivers initialize and configure FPGA peripherals to establish effective coordination with the RISC-V processor.

## 4.1. Primary and Golden Bootloader

Bootloader is a bare-metal program that does the following IP configurations:

- Configures the GPIO and UART IP
- For LPDDR4 MC configuration, it first reads if the PLL Lock status is set and then initiates Memory Training and waits until training is complete.
- Configures the QSPI flash controller to read the application software stored into external flash while FIFO is disabled using API and copies it into LPDDR4.
- It then calculates the CRC value on the entire FW copied into DDR using crc16\_ccit() API and compares the value with the original CRC value.
- Failure of the CRC check on the Primary application software triggers reconfiguration of the FPGA with the Golden FPGA bitstream image. This is done by triggering Multi-Boot Configuration module. This step is only used in Primary GSRD system.

## 4.2. Primary and Golden Application

- Executed by RISC-V RX CPU core from LPDDR4 where it initializes the BSP and Operating System
- Configures the TSE MAC handler with 1G Ethernet address, speed mode, MAC upper and lower. Passes TSE Core object to initialize the Ethernet IP and sets the MAC address.
- Creates an Ethernet frame using the API provided in ethernet\_frame.h.
- Configure the SGDMA IP for MM2S to transfer the Ethernet frame to the TSE MAC and set up S2MM to receive packets from the TSE MAC at 2-second intervals. Runs FreeRTOS scheduler and Task Handler.

For the PHY initialization, it configures the PHY using mdio\_phy\_init() API by performing a PHY reset before starting the TSE packet traffic. The PHY configuration checks if the Marvell 88E151X PHY is attached before performing the configuration.

This also captures the packets sent from the Avant board at two second intervals.



## 5. Design Constraints

The design constraints are divided into two parts, Pre-Synthesis (SDC) and Post-Synthesis Physical (PDC) constraints. They are used to ensure that the design meets the required performance, timing closure, functionality and physical placement requirements as per the FPGA device.

## 5.1. I/O Constraints

```
Ldc set sysconfiq {MULTI BOOT MODE=ENABLE MULTI BOOT SEL=STATIC BOOT SEL=DUAL
MSPI_ADDRESS_32BIT=ENABLE MSPI_COMMAND_32BIT=ENABLE PROGRAMN_RECOVERY=ENABLE}
create_clock -name {pll_refclk_i} -period 10 -waveform {0.000 5.000} [get_ports
pll_refclk_i]
create_clock -name {clk_125_in} -period 8 -waveform {0.000 4.000} [get_ports clk_125_in]
create clock -name {rgmii mdc o} -period 100 [get nets rgmii mdc o c]
#100MHz LPDDR4 PLL REFERENCE CLOCK
ldc_set_location -site {AD32} [get_ports pll_refclk_i]
ldc_set_location -site {AL10} [get_ports clk_125_in]
#RESET
ldc_set_location -site {AC17} [get_ports rstn_i]
ldc set port -iobuf {IO TYPE=LVCMOS18 PULLMODE=UP} [get ports rstn i]
#IIART
ldc_set_location -site {R3} [get_ports s1_uart_txd_o]
ldc_set_location -site {T3} [get_ports s1_uart_rxd_i]
Ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports s1_uart_rxd_i]
Ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports s1_uart_txd_o]
#GPTO
ldc_set_location -site {N7} [get_ports {s0_gpio[0]}]
ldc_set_location -site {L7} [get_ports {s0_gpio[1]}]
#ldc set location -site {L8} [get ports {s0 gpio[2]}]
#ldc_set_location -site {P8} [get_ports {s0_gpio[3]}]
#ldc_set_location -site {M8} [get_ports {s0_gpio[4]}]
#ldc_set_location -site {M9} [get_ports {s0_gpio[5]}]
#ldc_set_location -site {P10} [get_ports {s0_gpio[6]}]
#ldc_set_location -site {N10} [get_ports {s0_gpio[7]}]
ldc set port -iobuf {IO TYPE=LVCMOS33} [get ports {s0 gpio[*]}]
#SPI FLASH
ldc_set_port -iobuf {IO_TYPE=LVCMOS33 SLEWRATE=FAST} [get_ports SPI_CLK]
Ldc_set_port -iobuf {IO_TYPE=LVCMOS33 SLEWRATE=FAST} [get_ports SPI_CSS]
Ldc_set_port -iobuf {IO_TYPE=LVCMOS33 SLEWRATE=FAST} [get_ports SPI_MOSI]
Ldc_set_port -iobuf {IO_TYPE=LVCMOS33 SLEWRATE=FAST} [get_ports SPI_MISO]
ldc_set_port -iobuf {PULLMODE=UP} [get_ports SPI_D2]
ldc_set_port -iobuf {PULLMODE=UP} [get_ports SPI_D3]
ldc_set_location -site {L12} [get_ports SPI_MOSI]
ldc_set_location -site {L10} [get_ports SPI_D2]
ldc_set_location -site {L11} [get_ports SPI_MISO]
ldc_set_location -site {L9} [get_ports SPI_D3]
ldc_set_location -site {P9} [get_ports SPI_CLK]
ldc_set_location -site {P7} [get_ports SPI_CSS]
```



```
#FPGA CONFTG LFD
ldc_set_location -site {M8} [get_ports config_active_o]
ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports config_active_o]
#LPDDR4 MC LEDs
ldc_set_location -site {N10} [get_ports pll_lock_o]
ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports pll_lock_o]
ldc_set_location -site {P10} [get_ports init_done_o]
Ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports init_done_o]
ldc_set_location -site {M9} [get_ports trn_err_o]
ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports trn_err_o]
#LPDDR4 MC
ldc_set_location -site {AC26} [get_ports {ddr_ca_o[0]}]
ldc_set_location -site {AB27} [get_ports {ddr_ca_o[1]}]
ldc set location -site {AB28} [get ports {ddr ca o[2]}]
ldc_set_location -site {AC29} [get_ports {ddr_ca_o[3]}]
ldc_set_location -site {AB29} [get_ports {ddr_ca_o[4]}]
ldc_set_location -site {AD27} [get_ports {ddr_ca_o[5]}]
ldc_set_location -site {AB25} [get_ports {ddr_ck_o[0]}]
ldc_set_location -site {AB26} [get_ports {ddr_cke_o[0]}]
ldc_set_location -site {AA31} [get_ports {ddr_cs_o[0]}]
ldc_set_location -site {AF34} [get_ports ddr_reset_n_o]
ldc_set_location -site {AC23} [get_ports {ddr_dqs_io[0]}]
ldc_set_location -site {AC34} [get_ports {ddr_dqs_io[1]}]
ldc_set_location -site {AD22} [get_ports {ddr_dq_io[0]}]
ldc_set_location -site {AD21} [get_ports {ddr_dq_io[1]}]
ldc_set_location -site {AE25} [get_ports {ddr_dq_io[2]}]
ldc_set_location -site {AE24} [get_ports {ddr_dq_io[3]}]
ldc_set_location -site {AA21} [get_ports {ddr_dq_io[4]}]
ldc_set_location -site {Y21} [get_ports {ddr_dq_io[5]}]
ldc_set_location -site {AB24} [get_ports {ddr_dq_io[6]}]
ldc_set_location -site {AC24} [get_ports {ddr_dq_io[7]}]
ldc_set_location -site {AD34} [get_ports {ddr_dq_io[8]}]
ldc_set_location -site {AD33} [get_ports {ddr_dq_io[9]}]
ldc_set_location -site {AE32} [get_ports {ddr_dq_io[10]}]
ldc_set_location -site {AE31} [get_ports {ddr_dq_io[11]}]
ldc_set_location -site {AE33} [get_ports {ddr_dq_io[12]}]
ldc_set_location -site {AE34} [get_ports {ddr_dq_io[13]}]
ldc_set_location -site {AB34} [get_ports {ddr_dq_io[14]}]
ldc_set_location -site {AB33} [get_ports {ddr_dq_io[15]}]
ldc_set_location -site {AC21} [get_ports {ddr_dmi_io[0]}]
ldc_set_location -site {AF33} [get_ports {ddr_dmi_io[1]}]
ldc_set_location -site {AB30} [get_ports {ddr_ck_o[1]}]
ldc_set_location -site {Y29} [get_ports {ddr_dqs_io[2]}]
ldc_set_location -site {W23} [get_ports {ddr_dqs_io[3]}]
ldc_set_location -site {U29} [get_ports {ddr_dq_io[16]}]
ldc_set_location -site {V29} [get_ports {ddr_dq_io[17]}]
ldc_set_location -site {U30} [get_ports {ddr_dq_io[18]}]
ldc_set_location -site {U31} [get_ports {ddr_dq_io[19]}]
ldc_set_location -site {Y28} [get_ports {ddr_dq_io[20]}]
```



```
ldc_set_location -site {AA28} [get_ports {ddr_dq_io[21]}]
ldc_set_location -site {V30} [get_ports {ddr_dq_io[22]}]
ldc_set_location -site {W30} [get_ports {ddr_dq_io[23]}]
ldc_set_location -site {AA24} [get_ports {ddr_dq_io[24]}]
ldc set location -site {Y24} [get ports {ddr dg io[25]}]
ldc_set_location -site {U23} [get_ports {ddr_dq_io[26]}]
ldc set_location -site {U22} [get_ports {ddr_dq_io[27]}]
ldc_set_location -site {U25} [get_ports {ddr_dq_io[28]}]
ldc_set_location -site {T25} [get_ports {ddr_dq_io[29]}]
ldc_set_location -site {U24} [get_ports {ddr_dq_io[30]}]
ldc set location -site {T24} [get ports {ddr dg io[31]}]
ldc_set_location -site {V32} [get_ports {ddr_dmi_io[2]}]
ldc_set_location -site {V22} [get_ports {ddr_dmi_io[3]}]
# The ECLKDIV primitive already has constraint but the inferred name is not good.
# The constraint below only aims to assign a name to the generated clock.
create generated clock -name {sclk o} -source [get pins -hierarchical
{lscc_mc_avant_inst/u_ddrphy/pll_inst/gen_ext_outclkdiv*.u_pll.PLLC_MODE_inst/CLKOPHY}]
-divide_by 8 [get_pins -hierarchical {lscc_mc_avant_inst/u_ddrphy/u_eclkdiv/ECLKDIVOUT
}]
set_clock_uncertainty -setup 0.075 [get_clocks sclk_o]
# The PLL lock is false as it toggles only once for a long time
# It is also sampled by double FF
set_false_path -to [get_pins -hierarchical
{lscc_mc_avant_inst/u_ddrphy/i_csr/p_pll_lock_r1*/D}]
# This signal is asserted and then de-asserted while the clocks are stopped, thus, they
are false path.
set_false_path -to [get_pins -hierarchical {lscc_mc_avant_inst/u_ddrphy/u_eclkdiv/RST}]
# Constraints for the CDC logic on the DDRPHY's CSR
set_max_delay -from [get_pins -hierarchical
{lscc_mc_avant_inst/u_ddrphy/i_csr/wr_data_buff_r*/Q}] -to [get_pins -hierarchical
{lscc_mc_avant_inst/u_ddrphy/i_csr/s_apb_data_r*/D}] -datapath_only 3
set_max_delay -from [get_pins -hierarchical
\{lscc\_mc\_avant\_inst/u\_ddrphy/i\_csr/addr\_buff\_r*/Q\}] \ -to \ [get\_pins \ -hierarchical] \ -to \ [get\_pins \ -hierarchinal] \ -to \ [get\_pins \ -hierarchina
{lscc_mc_avant_inst/u_ddrphy/i_csr/s_apb_addr_r*/D}] -datapath_only 3
#Constraints for MC's FIFO DC instances
# The distributed RAM data output port to FIFO_DC data output register is already
guaranteed by the CDC logic and above constraints.
set max delay -from [get pins -hierarchical
{\lscc_mc_avant_inst/AXI_BI.u_axi_if/u_rd/ASYNC.u_ctrl_fifo/u_fifo_dc/*.dpram_inst/D0*}]
-datapath_only 3
set_max_delay -from [get_pins -hierarchical
{lscc_mc_avant_inst/AXI_BI.u_axi_if/u_rd/u_rd_rsp/u_data_fifo/u_fifo_dc/*.dpram_inst/D0*
}] -datapath only 3
set_max_delay -from [get_pins -hierarchical
{\lscc_mc_avant_inst/AXI_BI.u_axi_if/u_wr/ASYNC.u_ctrl_fifo/u_fifo_dc/*.dpram_inst/DO*}]
-datapath only 3
```



```
set max delay -from [get pins -hierarchical
{lscc_mc_avant_inst/AXI_BI.u_axi_if/u_wr/ASYNC.u_data_fifo/u_fifo_dc/*.dpram_inst/DO*}]
-datapath only 3
# The reset pin of double FF that synchronizes the reset de-assertion is false path
set_false_path -to [get_pins -hierarchical {lscc_mc_avant_inst/rst_n*/CD}]
set_false_path -to [get_pins -hierarchical {lscc_mc_avant_inst/reset_n*/CD}]
set_false_path -to [get_pins -hierarchical {lscc_mc_avant_inst/phy_srst_n*/CD}]
set_false_path -to [get_pins -hierarchical
{lscc_mc_avant_inst/u_ddrphy/start_rst_r*/PD}]
set_false_path -to [get_pins -hierarchical {lscc_mc_avant_inst/u_ddrphy/s_rst_n_r*/CD}]
# TSE MAC RGMII Constraints
ldc_set_location -site {Y10} [get_ports rgmii_txc_o]
ldc set location -site {AB12} [get ports rgmii txctl o]
ldc_set_location -site {Y11} [get_ports {rgmii_txd_o[0]}]
ldc_set_location -site {AA2} [get_ports {rgmii_txd_o[1]}]
ldc_set_location -site {Y2} [get_ports {rgmii_txd_o[2]}]
ldc_set_location -site {AB13} [get_ports {rgmii_txd_o[3]}]
ldc_set_location -site {Y7} [get_ports rgmii_rxc_i]
ldc_set_location -site {Y6} [get_ports rgmii_rxctl_i]
ldc_set_location -site {AC7} [get_ports {rgmii_rxd_i[0]}]
ldc_set_location -site {AC6} [get_ports {rgmii_rxd_i[1]}]
ldc_set_location -site {AD6} [get_ports {rgmii_rxd_i[2]}]
ldc_set_location -site {AD5} [get_ports {rgmii_rxd_i[3]}]
ldc_set_location -site {AA8} [get_ports rgmii_mdc_o]
ldc_set_location -site {Y9} [get_ports rgmii_mdio_o]
ldc set_port -iobuf {IO_TYPE=LVCMOS18} [get_ports rgmii_rxc_i]
ldc_set_port -iobuf {IO_TYPE=LVCMOS18} [get_ports rgmii_rxctl_i]
ldc set port -iobuf {IO TYPE=LVCMOS18} [qet ports {rqmii rxd i[*]}]
ldc_set_port -iobuf {IO_TYPE=LVCMOS18 SLEWRATE=FAST} [get_ports rgmii_txc_o]
ldc_set_port -iobuf {IO_TYPE=LVCMOS18 SLEWRATE=FAST} [get_ports rgmii_txctl_o]
ldc_set_port -iobuf {IO_TYPE=LVCMOS18 SLEWRATE=FAST} [get_ports {rgmii_txd_o[*]}]
Ldc_set_port -iobuf {IO_TYPE=LVCMOS18} [get_ports rgmii_mdc_o]
Ldc_set_port -iobuf {IO_TYPE=LVCMOS18 PULLMODE=UP} [get_ports rgmii_mdio_o]
ldc set location -site {AA9} [get ports phy resetn o]
Ldc_set_port -iobuf {IO_TYPE=LVCMOS18} [get_ports phy_resetn_o]
#create_clock -name {rgmii_rxc_i} -period 8 -waveform {2 6} [get_ports rgmii_rxc_i]
create_clock -name {rgmii_rxc_i} -period 8 [get_ports rgmii_rxc_i]
create_clock -name {rgmii_rxc_i_pad_0} -period 8
#create_clock -name {rgmii_txc_o} -period 8 [get_nets rgmii_txc_o_c]
# - phase-shift 90 Degree
set_input_delay -clock [get_clocks rgmii_rxc_i] -max 0.5 [get_ports {rgmii_rxctl_i
rgmii_rxd_i[*]}]
set_input_delay -clock [get_clocks rgmii_rxc_i] -clock_fall -min -add_delay -0.5
[get_ports {rgmii_rxctl_i rgmii_rxd_i[*]}]
set_output_delay -clock [get_clocks rgmii_txc_o_c] -max 1 [get_ports {rgmii_txctl_o
rgmii_txd_o[*]}]
set_output_delay -clock [get_clocks rgmii_txc_o_c] -clock_fall -min -add_delay -0.8
[get_ports {rgmii_txctl_o rgmii_txd_o[*]}]
```



```
set_clock_groups -group [get_clocks clk_125_in] -group [get_clocks rgmii_txc_o_c] -group
[get_clocks rgmii_rxc_i] -group [get_clocks rgmii_mdc_o] -asynchronous

set_clock_groups -group [get_clocks clk_125_in] -group [get_clocks rgmii_txc_o_c] -group
[get_clocks pll0_inst_clkos2_o_net] -group [get_clocks
{pll0_inst/lscc_pll_inst/clkout_testclk_o}] -group [get_clocks pll0_inst_clkos_o_net] -
group [get_clocks sclk_o] -group [get_clocks {pll0_inst_clkos3_o_net[0]}] -asynchronous

ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports TCK]
ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports TDI]
ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports TMS]
ldc_set_port -iobuf {IO_TYPE=LVCMOS33} [get_ports TDO]

set_false_path -from [get_ports rstn_i]
set_false_path -from [get_pins {cpu0_inst/system_resetn_o}]
```



## 6. Resource Utilization

Figure 6.1 shows the GSRD resource utilization and Table 6.1 shows the total LUT4, PFU register, I/O buffer, and EBR resource utilization for Avant-AT-E70.



Figure 6.1. GSRD Resource Utilization on Avant-AT-E70

**Table 6.1. GSRD Total Resource Utilization** 

| Resource                                      | Usage | Percentage Utilization |
|-----------------------------------------------|-------|------------------------|
| LUT4 (Logic + Distributed RAM + Ripple Logic) | 68593 | 17.25%                 |
| PFU Register                                  | 47925 | 12.05%                 |
| I/O Buffers                                   | 91    | _                      |
| EBR                                           | 78    | 7.87%                  |



## 7. Demo User Guide

## 7.1. Boot-Up Sequence

This section describes the RISC-V RX CPU boot up sequence that configures IP drivers, operating modes, bootloader and FreeRTOS application software execution.

Here is the description of the terms used throughout the document:

- Boot Up Process of starting the RISC-V RX CPU, loading the FreeRTOS application software from external SPI Flash into the LPDDR4 memory and executing the application.
- Bootloader Code that initializes and configures various peripherals and loads the FreeRTOS application software
  into LPDDR4 memory. It also checks for the CRC of the copied application and decides whether to execute the
  application software or load the next best bitstream hardware and corresponding software.
- FreeRTOS Application software that is loaded into LPDDR4 Memory and executed by RISC-V CPU at the end of boot up process.
- SPI Flash Non-volatile external memory that stores the FreeRTOS application software and multi-boot MCS bitstream.

The following is the boot up sequence shown in Figure 7.1:

- The system provides similar functionality both in Bare Metal and FreeRTOS mode. For the demo, the Golden and
  Primary application software binaries and their FPGA bitstream images are stored in external SPI Flash before the
  boot up sequence is initiated.
- The initial bootloader is a part of the internal system memory ROM embedded into the FPGA bitstream stored inside the external SPI Flash. Upon power-on boot up, the bootloader configures the peripherals and GSRD building blocks such as UART, GPIO, I2C, SGDMA, 1G TSE MAC, SGMII PCS, LPDDR4 and QSPI Controller.
- The bootloader loads the bitstream from the SPI Flash to program the SRAM of the FPGA and fetches the respective application software (Primary) via the QSPI flash controller.
- As the application software needs to be executed from the external memory, the RISC-V module loads it into LPDDR4 Memory controller.
- This application software is stored at the beginning of the LPDDR4 Memory. After the application software is loaded, the RISC-V CPU calculates the CRC of the application code in LPDDR4.
- The calculated LPDDR4 CRC is compared with the original CRC, that is a part of SPI Flash.
  - If the condition matches, the RISC-V CPU jumps to FreeRTOS execution from LPDDR4 memory
  - If the condition mismatches, the RISC-V CPU issues a FPGA REFRESH command to load the Golden bitstream and application software from SPI Flash.
- Upon the execution of the correct Primary or Golden application software from LPDDR4, the building blocks mentioned earlier are up and running with their associated drivers. For example, if any Ethernet data is expected to arrive, the RISC-V CPU sets up the SGDMA IP accordingly with address, data length and other configuration modes to successfully route the incoming Ethernet packets.
- When the Ethernet frame is received by the TSE MAC IP, it forwards it to SGDMA to transfer the data to its destination based on parameters set. The endpoint in this case is the main memory LPDDR4.
- You can also choose to store the data into another system memory based on SGDMA configuration.
- For outgoing data, the data is fetched from a location inside LPDDR4, and SGDMA transfers the data to TSE MAC for transmission outside the FPGA.
- When no data activity occurs over Ethernet, the RISC-V CPU continues running its tasks in the usual manner based on the loaded software execution.

FPGA-RD-02296-1.0





Figure 7.1. GSRD Boot-Up Sequence



## 7.2. Prerequisites

The following sections show the hardware and software requirements to execute the GSRD demonstration.

#### 7.2.1. Software Requirements

- Lattice Propel 2024.1 Package contains both Lattice Propel SDK and Lattice Propel Builder
  - Download here: Lattice Propel 2024.1
- Lattice Radiant 2024.1.1 Package contains IP Packager, Radiant Software, QuestaSim, and Programmer
  - Download here: Lattice Radiant 2024.1.1
- Lattice Propel 2024.1 Patch for Avant-AT-E Golden System Reference Design
  - Download here: Downloadable Software tab in the GHRD/GSRD Reference Design

## 7.2.2. Avant-AT-E Requirements

#### 7.2.2.1. Hardware Needed

The section describes the hardware needed to run the GSRD demonstration.

- Lattice Avant-E70 ES1 Evaluation Board
- USB Type-A UART cable for programming the bitstream, application software and proper terminal prints
- Electrical Ethernet FMC daughter card for Ethernet connection over RGMII
  - To purchase the daughter card, go to https://ethernetfmc.com/ and select the part number OP031-1V8.
- Ethernet cable to connect one of the Ethernet ports on FMC board to the Host PC
- 12 V power adapter for board power

#### 7.2.2.2. Hardware Setup

This section provides the procedure for setting up the Avant-E70 ES1 board, shown in Figure 7.2.



Figure 7.2 . Avant-AT-E70 Evaluation Board





Figure 7.3. Ethernet PHY FMC Card



Figure 7.4. Connections and Buttons needed for Demonstration

To setup the Lattice Avant-AT-E board for GSRD demonstration:

- 1. Connect the 12 V power adapter to J50.
- 2. Connect the Mini-USB Type-A cable from PC to J2.
- 3. Connect jumpers on Pin 1 and Pin 2 on both JP1 and JP2 switches to enable UART.
- 4. Align and carefully connect the Ethernet FMC daughter card onto J48 connector.
- 5. Connect the Ethernet RJ45 cable from the host PC cable to the Port0 of FMC card.
- 6. For FPGA executables programming, use SW7 in JTAG mode. Once programmed, switch to MSPI.
- 7. Turn on the SW6 switch.
- 8. SW1 is the FPGA Reset pushbutton to reset the GSRD design.
- 9. SW2 is the PROGRAMN pushbutton to switch between Primary and Golden GSRD manually.

### 7.2.2.3. Executables

This section provides the directory structure, file names and locations of the executables (SPI Flash) required for running the GSRD demonstration.

- Download the design package from the Lattice Semiconductor website.
  - Go to *Design File* in the GHRD/GSRD Demonstration, download the Avant-AT-E Golden System Reference Design and Demo V1.0 Bitstream file.



- Unzip the .zip file to your local directory, for example to <C:\user workspace>.
- The extracted directory has the following executables listed in Table 7.1.

Table 7.1. Executable Files for Winbond Flash

| File Description                                 | File Name              | Starting Address in SPI Flash |
|--------------------------------------------------|------------------------|-------------------------------|
| Primary Software with CRC                        | c_primary_appcrc.bin   | 0x028A 0000                   |
| Primary Software without CRC                     | c_primary_app.bin      | 0x028A 0000                   |
| Primary FPGA Bitstream                           | soc_primary_system.bit | 0x0000 0000                   |
| Golden Software with CRC                         | c_golden_appcrc.bin    | 0x0280 0000                   |
| Golden Software without CRC                      | c_golden_app.bin       | 0x0280 0000                   |
| Golden FPGA Bitstream                            | soc_golden_system.bit  | 0x0000 0000                   |
| Multi-Boot MCS File (Golden + Primary Bitstream) | multiboot_system.mcs   | 0x0000 0000                   |

## 7.3. Implementing the GHRD/GSRD Demo

This section describes the procedure for running the GSRD/GHRD demo using the pre-built executables and binary files in the design package.

## 7.3.1. Setting up the UART Terminal

The software code during the GSRD demonstration displays messages on the terminal through the UART interface. To setup the UART terminal:

- 1. Connect the Lattice Avant-AT-E Evaluation board to the PC/Laptop using USB Type-A UART cable.
- 2. Open Propel SDK 2024.1 tool.
- 3. Double-click on the terminal button shown in Figure 7.5.



Figure 7.5. UART Terminal Icon on Propel SDK Window



4. Choose **Serial Terminal** as shown in Figure 7.6. In Serial port dropdown list, select the last COM in the list as shown in Figure 7.7.

**Note:** This detail can also be found under the Ports (COM and LPT) section in your local PC, under Device Manager. Your COM port number can be different. If a USB port does not work, try a different USB port.



Figure 7.6. UART Launch Terminal Window



Figure 7.7. Device Manager Window on PC

5. Set Baud rate: 115200.

6. Click OK.

## 7.3.2. Setting up the Non-Volatile Memory Register

For the GSRD design on Lattice Avant-AT-E design, you need to ensure the settings of the One-Time-Programmable Non-Volatile Configuration Memory. You may skip this section if you have already done this step before. Otherwise, perform a one-time step by JTAG to modify the default MSPI addressing mode from 24-bit to 32-bit. This is necessary for the multi-boot feature to function properly.

## 7.3.3. Programming the Standalone Golden or Primary GSRD Bitstream and Application Software

- 1. Connect the Avant-AT-E70 Evaluation Board to a PC/laptop using USB cable as per the hardware setup mentioned in Hardware Setup section. Make sure the JP1 and JP2 are connected properly.
- 2. Keep SW7 in JTAG mode.
- 3. Power-on the board.



4. Launch Lattice Programmer tool. In the Getting Started dialog box, select **Create a new blank project**. Browse to the Project Location on your local machine. In this case, it can be the same folder as downloaded executables folder.



Figure 7.8. Launch Radiant Programmer from Windows Start



Figure 7.9. Radiant Programmer Start Window

5. Click OK.



Figure 7.10. Radiant Programmer .xcf Window

6. If the Device Family shows as Generic JTAG Device, click **Scan** Device as shown in Figure 7.11 to update the Device Family information automatically.



Figure 7.11. Scan Device Icon on Radiant Programmer



Figure 7.12. Select Device for Programming

7. Click on the highlighted item under the **Device** field to un-highlight it as shown in Figure 7.13.



Figure 7.13. Device Selected for Programmer

8. Double-click on the Operation tab or right-click and select Device Properties.



Figure 7.14. Select the Target Memory for Programming

9. Before programming, you need to erase the entire SPI Flash Memory by applying the settings shown in Figure 7.15.





Figure 7.15. Device Properties to Erase the SPI Flash

10. Click **OK** and click on the Program Device Icon or the menu item, **Run > Program Device**. This erases the entire Flash Memory. Wait for the process to complete.



Figure 7.16. Program Button to Program the SPI Flash

- 11. Power cycle the Lattice Avant board.
- 12. Erase the FPGA CRAM. Click OK.





Figure 7.17. Erase Only Operation for CRAM Programming

13. Skip steps 14 to 18 if you have performed the steps before. Otherwise, perform a one-time step required by JTAG to Program NV Register 1 to modify the default SPI Addressing and Command mode from 24 bits to 32 bits. You need to this only once for your board. Subsequent programming does not need to program NV Register 1 again.



Figure 7.18. One-Time Programmable Control NV Register1

- 14. Click **OK** and click the **Program Device** Icon or go to the menu item, **Run > Program Device**.
- 15. Change bit 0 to 1 for 32-bit MSPI Address and 32-bit MSPI Commands as shown in the Figure 7.19. For changing these bits, just click once on those 0 in the Chip Value row.





Figure 7.19. Settings to Select Chip Value

Note: Update the value of the two highlighted fields. NV Register 1 is an OTP (One-Time-Programmable) Register.

- 16. Click Program.
- 17. Power cycle the Avant-AT-E Evaluation Board.
- 18. To program the c\_golden\_appcrc.bin file into the SPI Flash, follow the settings as shown in Figure 7.20.



Figure 7.20. Device Properties to Program the SPI Flash



- 19. Click OK.
- 20. Use TCK Divider Setting (0-30x) to 4.



Figure 7.21. Cable Settings for device programming

21. Click the **Program Device** Icon or go to the menu item, **Run > Program Device**. The output console displays the Operation Successful message. Note that the *Verifying...* display does not show.



Figure 7.22. Radiant Programmer Console Output after Programming the SPI Flash

- 22. Power cycle the Avant-AT-E70 Evaluation board using SW6.
- 23. To program the FPGA Golden GSRD bitstream, double-click on the **Operation** tab to update the selections as shown in Figure 7.23. Make sure to provide the path to the .bit file location on your local machine where you have unzipped the executables.





Figure 7.23. Device Properties to Program the FPGA Bitstream in CRAM

24. Click **OK** and Click the **Program Device** Icon or go to the menu item, **Run > Program Device**. Wait until the operation is successful as shown in Figure 7.24.

```
INFO <85021074> - Check configuration setup: Start.

INFO <85021077> - Check configuration setup: Successful (Ignored JTAG Connection Checking).

INFO <85021278> - Device1 LAV-AT-E70ES1: Fast Configuration

INFO <85021298> - Operation Done. No errors.

INFO <85021371> - Elapsed time: 00 min : 27 sec

INFO <85021373> - Operation: successful.
```

Figure 7.24. Radiant Programmer Console Output after Bitstream is Programmed

- 25. Setup the UART terminal as mentioned in the Setting up the UART Terminal section.
- 26. Press **SW1 Reset** button on the board as highlighted in Figure 7.25.





Figure 7.25. SW1 Reset Button

- 27. The Golden GSRD output results are as follows:
  - a. Golden GSRD Bootloader
  - b. LPDDR4 Configuration and Memory Training Status
  - c. Ethernet PHY Configuration and Status
  - d. LPDDR4 and QSPI CRC matches
  - e. Application jumps to Golden FreeRTOS RISC-V.
  - f. Waits for Ethernet Link Up. As soon as you plug the Ethernet Cable into Port0 of FMC, you can see the traffic.
  - g. SGDMA Packet Received
  - h. FreeRTOS Task Scheduler Running
  - i. Hardware LED Status:
    - D12: PLL Lock
    - D13: LPDDR4 Init Done



```
*****************
***
          GSRD Golden Bootloader Avant-E
****************
INFO: REG_QSPI_FLASH_CMD_CODE_5: 0x6043102
Memory Controller Initialization:
INFO: DDR PLL Locked
INFO: LPDDR4 training complete; LPDDR4 training status = 7f
INFO: LPDDR4 initialized successfully
Memory Controller Initialization Complete.
QSPI Fast Read -- Cycle: 0
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8000f000
OSPI Fast Read -- Cycle: 1
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8001e000
QSPI Fast Read -- Cycle: 2
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8002d000
QSPI Fast Read -- Cycle: 3
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8003c000
QSPI Fast Read -- Cycle: 4
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8004b000
QSPI Fast Read -- Cycle: 5
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8005a000
OSPI Fast Read -- Cycle: 6
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x80069000
Reading and verifying firmware CRC value ...
Embedded LPDDR CRC value: 8c4
Calculated Firmware CRC value: 8c4
CRC matches successfully !!
Jumping to FreeRTOS application ...
```

Figure 7.26. Golden GSRD - Output on UART Terminal for Bootloader and FreeRTOS Start



```
*********************************
*** GSRD Golden FreeRTOS on RISC-V Avant-E ***
PHY Initialization:
INFO: PHY ID: dd1, Model: 1d
INFO: Control Register after write: 1140
INFO: Access Data Register (2): 796d
PHY Initialization Complete.
The granularity of pmp is 4.
pmp entry0: mode=0x01, perm=0x07, addr=0x20003102(*4)=0x8000c408, locked=0
pmp entry1: mode=0x01, perm=0x00, addr=0x20003103(*4)=0x8000c40c, locked=1
pmp entry2: mode=0x01, perm=0x00, addr=0x20003106(*4)=0x8000c418, locked=0
pmp entry3: mode=0x01, perm=0x07, addr=0x3fffffff(*4)=0xfffffffc, locked=0
------Waiting for link-up status ------
INFO: Checking link up status ...
INFO: Link up status: 796d
[Task] [sgdma_configure_tse_rx_task] [ID: 2147514080] Running, [Count: 0]
[Task] [print_rx_data_task] [ID: 2147516272] Running, [Count: 0]
[Task] [print rx data task] Data Received:
ff ff ff ff ff f8 ce 72 1b 79 72 8 6 0 1
8 0 6 4 0 1 f8 ce 72 1b 79 72 0 0 0
0 0 0 0 0 0 a9 fe 17 62 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0
[Task] [uart_task] [ID: 2147518464] Running, [Count: 0]
[Task] [sgdma_configure_tse_rx_tx_task] [ID: 2147514080] Running, [Count: 1]
[Task] [led_task] [ID: 2147520656] Running, [Count: 0]
[Task] [print_rx_data_task] [ID: 2147516272] Running, [Count: 60]
[Task] [print_rx_data_task] Data Received:
ff ff ff ff ff f8 ce 72 1b 79 72 8 0 45
1 48 6c b8 0 0 80 11 cc ed 0 0 0 0 ff ff
ff ff 0 44 0 43 1 34 bf 2a 1 1 6 0 73 76
52 10 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 f8 ce 72 1b 79 72 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
                                  a
```

Figure 7.27. Golden GSRD - Output on UART Terminal for FreeRTOS Running

- 28. Follow the same steps 5 to Step 25 to load the Primary GSRD Software and Bitstream. For Primary App CRC software, refer to the Executables section for the folder and file names.
- 29. The Primary GSRD output results are as follows:



```
***
        GSRD Primary Bootloader Avant-E
***************
INFO: REG_QSPI_FLASH_CMD_CODE_5: 0x6043102
Memory Controller Initialization:
INFO: DDR PLL Locked
INFO: LPDDR4 training complete; LPDDR4 training status = 7f
INFO: LPDDR4 initialized successfully
Memory Controller Initialization Complete.
OSPI Fast Read -- Cycle: 0
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8000f000
QSPI Fast Read -- Cycle: 1
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8001e000
QSPI Fast Read -- Cycle: 2
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8002d000
QSPI Fast Read -- Cycle: 3
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8003c000
QSPI Fast Read -- Cycle: 4
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8004b000
QSPI Fast Read -- Cycle: 5
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8005a000
OSPI Fast Read -- Cycle: 6
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x80069000
Reading and verifying firmware CRC value ...
Embedded LPDDR CRC value: b056
Calculated Firmware CRC value: b056
CRC matches successfully !!
Jumping to FreeRTOS application ...
```

Figure 7.28. Primary GSRD Bootloader- Output on UART Terminal



```
**************
    GSRD Primary FreeRTOS on RISC-V Avant-E
**********
PHY Initialization:
INFO: PHY ID: dd1, Model: 1d
INFO: Control Register after write: 1140
INFO: Access Data Register (2): 796d
PHY Initialization Complete.
The granularity of pmp is 4.
pmp entry0: mode=0x01, perm=0x07, addr=0x200030d6(*4)=0x8000c358, locked=0
pmp entry1: mode=0x01, perm=0x00, addr=0x200030d7(*4)=0x8000c35c, locked=1
pmp entry2: mode=0x01, perm=0x00, addr=0x200030da(*4)=0x8000c368, locked=0
pmp entry3: mode=0x01, perm=0x07, addr=0x3fffffff(*4)=0xffffffffc, locked=0
------Waiting for link-up status
INFO: Checking link up status ...
INFO: Link up status: 796d
Task rx tx id:2147512880 is running, 0
Task print rx data id:2147514048 is running, 0
RX reg received data:
ff ff ff ff ff f8 ce 72 1b 79 72 8 0 45 0
1 48 6c a2 0 0 80 11 cd 3 0
                          0
                            0
                              0 ff ff
ff ff 0 44 0 43 1 34 5 12 1
                          1
                            6
                              0 41 65
3e 3a 0 0 0 0 0 0 0 0 0
                              0 0 0
                            0
       0 0 0 f8 ce 72 1b 79 72 0
0 0 0 0 0 0 0 0 0 0 0 0
                              0 0
         0 0
              0 0 0
                     0 0
0
   0
     0
       0
                          0
                            0
                                 0
                              0
     0
       0
         0
            0
              0
                0
                   0
                     0
                        0
                          0
0
   0
     0
       0
         0
            0
              0
                0
                   0
                     0
                       0
                          0
                            0
                              0
                                 0
0
   0
     0
       0
         0
           0
              0 0 0
                     0
                       0
                          0
                            0
                              0
                                 0
       0 0
           0
              0 0
                  0 0
                       0
                          0
0
   0 0
       0 0 0
              0 0 0 0 0
                          0
                            0
                              0
                                 0
         0 0
0
   0
     0
       0
              0 0
                  0
                     0
                       0
                          0
                            0
                              0
                                 0
   0
     0
       0
         0
            0
              0
                0
                   0
                     0
                       0
                          0
                            0
0
   0
     0
       0
         0
           0
              0
                0
                  0
                     0 0
                          0
                            0
                              0
                                 0
0
   0 0 0 0
              9 9 9 9
                          0 0
                              0 0
                                   0
   0
     0 0 0 0 0 0 0 0 0 0 0 0
0
   0
     0 0 0 0 63 82 53 63 35 1 1 3d 7 1
```

Figure 7.29. Primary GSRD FreeRTOS- Output on UART Terminal

# 7.3.4. Programming the Golden, Primary Software and MCS file

This section describes the three scenarios of GSRD boot-up.

**Note:** The intent of the three scenarios is to showcase how manual and automatic multi-boot results would look like. Scenario 1 should be enough for you to test out the multi-boot. Scenarios 2 and 3 are merely to showcase the different multi-boot scenarios in GSRD.

### 7.3.4.1. Scenario 1: Manual Booting when both Primary and Golden FW are with CRC with MCS File Programming

- 1. Follow Steps 1 to 9 from the Programming the Golden, Primary Software and MCS file section. Do not power-cycle the board.
- 2. Keep the folder/file of executables handy.



To program the multiboot\_system.mcs file, locate the file in the executables folder that you downloaded and add
the file in the Programming file area. Start Address and End Address is allocated automatically. Confirm the settings
as shown in Figure 7.30.



Figure 7.30.Device Properties window to setup MCS programming file

- 4. Click **OK** and the **Program Device** icon or go to the menu item **Run > Program Device**. Wait until the operation is successful, which takes about 30-40 minutes.
- 5. Do not power-cycle the board yet.
- 6. Program both the **primary\_appcrc.bin** and **golden\_appcrc.bin** file as per Programming the Golden, Primary Software and MCS file section, step 17. Make sure to confirm that Start Address (Hex) for both the binaries as per Executables section.
- 7. Once both binaries are programmed, switch off the board.
- 8. Move SW7 to MSPI mode.
- 9. Switch on the board.
- 10. Setup the UART terminal as mentioned in the Setting up the UART Terminal section.
- 11. Wait for about 20 to 30 seconds for the FPGA to load the bitstream from the flash. Press **SW1** Reset button.



- 12. Results on UART Terminal is displayed as shown in Figure 7.31.
  - It loads the Primary GSRD project.
  - If you press the SW1 button again, it loads the same Primary GSRD project.

```
****************
***
                                                 ***
          GSRD Primary Bootloader Avant-E
*******
INFO: REG_QSPI_FLASH_CMD_CODE_5: 0x6043102
Memory Controller Initialization:
INFO: DDR PLL Locked
INFO: LPDDR4 training complete; LPDDR4 training status = 7f
INFO: LPDDR4 initialized successfully
Memory Controller Initialization Complete.
QSPI Fast Read -- Cycle: 0
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8000f000
OSPI Fast Read -- Cycle: 1
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8001e000
QSPI Fast Read -- Cycle: 2
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8002d000
QSPI Fast Read -- Cycle: 3
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8003c000
QSPI Fast Read -- Cycle: 4
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8004b000
QSPI Fast Read -- Cycle: 5
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8005a000
QSPI Fast Read -- Cycle: 6
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x80069000
Reading and verifying firmware CRC value ...
Embedded LPDDR CRC value: b056
Calculated Firmware CRC value: b056
CRC matches successfully !!
Jumping to FreeRTOS application ...
```

Figure 7.31. UART Terminal Output after Power-Cycling Board with MCS and Binaries Programmed

- 13. For the manual multi-boot, press **SW2 (PROGRAMN)** yellow button from the Hardware Setup section on the board just above the **SW1 Reset** button.
- 14. The results on UART terminal are displayed as shown in Figure 7.32. It switches/jumps to Golden GSRD project and stays there unless the **SW2 PROGRAMN** button is pressed.



```
****************
***
                                               ***
          GSRD Golden Bootloader Avant-E
INFO: REG_QSPI_FLASH_CMD_CODE_5: 0x6043102
Memory Controller Initialization:
INFO: DDR PLL Locked
INFO: LPDDR4 training complete; LPDDR4 training status = 7f
INFO: LPDDR4 initialized successfully
Memory Controller Initialization Complete.
QSPI Fast Read -- Cycle: 0
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8000f000
QSPI Fast Read -- Cycle: 1
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8001e000
QSPI Fast Read -- Cycle: 2
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8002d000
QSPI Fast Read -- Cycle: 3
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8003c000
QSPI Fast Read -- Cycle: 4
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8004b000
OSPI Fast Read -- Cycle: 5
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8005a000
QSPI Fast Read -- Cycle: 6
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x80069000
Reading and verifying firmware CRC value ...
Embedded LPDDR CRC value: 8c4
Calculated Firmware CRC value: 8c4
CRC matches successfully !!
Jumping to FreeRTOS application ...
```

Figure 7.32. Switches to Golden GSRD upon SW2 PROGRAMN Button

#### 7.3.4.2. Scenario 2: Manual Booting when Primary FW is with CRC, and Golden FW is without CRC

- 1. Power-off the board.
- 2. Keep SW7 on JTAG mode.
- 3. Power-on the board.
- 4. Program the MCS file as shown in the Scenario 1: Manual Booting when both Primary and Golden FW are with CRC with MCS File Programming section, step 2 to 5. If you have already run the scenario 1 entirely, skip this step. Otherwise, follow steps 2 to 5.
- 5. To program the c\_golden\_app.bin software file into the SPI Flash, follow the settings as shown in Figure 7.33.





Figure 7.33. Device Properties settings to program the Golden Application

6. Click OK and the Program Device Icon or go to Run > Program Device. Wait until the operation is successful.



Figure 7.34. Radiant Programmer Console Output After Programming

- 7. Switch off the board.
- 8. Move SW7 to MSPI Mode.
- 9. Switch on the board.
- 10. Setup UART terminal as mentioned in the Setting up the UART Terminal section.
- 11. Wait for about 20-30 seconds for the FPGA to load the bitstream from the flash press the **SW1 Reset** button.



12. The results on the UART terminal are displayed as shown in Figure 7.35 and loads the Primary GSRD project.

```
************
***
          GSRD Primary Bootloader Avant-E
*************
INFO: REG_QSPI_FLASH_CMD_CODE_5: 0x6043102
Memory Controller Initialization:
INFO: DDR PLL Locked
INFO: LPDDR4 training complete; LPDDR4 training status = 7f
INFO: LPDDR4 initialized successfully
Memory Controller Initialization Complete.
OSPI Fast Read -- Cvcle: 0
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8000f000
QSPI Fast Read -- Cycle: 1
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8001e000
QSPI Fast Read -- Cycle: 2
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8002d000
QSPI Fast Read -- Cycle: 3
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8003c000
QSPI Fast Read -- Cycle: 4
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8004b000
OSPI Fast Read -- Cycle: 5
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8005a000
QSPI Fast Read -- Cycle: 6
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x80069000
Reading and verifying firmware CRC value ...
Embedded LPDDR CRC value: b056
Calculated Firmware CRC value: b056
CRC matches successfully !!
Jumping to FreeRTOS application ...
```

Figure 7.35. Primary GSRD – UART Output after SW1 Reset where CRC Matched

- 13. Manually press the SW2 PROGRAMN button.
- 14. Results on the UART terminal are displayed as shown in Figure 7.36. It jumps to Golden GSRD project and shows as CRC mismatch and stays there.

© 2024 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.

FPGA-RD-02296-1.0



```
GSRD Golden Bootloader Avant-E
INFO: REG_QSPI_FLASH_CMD_CODE_5: 0x6043102
Memory Controller Initialization:
INFO: DDR PLL Locked
INFO: LPDDR4 training complete; LPDDR4 training status = 7f
INFO: LPDDR4 initialized successfully
Memory Controller Initialization Complete.
OSPI Fast Read -- Cycle: 0
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8000f000
QSPI Fast Read -- Cycle: 1
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8001e000
QSPI Fast Read -- Cycle: 2
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8002d000
QSPI Fast Read -- Cycle: 3
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8003c000
OSPI Fast Read -- Cycle: 4
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8004b000
OSPI Fast Read -- Cycle: 5
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8005a000
QSPI Fast Read -- Cycle: 6
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x80069000
Reading and verifying firmware CRC value ...
Embedded LPDDR CRC value: 76a6
Calculated Firmware CRC value: ffff
 ERROR: CRC Mis-matched!!!
```

Figure 7.36. UART Output Switching to Golden GSRD where CRC Mis-matched Intentionally

15. Press **SW2 PROGRAMN** button, and it loads back the Primary GSRD project.

#### 7.3.4.3. Scenario 3: Automatic Booting when Primary FW is without CRC and Golden FW has CRC

- 1. Power-off the board.
- 2. Keep SW7 on JTAG mode.
- 3. Power-on the board.
- 4. Program the MCS file as shown in the Scenario 1: Manual Booting when both Primary and Golden FW are with CRC with MCS File Programming section, Step 2 to 5. If you have already run the Scenario 1 entirely, skip this step. Otherwise, follow steps 2 to 5.
- 5. To program the c\_golden\_appcrc.bin software file into the SPI Flash, Follow the settings as shown in Figure 7.37.





Figure 7.37. Device Properties for Programming Golden App Binary with CRC

6. Click **OK** and the **Program Device** icon or go to **Run > Program Device**. Wait until the operation is successful.



Figure 7.38. Radiant Programmer Console Output After Successful Programming

7. To program the c\_primary\_app.bin software file into the SPI Flash, Follow the settings as shown in Figure 7.39.





Figure 7.39. Device Properties Window for Primary App Binary without CRC

8. Click **OK** and the **Program Device** icon or go to **Run > Program Device**. Wait until the operation is successful.



Figure 7.40. Radiant Programmer Console Output After Successful Programming

- 9. Switch off the board.
- 10. Move SW7 to MSPI Mode.



- 11. Switch on the board.
- 12. Setup UART terminal as mentioned in the Setting up the UART Terminal section.
- 13. Wait about 20 to 30 seconds for the FPGA to load the bitstream from the flash. Press **SW1 Reset** button.
- 14. The results on the UART terminal are displayed as shown in Figure 7.41.
  - It loads the Primary GSRD project first.
  - As soon as the FW CRC for Primary GSRD mismatches, it triggers a soft reset or automatic PROGRAMN.
  - It automatically loads the Golden GSRD bitstream and software.

```
*******************
***
          GSRD Primary Bootloader Avant-E
********
INFO: REG QSPI_FLASH_CMD_CODE_5: 0x6043102
Memory Controller Initialization:
INFO: DDR PLL Locked
INFO: LPDDR4 training complete; LPDDR4 training status = 7f
INFO: LPDDR4 initialized successfully
Memory Controller Initialization Complete.
QSPI Fast Read -- Cycle: 0
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8000f000
OSPI Fast Read -- Cycle: 1
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8001e000
QSPI Fast Read -- Cycle: 2
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8002d000
QSPI Fast Read -- Cycle: 3
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8003c000
QSPI Fast Read -- Cycle: 4
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8004b000
QSPI Fast Read -- Cycle: 5
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8005a000
QSPI Fast Read -- Cycle: 6
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x80069000
Reading and verifying firmware CRC value ...
Embedded LPDDR CRC value: 1bb
Calculated Firmware CRC value: ffff
 ERROR: CRC Mis-matched!!
```

Figure 7.41. Primary GSRD without CRC Fails – UART Terminal



```
***************
***
          GSRD Golden Bootloader Avant-E
INFO: REG_QSPI_FLASH_CMD_CODE_5: 0x6043102
Memory Controller Initialization:
INFO: DDR PLL Locked
INFO: LPDDR4 training complete; LPDDR4 training status = 7f
INFO: LPDDR4 initialized successfully
Memory Controller Initialization Complete.
QSPI Fast Read -- Cycle: 0
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8000f000
QSPI Fast Read -- Cycle: 1
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8001e000
QSPI Fast Read -- Cycle: 2
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8002d000
QSPI Fast Read -- Cycle: 3
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8003c000
QSPI Fast Read -- Cycle: 4
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8004b000
OSPI Fast Read -- Cycle: 5
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8005a000
QSPI Fast Read -- Cycle: 6
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x80069000
Reading and verifying firmware CRC value ...
Embedded LPDDR CRC value: 8c4
Calculated Firmware CRC value: 8c4
CRC matches successfully !!
Jumping to FreeRTOS application ...
```

Figure 7.42. Automatically Jumps to Boot-up Golden GSRD

- 15. Manually press SW2 PROGRAMN button.
- 16. The results on the UART terminal are displayed as shown in Figure 7.43. It jumps back to Primary GSRD where CRC fails again and switches to working the Golden GSRD project and stays there.



```
*********************************
***
          GSRD Primary Bootloader Avant-E
*********
INFO: REG_QSPI_FLASH_CMD_CODE_5: 0x6043102
Memory Controller Initialization:
INFO: DDR PLL Locked
INFO: LPDDR4 training complete; LPDDR4 training status = 7f
INFO: LPDDR4 initialized successfully
Memory Controller Initialization Complete.
QSPI Fast Read -- Cycle: 0
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8000f000
QSPI Fast Read -- Cycle: 1
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8001e000
QSPI Fast Read -- Cycle: 2
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8002d000
QSPI Fast Read -- Cycle: 3
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8003c000
QSPI Fast Read -- Cycle: 4
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8004b000
QSPI Fast Read -- Cycle: 5
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x8005a000
QSPI Fast Read -- Cycle: 6
INFO: Executing Quad I/O SPI Fast Read Command ...
Copying SPI content to LPDDR start addr: 0x80069000
Reading and verifying firmware CRC value ...
Embedded LPDDR CRC value: 1bb
Calculated Firmware CRC value: ffff
 ERROR: CRC Mis-matched!!
```

Figure 7.43. UART Terminal Output - After Pressing SW2 PROGRAMN Button

- 17. Connect the Ethernet cable to see the traffic.
- 18. Re-plug the Ethernet cable in the case of FreeRTOS stop at Ethernet link-up message.



# 8. Compiling the Reference Design

This section describes the process of compiling the GSRD/GHRD Reference Design. You must always start with the Golden GHRD/GSRD project which is a part of the Propel Template. Compilation is required to generate the necessary binary files and bitstreams from the source files. The compilation process involves the following software tools for generating the FPGA bitstream and software executable files.

- Lattice Propel Builder 2024.1 Patch
- Lattice Propel Software Development Kit (SDK) 2024.1
- Lattice Radiant Software 2024.1.1

These sections show the typical design and compilation follow for GSRD design.

- Building Bootloader and FreeRTOS binary files using Lattice Propel SDK
- Validating and generating the GSRD design using Lattice Propel Builder
- Synthesizing the RTL files and generating the bitstream using Lattice Radiant Software
- Generating the Multi-Boot MCS File

# 8.1. Building the Bootloader and FreeRTOS Binary Files Using Lattice Propel SDK

To build the Bootloader and FreeRTOS binary files:

- 1. Create a folder for your project on your PC.
- 2. Launch Propel SDK 2024.1 application.



Figure 8.1. Propel Builder Launcher

3. To select the workspace, browse to the created folder by clicking on the **Browse** button as shown in Figure 8.2 and click on **Launch** to launch the workspace.

**Note:** Name given below is Primary GSRD because you may be using this template to create your own project titles and make modifications on top of Golden SoC/C Templates.



Figure 8.2. Provide Name for Workspace Directory



4. Go to File > New > Lattice SoC Design Project.



Figure 8.3. Creating Lattice SoC Design Project

5. On the SoC Project window, provide name for your SoC project. Choose Processor as RISC-V RX, Family as LAV-AT, Device as LAV-AT-E70ES1, Package as LFG1156, and choose the GHRD SoC Project Avant-AT-E from Template Design as shown in Figure 8.4. Since you can make your own desired modifications to this project, the project name is called as soc\_primary\_gsrd.



Figure 8.4. SoC Project Window



6. Click Finish and it launches the SoC in Propel Builder. This generates the HDL files for IPs instantiated in the project.



Figure 8.5. Launched SoC in Propel Builder

7. Click on **Design > Validate Design**.



Figure 8.6. Validate Design in Propel Builder

3. The TCL Console should be as follows.

```
Reconsole

**sbp_design drc**

INFO <2359136> - Start: sbp_design drc.

INFO <2357031> - Dangling input Port 'BUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect0_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect0_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect0_inst'.

INFO <2357031> - Dangling input Port 'ARUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect0_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect0_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect0_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect0_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect0_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect0_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect1_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect1_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect1_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect1_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect1_inst'.

INFO <2357031> - Dangling input Port 'RUSER' is set to default value '0' on bus 'AXI_MO2' in component 'axi4_interconnect1_inst'.

INFO <23
```

Figure 8.7. TCL Console Output after Validating Design

Click on **Design > Generate.** 





Figure 8.8. Generate in Propel Builder

10. The TCL Console should be as follows. Note that the WARNING and INFO messages are expected.

```
RIConcole

* stp_design generate
LINFO (2255185) - Start: stp_design generate.
LINFO (2255185) - Start: stp_design generate.
LINFO (2255185) - Start: stp_design generate.

* stp_design save

* stp_design pave

* stp_design save

* stp_design pave

* stp_design
```

Figure 8.9. TCL Console Output after Generating Design.

11. Notice that after Generating the Design, it creates the sys\_env.xml file in your Project Directory as shown in Figure 8.10.



Figure 8.10. sys\_env.xml File Created

12. Proceed to the Propel SDK window. Click on File > New > Lattice C/C++ Project.



Figure 8.11. Creating Lattice C/C++ Project for Bootloader

© 2024 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.

FPGA-RD-02296-1.0



13. In C/C++ Project window, it automatically selects the generated sys\_env.xml file. From Select Example Application section, Select the GSRD Avant Bootloader, and provide a name for your bootloader as in Figure 8.12.



Figure 8.12. Bootloader C/C++ Selection

14. Click Next and Finish.





Figure 8.13. C/C++ Lattice Toolchain Setting

15. This loads the Bootloader project in your workspace shown in Figure 8.14.



Figure 8.14. Bootloader C Project Created

16. Similarly, create the FreeRTOS C Project. Go to File > New > Lattice C/C++ Project.





Figure 8.15. Creating C/C++ Project for FreeRTOS

17. From Select Example Application, Select the GSRD Avant FreeRTOS project. Provide the project name as shown in Figure 8.16.



Figure 8.16. FreeRTOS C/C++ Selection

18. Click Next and Finish.

**Note:** This is a manual step you need to perform. After the application project is created, it includes the crc add debug.txt, nocrc add debug.txt, crc add release.txt, nocrc add release.txt as shown in Figure 8.17.





Figure 8.17. FreeRTOS Project Created

19. Copy these four files.





Figure 8.18. Copy the CRC and NoCRC Add files

20. Paste it in your main c\_primary\_app project as shown in Figure 8.19.



Figure 8.19. Paste in FreeRTOS C project

21. It now adds the txt files under the FreeRTOS App C project as shown in Figure 8.20.





Figure 8.20. Copied Text Files

22. In the c\_primary\_bootloader main.c file, edit the new\_addr from GOLDEN\_COPY\_MEMORY\_START\_ADDR to PRIMARY COPY MEMORY START ADDR.

Note: You must update this new addr as per your design requirements. If you are just testing the Golden Template, skip this update.

```
int main(int argc, char **argv) {
    static uint8_t idx = 0;
    static uint8_t pin_state = 0xFF;
    unsigned int seq =0;
    unsigned int new_addr = PRIMARY COPY_MEMORY_START_ADDR
    unsigned int lppdr_addr=LPDDR_APPLICATION_MEMORY_START_ADDR;
    unsigned int crc_calculated = 0;
    unsigned int crc_fw = 0;
    uint32_t app_base = LPDDR_APPLICATION_MEMORY_START_ADDR;
    bsp_init();
```

Figure 8.21. Updated Primary Address

23. For RISC-V to initiate the Soft-Reset for multi-boot, you need to enable this function fw softreset() as follows. This function is already declared in the bootloader main.c file. This function sends a trigger signal to the Multi-Boot Config Module IP which in-turn switches the Primary GSRD to Golden GSRD to showcase Multi-Boot functionality if you programmed the MCS file as per the demo.

```
if(crc_calculated == crc_fw)
       printf("\r\nCRC matches successfully !!\r\n");
      printf("\r\nJumping to FreeRTOS application ...\r\n");
asm volatile ("lui x5, %[appStart]" :: [appStart] "i" (LPDDR_APPLICATION_MEMORY_START_ADDR >> 12));
asm volatile ("addi x5, x5, %[appStart]" :: [appStart] "i" (LPDDR_APPLICATION_MEMORY_START_ADDR & 0xFFF));
asm volatile ("jalr x0, x5, 0");
else
        printf("\r\n ERROR: CRC Mis-matched!!!\n");
```

Figure 8.22. Enable fw\_softreset() Function

24. In the c\_primary\_app folder, update the crc\_add\_debug.txt or crc\_add\_release.txt file as shown in Figure 8.23. Lines 5 and 12 must be replaced with the app project name that you provided; in this case the name is c primary app. Hence, the name of the file is replaced with c primary app.bin. Line 16 must contain the name as c\_primary\_appcrc.bin. This output file has the CRC for application software appended at the end of binary file.

© 2024 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.



```
crc_add_debug.txt × 🔟 nocrc_add_debug.txt
1# srec_cat command file to add the CRC and produce application file to be flashed
2# Usage: srec_cat @filename
4#first: create CRC checksum
5..\Debug\c_primary_app.bin -Binary
                                     # fill code area with 0xff
6-fill 0xFF 0x0000 0x40000
                                     # just keep code area for CRC calculation below
7-crop 0x0000 0x3fffe
8-CRC16_Big_Endian 0x3fffe -CCITT # calculate big endian CCITT CRC16 at given address.
9 -crop 0x3fffe 0x40000
                                     # keep the CRC itself
11 #second: add application file
12..\Debug\c_primary_app.bin -Binary
                                     # fill code area with 0xff
13-fill 0xFF 0x0000 0x3fffe
15# generate a Binary file
16-o ..\Debug\c_primary_appcrc.bin -Binary
```

Figure 8.23. Update crc\_add\_debug.txt

25. Similarly, in the noncrc\_add\_debug.txt or nocrc\_add\_release.txt, update the Lines 5 and 8 with the file name without CRC as shown in Figure 8.24.

Figure 8.24. Update noncrc\_add.txt

26. Open the Linker.ld File from c primary app.



Figure 8.25. Open Linker.Ld File

27. Update the MEMORY org address to 0x80000000 for FreeRTOS to run from LPDDR4.



```
Project Explorer ×
1/* Lattice Generated linker script, for normal executables */
                                            3 ENTRY (_start)
 5_HEAP_SIZE = DEFINED(_HEAP_SIZE) ? _HEAP_SIZE : 0x0;
6_STACK_SIZE = DEFINED(_STACK_SIZE) ? _STACK_SIZE : 0xA00;
      > 🗁 driver
      riscy errors.h
    > 🖹 sys_platform.h
> 🗁 FreeRTOS-Kernel
                                               sysmem0_inst (rwx) : org = 0x80000000, len = 0x20000
    > le board.c
     i board.hii FreeRTOSConfig.h
                                          13 SECTIONS
    main.c
                                              /* CODE */
.text : ALIGN(4)
    s osASM.S
                                             osmacro.h
servector.S
      cpu.svd
     cpu.yaml crc_add.txt
      N linker.ld
      nocrc_add.txt
      sys_env.xml
   c_primary_app.launch
                                               .gprof : ALIGN(4)
   nocrc_add.txt
                                              soc_primary_gsrd
                                               .ctors : ALIGN(4)
                                                 _ctors_start = .;
KEEP (*(.init_array*))
KEEP (*(SORT(.ctors.*)))
KFFP (*(.ctors))
```

Figure 8.26. Update Linker.ld File

28. Press Ctrl + s to save the change as shown in Figure 8.29.



Figure 8.27. Workspace

29. To create the bootloader binary file, right-click on c\_primary\_bootloader and select Build Project.



Figure 8.28. Build Bootloader Project



30. The console output is displayed as shown in Figure 8.31.

```
riscv-none-embed-gcc -march=rv32imac -mabi=ilp32 -msmall-data-limit=8 -mno-save-restore -00 -fmessage-length=0 -fsigned-char -ffunction-sections -fdata-sections -g3 -T "C:/Users/SKothari/Downloads/GSRD2.0_Final/Template_Testing/Avant/c_primary_bootloader/src/linker.ld" -nostartfiles -Xlinker --gc-sections -Wl,-Map,"c_primary_bootloader.map" - specs-picolibc.specs -DPICOLIBC_INTEGER_PRINTE_SCANF -0 "c_primary_bootloader.elf" /src/bsp/driver/vart/vart.o. /src/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/debugo. /src/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/bsp/driver/riscv_tros/trap.o. /src/bsp/driver/riscv_tros/trap.o. /src/bsp/driver/ris
```

Figure 8.29. Bootloader Build Project Console Output

31. This creates a debug folder as shown in Figure 8.30. The binary created is named as c\_primary\_bootloader.mem. This goes as a part of system memory in Propel Builder design.



Figure 8.30. Bootloader Binary Created

32. Now, before creating the Binary for FreeRTOS project, Right-Click on c\_primary\_app project and click on Properties.

FPGA-RD-02296-1.0





Figure 8.31. Properties

33. In case you wish to create a Release folder on your C project build, go to **C/C++ Build > Settings and Under Configuration tab**, select Release. Otherwise, skip to Step 47.



Figure 8.32. Select Release as Configuration

34. Click on Manage Configurations, select the Release, and click on Set Active.



Figure 8.33. Set Release as Active Configuration



35. Go to C/C++ Build > Settings > Build Steps and under Post-Build Steps > Command, add these commands as shown below for your respective builds i.e. for Debug or Release.

```
srec_cat.exe "@..\crc_add_debug.txt" && srec_cat.exe "@..\nocrc_add_debug.txt"
srec_cat.exe "@..\crc_add_release.txt" && srec_cat.exe "@..\nocrc_add_release.txt"
```



Figure 8.34. Adding Post Build Step for FreeRTOS Application CRC Binary Append

- 36. Click Apply and Close.
- 37. Right-click on c\_primary\_app and click on Build Project.



Figure 8.35. Build c\_primary\_app C/C++ Project



38. The console output is displayed as shown in Figure 8.36.

```
Invoking: GNU RISC-V Cross Create Listing
risev-none-embed-objidupp --source --all-headers --demangle --line-numbers --wide "c_primary_app.elf" > "c_primary_app.lst"
finished building: c_primary_app.lst

Invoking: GNU RISC-V Cross Print Size
risev-none-embed-size --format-berkeley "c_primary_app.elf"
text data bss dec hex filename
27512 1A0 27628 55280 d7f0 c_primary_app.elf
Finished building: c_primary_app.siz

Invoking: Lattice Create Memory Deployment
risev-none-embed-objcopy -0 binary --gpa-fill 0 "c_primary_app.elf" "c_primary_app.bin"; srec_cat "c_primary_app.bin" -Binary -byte-swap 4 -DISable Header -Output "c_primary_app.m
Finished building: c_primary_app.mem

srec_cat.exe "@.\crc_add_debug.txt" && srec_cat.exe "@.\nocrc_add_debug.txt"

10:10:01 Build Finished. 0 errors, 7 warnings. (took 44s.80ms)
```

Figure 8.36. FreeRTOS App Build Project Console Output

39. This creates the debug folder and the following files with **c\_primary\_app.bin** and **c\_primary\_appcrc.bin** binaries with CRC and without CRC as shown in Figure 8.37.



Figure 8.37. FreeRTOS App Binaries Created with CRC and without CRC

### 8.2. Validating and Generating the GSRD Design using Propel Builder

To validate and generate the GSRD design, perform the following steps:

 Select the soc project and Launch Propel Builder from Propel SDK as shown in Figure 8.38, if it is not already opened.



Figure 8.38. Open Propel Builder

2. The Primary GHRD SoC opens as shown as shown in Figure 8.39.





Figure 8.39. Propel Builder SoC Project

- 3. Before validating and generating the system, you need to pre-initialize the system memory.
- 4. Select the **System Memory** Instance from the Design View in the left column and it highlights the *sysmemO\_inst* as shown in Figure 8.40.



Figure 8.40. System Memory Highlighted

5. Double-click on the highlighted component shown in the schematic and it opens the Module/IP Block Wizard as shown in Figure 8.41.





Figure 8.41. System Memory IP Configuration

6. Click on **Initialization File's Value** area with three dots to locate the generated **c\_primary\_bootloader.mem**Bootloader file as shown in Figure 8.42.



Figure 8.42. Initialize System Memory with c\_primary\_bootloader.mem

- 7. Select the **c\_primary\_bootloader.mem** file created above.
- 8. Click Generate on the bottom-right corner of the IP Block Wizard as shown in Figure 8.43.





Figure 8.43. Click Generate



Figure 8.44.Bootloader file updated in System Memory

9. Wait until the processing is complete and click **Finish** as shown in Figure 8.45.





Figure 8.45. Click Finish

- 10. Go to **Design > Validate** and **Design and Design > Generate Icon**. Output shown is similar to Figure 8.7 and Figure 8.9 Make sure there are no DRC errors.
- 11. Make sure there are no errors. Note that the *INFO* <235999\*> messages on the TCL console are expected since these modules or IPs do not contain any software IP drivers.

### 8.3. Synthesizing the RTL Files and Generating the Bitstream using Lattice Radiant

To synthesize the RTL files and generate the bitstream, perform the following steps:

1. Click the Radiant icon from Propel Builder to launch the Radiant software as shown in Figure 8.46.



Figure 8.46. Run Radiant Icon

2. The Radiant window of your project is launched as shown in Figure 8.47.





Figure 8.47. Lattice Radiant 2024.1.1 Window

- 3. Click on Close on the pop-up about Updates.
- 4. Locate the following clock constraint.sdc and soc board constraint.pdc files in your Propel Installation area.



Figure 8.48. Constraint Files Folder

5. Right-click on **Pre-Synthesis Constraint Files > Add > Existing File** as shown in **Figure 8.49**.



Figure 8.49. Add Existing Pre-Synthesis Constraint



Select the clock\_constraint.sdc and Ensure that the Copy File to Directory is enabled as shown in Figure 8.50.
 Click Add.



Figure 8.50. Select clock\_constraint.sdc File

7. Similarly, add the soc\_board\_constraints.pdc file to the Post-Synthesis Constraint Files as shown in Figure 8.51. Click **Add**.



Figure 8.51. Select soc\_board\_constraint.pdc File

8. After you add these constraint files, the Radiant file list is updated as shown in Figure 8.52.





Figure 8.52. Pre and Post-Synthesis Constraint Files Added

9. Double-click on Strategy1.



Figure 8.53. Update the Strategy

10. Place and Route Strategy used for GSRD testing.

**Note:** You can update these fields as per their machine and run-time requirements. However, due to this change, the Radiant tool might update the warnings and place & route details.





Figure 8.54. Strategy used for Avant GSRD Testing

11. Click on the Green Run All icon to generate a bit file. Wait for the bitstream generation and check the logs.



Figure 8.55. Generating the Bit File

12. The compilation flow takes some time to complete. The .bit file is generated/updated in the project path (<root\_directory>/soc\_primary\_gsrd/ impl\_1) after compilation is completed successfully as shown in Figure 8.56.



Figure 8.56. Successful Radiant Flow and Bitstream Generation

**Note:** If you observe timing violations during Lattice Radiant compilation, this may be due to the Placement Iteration Point number for Place and Route not working optimally on your machine. In this case, perform the following steps.

- In Lattice Radiant software, go to Project > Active Strategy > Place & Route Design Settings.
- b. Increase Placement Iterations.
- c. Change Placement Save Best Run from 1 to 5.
- d. Click OK.
- e. Click on Export Files.
- 13. This reruns the Place and Route Design with five different incremental start point values. The Place & Route Reports shows all the five placement results and selects the best timing result.

© 2024 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.



#### 8.4. Generating the Multi-Boot MCS File

To generate the multi-boot MCS file, perform the following steps:

Note: Follow these steps only when you have or re-created both Golden and Primary bitstreams.

1. Launch the Lattice Programmer from Lattice Radiant as shown in Figure 8.57.



Figure 8.57. Launch Radiant Programmer from Windows Start

2. Provide the location of where you would like to store the programmer .xcf file. Click OK.



Figure 8.58. Radiant Programmer Getting Started Window

Note: This throws the error message shown in Figure 8.59 since there is no HW board connected.



Figure 8.59. Error if No HW Board is Connected

3. Click Tools > Deployment Tool.



Figure 8.60. Open Deployment Tool from Radiant Programmer

4. This opens the Deployment Tool window as shown in Figure 8.61.



Figure 8.61. Deployment Tool Start Window

5. Apply the settings as shown in Figure 8.62 and click OK.



Figure 8.62. Options for Creating New Deployment

- 6. Step 1 of 4: Select the Input File(s) window, as shown in Figure 8.63:
  - a. Click the File Name field to browse and select the primary gsrd's .bit from your primary soc project.
  - b. The Device Family and Device fields auto populates based on the bitstream .bit file selected.
  - c. Click Next.





Figure 8.63. External Memory Step 1 of 4: Select Input Files

- 7. In Step 2 of 4: Select the fields as shown in Figure 8.64.
  - a. Under Options tab: Choose Output Format as Intel Hex and SPI Flash Size(Mb) as 512.



Figure 8.64. External Memory Step 2 of 4: Select Options

- b. No changes needed in User Data Files field.
- c. Under Multiple Boot tab.
  - i. Select the Multiple Boot Option.
  - ii. Select Number of Alternate Patterns as 1.
  - iii. Under the Golden Pattern, browse and select the **Golden pattern bitstream** file. The Starting Address of Golden Pattern is automatically assigned. You can change it by clicking on the drop-down menu.



- iv. Under Alternate Pattern 1 field, click on the browse button and select the **golden soc gsrd's bitstream**. The Starting Address of this pattern is automatically assigned. You can change it by clicking on the drop-down menu. This is the pattern loaded during an event of next PROGRAMN/REFRESH or soft reset.
- v. Click Next.



Figure 8.65. External Memory Step 2 of 4: Multi-Boot

8. In Step 3 of 4: Select the Output File(s) as shown in Figure 8.66. Choose the location on your machine to generate an .mcs file.



Figure 8.66. External Memory Step 3 of 4: Select Output File(s)



- 9. Click Next.
- 10. In Step 4 of 4: Generate Deployment, click **Generate** at the bottom right corner as shown in Figure 8.67.



Figure 8.67. External Memory Step 4 of 4: General Development

11. Check for the following output as shown in Figure 8.68.

Lattice Radiant Deployment Tool has exited successfully.

Figure 8.68. MCS File Generated Successfully

- 12. The generated final .mcs file is now ready to be programmed into the external flash using the Radiant Programmer.
- 13. Close the Deployment Tool window.



# 9. Customizing the IP in the GSRD Design

This section describes the customization that can be applied to IP in the reference design. The hardware related modifications are made using Propel Builder, since it is the main design entry tool. The software related modifications are made using Propel SDK.

The following demonstrates this using an example of QSPI Flash Controller IP.

#### 9.1. Changing QSPI Flash Controller User Interface Parameters

The QSPI Flash Controller IP parameters are set according to the SPI Flash chips available on Avant-AT-E Board. You can change the IP parameters to suit the board and Flash chip in your project.

To modify the IP parameters:

1. In Propel Builder, double-click on the **qspi0\_inst** block.



Figure 9.1. IP Block

- 2. In the Module/IP Block Wizard, make the desired changes to the parameters that suits your board and Flash chip. For example, you'd like to change any or all.
  - Data Endianness from Big Endian to Little Endian and
  - System Clock Frequency from 100 to 200



Figure 9.2. Customize IP

3. Click Generate to make sure RTL is updated as per the customization and must generate without an error.



4. You can see the message in the TCL Console as shown in Figure 9.3. Ensure that are no errors.

% sbp\_config\_ip -vinv (latticesemi.com:ip:qspi0:1.2.0) -meta\_vinv (latticesemi.com:ip:qspi\_flash\_controller:1.2.0) -cfg\_value (SFI\_CLOCK\_PHASE:1,SFI\_CLOCK\_POLARITY:1,SYSTEM\_CLOCK\_FREQUENCY: 200,data\_endianness:fittle-endian,enable\_io\_primitive:true,interface:AXT4,supported\_protocol:00aid % sbp\_ceplace-vinv (latticesemi.com;ip:qspi0:1.2.0) -name (qspi0\_inst) -component (soc\_optionst)

Figure 9.3. TCL Console Output After Desired Customization

5. Click the **Validate** button as shown in Figure 9.4. Ensure that there are no errors.



Figure 9.4. Validate Design again is any IP is updated

6. Click the **Generate** button as shown in Figure 9.5. Ensure that there are no errors.



Figure 9.5. Generate again is any IP is updated

7. Once validated and generated, it updates the **sys\_env.xml** file in the **sge** folder under your project directory as shown in Figure 9.6.



Figure 9.6. New sys\_env.xml File Generated

- 8. If your IP is software driver dependent, the C projects must also be updated.
- 9. In your project under Propel SDK window, go to Project > Update Lattice C/C++ Project.



Figure 9.7. Update Lattice C/C++ Project



10. It opens the dialog box as shown in Figure 9.8.



Figure 9.8. Update System Dialog Window

11. Click **Browse** and select the **sys\_env.xml** file generated above.



Figure 9.9. New IP version Details

12. Select *Re-generate toolchain parameters and linker script* and *Update BSP Package* and click **Update** to reflect the latest configurations.





Figure 9.10. Generate BSP and Toolchain Parameters

13. Click Yes as shown in Figure 9.11 and the update window closes.



Figure 9.11. Confirm the Changes

- 14. Confirm that the BSP package was updated successfully. You can check it by reviewing the following:
  - sys\_platform.h file to review the updated parameter change.

```
#define QSPI0_INST_SYSTEM_CLOCK_FREQUENCY 200
#define QSPI0_INST_DATA_ENDIANNESS Little-endian
```

Figure 9.12. Confirm the Configuration Changes in sys\_platform.h

- 15. Clean and Build the Project.
- 16. If you hit any errors, it could be one of the following reasons:
  - Driver files has been updated.
  - Addresses in your C project might have changed.
- 17. Do the same XML updates for **c\_golden\_app** FreeRTOS project too.
- 18. Clean and Re-Build the Project.
- 19. Once new .mem file and binaries are created, follow the steps in the Validating and Generating the GSRD Design using Propel Builder section. Validate and generate the GSRD design using the Propel Builder.

© 2024 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.



## References

- RISC-V RX CPU IP Core (FPGA-IPUG-02254)
- System Memory IP (FPGA-IPUG-02073)
- Tri-Speed Ethernet MAC IP Core (FPGA-IPUG-02084)
- LPDDR4 Memory Controller for Avant Devices (FPGA-IPUG-02208)
- QSPI Flash Controller IP Core (FPGA-IPUG-02248)
- AXI Multi Port Bridge for Memory Controller Module (FPGA-IPUG-02246)
- SGDMA Controller IP Core (FPGA-IPUG-02131)
- UART IP Core (FPGA-IPUG-02105)
- GPIO IP Core (FPGA-IPUG-02076)
- AXI4 Interconnect IP (FPGA-IPUG-02196)
- AXI to APB Bridge IP (FPGA-IPUG-02198)
- Lattice Radiant Timing Constraints Methodology (FPGA-AN-02059)
- Lattice Radiant FPGA design software
- Lattice Solutions IP Cores web page
- Lattice Propel Design Environment web page
- Lattice Radiant Software User Guide
- Lattice Insights for Lattice Semiconductor training courses and learning plans



# **Technical Support Assistance**

www.latticesemi.com/Support/AnswerDatabase.

Submit a technical support case through www.latticesemi.com/techsupport.
For frequently asked questions, please refer to the Lattice Answer Database at



# **Revision History**

#### Revision 1.0, October 2024

| Section | Change Summary               |
|---------|------------------------------|
| All     | Initial preliminary release. |



www.latticesemi.com