# AC471 Application Note PolarFire FPGA Auto Update and In-Application Programming Using Splash Kit





а 🔨 Міскоснір company

Microsemi Headquarters

One Enterprise, Aliso Viejo, CA 92656 USA Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996 Email: sales.support@microsemi.com www.microsemi.com

©2018 Microsemi, a wholly owned subsidiary of Microchip Technology Inc. All rights reserved. Microsemi and the Microsemi logo are registered trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners. Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this

#### **About Microsemi**

Microsemi, a wholly owned subsidiary of Microchip Technology Inc. (Nasdaq: MCHP), offers a comprehensive portfolio of semiconductor and system solutions for aerospace & defense, communications, data center and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; enterprise storage and communication solutions, security technologies and scalable anti-tamper products; Ethernet solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Learn more at www.microsemi.com.

# а от Містозеті.

# Contents

| 1 | Revision History                                                                                                                                                                                                                                                           | 1                                            |
|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
| 2 | PolarFire FPGA Auto Update and In-Application Programming using Splash Kit                                                                                                                                                                                                 | 3<br>5<br>6<br>8<br>9                        |
| 3 | iberoDesign Flow21.1Synthesize.2.2Place and Route.2.3.2.1Resource Utilization.2.3Verify Timing.2.4Generate FPGA Array Data.2.5Configure Design Initialization Data and Memories.2.6Configure Programming Options.2.7Generate Bitstream.2.8Run PROGRAM Action.2             | 23<br>23<br>23<br>23<br>23<br>24<br>26<br>27 |
| 4 | Programming the Device Using FlashPro Software                                                                                                                                                                                                                             | 9                                            |
| 5 | Serial Terminal Emulation Program Setup                                                                                                                                                                                                                                    | 0                                            |
| 6 | Running the Demo       31         Programming the SPI Flash Using Fabric Logic       3         .2       Running Auto Update       3         .3       Running Authentication       3         .4       Running Auto Programming       3         .5       Running IAP       3 | 2<br>4<br>4<br>5                             |
| 7 | ppendix: Programming On-board SPI Flash Using Libero                                                                                                                                                                                                                       | 7                                            |
| 8 | oppendix: References                                                                                                                                                                                                                                                       | 8                                            |



# **Figures**

| Figure 1  | Core System Services IP Interfacing with Fabric User Logic | . 3 |
|-----------|------------------------------------------------------------|-----|
| Figure 2  | Firmware catalog                                           | . 4 |
| Figure 3  | PolarFire Programming Design Block Diagram                 |     |
| Figure 4  | Accessing On-board SPI Flash Using Fabric                  | . 7 |
| Figure 5  | SPI Flash Memory                                           | . 7 |
| Figure 6  | Top Level Libero Design                                    | . 8 |
| Figure 7  | PF_INIT_MONITOR Configuration                              | . 9 |
| Figure 8  | PF_CCC_0 Input Clock Configuration                         |     |
| Figure 9  | PF_CCC_0 Output Clock Configuration                        | 10  |
| Figure 10 | Mi-V Configuration                                         | 11  |
| Figure 11 | UART Configuration                                         | 12  |
| Figure 12 | PF_SRAM_AHBL_AXI Configuration                             | 13  |
| Figure 13 | CoreGPIO_0 Configuration                                   | 14  |
| Figure 14 | CoreSPI Configuration                                      | 15  |
| Figure 15 | CoreSysService_PF Configuration                            | 16  |
| Figure 16 | Memory Map                                                 | 17  |
| Figure 17 | CoreAHBLite_0 Configuration                                | 18  |
| Figure 18 | CoreAHBLite_1 Configuration                                | 19  |
| Figure 19 | CoreAPB3_0 Configuration                                   | 20  |
| Figure 20 | Clocking Structure                                         | 21  |
| Figure 21 | Libero Design Flow Options                                 | 22  |
| Figure 22 | Design and Memory Initialization                           | 24  |
| Figure 23 | Fabric RAMs Tab                                            | 25  |
| Figure 24 | Edit Fabric RAM Initialization Client                      | 25  |
| Figure 25 | Apply Fabric RAM Content                                   | 26  |
| Figure 26 | Configure Programming Options                              |     |
| Figure 27 | Generate Bitstream—Configure Bitstream Options             | 27  |
| Figure 28 | Board Setup                                                | 28  |
| Figure 29 | COM Port Number                                            | 30  |
| Figure 30 | Select Serial as the Connection Type                       | 30  |
| Figure 31 | PuTTY Configuration                                        |     |
| Figure 32 | Authentication and Programming Options                     | 32  |
| Figure 33 | Authentication Error                                       | 32  |
| Figure 34 | Erasing SPI Flash                                          | 33  |
| Figure 35 | Command Prompt Status                                      | 34  |
| Figure 36 | Auto Update                                                |     |
| Figure 37 | Successful Bitstream Authentication                        |     |
| Figure 38 | Successful IAP Image Authentication                        |     |
| Figure 39 | Notifying ERASE Action                                     | 35  |
| Figure 40 | Successful Auto Programming                                | 35  |
| Figure 41 | Successful IAP at Index 2                                  |     |
| Figure 42 | Successful IAP by Address                                  |     |
| Figure 43 | Configure Design Initialization Data and Memories Option   |     |
| Figure 44 | SPI Flash Tab                                              |     |
| Figure 45 | SPI Flash Programming                                      | 37  |



# **Tables**

| Table 1 | System Services Descriptor                       |
|---------|--------------------------------------------------|
| Table 2 | Design Requirements                              |
| Table 3 | I/O Signals                                      |
| Table 4 | Resource Utilization                             |
| Table 5 | Jumper Settings for PolarFire Device Programming |
| Table 6 | Jumper Settings for PolarFire Device Programming |
| Table 7 | Programming Images                               |



# 1 Revision History

The revision history describes the changes that were implemented in the document. The changes are listed by revision, starting with the current publication.

# 1.1 Revision 2.0

The document was updated for Libero SoC PolarFire v2.2 release.

# 1.2 Revision 1.0

The first publication of this document.



# 2 PolarFire FPGA Auto Update and In-Application Programming using Splash Kit

PolarFire<sup>®</sup> FPGAs support the SPI master programming mode for auto update and in-application programming (IAP). In this programming mode, the programming images are stored in an external SPI flash memory.

Auto update—on power-up, if the version of the update image is found to be different from the current programmed version, the System Controller reads the update image bitstream from the external SPI flash memory and programs the device.

IAP—the user application initiates the program action and the System Controller reads the bitstream from the external SPI flash memory to program the device.

The System Controller supports fetching programming images from SPI Flash device based on the Index value or direct addressing. The SPI directory contains the start addresses of the programming images.

The following components of PolarFire devices are programmable:

- FPGA fabric
- Secure non-volatile memory (sNVM)
- User security settings (keys, passcodes, and locks)

This document explains how to use the accompanying design to demonstrate the auto update and IAP features on the PolarFire Splash kit.

The on-board 1 GB Micron SPI flash device is connected to System Controller SPI and can be programmed using the fabric logic or Libero<sup>®</sup> SoC PolarFire software. For more information about programming the on-board SPI flash using Libero, see Appendix: Programming On-board SPI Flash Using Libero, page 37.

This application note includes the Mi-V soft processor, which initiates the system service requests for the device programming and enables the CoreSysService\_PF IP core to access the System Controller. For more information about the design implementation, and the necessary blocks and IP cores instantiated in Libero SoC PolarFire, see Demo Design, page 6.

This design can be programmed using any of the following options:

- Using the pre-generated.stp file: To program the device using the.stp file provided along with the design, see Programming the Device Using FlashPro Software, page 29.
- Using Libero SoC PolarFire: To program the device using Libero SoC PolarFire, see Libero Design Flow, page 22.

This design can be used as a reference to build a fabric design with programming features.



# 2.1 CoreSysService\_PF IP Overview

System Controller actions are initiated by the fabric logic through the system service interface (SSI) of the System Controller. The fabric logic requires the CoreSysService\_PF IP for initiating the system services. A service request interrupt to the System Controller is triggered when the fabric user logic writes a 16-bit system service descriptor to the SSI. The lower seven bits of the descriptor specify the service to be performed. The upper nine bits specify the address offset (0–511) in the 2 KB mailbox RAM. The mailbox address specifies the service-specific data structure used for any additional inputs or outputs for the service. The fabric logic must write additional parameters to the mailbox before requesting a system service. The following table lists the system service descriptor bits.

#### Table 1 • System Services Descriptor

| Descriptor Bit | Value     |
|----------------|-----------|
| 15:7           | MBOXADDR  |
| 6:0            | SERVICEID |

SSI consists of an asynchronous command-response interface that transfers a system service command from the fabric master to the System Controller and the status from the System Controller to the fabric master. The following figure shows how the CoreSysService\_PF IP Interfaces with the fabric logic.

#### *Figure 1* • Core System Services IP Interfacing with Fabric User Logic



The system services driver and the sample SoftConsole project are generated from Firmware Catalog as shown Figure 2, page 4.



In this design, the sample SoftConsole project is migrated to SoftConsole v5.2. The Mi-V soft processor is compatible with only SoftConsole v5.2 or later. The application files <code>main.c</code> and <code>hw\_platform.h</code> are modified to provide the programming user options, system clock frequency, and APB peripheral addresses.

#### Figure 2 • Firmware catalog

