# Hello FPGA Libero Design User Guide



## Introduction (Ask a Question)

Hello FPGA is a low cost, compact-sized, and a feature-rich FPGA kit based on the non-volatile, Flash-based, and low-power SmartFusion<sup>®</sup> 2 SoC FPGA (M2S010). SmartFusion 2 SoC FPGAs offer more resources in low density with a complete Microcontroller Subsystem (MSS) that includes a 166 MHz Arm<sup>®</sup> Cortex<sup>®</sup>-M3 processor with an Embedded Trace Macrocell (ETM) and Instruction Cache, embedded Flash, and extensive peripherals including CAN, TSE, and USB.

An ultra low-power Flash\*Freeze feature of SmartFusion 2 SoC FPGAs allows the retention of design while maintaining the I/O state for low-power applications. A single pin interrupt puts the device in the Flash\*Freeze mode and brings up these FPGAs to operational modes (within ~13 microseconds).

These FPGAs are ideal for general purpose functions such as Gigabit Ethernet or dual PCI Express control planes, bridging functions, input/output (I/O) expansion and conversion, video/image processing, system management and secure connectivity. These FPGAs are used by in Communications, Industrial, Medical, Defense, and Aviation markets.

The Hello FPGA kit is designed for FPGA beginners and enthusiasts. The Hello FPGA kit is ideal for developing control logic and data acquisition, image processing, signal processing, and artificial intelligence applications.

The kit supports the measurement of the live FPGA core power consumption while running the designs. The kit also allows you to freeze the design. The Hello FPGA kit includes a Microchip PIC32 MCU that is used to program the SmartFusion 2 SoC FPGA, monitor power, and general-purpose functions.

The Hello FPGA Kit demonstrates the following features of the SmartFusion 2 SoC FPGA:

- DSP functions: FIR Filter
- Parallel Processing and Complex functions: Artificial Intelligence (real time hand-written digit recognition)
- Low-Power: Shows power consumption in operational and Flash\*Freeze modes
- Instant ON: Highlighting fast wake-up from the Flash\*Freeze mode to Fully Functional mode

This user guide describes the following designs, which can be run on the kit:

- 1. Video Demo Design
- 2. Digit Recognition (AI) Demo Design
- 3. DSP FIR Filter Demo Design
- 4. Program and Debug

These designs are created using Microchip's Libero SoC Design Software. The software includes all of the necessary IPs required to build such application prototypes.



**Important:** These designs also include a user-friendly GUI application to test specific features functions. These demo designs include the Flash\*Freeze feature for demonstration. You can monitor the power consumption when FPGA is in Operational and Flash\*Freeze modes to evaluate the advantage of low-power.

The kit includes Arduino and Mikrobus connectors for flexibility for prototyping and expansion kits. This can be very useful as your knowledge of FPGA and the associated tools experience increases. The kit can work as a standalone unit or as an extension to existing Microchip kits.

The following figure shows the Hello FPGA kit, that has the SmartFusion 2 FPGA and MCU (PIC32MX795F512L).



The Hello FPGA kit includes the LCD board and the camera sensor. These boards can be connected to the Hello FPGA kit as shown in the following figure.



### Figure 2. LCD and Camera Sensor Boards





# **Table of Contents**

