

# **Table of Contents**

| Purpose                                             |
|-----------------------------------------------------|
| Introduction                                        |
| References                                          |
| Design Requirements                                 |
| Initializing the eNVM Using the Libero eNVM Client  |
| Initializing the eNVM Using the Cortex-M3 Processor |
| Design Description                                  |
| Hardware Implementation                             |
| Software Implementation                             |
| Setting Up the Design                               |
| Running the Design                                  |
| Conclusion                                          |
| Appendix A – Design Files                           |
| Appendix B – eNVM Driver APIs                       |
| List of Changes                                     |

## **Purpose**

This application note describes the different methods to initialize the embedded nonvolatile memory (eNVM) in the SmartFusion<sup>®</sup>2 system-on-chip (SoC) field programmable gate array (FPGA) devices.

# Introduction

•

The SmartFusion2 SoC FPGA devices have a maximum of two on-chip 256 KB flash memories called, eNVM. The eNVM is used to store the application code image or used to store data, which can be used by the end application. The eNVM can be initialized by these different methods:

- Using the eNVM client of the eNVM configurator in the Libero® System-on-Chip (SoC)
- Writing into the eNVM using ARM<sup>®</sup> Cortex<sup>™</sup>-M3 processor
  - In-application programming (IAP)
- Writing into the eNVM using custom logic in the FPGA fabric

This application note describes how to initialize the eNVM using the eNVM client in Libero and the Cortex-M3 processor. Refer to the Application Note AC429 for more information.

Refer to the "eNVM" chapter in *SmartFusion2 Microcontroller Subsystem User Guide* for detailed description of eNVM.



# References

The list of references used are:

- SmartFusion2 MSS Embedded Nonvolatile Memory (eNVM) Simulation
- SmartFusion2 Microcontroller Subsystem User Guide
- SmartFusion2 System Builder User Guide

# **Design Requirements**

| Design Requirements                                                                                                                     | Description                     |
|-----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Hardware Requirements                                                                                                                   |                                 |
| <ul> <li>SmartFusion2 Evaluation Kit has:</li> <li>12 V adapter</li> <li>FlashPro4 programmer</li> <li>USB A to Mini-B cable</li> </ul> | Rev C or later                  |
| Host PC or Laptop                                                                                                                       | Windows 64-bit Operating System |
| Software Requirements                                                                                                                   |                                 |
| Libero SoC for viewing the design files <ul> <li>FlashPro Programming Software</li> </ul>                                               | v11.4                           |
| SoftConsole                                                                                                                             | v3.4SP1                         |
| Host PC Drivers                                                                                                                         | USB to UART drivers             |
| One of the following serial terminal emulation<br>programs:<br>• HyperTerminal<br>• TeraTerm<br>• PuTTY                                 | -                               |

# Initializing the eNVM Using the Libero eNVM Client

The Libero eNVM client creates the necessary programming information that FlashPro uses to initialize the eNVM during the programming. The following steps describe how to generate a programming file with the eNVM client.

1. In SmartFusion2 SoC FPGA Libero project, double-click the ENVM\_INIT\_M3\_0 in the Libero SmartDesign window to open System Builder Configuration.

2. Go to **Memories** tab to open the **ENVM** window.

- \_ 🗆 🕳 X 📀 System Builder - Memories Device Features Memories Peripherals Clocks Microcontroller SECDED Security Memory Map Configure your external and embedded memories ENVM Available Client types User Clients in eNVM Data Storage Client Type DepthxWidth Start Address(Hex) Page Start Page End Initialization Order Lock Start A Serializatio Client Name Add to System. Usage Statistics Available Pages: 2032 Used Pages: 0 2032 Free Pages: Optimize Edit Delete Help 
  Cancel Back Next
- 3. Select **Data Storage** under **Available client types** and click **Add to System**, as shown in Figure 1.

Figure 1 • Adding the Client Type

The **Add Data Storage Client** window is displayed, as shown in Figure 2 on page 4. It supports four types of memory file formats:

- Intel-Hex
- Motorola-S
- Microsemi-Hex
- Microsemi-Binary

Create the memory file in any one of the above formats with your code or data. You can create the memory file for your code using the SoftConsole 3.4SP1 with the linker script "production-smartfusion2-execute-in-place.ld".



| Client name:   |                               |           |   |
|----------------|-------------------------------|-----------|---|
| eNVM           |                               |           |   |
| Content:       |                               |           |   |
| Memory         | file:                         |           |   |
| Forr           | mat: Intel-Hex 🔻              |           |   |
|                |                               |           |   |
|                | Use absolute addressing 🚺     |           |   |
| Content        | : filled with 0s              |           |   |
| No Cont        | ent (Client is a placeholder) |           |   |
| Start address: | 0x 0 🚔                        |           |   |
| Size of word:  | 8 V bits                      |           |   |
|                |                               |           |   |
| Number of Word | s: 1                          | (decimal) |   |
| Use as ROM     | 0                             |           |   |
| Use Content fo | or Simulation                 |           |   |
| ose content te | a sinulation                  |           |   |
|                |                               |           |   |
|                |                               |           |   |
|                |                               |           |   |
|                |                               |           |   |
|                |                               |           |   |
|                |                               |           |   |
|                |                               |           | 1 |



- 4. Enter the Client name.
- 5. Browse to the created Memory file, and click OK to add the eNVM client.

The Modify core - ENVM window (displayed next) shows the client and its size. You can also add more than one client with the different start address.

- 6. After adding the eNVM clients, click Next and Generate System Builder Component.
- 7. Save and generate the SmartDesign in Libero using the Generate Component.
- 8. Double-click the **Run Program Action** in the Libero **Design Flow** window to program the SmartFusion2 SoC FPGA to initialize the eNVM with the memory file.

# Initializing the eNVM Using the Cortex-M3 Processor

This application note describes how to initialize eNVM using Cortex-M3 processor with an example design. The design example describes how to write, read, and verify the data to or from different locations within the eNVM using the Cortex-M3 processor. The design description and implementation details are described in the following sections.

# **Design Description**

The design example included with this application note uses RC oscillator and Fabric CCC to generate the base clock to MSS CCC. In the design example, the MSS CCC is configured to run the M3\_CLK at 100 MHz, which drives the clock to Cortex-M3 processor. The MMUART\_1 is routed through FPGA fabric for communicating with the serial terminal program. The design receives the user given commands for read, write, and verify operations and corresponding address, length, and data through the serial terminal program. After completing every operation, it displays the status (success/fail) of operation on the serial terminal program.

# **Hardware Implementation**

The hardware implementation involves configuring System Builder. Figure 3 shows the top-level hardware design in SmartDesign.



The MSS\_CCC clock source is sourced from the FCCC via the **On-Chip Oscillator**. The FCCC is configured to provide the 100 MHz clock using GL0. Figure 4 shows the system clocks configurations for the M3\_CLK and APB\_0\_CLK clock settings.

