

# **Quick Start Design Guide**

## **PolarFire MIV\_RV32 v3.0**

October 2020



# Contents

---

|                                                                                                    |           |
|----------------------------------------------------------------------------------------------------|-----------|
| <b>1 Revision History.....</b>                                                                     | <b>1</b>  |
| 1.1 Revision 2.0.....                                                                              | 1         |
| 1.2 Revision 1.0.....                                                                              | 1         |
| <b>2 Introduction.....</b>                                                                         | <b>2</b>  |
| <b>3 Create a Libero Project.....</b>                                                              | <b>3</b>  |
| 3.1 Create the Core SmartDesign.....                                                               | 5         |
| 3.2 Clock Conditioning Circuit Configuration.....                                                  | 6         |
| 3.3 PolarFire RC Oscillator Configuration.....                                                     | 7         |
| 3.4 CoreRESET_PF Configuration.....                                                                | 7         |
| 3.5 PolarFire Initialization Monitor Configuration.....                                            | 8         |
| 3.6 MIV_RV32 Configuration.....                                                                    | 9         |
| 3.7 CoreJTAGDebug Configuration.....                                                               | 12        |
| 3.8 Memory and Peripheral Configurations—PolarFire SRAM.....                                       | 12        |
| <b>4 Peripheral Connections.....</b>                                                               | <b>14</b> |
| 4.1 CoreAPB3 Configuration.....                                                                    | 14        |
| 4.2 CoreUARTapb Configuration.....                                                                 | 14        |
| 4.3 CoreTimer 0 Configuration.....                                                                 | 14        |
| 4.4 CoreTimer 1 Configuration.....                                                                 | 15        |
| 4.5 CoreGPIO_IN Configuration.....                                                                 | 15        |
| 4.6 CoreGPIO_OUT Configuration.....                                                                | 15        |
| 4.7 Component Connections List.....                                                                | 16        |
| <b>5 Design Constraints.....</b>                                                                   | <b>20</b> |
| <b>6 Configure Design Initialization Data and Memories.....</b>                                    | <b>22</b> |
| 6.1 Configure LSRAM Memory via LSRAM Configurator.....                                             | 22        |
| 6.2 Configure LSRAM Memory via Configure Design Initialization Data and Memories Configurator..... | 22        |
| <b>7 Run Project from SoftConsole.....</b>                                                         | <b>25</b> |
| 7.1 Set System Clock Frequency and Peripheral Base Addresses.....                                  | 25        |
| 7.2 Build and Debug a Project.....                                                                 | 26        |
| 7.3 Create a Deployable Hex File.....                                                              | 28        |
| 7.4 Communicate via UART.....                                                                      | 29        |
| <b>8 Simulation of the Design.....</b>                                                             | <b>32</b> |

# Tables

---

|                                                 |    |
|-------------------------------------------------|----|
| Table 1 • PF_OSC_C0_0.....                      | 16 |
| Table 2 • PF_CCC_C0_0.....                      | 16 |
| Table 3 • PolarFire Initialization Monitor..... | 16 |
| Table 4 • MIV_RV32.....                         | 17 |
| Table 5 • CoreRESET_PF.....                     | 17 |
| Table 6 • CoreAPB3_C0_0.....                    | 18 |
| Table 7 • CoreUARTapb_C0_0.....                 | 18 |
| Table 8 • CoreGPIO_IN_0.....                    | 18 |
| Table 9 • CoreGPIO_OUT_0.....                   | 18 |
| Table 10 • CoreJTAGDebug_C0_0.....              | 19 |

# Figures

---