| 🞯 Firmware Catalog                     |                                       | _                                       |              |
|----------------------------------------|---------------------------------------|-----------------------------------------|--------------|
| File View Tools Help                   |                                       |                                         |              |
| View ( <u>52/160</u> ):                | Veb repositories                      | <u>Search</u> by all fields ( <u>52</u> |              |
| ✓ display only the latest version of a |                                       |                                         |              |
|                                        |                                       |                                         |              |
| Name                                   |                                       | 🛆 Version                               |              |
| Core10100_AHBAPB Driver                |                                       | 4.0.102                                 |              |
| Core16550 Driver                       |                                       | 2.3.100                                 |              |
| CoreAl Driver                          |                                       | 3.0.101                                 |              |
| CoreAhbNvm Driver                      |                                       | 2.1.102                                 |              |
| CoreDDRTip_PF Driver                   |                                       | 1.0.100                                 |              |
| CoreGPIO Driver                        |                                       | 3.2.101                                 |              |
| Corel2C Driver                         |                                       | 3.2.101                                 |              |
| CoreInterrupt Driver                   |                                       | 2.1.102                                 |              |
| CoreLPC Driver                         |                                       | 2.1.101                                 |              |
| CoreMACFilter Driver                   |                                       | 2.1.100                                 |              |
| CoreMMC Driver                         |                                       | 2.0.100                                 |              |
| CorePWM Driver                         |                                       | 2.3.101                                 |              |
| CoreSDLC Driver                        |                                       | 2.1.100                                 |              |
| CoreSPI Driver                         |                                       | 3.2.101                                 |              |
| CoreSysServices_PF Driver              | 1981 6                                | 2.0.102                                 |              |
| CoreTSE Driver                         | 🔛 Generate                            | 2.3.100                                 |              |
| CoreTimer Driver                       | X Remove from vault                   | 2.3.101                                 |              |
| CoreUARTapb Driver                     |                                       | 3.2.101                                 |              |
| CoreWatchdog Driver                    | Show details                          | 2.2.100                                 |              |
| Hardware Abstraction Layer (HAI        | <b>V</b>                              | 2.3.102                                 |              |
| PolarFire PCle Driver                  | Open documentation                    | 1.0.100 (*)                             |              |
| PolarFire Serdes Driver                | Generate sample project 🔸             | RISC-V SoftConsole v5.1                 | PolarFire Sy |
| PolarFire User Crypto Driver           |                                       | SoftConsole VS.1                        | PolarFire Sy |
| Documentation:                         |                                       |                                         |              |
| CoreSysServices PF Driver UG.pdf       |                                       |                                         | _            |
| CoreSysServices PF Driver RN.pdf       |                                       |                                         |              |
|                                        |                                       |                                         |              |
| Description: Bare metal software d     | river for CoreSysServices_PF Soft IP. |                                         |              |
| Supports all the services supported b  | W CoreSysServices DE Soft ID          |                                         |              |
| Device and design information service  |                                       |                                         |              |
| Design services                        |                                       |                                         | <b>•</b>     |
|                                        |                                       |                                         |              |
| New cores are available for do         | wnload Download them now!             |                                         | 🔛 Generate   |
|                                        |                                       |                                         |              |
|                                        |                                       |                                         |              |
|                                        |                                       |                                         | //           |



# 2.2 Design Requirements

The following table lists the resources required to run the design.

| Requirement                                                                                                                                                                                                                 | Version                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| Operating System                                                                                                                                                                                                            | Windows 7, 8.1, or 10                   |
| Hardware                                                                                                                                                                                                                    |                                         |
| PolarFire Splash Kit (MPF300TS-1FCG484EES)<br>– PolarFire Splash board<br>– 12 V, 5 A AC power adapter and cord<br>– USB 2.0 A to mini-B cable for universal<br>asynchronous receiver-transmitter (UART) and<br>programming | Rev 2 or later                          |
| Host PC                                                                                                                                                                                                                     |                                         |
| Software                                                                                                                                                                                                                    |                                         |
| FlashPro                                                                                                                                                                                                                    | 12.200.30.10                            |
| Libero SoC PolarFire Design Suite                                                                                                                                                                                           | 2.2                                     |
| Serial Terminal Emulation Program                                                                                                                                                                                           | PuTTY or HyperTerminal<br>www.putty.org |
| IP                                                                                                                                                                                                                          |                                         |
| PF_INIT_MONITOR                                                                                                                                                                                                             | 2.0.103                                 |
| PF_CCC                                                                                                                                                                                                                      | 1.0.113                                 |
| CoreJTAGDEBUG                                                                                                                                                                                                               | 2.0.100                                 |
| CORESET_PF                                                                                                                                                                                                                  | 2.1.100                                 |
| Mi-V soft processor (MIV_RV32IMA_L1_AHB)                                                                                                                                                                                    | 2.0.100                                 |
| COREAHBLite                                                                                                                                                                                                                 | 5.3.101                                 |
| COREAHBTOAPB3                                                                                                                                                                                                               | 3.1.100                                 |
| CoreAPB3                                                                                                                                                                                                                    | 4.1.100                                 |
| CoreUARTapb                                                                                                                                                                                                                 | 5.6.102                                 |
| CoreGPIO                                                                                                                                                                                                                    | 3.2.102                                 |
| CoreSysService_PF                                                                                                                                                                                                           | 2.3.116                                 |
| CORESPI                                                                                                                                                                                                                     | 5.1.104                                 |
| PF_SRAM_AHBL_AXI                                                                                                                                                                                                            | 1.1.125                                 |
| PF SPI macro                                                                                                                                                                                                                |                                         |
|                                                                                                                                                                                                                             |                                         |

#### Table 2 • Design Requirements

Note: Any serial terminal emulation program can be used. PuTTY is used in this application note.



# 2.3 **Prerequisites**

#### Before you start:

- Download the design files from the following location: http://soc.microsemi.com/download/rsc/?f=mpf\_ac471\_liberosocpolarfirev2p2\_df
- Download and install Libero SoC PolarFire v2.2 on the host PC from the following location. https://www.microsemi.com/products/fpga-soc/design-resources/design-software/libero-socpolarfire#downloads
   The latest versions of ModelSim and Synplify Pro are included in the Libero SoC PolarFire installation package.

# 2.4 Demo Design

The following steps describe the data flow in the design:

- 1. The host PC sends the system service requests to CoreUARTapb block through the UART Interface.
- 2. The Mi-V soft processor initializes the System Controller using the CoreSysService\_PF IP and sends the requested system service command to the System Controller.
- The System Controller executes the system service command by reading the bitstream images from the external SPI flash and sends the relevant response to the CoreSysService\_PF IP over the mailbox interface.
- 4. The Mi-V processor receives the service response and forwards the data to the UART interface.

The following figure shows the block diagram of the PolarFire programming design.

#### Figure 3 • PolarFire Programming Design Block Diagram





To initiate auto update or IAP system service request, the on-board SPI flash must be programmed with programming images. The fabric logic interfaces to the on-board SPI flash using SPI controller and PF\_SPI macro. When the System Controller's SPI is enabled and configured as master, the System Controller hands over the control of the SPI to the fabric on device power-up. The fabric logic programs the on-board SPI flash with flash directory and programming images using UART interface. The programming images are transfered from the host PC using SPI flash loader (spi\_loader.exe).

The on-board SPI flash can be programmed using fabric logic as shown in the following figure.

#### Figure 4 • Accessing On-board SPI Flash Using Fabric



---- Loading programming files into SPI Flash memory from host PC

The following figure shows the SPI flash memory with directory and programming images.

#### Figure 5 • SPI Flash Memory





When System Controller receives programming or authentication system service from fabric user logic, the System Controller fetches the programming images from the on-board SPI flash to execute the service request. In this application note, the following system services are initiated on user request.

- Bitstream authentication
- IAP image authentication
- Auto update
- IAP

For more information about the preceding services, see the UG0714: PolarFire FPGA Programming User Guide.

### 2.4.1 Design Implementation

The following figure shows the top-level Libero design of the PolarFire system services design.





The following table lists the important I/O signals of the design.

#### Table 3 • I/O Signals

| Signal        | Description                                            |
|---------------|--------------------------------------------------------|
| REF_CLK_0     | Input 50 MHz clock from the on-board 50 MHz oscillator |
| resetn        | On-board reset push-button for the PolarFire device    |
| RX            | Input signals received from the serial UART terminal   |
| ТХ            | Output signals transmitted to the serial UART terminal |
| GPIO_OUT[3:0] | On-board LED outputs                                   |
| GPIO_IN[3:0]  | To interface on-board DIP switches.                    |



### 2.4.2 IP Configuration

The following sections describe the IP cores used in the design and their configurations. The other IP cores retain the default configuration.

#### 2.4.2.1 **PF\_INIT\_MONITOR**

The PolarFire Initialization Monitor gets the status of device initialization including the LSRAM initialization. The following figure shows PF\_INIT\_MONITOR configuration.

Figure 7 • PF\_INIT\_MONITOR Configuration

| Configurator                                  | - 0                                |
|-----------------------------------------------|------------------------------------|
| PolarFire Initialization Monitor Configurator |                                    |
| crosemi:SgCore:PF_INIT_MONITOR:2.0.103        |                                    |
| Bank Monitor Simulation Options               | <u> </u>                           |
| Simulation Options                            |                                    |
| FABRIC_POR_N assertion delay (ns)             | DE INIT MONITOR O                  |
|                                               | PF_INIT_MONITOR_0                  |
| PCIE_INIT_DONE assertion delay (ns) 4         | FABRIC_POR_N                       |
| USRAM_INIT_DONE assertion delay (ns) 5        | PCIE_INIT_DONE-                    |
| SRAM_INIT_DONE assertion delay (ns) 6         | USRAM_INIT_DONE                    |
|                                               | SRAM_INIT_DONE<br>DEVICE_INIT_DONE |
| DEVICE_INIT_DONE assertion delay (ns) 7       | XCVR_INIT_DONE                     |
| Calibration monitor                           | USRAM_INIT_FROM_SNVM_DONE          |
| BANK 0_CALIB_STATUS assertion delay (ns)      | USRAM_INIT_FROM_UPROM_DONE         |
|                                               | USRAM_INIT_FROM_SPI_DONE           |
| BANK_1_CALIB_STATUS assertion delay (ns) 1    | SRAM_INIT_FROM_SNVM_DONE           |
| BANK_2_CALIB_STATUS assertion delay (ns)      | SRAM_INIT_FROM_UPROM_DONE          |
|                                               | SRAM_INIT_FROM_SPI_DONE            |
| BANK_4_CALIB_STATUS assertion delay (ns) 1    | AUTOCALIB_DONE                     |
| BANK_5_CALIB_STATUS assertion delay (ns) 1    | PF_INIT_MONITOR                    |
| BANK_6_CALIB_STATUS assertion delay (ns) 1    |                                    |
| BANK_7_CALIB_STATUS assertion delay (ns)      |                                    |
|                                               | ▼ Symbol                           |
| Help 🔻                                        | OK Cancel                          |

### 2.4.2.2 Instantiating CLKINT

From the Catalog, drag the CLKINT macro to SmartDesign. This macro is required as a 50 MHz clock oscillator with an accuracy of +/-50 ppm is available on the board. This clock oscillator is connected to the FPGA fabric to provide a system reference clock. The pin number of the 50 MHz oscillator is H7, and the pin name is GPIO239PB5/CLKIN\_W\_2/CCC\_SW\_CLKIN\_W\_2/CCC\_SW\_PLL0\_OUT0. When the pin is not hardwired to the PLL reference clock input, use CLKINT macro to promote it to global clock network.



### 2.4.2.3 **PF\_CCC\_0** Configuration

The PolarFire Clock Conditioning Circuitry (CCC) block takes an input clock of 50 MHz from the on-board oscillator passed through CLKINT and generates a 100 MHz fabric clock to the Mi-V processor subsystem and other peripherals. The following figures show the input and output clock configurations.

| Figure 8 • | PF_CCC_0 Input Clock Configuration |
|------------|------------------------------------|
|            | Configurator                       |

| Configurator                                                             | - 🗆 ×                  |
|--------------------------------------------------------------------------|------------------------|
| Clock Conditioning Circuitry (CCC)                                       |                        |
| Microsemi:5gCore:PF_CCC:1.0.113                                          |                        |
| <b>_</b>                                                                 |                        |
| Configuration PLL-Single                                                 |                        |
| Clock Options PLL Output Clocks                                          |                        |
| Input Frequency                                                          |                        |
| Input Frequency 50 MHz 🗌 Badkup Clock                                    |                        |
| Bandwidth High 💌                                                         |                        |
| Delay Lines                                                              |                        |
| Enable Delay Line                                                        |                        |
| C Feedback Clock Delay Delay Steps: 1                                    |                        |
| 6 Backup Clock Delay                                                     | PF_CCC_0               |
|                                                                          | OUTO_FABCLK_0          |
| Power / Jitter                                                           | -REF_CLK_0 PLL_LOCK_0- |
| Minimize ätter                                                           | PF_CCC                 |
| C Minimize VCO*                                                          | PF_CCC                 |
| C Minimize Power                                                         |                        |
| Feedback Mode                                                            |                        |
| Post-VCO 💌                                                               |                        |
| E Features                                                               |                        |
| Integer Mode                                                             |                        |
| SSCG Modulation                                                          |                        |
| Enable Dynamic Reconfiguration Interface (DRI)                           |                        |
| Export PowerDown Port     Wait For PLL Lock Before Exiting Flash *Freeze |                        |
| Wait Für FLL Lück bei vie Exiang Hash Freeze                             |                        |
|                                                                          | Symbol                 |
| Log                                                                      |                        |
| 🗐 Messages 😣 Errors 🗼 Warnings 🌐 Info                                    |                        |
|                                                                          |                        |
|                                                                          |                        |
| Help -                                                                   | OK Cancel              |

Figure 9 • PF\_CCC\_0 Output Clock Configuration

| Configurator                                                                         | - 🗆 X                     |
|--------------------------------------------------------------------------------------|---------------------------|
| Clock Conditioning Circuitry (CCC)                                                   |                           |
| Microsemi:SgCore:PF_CCC:1.0.113                                                      |                           |
| Configuration PLL-Single                                                             |                           |
|                                                                                      | -                         |
| Clock Options PLL Output Clocks                                                      |                           |
| For best results, put the highest frequency first.                                   |                           |
| Output Clock 0                                                                       | PF_CCC_0                  |
| ✓ Enabled                                                                            | -REF_CLK_0 OUT0_FABCLK_0- |
|                                                                                      | PF CCC                    |
| Requested Frequency 100 MHz C Actual Lower 100 MHz C Actual Higher 100 MHz           | 11_000                    |
| Requested Phase 0 Degrees C Actual Lower 0 Degrees C Actual Higher 0 Degrees         |                           |
| Dynamic Phase Shifting     Expose Enable Port     Enable Bypass     REF_PREDIV     Y |                           |
| Fabric Clock Fabric Clock (Gated)                                                    |                           |
|                                                                                      | Symbol                    |
| log                                                                                  |                           |
| 🔳 Messages 😵 Errors 🗼 Warnings 🎁 Info                                                |                           |
|                                                                                      |                           |
|                                                                                      |                           |
|                                                                                      |                           |
| Help •                                                                               | OK Cancel                 |



### 2.4.2.4 Mi-V Soft Processor Configuration

The Mi-V soft processor Reset Vector Address is set to 0x8000\_0000 from default value 0x6000\_0000. After device reset, the processor executes the application from LSRAM, which is mapped to 0x80000000, Hence, the Reset Vector Address is set to 0x80000000 as shown in the following figure.

In the Mi-V processor memory map, the 0x8000\_0000 to 0x8FFF\_FFFC range is defined for AHB memory interface and the 0x6000\_0000 to 0x7FFF\_FFFF range is defined for AHB I/O interface.

#### Figure 10 • Mi-V Configuration

| Configurator                             |          | -   |      | ×  |
|------------------------------------------|----------|-----|------|----|
| Mi-V RV32IMA_L1_AHB C                    | onfigura | tor |      |    |
| Microsemi:MiV:MIV_RV32IMA_L1_AHB:2.0.100 |          |     |      |    |
| Configuration                            |          |     |      |    |
| Reset Vector Address: 0x8000             | 0x0      |     | 0    |    |
|                                          |          |     |      |    |
|                                          |          |     |      |    |
|                                          |          |     |      |    |
|                                          |          |     |      |    |
|                                          |          |     |      |    |
|                                          | 0        |     | Cano | -1 |
| Help 🔹                                   | 0        |     | Cano | ei |



### 2.4.2.5 CoreUARTapb

The CoreUARTapb IP is connected to Mi-V soft processor as an APB slave. It interfaces with the host PC for UART communication. The default configuration settings of the CoreUARTapb IP are shown in the following figure:

- TX FIFO: Disabled by default.
  - The UART transmit state machine immediately begins to transmit data and continues transmission until the data buffer is empty in normal mode. If **TX FIFO** is enabled, it continues to transmit until **TX FIFO** is empty. In this design, normal mode (without FIFO) is selected.
- RX FIFO: Disabled by default.
- The UART receive state machine stores the data in receive data buffer if FIFO is not enabled.
- Configuration: Set to Programmable by default.

#### Figure 11 • UART Configuration

| CoreUARTapb Configurator         DiscosemicDirectCore:CoreUARTapb:5.6.102         Configuration         TX FIFO:       Disable TX FIFO ▼         RX FIFO:       Disable TX FIFO ▼         Configuration:       Programmable ▼         Baud Value:       1         Character Size:       7 bits ▼         Parity:       Parity Disabled ▼         RX Legacy Mode:       Disabled ▼         FIFO Implementation:       In RAM ▼         Baud Value Precision       ■         Enable Extra Precision:       ■         Fractional Part of Baud Value:       +0.0 ▼         Testbench:       User ▼         License:       C Obfuscated       © RTL | Configurator           |                     | -  |     | ×   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|---------------------|----|-----|-----|
| Configuration TX FIFO: Disable TX FIFO  RX FIFO: Disable RX FIFO  Configuration: Programmable  Baud Value: 1 Character Size: 7 bits  Parity: Parity Disabled  Parity: Parity Disabled  RX Legacy Mode: Disabled  FIFO Implementation: In RAM  Baud Value Precision Enable Extra Precision:  Fractional Part of Baud Value: +0.0  Testbench: User  License: C Obfuscated C RTL                                                                                                                                                                                                                                                                  | CoreUARTap             | b Configurator      |    |     |     |
| Core Configuration TX FIFO: Disable TX FIFO  RX FIFO: Disable RX FIFO  Configuration: Programmable Baud Value: 1 Character Size: 7 bits Parity: Parity Disabled RX Legacy Mode: Disabled RX Legacy Mode: Disabled FIFO Implementation: In RAM Baud Value Precision Enable Extra Precision: Fractional Part of Baud Value: $+0.0$ Testbench: User  Configuration: RTL                                                                                                                                                                                                                                                                           | Microsemi:DirectCore:C | CoreUARTapb:5.6.102 |    |     |     |
| TX FIFO: Disable TX FIFO   RX FIFO: Disable RX FIFO   Configuration: Programmable   Baud Value: 1   Character Size: 7 bits   Parity: Parity Disabled   RX Legacy Mode: Disabled   FIFO Implementation: In RAM   Enable Extra Precision:                                                                                                                                                                                                                                                                                                                                                                                                        | Configuration          |                     |    |     |     |
| RX FIFO: Disable RX FIFO  Configuration: Programmable Baud Value: 1 Character Size: 7 bits Parity Disabled Parity: Parity Disabled RX Legacy Mode: Disabled FIFO Implementation: In RAM Baud Value Precision Enable Extra Precision: Fractional Part of Baud Value: +0.0 Testbench: User License: C Obfuscated   RTL                                                                                                                                                                                                                                                                                                                           | Core Configuration     |                     |    |     |     |
| Configuration: Programmable<br>Baud Value: 1<br>Character Size: 7 bits<br>Parity: Parity Disabled<br>RX Legacy Mode: Disabled<br>FIFO Implementation: In RAM<br>Baud Value Precision<br>Enable Extra Precision:<br>Fractional Part of Baud Value: +0.0<br>Testbench: User<br>License: C Obfuscated  RTL                                                                                                                                                                                                                                                                                                                                        | TX FIFO:               | Disable TX FIFO 💌   |    |     |     |
| Baud Value: 1<br>Character Size: 7 bits<br>Parity: Parity Disabled<br>RX Legacy Mode: Disabled<br>FIFO Implementation: In RAM<br>Baud Value Precision<br>Enable Extra Precision:<br>Fractional Part of Baud Value: $\pm 0.0$<br>Itestbench: User<br>License: C Obfuscated C RTL                                                                                                                                                                                                                                                                                                                                                                | RX FIFO:               | Disable RX FIFO     |    |     |     |
| Character Size: 7 bits<br>Parity: Parity Disabled<br>RX Legacy Mode: Disabled<br>FIFO Implementation: In RAM<br>Baud Value Precision<br>Enable Extra Precision:<br>Fractional Part of Baud Value: $+0.0$<br>Testbench: User<br>License: O Obfuscated  RTL                                                                                                                                                                                                                                                                                                                                                                                      | Configuration:         | Programmable 💌      |    |     |     |
| Parity: Parity Disabled<br>RX Legacy Mode: Disabled<br>FIFO Implementation: In RAM<br>Baud Value Precision<br>Enable Extra Precision:<br>Fractional Part of Baud Value: +0.0<br>Testbench: User<br>License: C Obfuscated C RTL                                                                                                                                                                                                                                                                                                                                                                                                                 | Baud Value:            | 1                   |    |     |     |
| RX Legacy Mode: Disabled  FIFO Implementation: In RAM  Baud Value Precision Enable Extra Precision: Fractional Part of Baud Value: +0.0  Testbench: User  License:  Obfuscated  RTL                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Character Size:        | 7 bits 👻            |    |     |     |
| FIFO Implementation: In RAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Parity:                | Parity Disabled 💌   |    |     |     |
| Baud Value Precision<br>Enable Extra Precision:<br>Fractional Part of Baud Value: +0.0<br>Testbench: User<br>License: C Obfuscated © RTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RX Legacy Mode:        | Disabled 💌          |    |     |     |
| Enable Extra Precision:<br>Fractional Part of Baud Value: +0.0<br>Testbench: User<br>License: ^ Obfuscated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | FIFO Implementation    | n: In RAM           |    |     |     |
| Enable Extra Precision:<br>Fractional Part of Baud Value: +0.0<br>Testbench: User<br>License: ^ Obfuscated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                        |                     |    |     |     |
| Fractional Part of Baud Value: +0.0<br>Testbench: User<br>License: ^ Obfuscated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                     |    |     |     |
| Testbench: User I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                     |    |     |     |
| License: C Obfuscated @ RTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Fractional Part of Ba  | aud Value: +0.0 💌   |    |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Testbench: User 💌      |                     |    |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | License: 🔿 Obfuscated  | • RTL               |    |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                     |    |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                     |    |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                     |    |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                     |    |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                     |    |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                     |    |     |     |
| DEU UK L CADCEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Help •                 |                     | ок | Can | rel |

The SoftConsole application programs the baud rate, character size, and the parity configuration using the UART driver. If the **Fixed** option is selected, the user application can not overwrite these parameters.

### 2.4.2.6 CoreJTAGDEBUG

The CoreJTAGDebug IP connects the Mi-V soft processor to the JTAG header for debugging.



#### 2.4.2.7 **PF\_SRAM\_AHBL\_AXI** Configuration

The PF SRAM AHBL AXI IP is the main memory of the Mi-V processor, and it gets initialized with the user application from µPROM. It is connected to Mi-V soft processor as an AHB slave. LSRAM is configured for the following settings:

- Optimize for: By default, Low power is selected. It optimizes the LSRAM macro for low power. If design demands high speed memory access, High Speed can be selected.
- Fabric Interface type: By default, AHBLite is selected. The Mi-V soft processor is AHB based, so the SRAM is interfaced to the processor using AHB bus for code execution.
- Memory depth: This field is set to 65536 words to accommodate an application of up to 256 KB into • LSRAM. The present application is below 50 KB so this can fit into either sNVM or µPROM. In this design, µPROM is selected as data storage client. The following figure shows the PE SRAM AHRI AXI (I SRAM 0) IP configuration

| igure 12 • PF_SRAM_AHBL_AXI Configuration                                                                         |                   |
|-------------------------------------------------------------------------------------------------------------------|-------------------|
| PF_SRAM_AHBL_AXI Microsemi:SystemBuilder:PF_SRAM_AHBL_AXI:1.1.125                                                 |                   |
| Port settings Memory Initialization Settings                                                                      |                   |
| Optimize for C High Speed C Low power<br>SRAM type SRAM<br>Memory Depth( in words ) 65536<br>Use Native Interface | SRAM_AHB_AXI_UI_0 |
| Interface Settings  Fabric Interface type AHBLite Data Width 32                                                   | HCLK<br>HRESETN   |
| AXI4 interface options Address Width 32 Width of ID 8  Vite Interface                                             | AHBSlaveInterface |
| Read Interface                                                                                                    | SRAM_AHB_AXI_UI   |

#### Fi

Symbol



### 2.4.2.8 CoreGPIO\_0 Configuration

The CoreGPIO IP controls the on-board LEDs using GPIOs. It is connected to Mi-V soft processor as an APB slave. The configuration settings of the COREGPIO\_0 IP are as follows:

#### In the Global Configurations pane:

- APB Data width is set to 32
  - The design uses 32-bit data width for APB read and write data.
- Number of I/Os is set to 4
- The design controls 2 on-board LEDs for output and 2 DIP Switches for input.
- **I/O Bit:** The following list shows the sub-options under I/O Bit option.
- Output on reset: Set to 0.
  - Fixed Config: Yes
  - **I/O type:** As shown in the following figure, first two I/Os are configured as output and the last two I/Os are configured as input.
- **Note:** The first two I/Os configured as output are used by the design and last two I/Os are not used. The I/Os are interfaced to on-board LEDS and DIP switches.
  - Interrupt Type: Disabled
  - When I/O states change, no interrupt is required for the application.

The following figure shows the CoreGPIO\_0 configuration.

#### Figure 13 • CoreGPIO\_0 Configuration

| III Configurator                                                                                                                  | - |       | × |
|-----------------------------------------------------------------------------------------------------------------------------------|---|-------|---|
| CoreGPIO Configurator                                                                                                             |   |       |   |
| Microsemi:DirectCore:CoreGPI0:3.2.102                                                                                             |   |       |   |
| Configuration                                                                                                                     |   |       | - |
| Global Configuration       APB Data Width:     32       Single-bit interrupt port:     Disabled       Output enable:     Internal |   |       |   |
| I/O bit 0<br>Output on Reset: 0  Fixed Config:  I/O Type: Output Interrupt Type: Disabled                                         | • |       |   |
| I/O bit 1<br>Output on Reset: 0  Fixed Config:  I/O Type: Output Interrupt Type: Disabled                                         | • |       |   |
| I/O bit 2         Output on Reset:       Image: Tripped Config:         I/O Type:       Input Interrupt Type:         Disabled    | • |       |   |
| I/O bit 3         Output on Reset:       Image: Trived Config:         I/O Type:       Input Interrupt Type:         Disabled     | • |       | - |
|                                                                                                                                   | ж | Cance | 1 |



### 2.4.2.9 CoreSPI Configuration

The CoreSPI is used to program the external SPI flash using Mi-V processor. PF\_SPI macro interfaces the fabric logic to the external SPI flash, which is connected to System Controller.

- APB Data Width: select 32 as APB data width in the design is 32-bit. The default value is 8.
- Mode: select Motorola Mode (default) as the target SPI slave (VSC Phy) supports Motorola mode.
- Frame Size: enter 8. The default value is 4.
- FIFO Depth: enter 32 to store maximum frames (Tx and Rx) in FIFO. The default value is 4.
- **Clock Rate**: enter 16. The default value is 8. The SPI clock becomes system clock/ 2\*(16+1).
- **Keep SSEL active**: enabled to keep the slave peripheral active between back to back data transfers.

The following figure shows the CoreSPI configurator.

#### Figure 14 • CoreSPI Configuration

| Configurator                                              | -  |     |     |
|-----------------------------------------------------------|----|-----|-----|
| CoreSPI Configurator                                      |    |     |     |
| ficrosemi:DirectCore:CORESPI:5.1.104                      |    |     |     |
| Configuration                                             |    |     |     |
| vPB Data Width: ○ 8 ○ 16 ● 32                             |    |     |     |
| - SPI Configuration                                       |    |     |     |
| Mode:      O Motorola Mode      O TI Mode      O NSC Mode |    |     |     |
| Frame Size (4-32): 8                                      |    |     |     |
| FIFO Depth (1-32): 32                                     |    |     |     |
| Clock Rate (0-255): 16                                    |    |     |     |
| -Motorola Configuration                                   |    |     |     |
| Keep SSEL active 🔽                                        |    |     |     |
| Transfer Mode: C Normal C Custom                          |    |     |     |
| Free running dock                                         |    |     |     |
| Jumbo frames                                              |    |     |     |
| NSC Specific Configuration Standard                       |    |     |     |
| estbench: User                                            |    |     |     |
| icense: RTL                                               |    |     |     |
|                                                           |    |     |     |
|                                                           |    |     |     |
|                                                           |    |     |     |
|                                                           |    |     |     |
|                                                           |    |     |     |
|                                                           |    |     |     |
| Help 🔻                                                    | ОК | Can | cel |



### 2.4.2.10 CoreSysService\_PF Configuration

CoreSysServices IP provides access to the System Controller. It is connected to Mi-V soft processor as an APB slave. By default, all the service check boxes are selected. The application can initiate these selected services. CoreSysServices IP is configured as shown in the following figure.

| Figure 15 • | CoreSys | Service_ | PF | Configuration |
|-------------|---------|----------|----|---------------|
|-------------|---------|----------|----|---------------|

| Configurator                                                            | -      |       | ×  |
|-------------------------------------------------------------------------|--------|-------|----|
| CoreSysServices_PF Configurator                                         |        |       |    |
| Microsemi:DirectCore:CORESYS5ERVICE5_PF;2.3.116                         |        |       |    |
| Configuration                                                           |        |       |    |
| Device and Design Information Services                                  |        |       |    |
| Serial Number Service: 🔽 UserCode Service: 🔽                            |        |       |    |
| Design Version Service: 🔽 Device Certificate Service: 🔽                 |        |       |    |
| Read Digest Service: 🔽 Query Security Service: 🔽                        |        |       |    |
| Read Debug Info Service: 🔽                                              |        |       |    |
| Design Services                                                         |        |       |    |
| Bitstream Authentication Service: 🔽 IAP Image Authentication Service: 🔽 |        |       |    |
| Data Security Services                                                  |        |       | -1 |
| Digital Signature Service: 🔽 Secure NVM Write Service: 🔽                |        |       |    |
| Secure NVM Read Service: 🔽 PUF Emulation Service: 🔽                     |        |       |    |
| Nonce Service:                                                          |        |       |    |
| FlashFreeze Services                                                    |        |       | -1 |
| Flash Freeze Service: 🔽 FlashFreeze Timeout Value                       | 000000 |       |    |
| FlashFreeze Mailbox Address 0x100 Enable 2MHZ Osc (during Flash Freeze) |        |       |    |
| Fabric Services                                                         |        |       | -1 |
| Digest Check Service: 🔽 IAP Service: 🔽                                  |        |       |    |
| IAP Auto Update Service:                                                |        |       |    |
| Testbench: User 🔽                                                       |        |       |    |
| License: RTL                                                            |        |       |    |
|                                                                         |        |       |    |
|                                                                         |        |       |    |
|                                                                         |        |       |    |
| Help 👻                                                                  | ОК     | Cance | 2  |



### 2.4.2.11 Design Memory Map

The Mi-V processor bus interface memory map is shown in the following figure.

#### Figure 16 • Memory Map

| 🕺 Modify Memory Map                           |            |                         |                | ×   |
|-----------------------------------------------|------------|-------------------------|----------------|-----|
| Select Bus to View or<br>Assign Peripheral(s) | ,          | Assign peripherals to a | ddresses on bu | us: |
| CoreAHBLite 0                                 | Address    | Periphe                 | ral            |     |
| CoreAHBLite_1_0                               | 0x60000000 | CoreUARTapb_0:AP        | B_bif          | 1   |
|                                               | 0x60001000 | CoreGPIO_OUT:APE        | _bif           |     |
|                                               | 0x60002000 | core_sys_services_0:    | APBSlave       |     |
|                                               | 0x60003000 | SPI_Controller_1:AP     | B_bif          |     |
|                                               |            |                         |                |     |
| Help                                          |            | OK                      | Cancel         |     |
| SD Modify Memory Map                          |            |                         |                | ×   |
| Select Bus to View or<br>Assign Peripheral(s) | ,          | Assign peripherals to a | ddresses on bi | us: |
| CoreAHBLite_0                                 | Address    | Periphe                 | ral            |     |
| CoreAHBLite_1_0                               | 0x80000000 | pf_lsram_0:AHBSlav      | elnterface     |     |
|                                               | <b></b>    |                         |                |     |
|                                               |            |                         |                |     |
|                                               |            |                         |                |     |
|                                               |            |                         |                |     |
|                                               |            |                         |                |     |
|                                               |            |                         |                |     |
| Help                                          |            | ОК                      | Cancel         |     |



#### 2.4.2.11.1 CoreAHBLite Configuration

Two instances of CoreAHBLite are used in this design. The following figures show the configurations of CoreAHBLite\_0 and CoreAHBLite\_1 IP cores. The CoreAHBLite\_0 interfaces with the APB peripherals to the Mi-V processor at 0x6000\_0000.

#### *Figure 17* • CoreAHBLite\_0 Configuration

| Configurator                            |             |                       |                          |              |                             |            |                        | -  |     | ×   |
|-----------------------------------------|-------------|-----------------------|--------------------------|--------------|-----------------------------|------------|------------------------|----|-----|-----|
| CoreAHBLite Config                      | urato       | r                     |                          |              |                             |            |                        |    |     |     |
| Microsemi:DirectCore:CoreAHBLite:5.     | 3.101       |                       |                          |              |                             |            |                        |    |     |     |
| Configuration                           |             |                       |                          |              |                             |            |                        |    |     | _   |
| Memory space                            |             |                       |                          |              |                             |            |                        |    |     |     |
| Memory space:                           |             |                       | 4GB addressable space ap | oportioned i | nto 16 slave slots, each of | size 256MB | •                      |    |     |     |
| Address range seen by slave connec      | ted to huge | (2GB) slot interface: | C 0x0000000 - 0x7FFFF    | FFF          | € 0x80000000 - 0:           | XFFFFFFFF  |                        |    |     |     |
| Allocate memory space to combined regio | n slave     |                       |                          |              |                             |            |                        |    |     |     |
| Slot 0: 🗌 Slot 1: 🗌                     | Slot 2:     | Slot 3:               |                          |              |                             |            |                        |    |     |     |
| Slot 4: 🗖 Slot 5: 🗖                     | Slot 6:     | Slot 7:               | ī                        |              |                             |            |                        |    |     |     |
| Slot 8: 🔲 Slot 9: 🗖                     | Slot 10:    | □ Slot 11: □          | 1                        |              |                             |            |                        |    |     |     |
| Slot 12: 🗌 Slot 13: 🗍                   | Slot 14:    | □ Slot 15: □          | 1                        |              |                             |            |                        |    |     |     |
| Enable Master access                    |             |                       |                          |              |                             |            |                        |    |     |     |
| M0 can access slot 0:                   |             | M1 can access slot    | t 0: 🗆                   | M2 (         | can access slot 0:          |            | M3 can access slot 0:  |    |     |     |
| M0 can access slot 1:                   |             | M1 can access slot    | t 1: 🗆                   | M2 (         | can access slot 1:          |            | M3 can access slot 1:  |    |     |     |
| M0 can access slot 2:                   |             | M1 can access slot    | t 2:                     | M2 (         | can access slot 2:          |            | M3 can access slot 2:  |    |     |     |
| M0 can access slot 3:                   |             | M1 can access slot    | t 3:                     | M2 (         | can access slot 3:          |            | M3 can access slot 3:  |    |     |     |
| M0 can access slot 4:                   |             | M1 can access slot    | t 4:                     | M2 (         | can access slot 4:          |            | M3 can access slot 4:  |    |     |     |
| M0 can access slot 5:                   |             | M1 can access slot    | t 5:                     | M2 (         | can access slot 5:          |            | M3 can access slot 5:  |    |     |     |
| M0 can access slot 6:                   |             | M1 can access slot    | t 6: 🗆                   | M2 (         | can access slot 6:          |            | M3 can access slot 6:  |    |     |     |
| M0 can access slot 7:                   |             | M1 can access slot    | t 7:                     | M2 (         | can access slot 7:          |            | M3 can access slot 7:  |    |     |     |
| M0 can access slot 8:                   |             | M1 can access slot    | t 8:                     | M2 (         | can access slot 8:          |            | M3 can access slot 8:  |    |     |     |
| M0 can access slot 9:                   |             | M1 can access slot    | t 9:                     | M2 (         | can access slot 9:          |            | M3 can access slot 9:  |    |     |     |
| M0 can access slot 10:                  |             | M1 can access slot    | t 10:                    | M2 (         | can access slot 10:         |            | M3 can access slot 10: |    |     |     |
| M0 can access slot 11:                  |             | M1 can access slot    | t 11:                    | M2 (         | can access slot 11:         |            | M3 can access slot 11: |    |     |     |
| M0 can access slot 12:                  |             | M1 can access slot    | t 12:                    | M2 (         | can access slot 12:         |            | M3 can access slot 12: |    |     | •   |
| Help 🔻                                  |             |                       |                          |              |                             |            |                        | ОК | Can | cel |



The CoreAHBLite\_1 interfaces PF\_SRAM with Mi-V soft processor for accessing the LSRAM at memory address 0x8000\_0000. This configuration is required as the Mi-V processor executes the code from 0x8000\_0000.

| nfigurator                         |                 |                                 |                  |                                      |                 |                            | _ |  |
|------------------------------------|-----------------|---------------------------------|------------------|--------------------------------------|-----------------|----------------------------|---|--|
| reAHBLite Config                   | urator          |                                 |                  |                                      |                 |                            |   |  |
| osemi:DirectCore:CoreAHBLite:      | 5.3.101         |                                 |                  |                                      |                 |                            |   |  |
| Memory space:                      |                 | 16 64KB slot                    | s, plus reserved | space, plus 1 huge (2GB) slot beginr | ning at address | 0x80000000 🔽               |   |  |
| Address range seen by slave conne  | ected to huge ( | (2GB) slot interface: 🔿 0x00000 | 000 - 0x7FFFFFF  | F 0x8000000 - 0x                     | FFFFFFF         |                            |   |  |
| ocate memory space to combined reg | ion slave       |                                 |                  |                                      |                 |                            |   |  |
| Slot 0: 🔽 Slot 1: 🖵                | Slot 2: 「       | Slot 3:                         |                  |                                      |                 |                            |   |  |
| Slot 4: 🔽 Slot 5: 🗖                | Slot 6: 「       | Slot 7:                         |                  |                                      |                 |                            |   |  |
| Slot 8: 🗖 Slot 9: 🗖                | Slot 10: 「      | Slot 11:                        |                  |                                      |                 |                            |   |  |
| Slot 12: 🔽 Slot 13: 🗖              | Slot 14: 1      | Slot 15:                        |                  |                                      |                 |                            |   |  |
| able Master access                 |                 |                                 |                  |                                      |                 |                            |   |  |
| M0 can access slot 0:              |                 | M1 can access slot 0:           |                  | M2 can access slot 0:                |                 | M3 can access slot 0:      |   |  |
| M0 can access slot 1:              |                 | M1 can access slot 1:           |                  | M2 can access slot 1:                |                 | M3 can access slot 1:      |   |  |
| M0 can access slot 2:              |                 | M1 can access slot 2:           |                  | M2 can access slot 2:                |                 | M3 can access slot 2:      |   |  |
| M0 can access slot 3:              |                 | M1 can access slot 3:           |                  | M2 can access slot 3:                |                 | M3 can access slot 3:      |   |  |
| M0 can access slot 4:              |                 | M1 can access slot 4:           |                  | M2 can access slot 4:                |                 | M3 can access slot 4:      |   |  |
| M0 can access slot 5:              |                 | M1 can access slot 5:           |                  | M2 can access slot 5:                |                 | M3 can access slot 5:      |   |  |
| M0 can access slot 6:              |                 | M1 can access slot 6:           |                  | M2 can access slot 6:                |                 | M3 can access slot 6:      |   |  |
| M0 can access slot 7:              |                 | M1 can access slot 7:           |                  | M2 can access slot 7:                |                 | M3 can access slot 7:      |   |  |
| M0 can access slot 8:              |                 | M1 can access slot 8:           |                  | M2 can access slot 8:                |                 | M3 can access slot 8:      |   |  |
| M0 can access slot 9:              |                 | M1 can access slot 9:           |                  | M2 can access slot 9:                |                 | M3 can access slot 9:      |   |  |
| M0 can access slot 10:             |                 | M1 can access slot 10:          |                  | M2 can access slot 10:               |                 | M3 can access slot 10:     |   |  |
| M0 can access slot 11:             |                 | M1 can access slot 11:          | Г                | M2 can access slot 11:               |                 | M3 can access slot 11:     |   |  |
| M0 can access slot 12:             |                 | M1 can access slot 12:          |                  | M2 can access slot 12:               |                 | M3 can access slot 12:     |   |  |
| M0 can access slot 13:             |                 | M1 can access slot 13:          |                  | M2 can access slot 13:               |                 | M3 can access slot 13:     |   |  |
| M0 can access slot 14:             |                 | M1 can access slot 14:          |                  | M2 can access slot 14:               |                 | M3 can access slot 14:     |   |  |
| M0 can access slot 15:             |                 | M1 can access slot 15:          |                  | M2 can access slot 15:               |                 | M3 can access slot 15:     |   |  |
| M0 can access slot 16 (combined/h  |                 | M1 can access slot 16 (combine  |                  | M2 can access slot 16 (combined      |                 | M3 can access slot 16 (com |   |  |
| no can access siot to (combined/ni | uge): (♥        | mit can access slot to (combine | u/nuge): I       | m2 can access slot to (combined      | i/nuge): I      | ma can access slot 16 (com |   |  |



#### 2.4.2.11.2 COREAHBTOAPB3

The CoreAHBtoAPB3 works as a bridge in between the AHB and the APB domains. CoreAHBtoAPB3 interfaces with CoreAHBLite through its AHB interface and with CoreAPB3 through its APB interface.

#### 2.4.2.11.3 CoreAPB3 Configuration

The CoreAPB3 IP connects the peripherals, CoreSysService\_PF, CoreSPI, CoreGPIO, and CoreUARTapb as slaves. The configuration settings of **COREAPB3** are as follows:

APB Master Data bus width: 32-bit

The design uses 32-bit data width for APB read and write data.

- Number of address bits driven by master: 16
   The Mi-V processor accesses the slaves using the 16-bit. The final addresses for these slaves are translated into 0x6000\_0000, 0x6000\_1000, 0x6000\_2000 and 0x6000\_3000.
- Enabled APB slave slots: Slot 0 for CoreUARTapb, Slot 1 for CoreGPIO, Slot 2 for CoreSysService PF, and Slot 3 for CoreSPI.

The following figure shows the CoreAPB3 configuration.

#### *Figure 19* • CoreAPB3\_0 Configuration

| CoreAPB3 Configurator<br>Microsemi:DirectCore:CoreAPB3:4.1.100 |                                                      |   |
|----------------------------------------------------------------|------------------------------------------------------|---|
| Configuration                                                  |                                                      | • |
| Data Width Configuration                                       |                                                      | l |
| APB Master Data Bus Width 💿 32-bit 💿 16-bit                    | ◎ 8-bit                                              | l |
| Address Configuration                                          |                                                      | l |
| Number of address bits driven by master:                       | <b>1</b> 6 <b>•</b>                                  | l |
| Position in slave address of upper 4 bits of master address:   | [27:24] (Ignored if master address width >= 32 bits) | l |
| Indirect Addressing:                                           | Not in use 🔹                                         | l |
| Allocate memory space to combined region slave                 |                                                      |   |
| Slot 0: Slot 1: Slot 2:                                        | Slot 3:                                              |   |
| Slot 4: Slot 5: Slot 6:                                        | Slot 7:                                              |   |
| Slot 8: Slot 9: Slot 10:                                       | Slot 11:                                             | = |
| Slot 12: Slot 13: Slot 14:                                     | Slot 15:                                             | l |
| Enabled APB Slave Slots                                        |                                                      | l |
| Slot 0: 📝 Slot 1: 📝 Slot 2: 📝                                  | Slot 3: 🖉                                            | l |
| Slot 4: Slot 5: Slot 6:                                        | Slot 7:                                              | l |
| Slot 8: Slot 9: Slot 10:                                       | Slot 11:                                             | l |
| Slot 12: Slot 13: Slot 14:                                     | Slot 15:                                             |   |
| Testbench: User 💌                                              |                                                      |   |
| License: Obfuscated   RTL                                      |                                                      |   |
| Help 🔻                                                         | OK Cancel                                            | • |



# 2.5 Clocking Structure

The following figure shows the clocking structure of this design. The Mi-V processor supports up to 120 MHz and this design uses 100 MHz system clock.

#### Figure 20 • Clocking Structure





# 3 Libero Design Flow

The Libero design flow involves running the following processes in the Libero SoC PolarFire:

- Synthesize, page 23
- Place and Route, page 23
- Verify Timing, page 23
- Generate FPGA Array Data, page 23
- Configure Design Initialization Data and Memories, page 24
- Configure Programming Options, page 26
- Generate Bitstream, page 27
- Run PROGRAM Action, page 27

The following figure shows these options in the **Design Flow** tab.

#### Figure 21 • Libero Design Flow Options

| Design Flow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | x       |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| Top Module(root): PROC_SUBSYSTEM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | F       |
| Tool                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <b></b> |
| Create Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |
| Create SmartDesign                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |
| Create HDL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |
| Create SmartDesign Testbench                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |
| Create HDL Testbench                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |
| Verify Pre-Synthesized Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |
| Simulate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |
| Constraints                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |         |
| 🔤 👔 Manage Constraints                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |
| 🖌 🗇 🕨 Implement Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |
| 🖓 Netlist Viewer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| V Synthesize                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |
| V Place and Route                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |
| Verify Post Layout Implementation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |
| 🖌 🖳 Verify Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |
| 💩 Open SmartTime                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| 🛄 🛄 Verify Power                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| Program and Debug Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |
| 🖌 🖌 🖓 🖉 🖌 🖌 🖌 🖌 Value of the second |         |
| <ul> <li>Configure Design Initialization Data and Memories</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |
| 🖌 🖌 🖉 Generate Design Initialization Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |
| Configure Hardware                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |
| Programming Connectivity and Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |
| 🚽 👧 Configure Programmer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |
| 🔚 Device I/O States During Programming - JTAG M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |
| - 🗟 Configure Programming Options                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |
| 🛛 🚱 Configure Security                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |
| Program Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |
| 🐻 Generate Bitstream                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |
| Run PROGRAM Action                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |
| Program SPI Flash Image     Generate SPI Flash Image     Run PROGRAM_SPI_IMAGE Action                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |
| V Generate SPI Flash Image                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |
| Debug Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |
| Identify Debug Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |
| 😔 🥹 SmartDebug Design                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |
| Configure Permanent Locks for Production                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |
| Sconfigure OTP Security                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
| Handoff Design for Production                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |
| V Export Bitstream                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |
| Export FlashPro Express Job                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |         |
| Export SPI Flash Image                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |
| Export Pin Report                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |
| Export BSDL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | _       |
| E → Handoff Design for Debugging                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ▼       |



# 3.1 Synthesize

To synthesize the design:

- Double-click Synthesize from the Design Flow tab. When the synthesis is successful, a green tick mark appears as shown in Figure 21, page 22.
- 2. Right-click **Synthesize** and select **View Report** to view the synthesis report and log files in the **Reports** tab.
- **Note:** PROC\_SUBSYSTEM.srr and the PROC\_SUBSYSTEM\_compile\_netlist.log files are recommended to be viewed for debugging synthesis and compile errors.

# 3.2 Place and Route

The Place and Route process requires the I/O, timing, and floor planner constraints. This design includes following constraint files in the **Constraint Manager** window:

- The io.pdc and the user.pdc file for the I/O assignments
- The PROC SUBSYSTEM derived constaints.sdc file for timing constraints
- JTAG constraint.sdc file for creating the JTAG clock with 30 MHz frequency.
- The Async\_Clock\_groups.sdc file defines that the CCC\_0 output clock and the JTAG clock as asynchronous clocks.

To Place and Route, double-click Place and Route from the Design Flow window.

When place and route is successful, a green tick mark appears next to Place and Route.

**Note:** The file, PROC\_SUBSYSTEM\_place\_and\_route\_constraint\_coverage.xml is recommended to be viewed for place and route constraint coverage.

### 3.2.1 Resource Utilization

The resource utilization report is written to the PROC\_SUBSYSTEM\_layout\_log.log file in the Reports tab -> PROC\_SUBSYSTEM reports -> Place and Route. It lists the resource utilization of the design after place and route. These values may vary slightly for different Libero runs, settings, and seed values.

| Туре          | Used  | Total  | Percentage |
|---------------|-------|--------|------------|
| 4LUT          | 17822 | 299544 | 5.95       |
| DFF           | 10918 | 299544 | 3.64       |
| I/O Register  | 0     | 242    | 0.00       |
| Logic Element | 18529 | 299544 | 6.19       |

#### Table 4 •Resource Utilization

# 3.3 Verify Timing

To verify timing:

- Double-click Verify Timing from the Design Flow tab. When the design successfully meets the timing requirements, a green tick mark appears as shown in Figure 21, page 22.
- 2. Right-click **Verify Timing** and select **View Report**, to view the verify timing report and log files in the **Reports** tab.

# 3.4 Generate FPGA Array Data

To generate the FPGA array data:

- 1. Double-click Generate FPGA Array Data from the Design Flow window.
- 2. A green tick mark is displayed after the successful generation of the FPGA array data as shown in Figure 21, page 22.



# 3.5 Configure Design Initialization Data and Memories

The **Configure Design Initialization Data and Memories** step generates the LSRAM initialization client and adds it to sNVM,  $\mu$ PROM, or an external SPI flash, based on the type of non-volatile memory selected. In this design, the LSRAM initialization client is stored in the sNVM.

This process requires the user application executable file (hex file) to initialize the LSRAM blocks on device power-up. The hex file (application.hex) is available in the

DesignFiles\_Directory\Libero\_Project\hw\_project folder. When the hex file is imported, a memory initialization client is generated for LSRAM blocks.

Follow these steps:

1. Double-click **Configure Design Initialization Data and Memories** from the **Design Flow** window. The **Design and Memory Initialization** window opens as shown in the following figure.

#### Figure 22 • Design and Memory Initialization

| Design Initialization UPROM SNVM SPI Flash Fabric RAMs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Apply       Discard       Help         In design initialization, user design blocks such as LSRAM, µSRAM, transceivers, and PCIe can be initialized as an option using data stored in the non-volatile storage memory. The initialization data can be stored in µPROM, sNVM, or an external SPI Flash.         Follow the below steps to program the initialization data:       .         1. Set up your fabric RAMs initialization data;       .         2. Define the storage location of the initialization data       .         3. Generate the initialization data;       . |
| 4. Generate or export the bitstream<br>5. Program the device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| - First stage (sNVM)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| In the first stage, the initialization sequence de-asserts FABRIC_POR_N.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| In the second stage, the initialization sequence initializes the PCIe and XCVR blocks present in the design. Start address for second stage initialization dient: 0x 00000000                                                                                                                                                                                                                                                                                                                                                                                                    |
| Third stage (sNVM/uPROM/SPI-Flash)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| In the third stage, the initialization sequence initializes the Fabric RAMs present in the design.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| To save the initialization instructions in sNVM/uPROM/SPI-Flash, please use 'Fabric RAMs' tab to make your selection for each RAM client.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Image: Start address for sNVM clients:   0x   00000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Start address for uPROM dients: 0x 00000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Start address for SPI-Flash clients: 0x 00000400                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| SPI-Flash Binding: SPI-Flash - No-binding Plaintext 💌 SPI Clock divider value: 6 💌                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Time Out (s):                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Custom configuration file:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |



2. Select the **Fabric RAMs** tab and select the **pf\_Isram** client from the list and click **Edit** as shown in the following figure.

#### Figure 23 • Fabric RAMs Tab



3. In the Edit Fabric RAM Initialization Client dialog box, select the Content from file option, and locate the application.hex file from

 $\label{eq:linear} {\tt DesignFiles\_directory\Libero\_Project\hw\_project\mbox{ folder and Click OK as shown in the following figure.}$ 

Figure 24 • Edit Fabric RAM Initialization Client

| Edit Fabric RAM Initialization Client                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ?      | ×    |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------|--|--|
| Client name: PROC_SUBSYSTEM/pf_Isram Physical Name: PF_TPSRAM_AHB_AXI_0_PF_TPSRAM_R17C3/INST_ Fabric RAMs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RAM1K2 | )_IP |  |  |
| Content from file: application.hex  Type: |        |      |  |  |
| C No content (client is a placeholder and will not be programmed) Optimize for: C High Speed C Low power Uptimize for: C High Speed C Low power                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        |      |  |  |
| Help OK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Close  |      |  |  |



4. Click **Apply** as shown in the following figure.

#### Figure 25 • Apply Fabric RAM Content

| Apply Discard<br>Usage statistics                                         | Hel                    |                                                                                                                       |                        |                |
|---------------------------------------------------------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------|------------------------|----------------|
| LSRAM Memory                                                              |                        | s<br>I design configuration Edit                                                                                      |                        |                |
| Available Merr 174063616<br>Used Memoryl 344720<br>Free Memory( 173718896 |                        | Logical Instance Name                                                                                                 | PORTA<br>Depth * Width | POR<br>Depth * |
| Thee mentory 175710050                                                    | 1                      | PROC_SUBSYSTEM/Core_SPI_0/Core_SPI_0/USPI/URXF/fifo_mem_q\[0\]                                                        | 32x9                   | 32x9           |
|                                                                           | 2                      | PROC_SUBSYSTEM/Core_SPI_0/Core_SPI_0/USPI/UTXF/fifo_mem_q\[0\]                                                        | 32x9                   | 32x9           |
|                                                                           | 3                      | PROC_SUBSYSTEM/Mi_V_SoftProcessor_0/Mi_V_SoftProcessor_0/ChiselTop0/tile/rocket/core/_T_1189                          | 32x32                  | 32x32          |
|                                                                           | 4                      | PROC_SUBSYSTEM/Mi_V_SoftProcessor_0/Mi_V_SoftProcessor_0/ChiselTop0/tile/rocket/core/_T_1189[31:0]                    | 32x32                  | 32x32          |
| Used space                                                                | 5                      | PROC_SUBSYSTEM/Mi_V_SoftProcessor_0/Mi_V_SoftProcessor_0/ChiselTop0/tile/rocket/dcache/data/data_arrays_0_0[7:0]      | 2048x8                 | 2048x8         |
| Free space                                                                | 6                      | PROC_SUBSYSTEM/Mi_V_SoftProcessor_0/Mi_V_SoftProcessor_0/ChiselTop0/tile/rocket/dcache/data/data_arrays_0_1[7:0]      | 2048x8                 | 2048x8         |
| uSRAM Memory                                                              | 7                      | PROC_SUBSYSTEM/Mi_V_SoftProcessor_0/Mi_V_SoftProcessor_0/ChiselTop0/tile/rocket/dcache/data/data_arrays_0_2[7:0]      | 2048x8                 | 2048x8         |
| Available Memor 8515584                                                   | 8                      | PROC_SUBSYSTEM/Mi_V_SoftProcessor_0/Mi_V_SoftProcessor_0/ChiselTop0/tile/rocket/dcache/data/data_arrays_0_3[7:0]      | 2048x8                 | 2048x8         |
| Used Memory(By 328<br>Free Memory(By 8515256                              | 9                      | PROC_SUBSYSTEM/Mi_V_SoftProcessor_0/Mi_V_SoftProcessor_0/ChiselTop0/tile/rocket/dcache/tag_array_0[20:0]              | 128x21                 | 128x21         |
| 1100 1101 1101 110 100 100 100 100 100                                    | 10                     | PROC_SUBSYSTEM/Mi_V_SoftProcessor_0/Mi_V_SoftProcessor_0/ChiselTop0/tile/rocket/frontend/icache/data_arrays_0_0[31:0] | 2048x32                | 2048x32        |
|                                                                           | 11                     | PROC_SUBSYSTEM/Mi_V_SoftProcessor_0/Mi_V_SoftProcessor_0/ChiselTop0/tile/rocket/frontend/icache/tag_array_0[19:0]     | 128x20                 | 128x20         |
| 12                                                                        | PROC_SUBSYSTEM/PF_SRAM | 65536x40                                                                                                              | 65536x40               |                |
|                                                                           |                        |                                                                                                                       |                        |                |
| Used space                                                                |                        |                                                                                                                       |                        |                |

5. Click **Apply** in the **Design Initialization** tab.

6. From Libero Design Flow, click **Generate Initialization Data** to generate design initialization data. After successful generation of the Initialization data, a green tick mark appears next to **Generate Initialization Data** option as shown in the Figure 21, page 22.

# 3.6 Configure Programming Options

The Design version and user code (Silicon signature) are configured in this step. Double click Design flow->Program and Debug Design->Configure Programming Options to give values as shown in the following figure.

#### Figure 26 • Configure Programming Options

| Copen SmartTime                                                                       | Configure Programming Options                              | $\times$ |
|---------------------------------------------------------------------------------------|------------------------------------------------------------|----------|
| Program and Debug Design                                                              |                                                            |          |
| V Generate FPGA Array Data                                                            | Design name: PROC_SUBSYSTEM                                |          |
| Configure Design Initialization Data and Memo     Generate Design Initialization Data | Design version (number between 0 and 65535): 1             | _        |
| Configure Hardware                                                                    | Silicon signature (max length is 8 HEX chars): 0x 12345678 | -        |
| Programming Connectivity and Interface     Sconfigure Programmer                      |                                                            |          |
| Device I/O States During Programming - JT                                             | The International Cance                                    |          |
| 🐻 Configure Security                                                                  |                                                            |          |



# 3.7 Generate Bitstream

To generate the bitstream:

1. Right-click **Generate Bitstream** and select **Configure Options...** to select the bitstream components—Custom security, Fabric, and sNVM.

Figure 27 • Generate Bitstream—Configure Bitstream Options

| Configure Bitstream | ×         |
|---------------------|-----------|
| -Program            |           |
| Custom security     |           |
| ₩ Fabric            |           |
| SNVM                |           |
| Help                | OK Cancel |

- 2. Double-click **Generate Bitstream** from the **Design Flow** tab. When the bitstream is successfully generated, a green tick mark appears as shown in Figure 21, page 22
- 3. Right-click **Generate Bitstream** and select **View Report** to view the corresponding log file in the **Reports** tab.

### 3.8 Run PROGRAM Action

After generating the bitstream, the PolarFire device must be programmed with the Auto Update and IAP design.

Follow these steps to program the PolarFire device:

1. Ensure that the following jumper settings are set on the board.

| Table 5 • Jumper Settings for PolarFire Device Pr |
|---------------------------------------------------|
|---------------------------------------------------|

| Jumper Description |                                                                   |
|--------------------|-------------------------------------------------------------------|
| J5, J6, J7, J8, J9 | Close pin 2 and 3 for programming the PolarFire FPGA through FTDI |
| J11                | Close pin 1 and 2 for programming through FTDI chip               |
| J10                | Close pin 1 and 2 for programming through FTDI SPI                |
| J4                 | Close pin 1 and 2 for manual power switching using SW1            |
| J3                 | Open pin 1 and 2 for 1.0 V                                        |

2. Connect the power supply cable to the **J2** connector on the board.

- 3. Connect the USB cable from the host PC to the J1 (FTDI port) on the board.
- 4. Power on the board using the SW1 slide switch.



The following figure shows the board setup after these connections are made.

#### Figure 28 • Board Setup



5. Double-click Run PROGRAM Action from the Libero Design Flow.

The device is successfully programmed and the on-board LEDs glow. A green tick mark appears next to **Run PROGRAM Action** as shown in Figure 21, page 22.



# 4 Programming the Device Using FlashPro Software

This section describes how to program the PolarFire device with the .stp programming file using FlashPro. The .stp file is available at the following design files folder location:

mpf ac471 liberosocpolarfirev2p2 df\Programming File

To program the PolarFire device using FlashPro, complete the following steps:

1. Ensure that the jumper settings on the board are the same as those listed in the following table. **Note:** The power supply switch must be switched off while making the jumper connections.

| Jumper             | Description                                                       |
|--------------------|-------------------------------------------------------------------|
| J5, J6, J7, J8, J9 | Close pin 2 and 3 for programming the PolarFire FPGA through FTDI |
| J11                | Close pin 1 and 2 for programming through FTDI chip               |
| J10                | Close pin 1 and 2 for programming through FTDI SPI                |
| J4                 | Close pin 1 and 2 for manual power switching using SW1            |
| J3                 | Open pin 1 and 2 for 1.0 V                                        |

Table 6 • Jumper Settings for PolarFire Device Programming

2. Connect the power supply cable to the **J2** connector on the board.

3. Connect the USB cable from the host PC to the **J1** (FTDI port) on the board.

4. Power on the board using the **SW1** slide switch.

5. On the host PC, launch the FlashPro software.

 Click New Project to create a new project. In the New Project window, enter a project name.

7. Click Browse and navigate to the location where you want to save the project.

- 8. Select Single device as the programming mode and click OK to save the project.
- 9. Click Configure Device.
- 10. Click **Browse**, and select the progamming\_appnote\_v1.stp file from the following folder: <\$design file directory>\mpf\_ac471\_liberosocpolarfirev2p2\_df\Programming\_File
- 11. Click Open. The required programming file is selected and ready to be programmed in the device.
- 12. Click **PROGRAM** to program the device.

When the device is programmed successfully, a Run PASSED status is displayed.



# 5 Serial Terminal Emulation Program Setup

The user application receives programming commands on the serial terminal through the UART interface. This chapter describes how to set up the serial terminal program.

To setup PuTTY, perform the following steps:

- 1. Connect the USB cable from the host PC to the J1 (USB) port on the board.
- 2. Connect the power supply cable to the **J2** connector on the board.
- 3. Power on the board using the SW1 slide switch.
- 4. From the host PC, click Start and open **Device Manager** to note the second highest COM Port number and use that in the PuTTY configuration. In this example, COM Port 9 (COM9) is selected as shown in the following figure. COM Port-numbers may vary.

#### Figure 29 • COM Port Number

- Ports (COM & LPT)
   ECP Printer Port (LPT1)
   FlashPro5 Port (COM10)
   FlashPro5 Port (COM7)
   FlashPro5 Port (COM8)
   FlashPro5 Port (COM9)
- 5. From the host PC, click **Start**, and then find and select the PuTTY program.
- 6. Select **Serial** as the **Connection type** as shown in the following figure.

#### Figure 30 • Select Serial as the Connection Type

| 🕵 PuTTY Configuration | ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category:<br>         | Basic options for your PuTTY session         Specify the destination you want to connect to         Serial line       Speed         COM9       115200         Connection type:       Image: Comparison of the second session         Saved Sessions       Serial         C27       C5         C3       Load         C27       Save         C3       Leader         Case window on exit:       Default Settings         Case window on exit:       Only on clean exit |
| About                 | <u>O</u> pen <u>C</u> ancel                                                                                                                                                                                                                                                                                                                                                                                                                                          |

- 7. Set the **Serial line to connect** to COM port number noted in Step 3.
- 8. Set the Speed (baud) to 115200 as shown in the following figure.



9. Set the **Flow control** to **None** as shown in the following figure and click **Open**.

#### Figure 31 • PuTTY Configuration

| 🕵 PuTTY Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                      | ×                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| Category:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                      |                                                                         |
| Session     Logging     Terminal     Veyboard     Selu     S | Options contro<br>Select a serial line<br>Serial line to connect to<br>Configure the serial line<br>Speed (baud)<br>Data bits<br>Stop bits<br>Parity<br>Flow control | ling local serial lines<br>COM9<br>115200<br>8<br>1<br>None ~<br>None ~ |
| About                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                      | Open <u>C</u> ancel                                                     |

PuTTY opens successfully, and this completes the serial terminal emulation program setup. See Running the Demo, page 32.



# 6 Running the Demo

This section describes how to run the authentication, auto update and IAP. The following procedure assumes that the serial terminal is setup, for more information about setting up the serial terminal, see Serial Terminal Emulation Program Setup, page 30.

The on-board 1 GB Micron SPI flash device is connected to System Controller SPI and can be programmed using the fabric logic or Libero SoC PolarFire software. For more information about programming the on-board SPI flash using Libero, see Appendix: Programming On-board SPI Flash Using Libero, page 37.

Before you start:

- 1. Ensure that the device is programmed with the programming\_appnote\_v1.stp file.
- 2. Connect the power supply cable to the J2 connector on the board.
- 3. Connect the USB cable from the host PC to **J1** (FTDI port) on the board.
- 4. Ensure that on-board SW8 DIP 1 is set to Off.
- 5. Power-up the board using the SW1 slide switch.

### 6.1 Programming the SPI Flash Using Fabric Logic

After power-up, PuTTY displays the options as shown in the following figure. Observe the design version **01** in the device.

#### Figure 32 • Authentication and Programming Options

| Putty                                                                                                                                 | - | × |
|---------------------------------------------------------------------------------------------------------------------------------------|---|---|
| Design Version(MSB first): 00 01<br>32bit USERCODE/Silicon Signature (MSB first): 12345678<br>**** PolarFire Programming Example **** |   | ^ |
| Select option:<br>**AUTHENTICATION**<br>1. Bit-stream authentication                                                                  |   |   |
| <ol> <li>IAP image authentication</li> <li>**DEVICE PROGRAMMING**</li> <li>Auto programming</li> </ol>                                |   |   |
| <ol> <li>IAP Program by Index</li> <li>IAP Program by address</li> <li>Initiate Auto-Update</li> </ol>                                |   |   |
|                                                                                                                                       |   | 2 |

At this point, the on-board SPI Flash device is empty. Hence, selecting Option 1 or 2 returns unsuccessful status codes as shown in the following figure.

#### Figure 33 • Authentication Error



Selecting option 4, 5, or 6 does not initiate any program operation as the on-board SPI flash is empty. Power cycle the board. Observe the design version **01** in the device. This indicates auto update is not initiated and the device is not updated.



To program the SPI flash:

- 1. Power off the board using the SW1 slide switch. Close the PuTTY and set the on-board SW8 DIP 1 to On
- 2. Disconnect and connect the USB cable from the host PC to J1 (FTDI port) on the board. This ensures clearing off UART buffers.
- Power on the board using the SW1 slide switch. 3.
- Locate the load spi flash.bat batch file from the 4. \$DesignFiles Folder\host pc tool pf folder.
- 5. Right-click load spi flash.bat batch file and edit it as follows to match the COM port number. For example, COM Port 9 in this instance.
- spi loader.exe 54 golden image v0.spi update image v2.spi iap image v5.spi
- Double-click the load spi flash.bat file to load the programming images—listed in the 6. following table-into external SPI flash. The application firmware writes the flash directory contents into the external SPI flash along with programming images.

#### Table 7 • **Programming Images**

| Image Name          | Version | Silicon Signature/<br>User Code | Image Index in SPI<br>Flash Directory | Image Address in SPI<br>Flash Memory |
|---------------------|---------|---------------------------------|---------------------------------------|--------------------------------------|
| golden_image_v0.spi | 0       | 0x01234567                      | 0                                     | 0x00000400                           |
| update_image_v2.spi | 2       | 0x23456789                      | 1                                     | 0x00A00000                           |
| iap_image_v5.spi    | 5       | 0x56789ABC                      | 2                                     | 0x01400000                           |

The command window prompts to press enter to erase and program the SPI Flash with programming images.

The LED 4 blinks to indicate that the SPI Flash Erase operation is in progress. The command prompt displays the status as shown in the following figure.

#### Figure 34 • Erasing SPI Flash

C:\WINDOWS\system32\cmd.exe

×

D:\mpf\_ac471\_liberosocpolarfirev2p1\_df\host\_pc\_tool\_pf>spi\_loader.exe 54 golden\_image\_v0.spi update\_image\_v2.spi iap\_ima ge\_v5.spi Serial port \\.\COM54 successfully reconfigured.

Ensure the PolarFire Kit is running

Press 'Enter' to Program the External SPI flash ..

If you want to run programming options, change the DIP switch-1 position to OFF and power cycle the board.

The External SPI flash is erasing... Handshaking with PolarFire kit is in progress...



 The SPI Flash programming operation starts and takes 20-30 minutes to complete. LED 5 blinks to indicate that the SPI Flash programming operation is in progress.
 When the SPI Flash programming operation completes successfully, LED 5 starts to glow.
 The Command prompt shows the status and the time taken as shown in the following figure.

#### Figure 35 • Command Prompt Status

start time 22:54:23

end time 23:24:28

DONE press ctrl+c to terminate the application.

8. Close the application.

This concludes programming the on-board SPI flash memory.

# 6.2 Running Auto Update

To run auto update:

- 1. Set the on-board SW8 DIP 1 to Off.
- Start the PuTTY and power-cycle the board. The auto update is initiated and update image (update\_image\_v2.spi) gets programmed into the device.

Observe the design version 02 as shown in the following figure.

#### Figure 36 • Auto Update



# 6.3 Running Authentication

To run bitstream authentication:

1. Press 1 to initiate the bitstream authentication.

After successful authentication, PuTTY displays the status code as shown in the following figure.

#### Figure 37 • Successful Bitstream Authentication

```
COM9-PuTTY - C X

Bitstream authentication for image at address 0x1400000 is in progress...

Authentication status: SUCCESS

**** PolarFire Programming Example ****

Select option:

**AUTHENTICATION**

1. Bit-stream authentication

2. IAP image authentication
```



2. Press 2 to initiate the IAP image authentication.

After successful authentication, PuTTY displays the status code, as shown in the following figure.



| P COM9 - PuTTY –                                                                               | ×   |
|------------------------------------------------------------------------------------------------|-----|
|                                                                                                | ^   |
| IAP image authentication for image at index 2 is in progress<br>Authentication status: SUCCESS |     |
| **** PolarFire Programming Example **** Select option:                                         | - 1 |
| **AUTHENTICATION**                                                                             |     |
| <ol> <li>Bit-stream authentication</li> </ol>                                                  | ~   |

This concludes the bitstream and IAP image authentication.

### 6.4 Running Auto Programming

To run Auto programming:

- 1. Press 3 in PuTTY. The PuTTY notifies to erase the device using FlashPro and power-cycle the board as shown in the following figure.
- Figure 39 Notifying ERASE Action



2. Using FlashPro, erase the device and power-cycle the board.

All the LEDs stop glowing for few seconds, which indicates that the auto programming is in progress. The highest programming image version is selected from first two available images in external SPI Flash for auto programming. In this case, it is version 2 (update\_image\_v2.spi).

PuTTY displays the updated design version, as shown in the following figure.

#### Figure 40 • Successful Auto Programming

|    | Putty                                                                                                                        | -        | × |
|----|------------------------------------------------------------------------------------------------------------------------------|----------|---|
|    | Design Version(MSB first): 00 02<br>32bit USERCODE/Silicon Signature (MSB first):<br>**** PolarFire Programming Example **** | 23456789 | ^ |
|    | Select option:<br>**AUTHENTICATION**                                                                                         |          |   |
| 17 | <ol> <li>Bit-stream authentication</li> <li>IAP image authentication</li> </ol>                                              |          |   |
|    | **DEVICE PROGRAMMING**                                                                                                       |          |   |
|    | 3. Auto programming<br>4. IAP Program by Index                                                                               |          |   |
|    | 5. IAP Program by address                                                                                                    |          |   |
|    | 6. Initiate Auto-Update                                                                                                      |          | ~ |





# 6.5 Running IAP

To run IAP:

1. Press 4, IAP program by Index. After around 28 seconds, the IAP with image at index 2 is executed successfully and the design version **05** is displayed as shown in the following figure.

Figure 41 • Successful IAP at Index 2



 Press 5, IAP program by address. After around 28 seconds, the IAP with image at address 0x1400000 is executed successfully and the design version 05 is displayed as shown in the following figure.





This concludes running the IAP feature.



# 7 Appendix: Programming On-board SPI Flash Using Libero

Libero SoC PolarFire Design Suite supports the on-board SPI Flash programming using JTAG. For more information about the SPI Flash programming modes, see *UG0714: PolarFire FPGA Programming User Guide*.

To program the SPI flash using JTAG:

- 1. Ensure that the jumper settings on the board are the same as those listed in Table 5, page 27.
- 2. In the **Design Flow** window, select **Program and Debug Design** and then double-click **Configure Design Initialization Data and Memories**.

#### *Figure 43* • Configure Design Initialization Data and Memories Option



- 3. In the Design and Memory Initialization page, select the **SPI Flash** tab, as shown in Figure 44, page 37.
- 4. In SPI Flash Clients pane, add the required programming images (.spi images), and click **Apply**. These images are provided at

*mpf\_ac471\_liberosocpolarfirev2p2\_df\Libero\_Project\hw\_project\designer\PROC\_SUBSYSTEM\export.* 

#### Figure 44 • SPI Flash Tab

| Design Flow & X                                                                           | Reports & X PROC_SL                                   |              |                        |                                   |           |                                       |         |             |         | - |
|-------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------|------------------------|-----------------------------------|-----------|---------------------------------------|---------|-------------|---------|---|
|                                                                                           | Reports @ X   W PROC_SL                               | JESYSTEM     | S Constraint Manager   | X StartPage @ X Design            | and Memor | y Inibalization* e ×                  |         |             |         | - |
| Top Module(root): PROC_SUBSYSTEM 🛛 🖸 🖉 🜮                                                  | ✓ Design Initialization √ uPROM √                     | sivin / S    | PI Flash* Fabric RAMs  |                                   |           |                                       |         |             |         |   |
| Tool                                                                                      | Apply Discard                                         | Help         | ]                      |                                   |           |                                       |         |             |         |   |
| Verify Post Layout Implementation     Verify Timing                                       | F Enable Auto Update                                  |              |                        |                                   |           |                                       |         |             |         |   |
| Open SmartTime                                                                            | Manufacture: MICRON  Part No: MT250(J) 16888855F-05IT |              |                        |                                   |           |                                       |         |             |         |   |
| 💦 Verify Power                                                                            |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| Program and Debug Design                                                                  | Usage statistics                                      | SPI Flash Cl | ients                  |                                   |           |                                       |         |             |         |   |
| ✓ —•☐ Generate FPGA Array Data                                                            | Available memory (MB): 127                            | Add          | Edt D                  | elete                             |           |                                       |         |             |         |   |
| Configure Design Initialization Data and Memories     Generate Design Initialization Data | Used memory (MB): 27                                  |              |                        | Cicic                             |           |                                       |         |             |         |   |
| Configure Hardware                                                                        | Free memory (MB) : 100                                |              |                        | _                                 |           |                                       | Start   | End         | Design  |   |
| Programming Connectivity and Interface                                                    | Free memory (Ho) . 100                                | Program      | Name                   | Type                              | Index     | Content File                          | Address |             | Version |   |
| - A Configure Programmer                                                                  |                                                       | F            |                        | SPI Bitstream for Recovery/Golden |           |                                       | 0x400   | 0x91690f 0  |         |   |
| Bevice I/O States During Programming - JTAG M                                             |                                                       | M            | golden_image_v0        | SPI Bitstream for Recovery/Golden | 0         | designer/PROC_SUBSYSTEM/exp           | UX400   | 00/916901 0 |         |   |
| - Gonfigure Programming Options                                                           |                                                       | R            | update image v2        | SPI Bitstream for Auto Update     |           | D:<br>\mutvam\final\mof_ac466_liberos |         | 0x131650f 2 |         |   |
| - 🐻 Configure Security                                                                    |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| Program Design                                                                            |                                                       | N .          | iap_image_v5           | SPI Bitstream for IAP             | 2         | D:<br>\mutyam\final\mpf_ac466_liberos | 0x14000 | 0x1d1650f 5 |         |   |
| Generate Bitstream                                                                        |                                                       |              |                        |                                   |           | Landau A. et Mar. De 100 Dec 0011     |         |             |         |   |
| Run PROGRAM Action     Program SPI Flash Image                                            |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| Generate SPI Flash Image                                                                  |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| Run ERASE SPI FLASH Action                                                                |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| Debug Design                                                                              |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| - R Identify Debug Design                                                                 |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| SmartDebug Design                                                                         |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| Configure Permanent Locks for Production                                                  |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| Configure OTP Security                                                                    |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| B Handoff Design for Production                                                           |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| V Export Bitstream                                                                        |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| Export FlashPro Express Job                                                               |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| Export SPI Flash Image                                                                    |                                                       |              |                        |                                   |           |                                       |         |             |         |   |
| -• Export Pin Report                                                                      | Used space                                            | SPI Bitstre  | am for Recovery/Golden |                                   |           |                                       |         |             |         |   |
| Export BSDL                                                                               | Free space                                            |              | are for Auto Lindate   |                                   |           |                                       |         |             |         |   |
| Handoff Design for Debugging     Sport SmartDebug Data                                    |                                                       | ioni estatre | om or wate opeare      |                                   |           |                                       |         |             |         |   |
| w Export smartuebug Data                                                                  |                                                       |              |                        |                                   |           |                                       |         |             |         |   |

- 5. Connect the power supply cable to the **J2** connector on the board.
- 6. Connect the USB cable from the host PC to **J1** (FTDI port) on the board.
- 7. Double-click **Generate SPI Flash Image** and double-click **Run PROGRAM\_SPI\_IMAGE Action** to get the SPI flash programmed with the programming images as shown in the following figure.

#### Figure 45 • SPI Flash Programming



- 8. Power-cycle the board once you program the device.
- **Note:** If you program the external SPI flash using Libero, set the on-board **SW8** DIP 1 to **On** because the fabric design is not required to program the SPI flash. Libero takes approximately 30 minutes to program the three programming files into SPI Flash.

This concludes the on-board SPI Flash Programming.



# 8 Appendix: References

This section lists documents that provide more information about programming and other IP cores used.

- For more information about PolarFire FPGA programming, see the UG0714: PolarFire FPGA *Programming User Guide*.
- For more information about the CoreJTAGDEBUG IP core, see CoreJTAGDebug\_HB.pdf from Libero->Catalog.
- For more information about the CoreAHBtoAPB3 IP core, see CoreAHBtoAPB3\_HB.pdf.
- For more information about the CoreUARTapb IP core, see CoreUARTapb\_HB.pdf.
- For more information about the CoreAHBLite IP core, see CoreAHBLite\_HB.pdf.
- For more information about the CoreAPB3 IP core, see CoreAPB3\_HB.pdf.
- For more information about the CoreGPIO IP core, see CoreGPIO\_HB.pdf.
- For more information about the PolarFire initialization monitor, see UG0725: PolarFire FPGA Device Power-Up and Resets User Guide.
- For more information about how to build a Mi-V processor subsystem for PolarFire devices, see TU0775: PolarFire FPGA: Building a Mi-V Processor Subsystem Tutorial.
- For more information about the PF\_CCC IP core, see UG0684: PolarFire FPGA Clocking Resources User Guide.
- For more information about migration of SoftConsole v5.1 project to SoftConsole v5.2, see AC465: Migrating a SoftConsole v5.1 Project to SoftConsole v5.2 Application Note.
- For more information about the SRAM buffer, see UG0680: PolarFire FPGA Fabric User Guide.
- For more information about Libero, ModelSim, and Synplify, see the Microsemi Libero SoC PolarFire web page.