| Intr                                                    | Introduction1                       |                                       |    |  |       |                             |  |  |  |
|---------------------------------------------------------|-------------------------------------|---------------------------------------|----|--|-------|-----------------------------|--|--|--|
| 1.                                                      | Video                               | Video Demo Design5                    |    |  |       |                             |  |  |  |
|                                                         | 1.1.                                | Line_write_read Module                | 5  |  |       |                             |  |  |  |
|                                                         | 1.2.                                | FlashFreeze_SB Module                 | 6  |  |       |                             |  |  |  |
|                                                         | 1.3.                                | UART_interface                        | 9  |  |       |                             |  |  |  |
|                                                         | 1.4.                                | APB3_if (APB Target)1                 | 0  |  |       |                             |  |  |  |
|                                                         | 1.5.                                | Mux_2_11                              | 1  |  |       |                             |  |  |  |
|                                                         | 1.6.                                | FF_EXT1                               | 1  |  |       |                             |  |  |  |
|                                                         | 1.7.                                | FF_GENERATOR1                         | 2  |  |       |                             |  |  |  |
|                                                         | 1.8.                                | OSC_C0 IP1                            | 2  |  |       |                             |  |  |  |
|                                                         | 1.9.                                | Resource Utilization1                 | 3  |  |       |                             |  |  |  |
| 2.                                                      | Digit I                             | Digit Recognition (AI) Demo Design    |    |  |       |                             |  |  |  |
|                                                         | 2.1.                                | FlashFreeze SmartDesign               | 4  |  |       |                             |  |  |  |
|                                                         | 2.2.                                | Apb3 if (APB Target)                  | 5  |  |       |                             |  |  |  |
|                                                         | 2.3.                                | Line write read SmartDesign           | 6  |  |       |                             |  |  |  |
|                                                         | 2.4.                                | TOP CNN                               | 7  |  |       |                             |  |  |  |
|                                                         | 2.5.                                | Resource Utilization1                 | 7  |  |       |                             |  |  |  |
| 3.                                                      | DSP FIR Filter Demo Design          |                                       |    |  |       |                             |  |  |  |
|                                                         | 3.1.                                | FlashFreeze_SB_0 Module1              | 9  |  |       |                             |  |  |  |
|                                                         | 3.2.                                | FIR_FILTER_0 Module                   | 20 |  |       |                             |  |  |  |
|                                                         | 3.3.                                | LCD_DISPLAY_0 Module                  | 1  |  |       |                             |  |  |  |
|                                                         | 3.4.                                | Resource Utilization2                 | 2  |  |       |                             |  |  |  |
| 4.                                                      | Program and Debug2                  |                                       |    |  |       |                             |  |  |  |
| 5.                                                      | Revision History                    |                                       |    |  |       |                             |  |  |  |
| Mic                                                     | rochip                              | FPGA Support2                         | 25 |  |       |                             |  |  |  |
| Mic                                                     | rochip                              | Information                           | 25 |  |       |                             |  |  |  |
|                                                         | The Microchip Website               |                                       |    |  |       |                             |  |  |  |
|                                                         | Product Change Notification Service |                                       |    |  |       |                             |  |  |  |
| Customer Support                                        |                                     |                                       |    |  |       |                             |  |  |  |
|                                                         | Micro                               | chip Devices Code Protection Feature2 | 25 |  |       |                             |  |  |  |
| Legal Notice<br>Trademarks<br>Quality Management System |                                     |                                       |    |  |       |                             |  |  |  |
|                                                         |                                     |                                       |    |  | World | Norldwide Sales and Service |  |  |  |



## 1. Video Demo Design (Ask a Question)

The following figure shows the top-level video demo design in Libero<sup>®</sup> SoC software.



Figure 1-1. Top-Level Hardware Implementation (Video Demo)

The video demo design interfaces the Camera Sensor OV7725 and LCD with the SmartFusion 2 SoC FPGA. The design also includes the Flash\*Freeze feature.

The top module contains the following modules:

- 1.1. Line\_write\_read Module
- 1.2. FlashFreeze\_SB Module
- 1.3. UART\_interface
- 1.4. APB3\_if (APB Target)
- 1.6. FF\_EXT
- 1.7. FF\_GENERATOR
- 1.5. Mux\_2\_1
- 1.8. OSC\_C0 IP

## 1.1 Line\_write\_read Module (Ask a Question)

The Line\_write\_read module acquires the data from the OV7725 Camera sensor, performs image scaling as well as image enhancement, and sends the data to the LCD screen. The OV7725 camera has an array size of 640 x 480 and is configured to operate in RGB 565 format. The LCD ILI9488 has a display resolution of 480 x 320. The WRITE\_LSRAM module down samples the 640 x 480 camera data to 480 x 320 LCD resolution. After down sampling the image, data goes through image enhancement that can be configured through UART. The Image Enhancement block writes the data into the



dual-port RAM. LCD\_FSM reads the data from the dual-port RAM and sends it to the LCD display as per the LCD interface protocol. The following figure shows the components of the Line\_read\_write module.

Figure 1-2. Line\_write\_read Module in SmartDesign



The Line\_write\_read module contains the following components:

- 1.1.1. WRITE\_LSRAM\_0
- 1.1.2. Image Enhancement
- 1.1.3. LCD\_FSM

### 1.1.1 WRITE\_LSRAM\_0 (Ask a Question)

Signals from the Camera PLK\_I, H\_REF, and DATA\_I(8) are transferred through the double flip-flop synchronizer circuit to ensure the integrity of these signals. Input data signal from the camera DATA\_I is considered valid when the H\_REF signal is high. Data from the camera is in the form of RGB 5:6:5 format and is split across two clock cycles. Down sampling from 640 pixels per horizontal line to 480 pixels per horizontal line is achieved by skipping a pixel for every four pixels. Down sampling from 480 lines to 320 lines is achieved by skipping one horizontal line for every three lines.

#### 1.1.2 Image Enhancement (Ask a Question)

This module performs modification on the pixel output data from WRITE\_LSRAM based on the user-controlled data provided by the UART block. User-controlled data includes contrast, brightness, and RGB color adjustment values.

#### 1.1.3 LCD\_FSM (Ask a Question)

The LCD\_FSM module reads data from the dual-port RAM and sends it to the LCD display. The module starts reading the dual-port RAM when the write address in WRITE\_LSRAM reaches 160. The LCD\_FSM module also resets the registers of the LCD based on the V\_Sync signal of the camera, which indicates the start of new frame data. LCD\_FSM provides data to the LCD based on the interface protocol.

### 1.2 FlashFreeze\_SB Module (Ask a Question)

The FlashFreeze\_SB\_MSS module configures the MSS. The I<sup>2</sup>C peripheral in MSS is used to configure camera registers. MSS is the APB initiator which is connected to the APB target (apb3\_if) module to initialize LCD registers during start-up. The FlashFreeze\_SB\_MSS module provides the feature of low power flip-flop (FF) mode to the FPGA. The FF\_Entry\_SW signal provides the hardware interrupt for FF to MSS. When interrupt comes, MSS executes the instruction related to FF firmware through which FPGA goes into the Flash\*Freeze mode. MSS is in an infinite loop when the FPGA fabric is



in the Flash\*Freeze mode. The following figure shows the components of the FlashFreeze\_SB\_MSS module.

#### Figure 1-3. FlashFreeze\_SB\_MSS\_0 Module



#### 1.2.1 CCC IP (Ask a Question)

The CCC IP is available from the **Clock and Management** group in the Libero SoC IP catalog. The CCC IP acquires the 25/50 MHz clock from the on-chip oscillator IP and generates the GL0 clock of 100 MHz and GL1 of 24 MHz clock. All the modules inside FPGA work on GL0 clock.

The following figure shows the configuration of the CCC IP.



#### Figure 1-4. CCC IP Configuration



### 1.2.2 FLASH\_FREEZE IP (Ask a Question)

The FLASH\_FREEZE IP is available in Libero SoC > Catalog. The SmartFusion 2 SoC FPGA devices provide an ultra-low static power solution through Flash\*Freeze technology. The Flash\*Freeze mode entry retains all the Static Random Access Memory (SRAM) and registers information. The Flash\*Freeze mode exit achieves rapid recovery to Active mode (approximately 13 µs).

The following figure shows the FLASH\_FREEZE IP.

Figure 1-5. FLASH\_FREEZE IP



#### 1.2.3 MSS IP (Ask a Question)

The SmartFusion 2 Microcontroller Subsystem (MSS) IP is available under **Libero SoC** > **Catalog** > **Processors**. The MSS Component Configurator represents a graphical block diagram of the SmartFusion 2 Microcontroller Subsystem. Each of MSS sub-blocks can be enabled or disabled as per the application requirements. This design uses FIC\_0 for APB interface and I2C\_0 to enable camera configuration interface and GPIO to acquire an external signal.



#### Figure 1-6. MSS Component Configuration



### 1.3 UART\_interface (Ask a Question)

The following figure shows the UART\_interface in SmartDesign.

Figure 1-7. UART\_interface





The UART\_interface SmartDesign performs the task of communication between the SmartFusion 2 FPGA and the PC with PIC microcontroller as a bridge. Based on the data from Hello\_FPGA GUI, receive\_data module generates the address and data. The Addr\_decoder module generates the values of brightness, contrast, and color and provides it to the Image\_enchancement module.

### 1.3.1 COREUART\_CO (Ask a Question)

The COREUART IP is available in the Libero SoC peripheral IP catalog. The BAUD rate of UART is 230400, based on the operating clock frequency, BAUD\_VAL, and BAUD\_VAL\_FRACTION values. The following figure shows the CoreUART configuration.

Figure 1-8. COREUART\_C0\_0 Configuration



### 1.4 APB3\_if (APB Target) (Ask a Question)

The following figure shows the APB3 interface module.





The Apb3\_if module implements the APB target interface to communicate with APB3 initiator (MSS). LCD initialization is done through this module based on the control and data provided by MSS. After LCD initialization, MSS gives the command to the APB target to generate init\_done signal.

## 1.5 Mux\_2\_1 (Ask a Question)

The following figure shows the Mux\_2\_1 configuration.

Figure 1-10. mux\_2\_1\_0



MSS provides the select signal (Init\_done) to the MUX, MSS first initializes LCD and after initialization, MSS gives the LCD control to the FPGA fabric.

### 1.6 FF\_EXT (Ask a Question)

The following figure shows the FF\_EXT configuration.





The FF\_EXT module generates the pulse based on the PPL lock signal. The output pulse is given to the PIC controller, which signifies that the FPGA fabric is out of Flash\*Freeze mode.

### 1.7 FF\_GENERATOR (Ask a Question)

The following figure shows the FF\_GENERATOR configuration.

Figure 1-12. FF\_GENERATOR\_0 Module



The FF\_Generator module implements a power-down signal for the camera module based on the Flash\*Freeze signal FF\_to\_start\_i, which indicates that the fabric is in Flash\*Freeze or Active mode.

### 1.8 OSC\_C0 IP (Ask a Question)

The OSC\_C0 IP is available in the Libero SoC clock and management IP catalog. There are three oscillator blocks in the SmartFusion 2 device that can be used in different use models:

- On-chip 25/50 MHz RC Oscillator: This oscillator generates a 50 MHz waveform when the core supply voltage is 1.2V and 25 MHz when the supply voltage is 1.0V. The device core voltage can be selected from the Libero SoC Device Settings dialog box.
- On-chip 1 MHz RC Oscillator
- Main Crystal Oscillator



The following figure shows the configuration of the OSC\_C0 IP core.

### Figure 1-13. OSC\_C0 IP Core Configuration



## 1.9 Resource Utilization (Ask a Question)

The following table lists the resource utilization of the Video demo design.

| Туре                       | Used | Total | Percentage |
|----------------------------|------|-------|------------|
| 4LUT                       | 558  | 12084 | 4.62       |
| DFF                        | 584  | 12084 | 4.83       |
| User I/O<br>(single-ended) | 37   | 138   | 26.81      |
| RAM1K18                    | 1    | 21    | 4.76       |
| MACC                       | 3    | 22    | 13.64      |

#### Table 1-1. Resource Utilization



# 2. Digit Recognition (AI) Demo Design (Ask a Question)

The following figure shows the top-level AI digit recognition demo design in Libero SoC software.

Figure 2-1. Top-Level Hardware Implementation (AI Digit Recognition)



Al Digit Recognition Libero project aims to show Artificial Intelligence (AI) application. The Libero design for AI digit recognition is similar to the Video Demo Libero project with the following additional modules.

- 2.1. FlashFreeze SmartDesign
- 2.2. Apb3\_if (APB Target)
- 2.3. Line\_write\_read SmartDesign
- 2.4. TOP CNN

## 2.1 FlashFreeze SmartDesign (Ask a Question)

The following figure shows the FlashFreeze\_SB configuration.



#### Figure 2-2. FlashFreeze\_SB\_MSS\_0



The FlashFreeze\_SB\_MSS configures MSS. The I2C peripheral in MSS is used to configure camera registers. MSS is the APB initiator which is connected to the APB target (apb3\_if) module to initialize LCD registers during startup.

The Flash\_FREEZE module provides the feature of low power Flash\*Freeze mode to the FPGA. The FF\_Entry\_SW signal provides the hardware interrupt for Flash\*Freeze to MSS. When there is an interrupt, MSS executes the instruction related to Flash\*Freeze firmware through which FPGA goes into the Flash\*Freeze mode. While FPGA is in Flash\*Freeze mode, MSS will wait for the FPGA to come out of Flash\*Freeze. MSS identifies that the FPGA is out of Flash\*Freeze mode based on the FF\_done signal interrupt. After receiving the FF\_done signal interrupt, the MSS can communicate with FPGA through APB.

## 2.2 Apb3\_if (APB Target) (Ask a Question)

The Apb3\_if IP is an APB target module that communicates with the MSS. MSS first loads the weights into the Convolution Neural Network (CNN) SD through APB target. After loading weights, MSS initializes the LCD display and transfers the LCD control to the FPGA fabric through init\_done signal. APB target acquires the digit recognized result from the CNN SD. MSS loads the graphics related to the recognized digit in to the LSRAM for On Screen Display (OSD) of the recognized digit.

The following figure shows the APB target module configuration.



#### Figure 2-3. apb3\_if\_0 Target Module Configuration



## 2.3 Line\_write\_read SmartDesign (Ask a Question)

The following figure shows the Line\_write\_read module.

Figure 2-4. Line\_write\_read SmartDesign



Line\_write\_read SmartDesign displays the following images on LCD:

- Image from camera
- Image from camera in the scalable of size 28 x 28 at top left corner of LCD
- Recognized digit of size 80 x 80 at bottom left corner



FPGA receives video from the camera with a resolution of 640 x 480 at 30 fps. WRITE\_LSRAM performs scaling of the input video to the 480 x 320 video format of LCD and writes scalable data on the ramDualPort\_0. Similarly, WRITE\_LSRAM\_SCALE performs scaling of video from the camera to the 28 x 28, which is the resolution required by CNN. The actual scaled image passed on to CNN is displayed through the 28 x 28 scaled image. Recognized digit OSD data is provided by the MSS through the APB target of size 80x80; the WRITE\_LSRAM\_DIGIT module saves digit OSD data into the ramDualPort\_2. The Init\_done signal from MSS indicates that the LCD is initialized and MSS gives control of LCD to the LCD\_FSM module. The LCD\_FSM module reads data from all these RAMs and displays it on the LCD according to the interface protocol.

### 2.4 TOP CNN (Ask a Question)

The following figure shows the block diagram of the implemented SmartDesign.



Figure 2-5. Implemented SmartDesign Block Diagram

The network implemented in the demo contains four convolution layers, a max pool layer, and a fully connected layer. The network is trained from the standard MNIST handwritten digit database, which contains the digits in 28 x 28 resolution images. CNN can detect a single digit in the 28 x 28 image when the aspect ratio of the digit is approximately equal to the aspect ratio of the trained image data set. The network is built for only 10 classes for digits from 0 to 9 and does not use a class that shows no digit. Even though the camera is not pointing to a digit, the network still outputs a digit that has the maximum value from the fully connected layer.

### 2.5 Resource Utilization (Ask a Question)

The following table lists the resource utilization of the digit recognition demo design.

| Туре                       | Used | Total | Percentage |
|----------------------------|------|-------|------------|
| 4LUT                       | 7203 | 12084 | 59.61      |
| DFF                        | 7168 | 12084 | 59.32      |
| User I/O<br>(single-ended) | 37   | 138   | 26.81      |
| RAM1K18                    | 20   | 21    | 95.24      |
| MACC                       | 20   | 22    | 90.91      |
| Chip Globals               | 8    | 8     | 100        |

#### Table 2-1. Resource Utilization



# 3. DSP FIR Filter Demo Design (Ask a Question)

In this DSP FIR filter demo design, the FIR filter is implemented in the fabric for Low pass, High pass, Band pass, and Band reject filtering operations. The host interface is implemented in the fabric to communicate with the host PC. A user friendly Graphical User Interface (GUI) generates the filter coefficients, input signals (Pass-band frequency + Stop-band frequency) and also plots the input/ output waveforms and the required spectrum. Microchip's CoreFIR filter IP is used to suppress the unwanted frequency components and generates the output signals to verify the filtering operation.





The demo design also implements an LCD display application, which displays images stored in SPI Flash on an ILI9488 LCD display. MSS UART is used to read and write the image data into the SPI Flash. For this demo, the SPI Flash is preloaded with Microchip's logo and a Hello FPGA board image.

Both the applications use UART communication to interface with PIC32 microcontroller which is interfaced with host PC for GUI, due to which a UART\_SELECTION module is used to switch between fabric UART and MSS UART. The Fabric UART is used for DSP FIR application and MSS UART is used for LCD display application.

The following figure shows the top-level DSP FIR\_LCD\_FF demo design in Libero SoC software.



#### Figure 3-2. Top-Level DSP Design



The top module contains the following modules:

- 3.1. FlashFreeze\_SB\_0 Module
- 3.2. FIR\_FILTER\_0 Module
- 3.3. LCD\_DISPLAY\_0 Module

### 3.1 FlashFreeze\_SB\_0 Module (Ask a Question)

The FlashFreeze\_SB\_0 module configures the MSS for the following tasks.

- The SPI peripheral in MSS is used to store the images in SPI Flash and to read the images from SPI Flash.
- The UART peripheral in MSS is used to communicate with a GUI on host PC through PIC32 microcontroller.
- MSS is the APB initiator which is connected to the APB target (apb3\_if) module to initialize LCD registers during start-up.
- The Flash\_FREEZE module provides the feature of low-power Flash\*Freeze mode to the FPGA. The FF\_Entry\_SW signal provides the hardware interrupt for Flash\*Freeze to MSS.

When a Flash\*Freeze user interrupt is received by MSS, the instruction related to Flash\*Freeze is executed and the FPGA goes into the Flash\*Freeze mode. MSS is in an infinite loop when the FPGA fabric is in the Flash\*Freeze mode.

The following figure shows the blocks in the FlashFreeze\_SB\_0 module.



#### Figure 3-3. FlashFreeze\_SB\_0 Module



### 3.2 FIR\_FILTER\_0 Module (Ask a Question)

The FIR\_FILTER\_0 module implements the user logic in the fabric. This module implements the following finite-state machines.

- Data Handling: Implements and controls operations such as loading the filter input data to the corresponding input data buffer and loading filter coefficients to the corresponding coefficient memory buffers.
- Filter Control: Controls the FIR filter operation. Loads the filtered data into the corresponding output buffer.
- CoreFIR IP: The Core FIR IP is used in Re-loadable Coefficient mode to support Low pass, High pass, Band pass, and Band reject filters.
- TPSRAM IP: The TPSRAM IP is used to implement Filter coefficient buffer, Input signal data buffer, and Output signal buffer.

The following figure shows the blocks in the FIR\_FILTER\_0 module.



#### Figure 3-4. FIR\_FILTER Module



## 3.3 LCD\_DISPLAY\_0 Module (Ask a Question)

The LCD\_DISPLAY\_0 module implements the following functionalities:

- apb3\_if: Apb3\_if module implements the APB target Interface to communicate with APB3 initiator (MSS). LCD initialization is done through this module based on the control and data words provided by MSS. After LCD initialization, MSS gives the command to the APB target to generate init\_done signal. After the init\_done signal, MSS reads the images from SPI Flash and stores the data into the dual-port RAM through abp3\_if module.
- LCD\_FSM: The LCD\_FSM module reads data from the dual-port RAM and sends it to the LCD display. The module starts reading the dual port RAM when the write address in WRITE\_LSRAM reaches 160. The LCD\_FSM also resets the registers of the LCD based on the V\_Sync signal of the camera, which indicates the start of new frame data. LCD\_FSM provides data to the LCD based on the interface protocol.
- mux\_2\_1: MSS provides the select signal (Init\_done) to the MUX; MSS first initializes the LCD and after initialization; MSS gives LCD control to the FPGA fabric.

The following figure shows the blocks in the LCD\_DISPLAY\_0 module.

Figure 3-5. LCD\_DISPLAY\_0 module





## 3.4 Resource Utilization (Ask a Question)

The following table lists the resource utilization of the DSP demo design.

### Table 3-1. Resource Utilization

| Туре          | Used | Total | Percentage |
|---------------|------|-------|------------|
| 4LUT          | 1430 | 12084 | 11.83      |
| DFF           | 2335 | 12084 | 19.32      |
| Logic Element | 2540 | 12084 | 21.02      |



## 4. Program and Debug (Ask a Question)

The PIC Microcontroller **PIC32MX795F512L** of hello FPGA kit is pre-programmed with firmware. This microcontroller is used to program the SmartFusion 2 device with bit stream and measure the FPGA core power.

This PIC microcontroller executes the In-System programming application using DirectC to program the SmartFusion 2 device with the provided bit stream file (.dat). The microcontroller gets the bit stream file from host PC over UART with a baud rate of 460800 and programs FPGA. The microcontroller executes the DirectC JTAG program and enables five GPIO pins, which are interfaced with the JTAG pins of the FPGA for programming. The PIC microcontroller transfers the data to the SmartFusion 2 device over an UART interface. The UART module of SmartFusion 2 device is configured to operate at baud rate of 230400.

The PIC microcontroller communicates with the current sensor IC (PAC1710) over I2C and gets the data to calculate the FPGA core power and displays it in the GUI. It also sends signals to FPGA for Flash\*Freeze entry and exit operations. It also measures the time taken from Flash\*Freeze exit to FPGA functional. The microcontroller receives data from GUI using UART1 and transfers the data to FPGA using UART2. The microcontroller receives the data from FPGA using UART2 and transfers the data to GUI using UART1.

This PIC microcontroller can be programmed using the PICkit<sup>™</sup>3 - 6-pin connector, which is connected to header J5 of the Hello FPGA Kit. Using MPLAB X IDE, MPLAB XC32 Compiler, and MPLAB Harmony, you can develop and debug the microcontroller application. For more information, see https://www.microchip.com/en-us/tools-resources/develop/mplab-x-ide#Downloads%20and%20Documentation.

The Libero SoC GUI provides an option to program FPGA using the demo design programming files. If you want to perform program and debug operations on FPGA, the external hardware FlashPro4 (https://www.microchip.com/en-us/development-tool/FLASHPRO4) is required. Flashpro4 can be connected using the FPGA JTAG header on the kit to the host PC.



**Important:** Libero SoC software must be installed on a host PC to develop any FPGA designs and program the SmartFusion 2 device.

The SmartFusion 2 device includes Cortex-M3 microcontroller, which runs the user applications. These applications can be developed and debugged using the SoftConsole software and FlashPro4 hardware.

For more information about Libero SoC and SoftConsole tools, see https://www.microchip.com/en-us/products/fpgas-and-plds/fpga-and-soc-design-tools.

The demo design files can be customized and reprogrammed to Hello FPGA Kit. You can download the demo design file from: www.microchip.com/en-us/development-tool/M2S-HELLO-FPGA-KIT#resources.



# 5. Revision History (Ask a Question)

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

| Revision | Date    | Description                                                                                                               |
|----------|---------|---------------------------------------------------------------------------------------------------------------------------|
| А        | 06/2023 | The following is a summary of changes made in this revision.<br>• The document was migrated to the Microchin template     |
|          |         | <ul> <li>The document number was updated to DS50003539A from UG0891.</li> <li>Added Program and Debug section.</li> </ul> |
| 1.0      | —       | This is the first publication of the document.                                                                            |

Table 5-1. Revision History



# Microchip FPGA Support (Ask a Question)

Microchip FPGA products group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, and worldwide sales offices. Customers are suggested to visit Microchip online resources prior to contacting support as it is very likely that their queries have been already answered.

Contact Technical Support Center through the website at www.microchip.com/support. Mention the FPGA Device Part number, select appropriate case category, and upload design files while creating a technical support case.

Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization.

- From North America, call 800.262.1060
- From the rest of the world, call 650.318.4460
- Fax, from anywhere in the world, 650.318.8044

# Microchip Information (Ask a Question)

## The Microchip Website (Ask a Question)

Microchip provides online support via our website at www.microchip.com/. This website is used to make files and information easily available to customers. Some of the content available includes:

- Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- **General Technical Support** Frequently Asked Questions (FAQs), technical support requests, online discussion groups, Microchip design partner program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

## Product Change Notification Service (Ask a Question)

Microchip's product change notification service helps keep customers current on Microchip products. Subscribers will receive email notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, go to www.microchip.com/pcn and follow the registration instructions.

### Customer Support (Ask a Question)

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- Local Sales Office
- Embedded Solutions Engineer (ESE)
- Technical Support

Customers should contact their distributor, representative or ESE for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in this document.

Technical support is available through the website at: www.microchip.com/support

## Microchip Devices Code Protection Feature (Ask a Question)

Note the following details of the code protection feature on Microchip products:



- Microchip products meet the specifications contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is secure when used in the intended manner, within operating specifications, and under normal conditions.
- Microchip values and aggressively protects its intellectual property rights. Attempts to breach the code protection features of Microchip product is strictly prohibited and may violate the Digital Millennium Copyright Act.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of its code. Code protection does not mean that we are guaranteeing the product is "unbreakable". Code protection is constantly evolving. Microchip is committed to continuously improving the code protection features of our products.

## Legal Notice (Ask a Question)

This publication and the information herein may be used only with Microchip products, including to design, test, and integrate Microchip products with your application. Use of this information in any other manner violates these terms. Information regarding device applications is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. Contact your local Microchip sales office for additional support or, obtain additional support at www.microchip.com/en-us/support/design-help/ client-support-services.

THIS INFORMATION IS PROVIDED BY MICROCHIP "AS IS". MICROCHIP 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 ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE, OR WARRANTIES RELATED TO ITS CONDITION, QUALITY, OR PERFORMANCE.

IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL, OR CONSEQUENTIAL LOSS, DAMAGE, COST, OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE INFORMATION OR ITS USE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY RELATED TO THE INFORMATION OR ITS USE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THE INFORMATION.

Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

### Trademarks (Ask a Question)

The Microchip name and logo, the Microchip logo, Adaptec, AVR, AVR logo, AVR Freaks, BesTime, BitCloud, CryptoMemory, CryptoRF, dsPIC, flexPWR, HELDO, IGLOO, JukeBlox, KeeLoq, Kleer, LANCheck, LinkMD, maXStylus, maXTouch, MediaLB, megaAVR, Microsemi, Microsemi logo, MOST, MOST logo, MPLAB, OptoLyzer, PIC, picoPower, PICSTART, PIC32 logo, PolarFire, Prochip Designer, QTouch, SAM-BA, SenGenuity, SpyNIC, SST, SST Logo, SuperFlash, Symmetricom, SyncServer, Tachyon, TimeSource, tinyAVR, UNI/O, Vectron, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

AgileSwitch, APT, ClockWorks, The Embedded Control Solutions Company, EtherSynch, Flashtec, Hyper Speed Control, HyperLight Load, Libero, motorBench, mTouch, Powermite 3, Precision Edge, ProASIC, ProASIC Plus, ProASIC Plus logo, Quiet- Wire, SmartFusion, SyncWorld, Temux, TimeCesium, TimeHub, TimePictra, TimeProvider, TrueTime, and ZL are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, Augmented Switching, BlueSky, BodyCom, Clockstudio, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic



Average Matching, DAM, ECAN, Espresso T1S, EtherGREEN, GridTime, IdealBridge, In-Circuit Serial Programming, ICSP, INICnet, Intelligent Paralleling, IntelliMOS, Inter-Chip Connectivity, JitterBlocker, Knob-on-Display, KoD, maxCrypto, maxView, memBrain, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, RTAX, RTG4, SAM-ICE, Serial Quad I/O, simpleMAP, SimpliPHY, SmartBuffer, SmartHLS, SMART-I.S., storClad, SQI, SuperSwitcher, SuperSwitcher II, Switchtec, SynchroPHY, Total Endurance, Trusted Time, TSHARC, USBCheck, VariSense, VectorBlox, VeriPHY, ViewSpan, WiperLock, XpressConnect, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

The Adaptec logo, Frequency on Demand, Silicon Storage Technology, and Symmcom are registered trademarks of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

<sup>©</sup> 2023, Microchip Technology Incorporated and its subsidiaries. All Rights Reserved.

ISBN: 978-1-6683-2615-2

### Quality Management System (Ask a Question)

For information regarding Microchip's Quality Management Systems, please visit www.microchip.com/quality.



# Worldwide Sales and Service

| AMERICAS                  | ASIA/PACIFIC          | ASIA/PACIFIC            | EUROPE                |
|---------------------------|-----------------------|-------------------------|-----------------------|
| Corporate Office          | Australia - Sydney    | India - Bangalore       | Austria - Wels        |
| 2355 West Chandler Blvd.  | Tel: 61-2-9868-6733   | Tel: 91-80-3090-4444    | Tel: 43-7242-2244-39  |
| Chandler, AZ 85224-6199   | China - Beijing       | India - New Delhi       | Fax: 43-7242-2244-393 |
| Tel: 480-792-7200         | Tel: 86-10-8569-7000  | Tel: 91-11-4160-8631    | Denmark - Copenhagen  |
| Fax: 480-792-7277         | China - Chengdu       | India - Pune            | Tel: 45-4485-5910     |
| Technical Support:        | Tel: 86-28-8665-5511  | Tel: 91-20-4121-0141    | Fax: 45-4485-2829     |
| www.microchip.com/support | China - Chongqing     | Japan - Osaka           | Finland - Espoo       |
| Web Address:              | Tel: 86-23-8980-9588  | Tel: 81-6-6152-7160     | Tel: 358-9-4520-820   |
| www.microchip.com         | China - Dongguan      | Japan - Tokyo           | France - Paris        |
| Atlanta                   | Tel: 86-769-8702-9880 | Tel: 81-3-6880- 3770    | Tel: 33-1-69-53-63-20 |
| Duluth, GA                | China - Guangzhou     | Korea - Daegu           | Fax: 33-1-69-30-90-79 |
| Tel: 678-957-9614         | Tel: 86-20-8755-8029  | Tel: 82-53-744-4301     | Germany - Garching    |
| Fax: 678-957-1455         | China - Hangzhou      | Korea - Seoul           | Tel: 49-8931-9700     |
| Austin, TX                | Tel: 86-571-8792-8115 | Tel: 82-2-554-7200      | Germany - Haan        |
| Tel: 512-257-3370         | China - Hong Kong SAR | Malaysia - Kuala Lumpur | Tel: 49-2129-3766400  |
| Boston                    | Tel: 852-2943-5100    | Tel: 60-3-7651-7906     | Germany - Heilbronn   |
| Westborough, MA           | China - Nanjing       | Malaysia - Penang       | Tel: 49-7131-72400    |
| Tel: 774-760-0087         | Tel: 86-25-8473-2460  | Tel: 60-4-227-8870      | Germany - Karlsruhe   |
| Fax: 774-760-0088         | China - Qingdao       | Philippines - Manila    | Tel: 49-721-625370    |
| Chicago                   | Tel: 86-532-8502-7355 | Tel: 63-2-634-9065      | Germany - Munich      |
| ltasca, IL                | China - Shanghai      | Singapore               | Tel: 49-89-627-144-0  |
| Tel: 630-285-0071         | Tel: 86-21-3326-8000  | Tel: 65-6334-8870       | Fax: 49-89-627-144-44 |
| Fax: 630-285-0075         | China - Shenyang      | Taiwan - Hsin Chu       | Germany - Rosenheim   |
| Dallas                    | Tel: 86-24-2334-2829  | Tel: 886-3-577-8366     | Tel: 49-8031-354-560  |
| Addison, TX               | China - Shenzhen      | Taiwan - Kaohsiung      | Israel - Ra'anana     |
| Tel: 972-818-7423         | Tel: 86-755-8864-2200 | Tel: 886-7-213-7830     | Tel: 972-9-744-7705   |
| Fax: 972-818-2924         | China - Suzhou        | Taiwan - Taipei         | ltaly - Milan         |
| Detroit                   | Tel: 86-186-6233-1526 | Tel: 886-2-2508-8600    | Tel: 39-0331-742611   |
| Novi, MI                  | China - Wuhan         | Thailand - Bangkok      | Fax: 39-0331-466781   |
| Tel: 248-848-4000         | Tel: 86-27-5980-5300  | Tel: 66-2-694-1351      | Italy - Padova        |
| Houston, TX               | China - Xian          | Vietnam - Ho Chi Minh   | Tel: 39-049-7625286   |
| Tel: 281-894-5983         | Tel: 86-29-8833-7252  | Tel: 84-28-5448-2100    | Netherlands - Drunen  |
| Indianapolis              | China - Xiamen        |                         | Tel: 31-416-690399    |
| Noblesville, IN           | Tel: 86-592-2388138   |                         | Fax: 31-416-690340    |
| Tel: 317-773-8323         | China - Zhuhai        |                         | Norway - Trondheim    |
| Fax: 317-773-5453         | Tel: 86-756-3210040   |                         | Tel: 47-72884388      |
| Tel: 317-536-2380         |                       |                         | Poland - Warsaw       |
| Los Angeles               |                       |                         | Tel: 48-22-3325737    |
| Mission Viejo, CA         |                       |                         | Romania - Bucharest   |
| Tel: 949-462-9523         |                       |                         | Tel: 40-21-407-87-50  |
| Fax: 949-462-9608         |                       |                         | Spain - Madrid        |
| Tel: 951-273-7800         |                       |                         | Tel: 34-91-708-08-90  |
| Raleigh, NC               |                       |                         | Fax: 34-91-708-08-91  |
| Tel: 919-844-7510         |                       |                         | Sweden - Gothenberg   |
| New York, NY              |                       |                         | Tel: 46-31-704-60-40  |
| Tel: 631-435-6000         |                       |                         | Sweden - Stockholm    |
| San Jose, CA              |                       |                         | Tel: 46-8-5090-4654   |
| Tel: 408-735-9110         |                       |                         | UK - Wokingham        |
| Tel: 408-436-4270         |                       |                         | Tel: 44-118-921-5800  |
| Canada - Toronto          |                       |                         | Fax: 44-118-921-5820  |
| Tel: 905-695-1980         |                       |                         |                       |
| Fax: 905-695-2078         |                       |                         |                       |