|                                                                                  |    |
|----------------------------------------------------------------------------------|----|
| Figure 1 • Create a Libero Project.....                                          | 3  |
| Figure 2 • Project Name and Location.....                                        | 3  |
| Figure 3 • Select Device and Part.....                                           | 4  |
| Figure 4 • New Project Home Screen.....                                          | 4  |
| Figure 5 • Create a New SmartDesign.....                                         | 4  |
| Figure 6 • New SmartDesign Canvas.....                                           | 5  |
| Figure 7 • Design Segment.....                                                   | 5  |
| Figure 8 • Create a Component for SmartDesign.....                               | 6  |
| Figure 9 • Clock Conditioning Circuitry (CCC) Configuration Menu.....            | 6  |
| Figure 10 • Change Requested Frequency to 50 MHz.....                            | 6  |
| Figure 11 • Enable 160 MHz Oscillator.....                                       | 7  |
| Figure 12 • Instantiating CoreRESET_PF .....                                     | 7  |
| Figure 13 • CoreRESET_PF Configurator Default Settings.....                      | 8  |
| Figure 14 • PolarFire Initialization Monitor Configurator Required Settings..... | 9  |
| Figure 15 • Instantiate MIV_RV32 Core.....                                       | 9  |
| Figure 16 • MIV_RV32 Configurator Setup.....                                     | 10 |
| Figure 17 • Update the MIV_RV32 Memory Map.....                                  | 11 |
| Figure 18 • Instantiate CoreJTAGDebug.....                                       | 12 |
| Figure 19 • CoreJTAGDebug Configurator Default Settings.....                     | 12 |
| Figure 20 • PF_SRAM_AHBL_AXI Configuration.....                                  | 13 |
| Figure 21 • CoreAPB3 Required Configuration.....                                 | 14 |
| Figure 22 • CoreGPIO_IN Configuration.....                                       | 15 |
| Figure 23 • CoreGPIO_OUT Configuration.....                                      | 15 |
| Figure 24 • Final Design.....                                                    | 19 |
| Figure 25 • Design Flow Progression.....                                         | 23 |
| Figure 26 • Design Initialization Data and Memories Configurator.....            | 23 |
| Figure 27 • Fabric RAM Initialization Configurator.....                          | 24 |
| Figure 28 • Design Initialization Data and Memories Configurator.....            | 24 |
| Figure 29 • Set System Clock Frequency and Peripheral Base Addresses.....        | 25 |
| Figure 30 • MIV_RV32 Configurator Memory Map.....                                | 26 |
| Figure 31 • Build Configurations.....                                            | 27 |
| Figure 32 • Build and Debug a Project.....                                       | 27 |
| Figure 33 • Select a Debug Configuration.....                                    | 28 |
| Figure 34 • Run a Program.....                                                   | 28 |
| Figure 35 • Open Device Manager.....                                             | 29 |
| Figure 36 • Find COM Ports in Device Manager.....                                | 29 |
| Figure 37 • Location of Baud Rate Value.....                                     | 30 |
| Figure 38 • Serial Output from COM9 Terminal.....                                | 30 |
| Figure 39 • Output from SoftConsole Terminal.....                                | 31 |
| Figure 40 • UART Clock Frequency Issues.....                                     | 31 |

# 1 Revision History

---

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

## 1.1 Revision 2.0

Revision 2.0 was published in October 2020. The following is a summary of changes.

- Changed the core name to MIV\_RV32 from MIV\_RV32IMC.
- Updated figures to reflect v3.0 updates.

## 1.2 Revision 1.0

Revision 1.0 was published in March 2020. It is the first publication of this document.

## 2 Introduction

---

This guide provides quick-start steps to set up the MIV\_RV32 IP core in Libero, generate a bitstream, and download the FPGA data to a device. Debug software and use a serial terminal to capture UART output in SoftConsole. This guide is targeted towards the PolarFire Evaluation Kit. Note that the MIV\_RV32 IP core is written in System Verilog.

## 3 Create a Libero Project

Open Libero and select **Project > New Project** from the top menu.

**Figure 1 • Create a Libero Project**



From Project Details, enter **Project name** and **Project location** then click **Next**.

**Figure 2 • Project Name and Location**



From Device Selection, for example select **MPF300TS\_1FCG1152I used on the PolarFire Evaluation Board**. The following Part Filter search terms can be used to find the correct device.

- Family: PolarFire
- Die: MPF300TS
- Package: FCG1152I
- Range: IND

**Figure 3 • Select Device and Part**

Click **Finish**.

The following New Project Home Screen will appear.

**Figure 4 • New Project Home Screen**

Create a new SmartDesign by selecting **File > New > SmartDesign** and name it **BaseDesign**.

**Figure 5 • Create a New SmartDesign**

Once the SmartDesign has been created, a blank canvas will appear where the example design will be created.

**Figure 6 • New SmartDesign Canvas**

### 3.1 Create the Core SmartDesign

The following design can be produced using this document.

**Figure 7 • Design Segment**

#### Components needed:

- 1 × PolarFire RC Oscillators (OSC) (v1.0.102)
- 1 × Clock Conditioning Circuit (CCC) (v2.2.100)
- 1 × COREREST\_PF (v2.2.107)
- 1 × PF\_INIT\_MONITOR (v2.0.105)
- 1 × CoreJTAGDebug (v3.1.100)
- 1 × MIV\_RV32 (v3.0.100)
- 1 × PF\_SRAM\_AHBL\_AXI (v1.2.105)
- 1 × CoreAPB3 (v4.1.100)
- 1 × CoreUARTapb (v5.6.102)
- 2 × CoreGPIO (GPIO\_IN and GPIO\_OUT) (v3.2.102)
- 2 × CoreTimer (v2.0.103)

**Note:** These are the latest components at the time of publication, please always use the latest available components from the catalog.

## 3.2 Clock Conditioning Circuit Configuration

To add the Clock Conditioning Circuitry to the SmartDesign, select the **Catalog** tab, search for **CCC**, and double click on it. A dialog box will appear with the default name **PF\_CCC\_0**. Select **OK**.

**Figure 8 • Create a Component for SmartDesign**



The following Clock Conditioning Circuitry (CCC) configuration menu will open. Change the clock **Input Frequency** to **160 MHz**.

**Figure 9 • Clock Conditioning Circuitry (CCC) Configuration Menu**



Under Output Clock 0, change **Requested Frequency** to **50 MHz**.

**Figure 10 • Change Requested Frequency to 50 MHz**



### 3.3 PolarFire RC Oscillator Configuration

To add the PolarFire RC Oscillator to the SmartDesign, select the **Catalog** and search for **OSC**. Double click on the **PolarFire RC Oscillator** to instantiate it in the SmartDesign. The default configuration should be used.

**Figure 11 • Enable 160 MHz Oscillator**



### 3.4 CoreRESET\_PF Configuration

To add the CORERESET\_PF to the SmartDesign, select the **Catalog** and search for **reset**. Double click on **CoreReset\_PF** to instantiate it into the SmartDesign.

**Figure 12 • Instantiating CoreRESET\_PF**



The default configuration for CoreRESET\_PF can be used.

**Figure 13 • CoreRESET\_PF Configurator Default Settings**

### 3.5 PolarFire Initialization Monitor Configuration

Search for monitor in the catalog and double click **PolarFire Initialisation Monitor** to instantiate in the SmartDesign. Uncheck the **Calibration Monitor** and **Calibration Start** boxes as shown in the following figure.

**Figure 14 • PolarFire Initialization Monitor Configurator Required Settings**

## 3.6 MIV\_RV32 Configuration

To add the MIV\_RV32 to the SmartDesign, search for **MIV RV32** in the catalog and double click to instantiate. The default configuration is shown in the following figure.

**Figure 15 • Instantiate MIV\_RV32 Core**

**Figure 16 • MIV\_RV32 Configurator Setup**

The memory map is set to the following address range.

Figure 17 • Update the MIV\_RV32 Memory Map



### 3.7 CoreJTAGDebug Configuration

To add the CoreJTAGDebug block to the SmartDesign, search CoreJTAGDebug in the catalog and double click to instantiate.

**Figure 18 • Instantiate CoreJTAGDebug**



The default configuration for CoreJTAGDebug can be used.

**Figure 19 • CoreJTAGDebug Configurator Default Settings**



### 3.8 Memory and Peripheral Configurations—PolarFire SRAM

To add the PolarFire SRAM to the SmartDesign, search for sram and select PolarFire SRAM (AHBLite and AXI). Under Memory Settings, configure **Memory Depth (in words)** to **65536**. Under Interface Settings, configure **Fabric Interface type** to **AHBLite**. The MIV\_RV32 core is connected directly to the PF\_SRAM\_AHBL\_AXI block.

**Figure 20 • PF\_SRAM\_AHBL\_AXI Configuration**

## 4 Peripheral Connections

The following section describes the peripheral configurations and connections for the design.

### 4.1 CoreAPB3 Configuration

To add the CoreAPB3 to the SmartDesign, search for coreapb3 and double-click to instantiate it in the SmartDesign. Configure the core to set the **Number of address bits driven by master** to 16 and under **Enable APB Slots** check **Slots 1, 2, 3, 4, and 5**. CoreAPB3 can be connected directly to the core.

**Figure 21 • CoreAPB3 Required Configuration**



### 4.2 CoreUARTapb Configuration

To add CoreUARTapb to the SmartDesign, search for CoreUARTapb in the catalog and double click to instantiate. The default name and configuration for CoreUARTapb can be used.

### 4.3 CoreTimer\_0 Configuration

To add CoreTimer\_0 to the SmartDesign search for CoreTimer in the catalog and double click to instantiate. The default name and configuration for CoreTimer can be used.

## 4.4 CoreTimer 1 Configuration

To add CoreTimer\_1 to the SmartDesign search for CoreTimer in the catalog and double click to instantiate. The default name and configuration for CoreTimer can be used.

## 4.5 CoreGPIO\_IN Configuration

To add CoreGPIO to the SmartDesign search for CoreGPIO in the catalog and double click to instantiate. Enter the component name as CoreGPIO\_IN. This CoreGPIO is configured to have two fixed configured inputs as shown in the following figure.

**Figure 22 • CoreGPIO\_IN Configuration**



## 4.6 CoreGPIO\_OUT Configuration

To add CoreGPIO to the SmartDesign search for CoreGPIO in the catalog and double click to instantiate. Enter the component name as CoreGPIO\_OUT. This CoreGPIO is configured to have four fixed configured outputs as shown in the following figure.

**Figure 23 • CoreGPIO\_OUT Configuration**



## 4.7 Component Connections List

The following tables list each component and each component it is connected to.

**Table 1 • PF\_OSC\_CO\_0**

| Connect From                | Connect To            |
|-----------------------------|-----------------------|
| PF_OSC_CO_0:RCOSC_160MHZ_GL | PF_CCC_CO_0:REF_CLK_0 |

**Table 2 • PF\_CCC\_CO\_0**

| Connect From              | Connect To                 |
|---------------------------|----------------------------|
| PF_OSC_CO_0:OUT0_FABCLK_0 | CORERESET_PF_CO_0:CLK      |
|                           | MIV_RV32_CO_0:clk          |
|                           | PF_SRAM_AHBL_AXI_CO_0:HCLK |
|                           | COREUARTAPB_CO_0:PCLK      |
|                           | CORETIMER_CO_0:PCLK        |
|                           | CORETIMER_C1_0:PCLK        |
|                           | COREGPIO_IN_0:PCLK         |
|                           | COREGPIO_OUT_0:PCLK        |
| PF_CCC_CO_0:PLL_LOCK_0    | CORERESET_PF_CO_0:PLL_LOCK |

**Table 3 • PolarFire Initialization Monitor**

| Connect From                                    | Connect To                   |
|-------------------------------------------------|------------------------------|
| PF_INIT_MONITOR_CO_0:FABRIC_POR_N               | CORERESET_PF_CO_0:FPGA_POR_N |
| PF_INIT_MONITOR_CO_0:DEVICE_INIT_DONE           | CORERESET_PF_CO_0:INIT_DONE  |
| PF_INIT_MONITOR_CO_0:PCIE_INIT_DONE             | Mark Unused                  |
| PF_INIT_MONITOR_CO_0:SRAM_INIT_DONE             | Mark Unused                  |
| PF_INIT_MONITOR_CO_0:XCVR_INIT_DONE             | Mark Unused                  |
| PF_INIT_MONITOR_CO_0:USRAM_INIT_FROM_SNVM_DONE  | Mark Unused                  |
| PF_INIT_MONITOR_CO_0:USRAM_INIT_FROM_UPROM_DONE | Mark Unused                  |
| PF_INIT_MONITOR_CO_0:USRAM_INIT_FROM_SPI_DONE   | Mark Unused                  |
| PF_INIT_MONITOR_CO_0:SRAM_INIT_FROM_SNVM_DONE   | Mark Unused                  |
| PF_INIT_MONITOR_CO_0:SRAM_INIT_FROM_UPROM_DONE  | Mark Unused                  |
| PF_INIT_MONITOR_CO_0:SRAM_INIT_FROM_SPI_DONE    | Mark Unused                  |

| Connect From                        | Connect To  |
|-------------------------------------|-------------|
| PF_INIT_MONITOR_C0_0:AUTOCALIB_DONE | Mark Unused |

**Table 4 • MIV\_RV32**

| Connect From                       | Connect To                              |
|------------------------------------|-----------------------------------------|
| MIV_RV32_C0_0:JTAG_TCK             | COREJTAGDEBUG_C0_0:TGT_TCK_0            |
| MIV_RV32_C0_0:JTAG_TDI             | COREJTAGDEBUG_C0_0:TGT_TDI_0            |
| MIV_RV32_C0_0:JTAG_TDO             | COREJTAGDEBUG_C0_0:TGT_TDO_0            |
| MIV_RV32_C0_0:JTAG_TMS             | COREJTAGDEBUG_C0_0:TGT_TMS_0            |
| MIV_RV32_C0_0:JTAG_TRSTN           | COREJTAGDEBUG_C0_0:TGT_TRSTN_0          |
| MIV_RV32_C0_0:EXT_RESETN           | Mark unused                             |
| MIV_RV32_C0_0:JTAG_TDO_DR          | Mark unused                             |
| MIV_RV32_C0_0:EXT_IRQ              | CORETIMER_C1_0:TIMINT                   |
| MIV_RV32_C0_0:MSYS_EI[5:1]         | Tie low                                 |
| MIV_RV32_C0_0:MSYS_EI[0]           | CORETIMER_C0_0:TIMINT                   |
| MIV_RV32_C0_0:TIME_COUNT_OUT[63:0] | Mark unused                             |
| MIV_RV32_C0_0:AHBL_M_SLV           | PF_SRAM_AHBL_AXI_C0_0:AHBSLAVEINTERFACE |
| MIV_RV32_C0_0:APB_MSTR             | COREAPB3_C0_0:APB3MASTER                |

**Table 5 • CoreRESET\_PF**

| Connect From                         | Connect To                                                                                                                                                                         |
|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CORERESET_PF_C0_0:EXT_RSTN           | Promote to top level and rename to DEVRST_N. To rename the input port EXT_RSTN, right-click the port and select Modify/Rename, a text box will open. Enter DEVRST_N and select OK. |
| CORERESET_PF_C0_0:BANK_x_VDDI_STATUS | Tie high                                                                                                                                                                           |
| CORERESET_PF_C0_0:BANK_y_VDDI_STATUS | Tie high                                                                                                                                                                           |
| CORERESET_PF_C0_0:SS_BUSY            | Tie low                                                                                                                                                                            |
| CORERESET_PF_C0_0:FF_US_RESTORE      | Tie low                                                                                                                                                                            |
| CORERESET_PF_C0_0:PLL_POWERDOWN_B    | Mark unused                                                                                                                                                                        |
| CORERESET_PF_C0_0:FABRIC_RESET_N     | MIV_RV32_C0_0:RESETN                                                                                                                                                               |
|                                      | PF_SRAM_AHBL_AXI_C0_0:HRESETN                                                                                                                                                      |
|                                      | COREUARTAPB_C0_0:PRESETN                                                                                                                                                           |

| Connect From | Connect To             |
|--------------|------------------------|
|              | CORETIMER_CO_0:PRESETN |
|              | CORETIMER_C1_0:PRESETN |
|              | COREGPIO_IN_0:PRESETN  |
|              | COREGPIO_OUT_0:PRESETN |

**Table 6 • CoreAPB3\_CO\_0**

| Connect From             | Connect To               |
|--------------------------|--------------------------|
| COREAPB3_CO_0:APBMSLAVE1 | COREUARTAPB_CO_0:APB_BIF |
| COREAPB3_CO_0:APBMSLAVE2 | GOREGPIO_IN_0:APB_BIF    |
| COREAPB3_CO_0:APBMSLAVE3 | CORETIMER_CO_0:APBSLAVE  |
| COREAPB3_CO_0:APBMSLAVE4 | CORETIMER_C1_0:APBSLAVE  |
| COREAPB3_CO_0:APBMSLAVE5 | COREGPIO_OUT_0:APB_BIF   |

**Table 7 • CoreUARTapb\_CO\_0**

| Connect From                 | Connect To           |
|------------------------------|----------------------|
| COREUARTAPB_CO_0:RX          | Promote to top level |
| COREUARTAPB_CO_0:TX          | Promote to top level |
| COREUARTAPB_CO_0:TXRDY       | Mark unused          |
| COREUARTAPB_CO_0:RXRDY       | Mark unused          |
| COREUARTAPB_CO_0:PARITY_ERR  | Mark unused          |
| COREUARTAPB_CO_0:OVERFLOW    | Mark unused          |
| COREUARTAPB_CO_0:FRAMING_ERR | Mark unused          |

**Table 8 • CoreGPIO\_IN\_0**

| Connect From                | Connect To           |
|-----------------------------|----------------------|
| COREGPIO_IN_0:GPIO_IN[1:0]  | Promote to top level |
| COREGPIO_IN_0:INT[1:0]      | Mark unused          |
| COREGPIO_IN_0:GPIO_OUT[1:0] | Mark unused          |

**Table 9 • CoreGPIO\_OUT\_0**

| Connect From                | Connect To |
|-----------------------------|------------|
| COREGPIO_OUT_0:GPIO_IN[3:0] | Tie low    |

| Connect From                 | Connect To           |
|------------------------------|----------------------|
| COREGPIO_OUT_0:INT[3:0]      | Mark unused          |
| COREGPIO_OUT_0:GPIO_OUT[3:0] | Promote to top level |

**Table 10 • CoreJTAGDebug\_CO\_0**

| Connect From             | Connect To           |
|--------------------------|----------------------|
| COREJTAGDEBUG_CO_0:TCK   | Promote to top level |
| COREJTAGDEBUG_CO_0:TDI   | Promote to top level |
| COREJTAGDEBUG_CO_0:TDO   | Promote to top level |
| COREJTAGDEBUG_CO_0:TMS   | Promote to top level |
| COREJTAGDEBUG_CO_0:TRSTB | Promote to top level |

**Figure 24 • Final Design**

## 5 Design Constraints

---

Add the I/O constraints for the PolarFire Evaluation Kit to the design flow tab and select Manage Constraints. Under the I/O Attributes tabs, add the following constraints by selecting New and naming the file io\_constraints. Then, copy the constraints below into this file. Save the constraints file and select the check box under Place and Route. Save the I/O constraints.

```
# -- User PushButtons I/O --
set_io -port_name {GPIO_IN[1]} \
  -pin_name B27 \
  -fixed true \
  -DIRECTION INPUT

set_io -port_name {GPIO_IN[0]} \
  -pin_name C21 \
  -fixed true \
  -DIRECTION INPUT

set_io -port_name DEVRST_N \
  -pin_name K22 \
  -fixed true \
  -DIRECTION INPUT

# -- LEDs I/O --
set_io -port_name {GPIO_OUT[0]} \
  -pin_name F22 \
  -fixed true \
  -DIRECTION OUTPUT

set_io -port_name {GPIO_OUT[1]} \
  -pin_name B26 \
  -fixed true \
  -DIRECTION OUTPUT

set_io -port_name {GPIO_OUT[2]} \
  -pin_name C26 \
  -fixed true \
  -DIRECTION OUTPUT

set_io -port_name {GPIO_OUT[3]} \
  -pin_name D25 \
  -fixed true \
  -DIRECTION OUTPUT

# -- UART RX/TX --
set_io -port_name RX \
  -pin_name H18 \
  -fixed true \
  -DIRECTION INPUT

set_io -port_name TX \
  -pin_name G17 \
  -fixed true \
  -DIRECTION OUTPUT
```

Add the Timing constraints to the design flow tab and select Manage Constraints. Under the Timing tab, add the following constraints by selecting New and naming the file io\_jtag\_constraints. Then, copy the constraints below into this file.

```
#Constraining the JTAG clock to 6 MHz
create_clock -name {TCK} -period 166.67 -waveform {0 83.33} [ get_ports { TCK } ]
set_clock_groups -name {async1} -asynchronous -group [ get_clocks {
  PF_CCC_C0_0/PF_CCC_C0_0/pll_inst_0/OUT0 } ] -group [ get_clocks { TCK } ]
```

Save the constraints file, and associate it with Synthesis, Place and Route and Timing Verification by selecting each of the check boxes. It is also important to add in the derived constraints. This is done by selecting Derive Constraints in the Timing tab and accepting the default settings. Save the Timing Constraints.

## 6 Configure Design Initialization Data and Memories

The PolarFire LSRAM can be configured to boot a program from power-on reset. There are two ways to configure this:

- Configure the LSRAM memory via the LSRAM configurator.
- Configure the LSRAM memory via the Configure Design Initialisation Data and Memories configurator.

### 6.1 Configure LSRAM Memory via LSRAM Configurator

Open the SmartDesign, BaseDesign if closed. Locate the PF\_SRAM\_AHBL\_AXI\_C0\_0.

1. Right-click on the core and select **Configure**.
2. Select the Memory Initialisation Settings tab.
3. Select the **Initialise RAM at Power up** check box.
4. Select the hex file created by SoftConsole when building a project (see section [Create a Deployable Hex File](#)).
5. In the Design Flow tab, select **Generate bitstream**. Once this has completed, the programming file is ready to download to the FPGA board.
6. Connect the power cable to your FPGA board.
7. Connect the USB cable to the Embedded FlashPro5 micro USB port and to the USB port of your computer.
8. In the Design Flow tab, select **Run Program Action** to download the programming file to the FPGA.

### 6.2 Configure LSRAM Memory via Configure Design Initialization Data and Memories Configurator

If you have run through the bitstream generation and you'd like to add or change the firmware in the LSRAM, this can be done via the Configure Design Initialization Data and Memories configurator.

**Figure 25 • Design Flow Progression**

1. Run the flow so that the "Generate FPGA Array Data" step in the design flow is completed.
2. Select the Fabric RAMs tab.
3. Select Filter out Inferred RAM (Optional).
4. Double-click on the RAM to be initialized to open its configurator.

**Figure 26 • Design Initialization Data and Memories Configurator**

5. Under **Ram Initialization Options**, select **Content from file** and select the hex file created by SoftConsole when building a project (see section [Create a Deployable Hex File](#)).
6. Choose the appropriate storage location, for example **sNVM**.

**Figure 27 • Fabric RAM Initialization Configurator**

7. Click **OK** and return to Libero.

8. Click **Apply** in the Fabric RAMs tab.

**Figure 28 • Design Initialization Data and Memories Configurator**

9. In the Design Flow tab, select **Generate bitstream**. Once this has completed, the programming file is ready to download to the FPGA board.

10. Connect the power cable to your FPGA board.

11. Connect the USB cable to the Embedded FlashPro5 USB port and to the USB port of your computer.

12. In the Design Flow tab, select **Run Program Action** to download the programming file to the FPGA.

## 7 Run Project from SoftConsole

The following steps explain how to build and run a project in SoftConsole for the MIV\_RV32 core. Open SoftConsole and the example project X.

### 7.1 Set System Clock Frequency and Peripheral Base Addresses

If UART is being used, the system clock frequency needs to be provided to the software and is done in the “hw\_platform.h” file by changing the #define SYS\_CLK\_FREQ to the clock frequency (note this value must be in hertz).

**Figure 29 • Set System Clock Frequency and Peripheral Base Addresses**



The “hw\_platform.h” file is also used to set the base address for peripherals, the base address of a peripheral can be found in the project memory map generated by Libero.

The peripheral address in the hw\_platform.h file must match the address in Libero for the peripheral to function correctly. These peripherals are addressed for 0x0 because the core redirects these addresses accordingly. Configuration settings for peripherals are displayed in the following figure.

**Figure 30 • MIV\_RV32 Configurator Memory Map**

## 7.2 Build and Debug a Project

When you're ready to build your project, right-click on the project and select **Build Configurations > Set Active > 5 miv32imc-Debug** as shown in the following figure. Then, click the **Build** icon. In this case, the project is being built for debug.

**Figure 31 • Build Configurations****Figure 32 • Build and Debug a Project**

Once you have an error-free build, you can test it on your device. Make sure your device is connected and powered on, then click the **Debug** icon. If this is your first time debugging this project, you will have to select a debug configuration.

**Figure 33 • Select a Debug Configuration**



Once you have selected a debug configuration, click **Debug**. This will download the program to your device and take you to the debug perspective. The program will launch and halt on main. It can be run by clicking **Resume** or pressing **F8**.

**Figure 34 • Run a Program**



To add breakpoints and step through the code, ensure you are in the main.c tab.

## 7.3 Create a Deployable Hex File

The following steps create a hex file in SoftConsole:

1. Open the Project Properties, right-click > **Project Properties**.
2. Select the correct linker script > **GNU RISC-V Cross Create Flash Image** > **General**.
3. In the Other Flags window add, where the MEMORY\_ADDRESS is the base address in the linker (for example, 0x60000000).

#### 4. Select **Apply** and **Close**.

A build configuration can be created, which will allow you to create deployable builds without needing to repeat this step. For more information, see the SoftConsole Release Notes section “Projects”.

## 7.4 Communicate via UART

The following are needed to communicate via UART:

- The COM port your is using and its baud rate
- A serial communication client (the built-in terminal in SoftConsole is used in this example)

Device Manager can be used to find the COM port of your device. To open it, right-click on **Start** and select **Device Manager**.

**Figure 35 • Open Device Manager**



The COM port for your device will be one of those listed under **Ports (COM & LPT)**. It may not be clear which one is your device and may require trial and error to find the correct port.

**Figure 36 • Find COM Ports in Device Manager**



The baud rate for the UART connection can be found in the `hw_platform.h` file within the SoftConsole project.

**Figure 37 • Location of Baud Rate Value**



```

 85 #define TMR0_1IRQN      External_31_IRQ
 86
 87 On the MV2 core, there is one external interrupt and it can also have
 88 up to six optional external system interrupts. On these cores there is no PLIC
 89 support. Therefore, it is necessary to directly define the interrupt mapping on the legacy
 90 RV32 core no interrupt number mapping is necessary on MV2 core.
 91 */
 92
 93 /*-----*/
 94 /* Baud value to achieve a 15300 baud rate with system clock defined by
 95 * SYS_CLK_FREQ.
 96 * This value is calculated using the following equation:
 97 * BAUD_VALUE = ((SYS_CLK_FREQ / (16 * BAUD_RATE)) - 1)
 98 */
 99 /*-----*/
100 /*-----*/
101 /* Baud value to achieve a 37680 baud rate with system clock defined by
102 * SYS_CLK_FREQ.
103 * This value is calculated using the following equation:
104 * BAUD_VALUE = ((SYS_CLK_FREQ / (16 * BAUD_RATE)) - 1)
105 */
106 /*-----*/
107 /* Define MSCC_STUDIO_THRU_CORE_UART_APB
108 * Define standard I/Os to be redirected to a terminal via UART.
109 */
110 #ifndef MSCC_STUDIO_THRU_CORE_UART_APB
111
112 #endif
113 /*-----*/
114 /* End of user section
115 */
116 #endif /* HU_PLATFORM_H */
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143

```

Open the serial communication client within SoftConsole by selecting **Window > Show View > Terminal**. Then, input the values for your COM port and baud rate.

**Figure 38 • Serial Output from COM9 Terminal**



Run your program and any UART output will be displayed in the communication client's terminal.

**Figure 39 • Output from SoftConsole Terminal**

```
System Timer Blinky Example

Observe the LEDs blinking on the board. The LED pattern changes every time a system timer interrupt occurs

Internal Timer Interrupt
Internal Timer Interrupt
Internal Timer Interrupt|
```

If the UART output isn't as expected (that is, the random/unknown characters are as shown in the following figure) it is more than likely an issue with the clock frequency in the `hw_platform.h` file and can be fixed by following the steps in this section.

#### Figure 40 • UART Clock Frequency Issues

```
tiny_blink_cfg (IRD-LT-M31868) [COM9] @
```

## 8 Simulation of the Design

---

This section describes how to simulate the design. The PF\_LSRAM must be initialized with a program (.hex) for the MIV\_RV32 core to execute.

**Note:** If the PF\_LSRAM has not been initialized with a program, complete steps 1–4 from the previous section [Configure LSRAM Memory via LSRAM Configurator](#).

The following steps create a testbench with the BaseDesign instantiated in it.

1. Right-click on the BaseDesign SmartDesign, then select **Create Testbench > HDL**.
2. Name the testbench **BaseDesign\_TB** and select the language **Verilog**.

The following steps run the simulation:

1. Select the **Simulation** tab and right-click on the **BaseDesign\_TB**.
2. Select **Simulate Pre-Synthesis Design > Open Interactively** to open ModelSim.
3. Once ModelSim has opened, expand **BaseDesign\_TB** and add **MIV\_RV32\_C0\_0** to the waveform.

**Note:** To add signals to the waveform, right-click and select **Add wave**. This will add all of the top level signals of **MIV\_RV32\_C0\_0** to the waveform viewer.

4. To run the simulation, go to the transcript window and type **run 100us**. This will run the simulation for 100  $\mu$ s.



**Microsemi**  
2355 W. Chandler Blvd.  
Chandler, AZ 85224 USA

Within the USA: +1 (480) 792-7200  
Fax: +1 (480) 792-7277

[www.microsemi.com](http://www.microsemi.com) © 2020 Microsemi and its corporate affiliates. All rights reserved. Microsemi and the Microsemi logo are trademarks of Microsemi Corporation and its corporate affiliates. All other trademarks and service marks are the property of their respective owners.

Microsemi's product warranty is set forth in Microsemi's Sales Order Terms and Conditions. Information contained in this publication is provided for the sole purpose of designing with and using Microsemi products. Information regarding device applications and the like is provided only for your convenience and may be superseded by updates. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is your responsibility to ensure that your application meets with your specifications. THIS INFORMATION IS PROVIDED "AS IS." MICROSEMI MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL MICROSEMI BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUENTIAL LOSS, DAMAGE, COST OR EXPENSE WHATSOEVER RELATED TO THIS INFORMATION OR ITS USE, HOWEVER CAUSED, EVEN IF MICROSEMI HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROSEMI'S TOTAL LIABILITY ON ALL CLAIMS IN RELATED TO THIS INFORMATION OR ITS USE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, YOU PAID DIRECTLY TO MICROSEMI FOR THIS INFORMATION. Use of Microsemi devices in life support, mission-critical equipment or applications, and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend and indemnify Microsemi from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microsemi intellectual property rights unless otherwise stated.

Microsemi Corporation, a subsidiary of Microchip Technology Inc. (Nasdaq: MCHP), and its corporate affiliates are leading providers of smart, connected and secure embedded control solutions. Their easy-to-use development tools and comprehensive product portfolio enable customers to create optimal designs which reduce risk while lowering total system cost and time to market. These solutions serve more than 120,000 customers across the industrial, automotive, consumer, aerospace and defense, communications and computing markets. Headquartered in Chandler, Arizona, the company offers outstanding technical support along with dependable delivery and quality. Learn more at [www.microsemi.com](http://www.microsemi.com).

50200909