| _ |                         |                  |                 |             |                |
|---|-------------------------|------------------|-----------------|-------------|----------------|
| C | System Builder - Clocks |                  |                 |             |                |
|   | Device Features         | s > Memo         | ries > > Periph | erals       | $\rangle \sum$ |
|   |                         |                  |                 | Config      | gure (         |
|   | Clock Fabric CCC        | Chip Oscillators |                 |             | f              |
|   | System Clock            |                  |                 |             | -              |
|   | 50.0                    | MHz              |                 |             |                |
|   | On-chip 25/50 MHz RC    | Oscillator       |                 | •           |                |
|   | Cortex-M3 and MSS Ma    | in Clock         |                 |             |                |
|   | M3_CLK                  | =                | 100.00          | MHz 100.000 |                |
|   | MDDR Clocks             |                  |                 |             |                |
|   | MDDR_CLK                | = M3_CLK *       | 1               | •           |                |
|   | DDR/SMC_FIC_CLK         | = MDDR_CLK       | / 1             | •           |                |
|   | MSS APB_0/1 Clocks      |                  |                 |             |                |
|   | APB_0_CLK               | = M3_CLK /       | 1               | ▼ 100.000   |                |
|   | APB_1_CLK               | = M3_CLK /       | 1               | ▼ 100.000   |                |
|   | 1                       |                  |                 |             |                |

Figure 4 • Clock Configurations



The MMUART\_1 is used for reading and writing to the HyperTerminal window. On the SmartFusion2 Evaluation Kit Board, the MMUART\_1 TX and RX are connected to the mini-B USB through I/Os. Figure 5 shows the MMUART\_1 configuration.

| Configuration       | Duplex Mode<br>Async/Sync Mode | Full Duplex     |                  |                        |
|---------------------|--------------------------------|-----------------|------------------|------------------------|
| Assignment          | Use Modem Interfac             |                 | Advanced Options | $\boldsymbol{\lambda}$ |
| MSIO<br>Full Duplex | Direction                      | Main Connection | Package Pin      |                        |
| RXD                 | IN                             | IO 👻            | G18              |                        |
| TXD                 | олт                            |                 | H19              |                        |

Figure 5 • MMUART\_1 Configuration

## **Software Implementation**

The software design example performs the write, read, and verify tasks on receiving commands from user through HyperTerminal.

The design uses following firmware drivers:

- SmartFusion2 MSS MMUART driver:
- To communicate with the serial terminal program running on Host PC.

The design implements APIs to read, write, and, verify the data. The API implementation and usage is described in the following sections. Refer to "Appendix B – eNVM Driver APIs" on page 13 for the API C code.

## Write Operation

The design uses the **NVM\_write()** API to write or program the data to eNVM over any memory range within the limits of 256 KB. This function supports programming data that spawns across multiple pages. The function prototype is shown below.

```
nvm_status_t
NVM_write
    uint32_t start_addr,
    const uint8_t * pidata,
    uint32_t length,
    uint32_t lock_page
);
```

The data is written from the memory location specified by the first parameter *start\_addr*. This address is the relative address which is added to the eNVM base address 0x60000000. The *pidata* parameter is the byte aligned starting address of the input data. The *length* parameter is the number of data bytes that are to be programmed. On successful execution, this function returns SUCCESS, otherwise it returns INVALID\_PARAMETER.

#### Example:

```
uint8_t idata[815] = {"Z"};
nvm_status_t status = NVM_write( (0x0, idata, sizeof(idata), NVM_DO_NOT_LOCK_PAGE);
```

The NVM\_write() API calls the write\_nvm() API to perform the page write into eNVM after aligning the input data into pages. The write\_nvm() API uses the eNVM controller's page-wise write command. It uses the following sequence to write or program the eNVM page.

- Request the access to eNVM by writing the 0x1 to the controller register REQ\_ACCESS of eNVM.
- 2. Poll to the REQ\_ACCESS for 0x5 (Cortex-M3 processor access to eNVM is granted).
- 3. Fill the WDBUFFER with the data that needs to be written into eNVM.
- 4. To write the data to eNVM array, write the CMD control register with page program and the address of the page.
- Poll for eNVM busy bit in the STATUS control register of eNVM for '1'. The '0' for this bit indicates that eNVM is busy in programming the data to eNVM array. On programming, the eNVM controller makes busy bit to '0'.
- Release the Cortex-M3 processor access to eNVM by writing 0x0 to the controller register REQ\_ACCESS of eNVM.

The page program command programs the entire page with the data in the WDBUFFER.

Note: eNVM frequency range (NV\_FREQRNG field of ENVM\_CR System Register) value must be set to maximum value 15 to ensure the correct programming of the eNVM. After programming eNVM, restore the original frequency range value for eNVM read or verify operations.

## **Read Operation**

The design uses the **MSS\_NVM\_read()** API to read the data from eNVM over any memory range within the limits of 256 KB. The function prototype is shown below.

```
nvm_status_t
MSS_NVM_read
(
    uint8_t * addr,
    uint8_t * podata,
    uint32_t len
);
```

The data is read from the memory location specified by the first parameter *addr*. This address is the relative address which is added to the eNVM base address 0x60000000. The *addr* parameter is the byte aligned address of eNVM from which the data is to be read. The *podata* parameter is the byte aligned address of the output buffer in which the read data is to be stored. The *len* parameter is the number of data bytes that are to be read. On successful execution, this function returns SUCCESS, otherwise it returns INVALID\_PARAMETER.

#### Example:

```
uint8_t outbuf[815] = {0};
nvm_status_t status = MSS_NVM_read( 0, outbuf, sizeof(outbuf) );
```

The read API reads the data from eNVM similar to that of reading from any other memory location because the eNVM controller supports RAM type of accessing for read operation. This API also checks for the 2-bit error while reading eNVM.



## **Verify Operation**

The design uses the **NVM\_verify** API to verify the eNVM memory against the reference data provided. This function supports verification that spawns across multiple pages. The function prototype is shown below.

```
nvm_status_t
NVM_verify
(
    uint32_t addr,
    const uint8_t * pidata,
    uint32_t length
);
```

The data is verified from the memory location specified by the first parameter *addr*. This address is the relative address which is added to the eNVM base address 0x60000000. The *addr* parameter is the byte aligned address of eNVM from which the data is to be verified. The *pidata* parameter is the byte aligned starting address of the reference input data against which the verification should be performed. The *length* parameter is the number of data bytes that are to be verified. On successful execution, this function returns SUCCESS, otherwise it returns INVALID\_PARAMETER.

#### Example:

```
uint8_t idata[815] = {"Z"};
nvm_status_t status = NVM_write( (0x0, idata, sizeof(idata), NVM_DO_NOT_LOCK_PAGE);
status = NVM_verify( 0x0, idata, sizeof(idata) );
```

The NVM\_verify() API calls the verify\_nvm() API to perform the page verify to eNVM after aligning the input data into pages. The verify\_nvm() API uses the eNVM controller's page-wise verify command. It uses the following sequence to verify the data in the eNVM page.

- Request the access to eNVM by writing the 0x1 to the controller register REQ\_ACCESS of eNVM.
- 2. Poll to the REQ\_ACCESS for 0x5 (Cortex-M3 processor access to eNVM is granted).
- 3. Fill the WDBUFFER with the data to verify the data in the eNVM array.
- 4. To verify the data in the eNVM array, write the CMD control register verify page program and the address of the page.
- Poll for eNVM busy bit in the STATUS control register of eNVM for '1'. The '0' for this bit indicated eNVM is busy in programming the data to eNVM array. On programming, the eNVM controller makes busy bit to '0'.
- Check the bit[1] of STATUS register for '0' which indicates verify success. It is 1 in case of verify failure.
- Release the Cortex-M3 processor access to eNVM by writing 0x0 to the controller register REQ\_ACCESS of eNVM.

# Setting Up the Design

Connect the following jumpers on the SmartFusion2 SoC FPGA Evaluation Kit, as described in Table 2. While making the jumper connections, the power supply switch SW7 on the board should be in OFF position.

#### Table 2 • SmartFusion2 SoC FPGA Evaluation Kit Jumper Settings

| Jumper            | Pin (From) | Pin (To) | Comments                                                                                                        |
|-------------------|------------|----------|-----------------------------------------------------------------------------------------------------------------|
| J22,J23,J24,J8,J3 | 1          |          | These are the default jumper settings of the Evaluation Kit board. Make sure these jumpers are set accordingly. |

# **Running the Design**

The following steps describe how to run the design:

- 1. Connect the FlashPro4 programmer to the J5 connector of SmartFusion2 SoC FPGA Evaluation Kit.
- Connect one end of the USB mini-B cable to the J18 connector provided on the SmartFusion2 SoC FPGA Evaluation Kit. Connect the other end of the USB cable to the host PC. Make sure that the USB to UART bridge drivers are automatically detected (can be verified in the Device Manager), as shown in Figure 6 on page 9.
- Note: Copy the COM port number for serial port configuration. Ensure that the COM port location is specified as "on USB Serial Converter D" as shown in Figure 6.



#### Figure 6 • USB to UART Bridge Drivers

- 3. If USB to UART bridge drivers are not installed, download and install the drivers from www.microsemi.com/soc/documents/CDM\_2.08.24\_WHQL\_Certified.zip.
- 4. Connect the power supply to the J6 connector and change the power supply switch SW7 to ON.
- Program the SmartFusion2 SoC FPGA Evaluation Kit Board with the generated or provided \*.stp file (refer to "Appendix A – Design Files" on page 12) using FlashPro.
- 6. Invoke the standalone SoftConsole3.4 Integrated Design Environment (IDE).
- 7. Load the SoftConsole project from the provided design files.
- 8. Launch the debugger in SoftConsole.
- 9. Start a **HyperTerminal** with the baud rate set to 57600, 8 data bits, 1 stop bit, no parity, and no flow control.

If your PC does not have a HyperTerminal program, use any free serial terminal emulation program as PuTTY or Tera Term. Refer to the *Configuring Serial Terminal Emulation Programs Tutorial* for configuring HyperTerminal, Tera Term, and PuTTY.



- 10. When you run the debugger in SoftConsole, the HyperTerminal window shows a message to enter your choice.
- 11. Enter the choice to write. It prompts for address, length, and data consequently. Enter the values, as shown in Figure 7.
- 12. On writing, it displays the message as "write operation successful".

| Eile Edit View Call Transfer Help                                       |          |
|-------------------------------------------------------------------------|----------|
|                                                                         |          |
| Enter your choice and press Enter                                       |          |
| 1. Read                                                                 |          |
| 2. Write                                                                |          |
| 3. Verify                                                               |          |
| 2<br>Enter the address (0 to 30000) to write and press Enter            | <b>N</b> |
| 100<br>Enter the length (1 to 1024) of data to write and press Enter    |          |
| 10<br>Select the data type to write and press enter:                    |          |
| 1. Incremental pattern                                                  |          |
| 2. Even numbers                                                         |          |
| 3. User specific (two digit numbers)                                    |          |
| 1<br>Write operation successful for                                     |          |
| address = 100                                                           |          |
| length = 10                                                             | -        |
| Connected 0:03:54 Auto detect 57600 8-N-1 SCROLL CAPS MUM Capture Print | echo 🥼   |

Figure 7 • Write Operation

13. Enter the choice to verify. It prompts for address, length, and data consequently. Enter the values, as shown in Figure 8.



14. On writing, it displays the message as "verify operation successful".

| SF2_57600 - HyperTer       | minal                       |             |           |           |           |              | × |
|----------------------------|-----------------------------|-------------|-----------|-----------|-----------|--------------|---|
| <u>File Edit View Call</u> | <u>T</u> ransfer <u>H</u> e | elp         |           |           |           |              |   |
| 🗅 🗳 🏐 🕉 🗈 🎽                | 98                          |             |           |           |           |              |   |
| Enter your choi            | ce and pre                  | ss Enter    |           |           |           |              |   |
| 1. Read                    |                             |             |           |           |           |              |   |
| 2. Write                   |                             |             |           |           |           |              |   |
| 3. Verify                  |                             |             |           |           |           |              |   |
| 3<br>Enter the addre       | ss (0 to 3                  | 0000) to ve | erify and | l press i | Enter     |              |   |
| 100<br>Enter the lengt     | h (1 to 10                  | 24) of data | to ver:   | ify and ; | press Ent | er           |   |
| 10<br>Select the data      | to verify                   | .=          |           |           |           |              |   |
| 1. Incremental             | pattern                     |             |           |           |           |              |   |
| 2. Even number             | S                           |             |           |           |           |              |   |
| 3. User specif             | ic (two di                  | git numbers | ;)        |           |           |              |   |
| 1<br>Verify operatio       | n successf                  | ul for      |           |           |           |              | = |
| address = 100              |                             |             |           |           |           |              |   |
| length = 10                |                             |             |           |           |           |              | - |
| Connected 0:04:23          | Auto detect                 | 57600 8-N-1 | SCROLL    | CAPS      | MM Captu  | e Print echo |   |

#### Figure 8 • Verify Operation

- 15. Enter the choice to read. It prompts for address and length consequently. Enter the values as shown in Figure 9.
- 16. On reading, it displays all the read values.



Figure 9 • Read Operation



# Conclusion

This application note describes how to initialize the eNVM using the eNVM client of the eNVM configurator in the Libero SoC and using the Cortex-M3 processor.

# Appendix A – Design Files

You can download the design files from the Microsemi SoC Products Group website: http://soc.microsemi.com/download/rsc/?f=m2s\_ac391\_envm\_initialization\_liberov11p4\_an\_df

The design file consists of Libero Verilog, SoftConsole software project, programming files (\*.stp) for SmartFusion2 SoC FPGA Evaluation Kit. Refer to the Readme.txt file included in the design file for the directory structure and description.

# Appendix B – eNVM Driver APIs

### write\_nvm()

```
static uint32 t
write_nvm
(
    uint32 t addr,
    const uint8_t * pidata,
    uint32 t length,
    uint32 t lock_page,
    uint32_t * p_status
)
{
    uint32 t length written;
    uint32 t offset;
    *p status = 0u;
    offset = addr & NVM OFFSET SIGNIFICANT BITS; /* Ignore remapping.
    ASSERT(offset <= NVM1 TOP OFFSET);
    /* Adjust length to fit within one page. */
    length_written = get_remaining_page_length(offset,
                                                        length)
    if(offset <= NVM1 TOP OFFSET)
    {
        uint32_t block;
        volatile uint32 t ctrl_status;
        uint32 t errors;
        if(offset < NVM1_BOTTOM_OFFSET)
        {
            block = NVM BLOCK 0;
        }
        else
        {
            block = NVM BLOCK 1;
            offset = offset - NVM1 BOTTOM OFFSET;
        }
        fill wd buffer(pidata, length written, block, offset);
        /* Set requested locking option. */
        g_nvm[block]->PAGE_LOCK = lock_page;
          Issue program command */
        g nvm[block]->CMD = PROG ADS | (offset & PAGE ADDR MASK);
        /* Wait for NVM to become ready. */
        ctrl_status = wait_nvm_ready(block);
        /* Check for errors. */
        errors = ctrl status & WRITE ERROR MASK;
        if(errors)
        {
          /* Signal that an error occured by returning 0 a a number of bytes written. */
           length written = 0u;
           *p status = g nvm[block]->STATUS;
        }
        else
        {
```

```
SmartFusion2 SoC FPGA - eNVM Initialization - Libero SoC v11.4
```

```
/* Perform a verify. */
             g_nvm[block]->CMD = VERIFY_ADS | (offset & PAGE_ADDR_MASK);
             /* Wait for NVM to become ready. */
             ctrl_status = wait_nvm_ready(block);
             /* Check for errors. */
             errors = ctrl status & WRITE ERROR MASK;
             if(errors)
             {
             /* Signal that an error occured by returning 0 a a number of bytes written. */
                 length_written = 0u;
                  *p_status = g_nvm[block]->STATUS;
             }
        }
    }
    return length written;
}
MSS_NVM_read()
nvm status t
MSS_NVM_read
(
    uint8_t * addr,
uint8_t * podata,
uint32_t len
)
{
 nvm status t status = NVM SUCCESS;
    uint8 t * nvmaddr = 0u;
         /* add read offset to read the data *
        nvmaddr = ( (uint8_t *) ( NVM_BASE_ADDRESS + addr ) );
while( ( len > 0) && ( NVM_SUCCESS == status ) )
         {
             len--;
             podata[len] = nvmaddr[len];
                  if ( (g_nvm[NVM_BLOCK_0]->STATUS & MSS_NVM ECC2 ) )
                      status = FAILED;
        }
    return status;
}
```

## verify\_nvm()

```
static uint32 t
verify_nvm
(
    uint32 t addr,
    const uint8 t * pidata,
    uint32_t length,
    uint32_t * p_status
)
{
    uint32 t length verified;
    uint32 t offset;
    *p status = Ou;
    offset = addr & NVM OFFSET SIGNIFICANT BITS; /* Ignore remapping.
    ASSERT(offset <= NVM1 TOP OFFSET);
    /* Adjust length to fit within one page. */
    length_verified = get_remaining_page_length(offset, length);
    if(offset <= NVM1_TOP_OFFSET)
    {
        uint32_t block;
        volatile uint32 t ctrl status;
        uint32 t errors;
        if(offset < NVM1_BOTTOM_OFFSET)
        {
            block = NVM BLOCK 0;
        }
        else
        {
            block = NVM_BLOCK_1;
            offset = offset - NVM1 BOTTOM OFFSET;
        }
        fill wd buffer (pidata, length verified, block, offset);
        /* Perform a verify. */
        g nvm[block]->CMD = VERIFY ADS | (offset & PAGE ADDR MASK);
        /* Wait for NVM to become ready. */
        ctrl status = wait nvm ready(block);
        /* Check for errors. */
        errors = ctrl_status & WRITE_ERROR_MASK;
        if(errors)
          /* Signal that an error occured by returning 0 a a number of bytes written. */
            length verified = 0u;
            *p_status = g_nvm[block]->STATUS;
          }
    return length verified;
}
```



SmartFusion2 SoC FPGA - eNVM Initialization - Libero SoC v11.4

# **List of Changes**

The following table lists critical changes that were made in each revision of the document.

| Revision*                     | Changes                                                                          | Page |
|-------------------------------|----------------------------------------------------------------------------------|------|
| Revision 6                    | Updated the document for Libero SoC v11.4 software release (SAR 59913).          | NA   |
| (September 2014)              | Updated the document for SmartFusion2 Evaluation Kit details (SAR 59913).        | NA   |
| Revision 5<br>(May 2014)      | Updated the document for Libero SoC v11.3 software release (SAR 57098).          | NA   |
| Revision 4<br>(November 2013) | Updated the document for Libero SoC v11.2 software release (SAR 52884).          | NA   |
| Revision 3<br>(May 2013)      | Updated the document for Libero SoC v11.0 software release (SAR 47576).          | NA   |
| Revision 2<br>(March 2013)    | Updated the document for Libero SoC v11.0 beta SP1 software release (SAR 44871). | NA   |
| Revision 1<br>(November 2012) | Updated the document for Libero SoC v11.0 beta SPA software release (SAR 42847). | NA   |

Note: \*The revision number is located in the part number after the hyphen. The part number is displayed at the bottom of the last page of the document. The digits following the slash indicate the month and year of publication.



Microsemi Corporate Headquarters One Enterprise, Aliso Viejo CA 92656 USA Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996 E-mail: sales.support@microsemi.com Microsemi Corporation (Nasdaq: MSCC) offers a comprehensive portfolio of semiconductor and system solutions for communications, defense and security, aerospace, and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs, and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; security technologies and scalable anti-tamper products; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Microsemi is headquartered in Aliso Viejo, Calif. and has approximately 3,400 employees globally. Learn more at **www.microsemi.com**.

© 2014 Microsemi Corporation. All rights reserved. Microsemi and the Microsemi logo are trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners.