Demo Guide





# **Revision History**

| Date                          | Revision | Change        |
|-------------------------------|----------|---------------|
| 22 <sup>nd</sup> August, 2014 | 1        | First Release |

### **Confidentiality Status**

This document is a Non-Confidential.



# **Table of Contents**

| Preface                                                                                    | 1 |
|--------------------------------------------------------------------------------------------|---|
| About this document                                                                        | 4 |
| Intended Audience                                                                          | 4 |
| References                                                                                 | 4 |
| Microsemi <sup>®</sup> Publications                                                        | 4 |
| Interfacing SmartFusion2 SoC FPGA with External LPDDR Memory through MDDR Controller       | 5 |
| Introduction                                                                               | 5 |
| Demo Design                                                                                | 3 |
|                                                                                            | ô |
| Demo Design Features                                                                       |   |
| Demo Design Description                                                                    |   |
| Running the Demo using Simulation                                                          |   |
| Simulation                                                                                 |   |
| Running the Simulation                                                                     |   |
| Setting up the Hardware Demo                                                               |   |
| Programming the Demo Design                                                                | Э |
| Setting up the Device                                                                      |   |
| Programming the Device                                                                     |   |
| Performing a Single Data Transfer                                                          |   |
| Performing Burst Data Transfer                                                             | 5 |
| Conclusion                                                                                 |   |
| Appendix A: Configuring the MDDR Controller                                                | 3 |
| MDDR Configuration Tab                                                                     |   |
| Appendix B: Finding the Correct COM Port Number When Using the USB 3.0                     |   |
| Appendix C: Performing Write/Read Operation When Non 64-Bit Aligned Address is Provided 34 |   |
| Product Support                                                                            |   |
| Customer Service                                                                           |   |
| Customer Technical Support Center                                                          |   |
| Technical Support                                                                          |   |
| Website                                                                                    |   |
| Contacting the Customer Technical Support Center                                           |   |
| Email                                                                                      |   |
| Outside the U.S.                                                                           |   |
| ITAR Technical Support                                                                     | 7 |
|                                                                                            |   |
|                                                                                            |   |
|                                                                                            |   |



# Preface

### About this document

This demo guide is for SmartFusion<sup>®</sup>2 system-on-chip (SoC) field programmable gate array (FPGA) devices. It provides instructions on how to use the corresponding reference design.

### **Intended Audience**

The following designers using the SmartFusion2 devices:

- FPGA designers
- System-level designers
- Embedded designers

### References

### Microsemi<sup>®</sup> Publications

- SmartFusion2 SoC FPGA High Speed DDR Interfaces User Guide
- SmartFusion2 System Builder User Guide
- SmartFusion2 SoC Evaluation Kit User Guide

Refer to the following web page for a complete and up-to-date listing of SmartFusion2 SoC device documentation: http://www.microsemi.com/index.php?option=com\_content&id=2034&lang=en&view=article#documents.



### Introduction

This demo shows that the high performance memory subsystem (HPMS) DDR controller accessing the external DDR SDRAM memories in the SmartFusion2 SoC devices. The demo has two parts:

- Demo using simulation
- · Demo using the SmartFusion2 SoC Evaluation Kit

In the demo design, the AXI Master in the FPGA Fabric accesses the Low Power DDR (LPDDR) memory present in the SmartFusion2 SoC Evaluation Kit board using the MDDR Controller. A utility, SF2\_MDDR\_Demo is provided along with the demo deliverables. Using the utility, you can drive the AXI Master logic. The AXI Master converts the commands from the utility to AXI transactions for the MDDR Controller to perform the read/write operations on the LPDDR memory.

Table 1 • Design Requirements

3

| Design Requirements                      | Description                         |
|------------------------------------------|-------------------------------------|
| Hardware Requirements                    |                                     |
| SmartFusion2 SoC Evaluation Kit has:     | Rev C or later                      |
| FlashPro4 programmer                     |                                     |
| 12 V adapter                             |                                     |
| USB A to Mini-B cable                    |                                     |
| Host PC or Laptop                        | Any 64-bit Windows Operating System |
| Software Requirements                    |                                     |
| Libero <sup>®</sup> System-on-Chip (SoC) | v11.4                               |
| FlashPro programming software            | v11.4                               |
| Microsoft .NET Framework 4               | -                                   |
| Host PC Drivers                          | USB to UART drivers                 |



### **Demo Design**

#### Introduction

The demo design files are available for download from the following path in the Microsemi website: http://soc.microsemi.com/download/rsc/?f=SF2\_MDDR\_Demo\_11p4\_DF

Design files include:

- Demo\_utility
- Libero\_project
  - SF2\_MDDR\_Demo
- Programming\_file
- Source\_files
- readme.txt

Figure 1 shows the top level structure of the design files. For further details, refer to the readme.txt file.



#### Figure 1 • Demo Design Files Top Level Structure

Figure 2 on page 7 shows the top level view of demo design.

In the demo design, the AXI Master implemented in the FPGA Fabric accesses the LPDDR memory present in the SmartFusion2 Evaluation Kit board using the MDDR Controller. The AXI Master logic communicates to the MDDR controller through CoreAXI interface and the DDR\_FIC interface. The read/write operations initiated by the SF2\_MDDR\_Demo utility are sent to the UART\_IF block using the UART protocol. The AXI Master receives the address and the data from the UART\_IF block. During a write operation, the UART\_IF block sends the address and data to the AXI Master logic.



During a read operation, the UART\_IF block sends the address to the AXI Master and stores the read data in TPSRAM. When the read operation is complete, the read data is sent to the Host PC through UART.



#### Figure 2 • SmartFusion2 MDDR Demo Block Diagram

In this demo design, different blocks are configured as shown below:

- MDDR Controller is configured for LPDDR memory available in the SmartFusion2 Evaluation Kit board. The LPDDR memory is a Micron DRAM part (part number MT46H32M16LF)
- DDR\_FIC is configured for AXI bus interface.
- AXI clock is configured for 80 MHz and LPDDR clock is configured for 160 MHz.
- TPSRAM IP has the following configuration:
  - Write port depth: 256
  - Write port width: 64
  - Read port depth: 2048
- Read port width: 8

Refer to "Appendix A: Configuring the MDDR Controller" on page 28 for information on how to configure the DDR controller.



### **Demo Design Features**

The SF2 MDDR demo design has the following features:

- Single AXI read/write transactions
- 16-beat burst AXI read/write transactions
- LPDDR memory model simulation using SmartDesign testbench
- Design validation using the SmartFusion2 SoC Evaluation Kit board that has the LPDDR memory
- Initiation of the read/write transactions using SF2 MDDR Demo utility

#### **Demo Design Description**

The demo design consists of the following SmartDesign components:

- **MDDR\_Demo\_top\_0**: This SmartDesign handles the data transactions between the MDDR controller and LPDDR SDRAM.
- **UART\_IF\_0**: This SmartDesign handles the communication between the Host PC and the SmartFusion2 SoC Evaluation Kit Board.

Figure 3 shows the MDDR\_Demo\_top\_0 and UART\_IF\_0 connection



Figure 3 • SF2\_MDDR\_Demo SmartDesign





#### MDDR\_Demo\_top\_0

This consists of the MDDR\_Demo\_0 subsystem generated using the System Builder and the AXI\_IF\_0 master logic. The AXI\_IF\_0 master logic is an RTL code that implements the AXI read and write transactions. It receives the read/write operations, burst length (RLEN and WLEN), address and data as inputs. Based on inputs received, it communicates with the LPDDR memory through the MDDR controller.

Figure 4 shows the MDDR\_Demo\_top\_0 SmartDesign component.



Figure 4 • MDDR\_Demo\_top\_0 SmartDesign Component



#### UART\_IF\_0

The UART\_IF\_0 SmartDesign component handles the communication between Host PC demo utility and the AXI Master logic. The MMUART\_1 block present in the MSS subsystem receives the UART signals from the Host PC user interface, the Cortex-M3 processor sends this user data to the DATAHANDLE\_FSM block present in the FPGA fabric using the FIC\_0 APB slave interface. DATAHANDLE\_FSM is an APB slave wrapper, which sends the received data to the UART\_IF\_FSM\_0 block.

For a single write operation, the UART\_IF\_FSM\_0 wrapper receives the address and data from the demo utility. For a burst write operation, the address and data are received from the demo utility and the subsequent incremental data are provided by the UART\_IF\_FSM\_0 wrapper.

For a burst read operation, UART\_IF\_FSM\_0 collects the address from the demo utility and sends that to the AXI\_IF\_0 master logic. It then receives the read data from the AXI\_IF\_0 master logic and stores it in the TPSRAM\_0. After completion of the read burst transactions, the Cortex-M3 processor reads the TPSRAM\_0 buffer through DATAHANDLE\_FSM (APB wrapper) block. The received data is sent to the Host PC using the MMUART 1 block.





Figure 5 • UART\_IF\_0 SmartDesign Component



### **Running the Demo using Simulation**

#### Introduction

The demo design can be simulated using SmartDesign Testbench and the LPDDR memory model (MT46H32M16LF with 512 Mb density).

The simulation is set to run the following:

- Single AXI write and read operation
- 16-beat AXI burst write and read operation

Figure 6 shows the AXI\_LPDDR\_Simulation SmartDesign Testbench. The AXI\_testbench provides the read/write operations, burst length, address, and data to the MDDR\_Demo\_top\_0 SmartDesign component.



Figure 6 • AXI\_LPDDR\_Simulation SmartDesign Testbench



To run simulation, ensure that the following files are present in the Libero SoC project:

- dram.v
- dram\_parameters.vh
- AXI testbench.v

The default location of the above mentioned files is,

<Download folder>\SF2\_MDDR\_Demo\_DF\Libero\_project\SF2\_MDDR\_Demo\stimulus

#### Simulation

Simulation setup configuration can be set properly by using the following steps:

- 1. Launch the Libero SoC software.
- 2. Browse the SF2\_MDDR\_Demo project provided in the design file.
- 3. Go to Project > Project Settings > Simulation Options.
- 4. Ensure that the DO File tab has the configuration as shown in Figure 7.

| Device<br>Device I/O Settings     | Vuse automatic DO file                      | Save             |
|-----------------------------------|---------------------------------------------|------------------|
| Preferred HDL Type                | Simulation runtime: 900us                   | Restore Defaults |
| Design Flow<br>Simulation Options | Testbench module name: AXI_LPDDR_Simulation |                  |
| DO File                           | Top level instance name: <top>_0</top>      |                  |
| Waveforms<br>Vsim commands        | Generate VCD file                           |                  |
| Simulation Libraries              | VCD file name: power.vcd                    |                  |
| SmartFusion2<br>COREAPB3_LIB      | Select Verilog Language Syntax              |                  |
| COREAPB5_LIB                      | Verilog 2001                                |                  |
|                                   | System Verilog                              |                  |
|                                   | Select VHDL Language Syntax                 |                  |
|                                   | VHDL 2008                                   |                  |
|                                   |                                             |                  |
|                                   | User defined DO file:                       |                  |
|                                   | DO command parameters:                      |                  |
| Help                              |                                             | Close            |
| нер                               |                                             | Close            |



5. Ensure that the **Waveforms** tab has the configuration as shown in Figure 8.

| Project Settings                                                                                                                                          | 1000 1000 1000                                                                                                                               |   | ? <mark>x</mark>         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---|--------------------------|
| Device<br>Device I/O Settings<br>Preferred HDL Type<br>Design Flow<br>Simulation Options<br>DO File<br>Waveforms<br>Vsim commands<br>Simulation Libraries | ✓ Include DO file         wave.do         Display waveforms for       top_level AXI_LPDDR_Simulation         ✓ Log all signals in the design |   | Save<br>Restore Defaults |
| <ul> <li>Simulation Libraries<br/>SmartFusion2<br/>COREAPB3_LIB</li> </ul>                                                                                |                                                                                                                                              |   | Ó.                       |
|                                                                                                                                                           |                                                                                                                                              | Č |                          |
| Help                                                                                                                                                      |                                                                                                                                              |   | Close                    |
| <i>Figure 8 ∙</i> Waveforn                                                                                                                                | ns Settings                                                                                                                                  |   |                          |
| C                                                                                                                                                         |                                                                                                                                              |   |                          |
|                                                                                                                                                           |                                                                                                                                              |   |                          |



- 6. Go to **Design Flow** tab.
- 7. Right click Simulate under Verify Pre synthesized Design and then select, Organize Input Files > Organize Stimulus Files.



Figure 9 • Invoking Organize Stimulus Files Window

8. Ensure that the Organize Stimulus files window has the configuration as shown in Figure 10.

| Organize Stimulus files of SF2_MDDR_Dem<br>Click to select a Stimulus file in the project, and us<br>Use the Remove button to remove Stimulus files.<br>Use the Up/Down arrow buttons to specify the or | e the Add button to pass the |   |          | ool. |                           |                      |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|---|----------|------|---------------------------|----------------------|
| Use list of files organized by<br>Clibero (default list)<br>User                                                                                                                                        |                              |   |          |      |                           | <b>→ •</b>           |
| Stimulus files in the project                                                                                                                                                                           | Origin                       | - |          |      | Associated Stimulus files | Origin               |
| 1 axi_master.v                                                                                                                                                                                          | MDDR_Demo                    |   |          | 1    | AXI_testbench.v           | User                 |
| 2 axi_slave.v                                                                                                                                                                                           | MDDR_Demo                    | Е | Add ->   | 2    | AXI_LPDDR_Simulation.v    | AXI_LPDDR_Simulation |
| 3 coreparameters.v                                                                                                                                                                                      | SmartDesign                  |   |          | 3    | RESET_GEN.v               | AXI_LPDDR_Simulation |
| 4 axi_master.v                                                                                                                                                                                          | SmartDesign                  |   |          |      |                           |                      |
| 5 axi_slave.v                                                                                                                                                                                           | SmartDesign                  |   | + Remove |      |                           |                      |
| 6 coreparameters.v                                                                                                                                                                                      | MDDR_Demo                    |   | - Remove |      |                           |                      |
| 7 bfm_ahbtoapb.v                                                                                                                                                                                        | MDDR_Demo                    |   |          |      |                           |                      |
| 9 bfm anb v                                                                                                                                                                                             | MDDR Domo                    | - |          |      |                           |                      |
| Help                                                                                                                                                                                                    |                              |   |          |      |                           | OK Cancel            |

Figure 10 • Organize Stimulus Files Window



#### **Running the Simulation**

- 1. Right click Simulate under Verify Pre Synthesized Design.
- 2. Click Open Interactively.
- 3. Simulation requires 900us to complete as mentioned in the 3rd point under "Simulation" section on page 12.

Figure 11 shows the transcript window of the simulation.

| e <u>E</u> dit <u>V</u> iew <u>C</u> or |             |                              |            | 1        | _          | s <u>W</u> indow | Help      | EN EI E  | <b>K</b> 📣 1      | and m-1 | -m     |       |      |     |       |  |
|-----------------------------------------|-------------|------------------------------|------------|----------|------------|------------------|-----------|----------|-------------------|---------|--------|-------|------|-----|-------|--|
|                                         |             | • 🔍 ا تبت کیت                |            | <u> </u> | • 🖛 🖦      | ET   100         | fs 🛊 📃    |          | 2 👑 📋             |         | 600)   |       |      |     |       |  |
| ColumnLayout AllCo                      |             |                              | <u> </u>   |          |            |                  | 1         |          |                   |         |        |       |      |     |       |  |
| 4444                                    |             | 3≪ • ⇒€ • ऄॖ•                | Search:    |          |            |                  |           |          |                   |         |        | 1.    | ŢŢ   |     |       |  |
| Transcript<br>At Time                   | 809130650 p | s AXI_LPDDR                  | Simulation | dram 0   | DO DOS Dr  | ivers.PFM        | ) Bank -  | 0 Row    | - 0000            | Col -   | 042 1  | ata - | 5678 |     | 10000 |  |
| At Time                                 |             | s AXI LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | S AXI LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| Debug: At Time                          | 8091        | 36900 ps AXI                 | LPDDR_Sim  | ulation. | dram_0.Co  | ontrol_Logi      | c:READ:   | BAnk = 0 | , Col =           | 048     |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      | • • |       |  |
| At Time                                 |             | s AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time<br>At Time                      |             | s AXI_LPDDR_<br>s AXI LPDDR  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR_<br>s AXI LPDDR  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 | 809161900 p | s AXI_LPDDR                  | Simulation | .dram_0. | DQ_DQS_Dr  | ivers:READ       | : BAnk =  | 0, Row   | = 0000,           | Col =   |        |       |      |     |       |  |
| Debug: At Time                          | 8091        | 61900 ps AXI                 | _LPDDR_Sim | ulation. | dram_0.Co  | ontrol_Logi      | c:READ:   | BAnk = 0 | , Col =           | 050     |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time<br>At Time                      |             | s AXI_LPDDR_<br>s AXI LPDDR  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR_<br>s AXI_LPDDR  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| Debug: At Time                          |             | 86900 ps AXI                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 | 809190025 p | s AXI_LPDDR_                 | Simulation | .dram_0. | DQ_DQS_Dr  | ivers:REAL       | : BAnk =  | 0, Row   | = 0000,           | Col =   | 055, I | ata = | 0000 |     |       |  |
| At Time                                 |             | s AXI_LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 | 809196275 p | s AXI_LPDDR_                 | Simulation | .dram_0. | DQ_DQS_Dr  | ivers:REAL       | ): BAnk = | 0, Row   | = 0000,           | Col =   | 057, 1 | ata = | 1234 |     |       |  |
| At Time<br>At Time                      |             | s AXI_LPDDR_<br>s AXI LPDDR  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| Debug: At Time                          | 8092        | 11900 ps AXI                 | _LPDDR_Sim | ulation. | dram_0.Co  | ntrol_Logi       | c:READ:   | BAnk = 0 | , Col =           | 060     |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time<br>At Time                      | 809221275 p | s AXI_LPDDR_<br>s AXI_LPDDR_ | Simulation | .dram_0. | DQ_DQS_Dr  | ivers:REAL       | : BAnk =  | 0, Row   | = 0000,           | Col =   | 05f, I | ata = | 1234 |     |       |  |
| At Time<br>At Time                      | 809224400 p | s AXI_LPDDR_<br>s AXI_LPDDR_ | Simulation | dram 0.  |            | ivers:REAL       | Bank =    | 0, ROW   | = 0000,<br>- 0000 | Col =   | 061 1  | ata = | 0030 |     |       |  |
| At Time                                 |             | s AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 | 809233775 p | s AXI_LPDDR                  | Simulation | .dram 0. | DO DOS Dr  | ivers:REAL       | : BAnk =  | 0, Row   | = 0000.           | Col =   | 063, I | ata = | 1234 |     |       |  |
| At Time                                 |             | s AXI_LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| Debug: At Time                          | 8092        | 36900 ps AXI                 | _LPDDR_Sim | ulation. | dram_0.Co  | ntrol_Logi       | c:READ:   | BAnk = 0 | , Col =           | 068     |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time<br>At Time                      |             | s AXI_LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At lime<br>At Time                      |             | s AXI_LPDDR_<br>s AXI_LPDDR  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | S AXI LEDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | S AXI LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | s AXI_LPDDR                  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time                                 |             | S AXI_LPDDR_                 |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At Time<br>At Time                      |             | s AXI_LPDDR_<br>s AXI LPDDR  |            |          |            |                  |           |          |                   |         |        |       |      |     |       |  |
| At lime<br>Debug: At Time               |             | 93145 ps AXI                 |            |          |            |                  |           |          |                   |         |        | dud = | 1234 |     |       |  |
| AXI_LPDDR_Simula                        |             |                              |            |          |            | 145 ps Ent       |           |          |                   |         |        |       |      |     |       |  |
| M 2>                                    |             | rto X Stores                 |            | ibrary × | 📑 Memory I | List 🗙 🖉 sir     |           |          |                   |         |        |       |      |     |       |  |
| Transcript × 📰 Wa                       |             | ects × 🐡 Proce               |            |          | Memory I   | LIST A SI        |           |          |                   |         |        |       |      |     |       |  |

Figure 11 • Simulation Completed



Figure 12 shows the single AXI write and AXI read operation.



Figure 13 shows the 16-beat AXI burst write and read operation.



Figure 13 • 16-Beat AXI Burst Write and Read



### Setting up the Hardware Demo

Use the following steps to setup the hardware demo:

1. Connect the jumpers on the SmartFusion2 SoC Evaluation Kit as shown in Table 2.

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

| Jumper | Pin (from) | Pin (to) | Comments |
|--------|------------|----------|----------|
| J22    | 1          | 2        | Default  |
| J23    | 1          | 2        | Default  |
| J24    | 1          | 2        | Default  |
| J8     | 1          | 2        | Default  |
| J3     | 1          | 2        | Default  |

CAUTION: While making the jumper connections, the power supply switch SW7 must be switched off.

- 2. Connect the Power supply to the J6 connector, switch on the power supply switch, SW7.
- 3. Connect the FlashPro4 programmer to the J5 connector of the SmartFusion2 Evaluation Kit.
- 4. Connect the Host PC USB port to the SmartFusion2 Evaluation Kit board's J18 USB connector using the USB mini-B cable.

Figure 14 shows the board setup for running the SmartFusion2 MDDR demo on the SmartFusion2 Evaluation Kit.



Figure 14 • SmartFusion2 Evaluation Kit



5. Ensure that the USB to UART bridge drivers are automatically detected. This can be verified in the **Device Manager** of the Host PC. The FTDI USB to UART converter enumerates four COM ports. For USB 2.0, note down the USB Serial Converter D COM port number to use it in the GUI. Figure 15 shows the USB 2.0 Serial port properties. As shown in Figure 15, COM7 is connected to USB Serial Converter D. Refer to "Appendix B: Finding the Correct COM Port Number When Using the USB 3.0" on page 32 for finding the correct COM port in USB 3.0.



Figure 15 • USB Serial 2.0 Port Properties

6. If the 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.



### **Programming the Demo Design**

Use the following steps to program the demo:

- Download the demo design from: http://soc.microsemi.com/download/rsc/?f=SF2\_MDDR\_Demo\_11p4\_DF
- 2. Switch **ON** the SW7 power supply switch.
- 3. Launch the FlashPro software.
- 4. Click New Project.
- 5. In the New Project window, type the project name as SF2\_MDDR\_Demo.



Figure 16 • FlashPro New Project

- 6. Click Browse and navigate to the location where you want to save the project.
- 7. Select Single device as the Programming mode.
- 8. Click **OK** to save the project.



#### **Setting up the Device**

Use the following steps to configure the device:

- 1. Click Configure Device on the FlashPro GUI.
- Click Browse and navigate to the location where the SF2\_MDDR\_Demo.stp file is located and select the file. The default location is:
  - $<\!\!download\_folder\!\!>\!\!\SF2\_MDDR\_Demo\_DF\!\!\Programming\_file\!\!\.$
- 3. Click **Open**. The required programming file is selected and is ready to be programmed in the device.



Figure 17 • FlashPro Project Configured



### **Programming the Device**

Use the following steps to start programming the device:

1. Click **PROGRAM** to start programming the device. Wait until you get a message indicating that the **PROGRAM PASSED**.



Figure 18 • FlashPro Program Passed



#### **Running the Hardware Demo**

The SmartFusion2 SoC MDDR demo comes with utility,  $SF2\_MDDR\_Demo$  that runs on the Host PC to communicate with the SmartFusion2 SoC Evaluation Kit. The UART protocol is used as the underlying communication protocol between the Host PC and the SmartFusion2 SoC Evaluation Kit. Figure 19 shows the initial screen of the  $SF2\_MDDR\_Demo$  utility.



#### Figure 19 • SF2\_MDDR\_Demo Utility

The SF2\_MDDR\_Demo utility has the following sections:

- Serial Port Configuration: Displays the serial port. Baud rate is fixed at 115200.
- Data Transfer Type: Single or Burst.
- LPDDR SDRAM: Provides Address and Data.
- LPDDR Burst Read: Displays the Burst Read Values for the corresponding address.
- C: Clears the existing data.





#### Steps to run the GUI

- Launch the utility. The default location is: <download\_folder>\\SF2\_MDDR\_Demo\_DF\Demo\_Utility\SF2\_MDDR\_Demo.exe.
- 2. Select the appropriate COM port from drop down menu. In this case, it is COM 7.
- 3. Click **Connect**. The connection status along with the COM Port and Baud rate is shown in the left bottom corner of the screen. Figure 20 shows the connection status of the utility.

| COM Port COM7 -                       |      | SI.No  | Address | Data       |      |
|---------------------------------------|------|--------|---------|------------|------|
|                                       |      | 31.110 | Address | Data       |      |
| Data Transfer Type                    |      |        |         |            |      |
| <ul> <li>Single (8 - byte)</li> </ul> |      |        |         |            |      |
|                                       |      |        |         |            |      |
| Burst (2048 - byte)                   |      |        |         |            |      |
| LPDDR SDRAM                           |      |        |         |            |      |
| Address 00000000 C                    |      |        |         |            |      |
|                                       |      |        |         |            |      |
| Data 0123456789ABCDEF C               |      |        |         |            | -    |
|                                       |      |        |         |            |      |
|                                       |      |        |         |            |      |
| Disconnect Write                      | Read |        | Exit    | SMARTFUSIO | NP 2 |
| UISCONNECT WINC                       | nouu |        |         | SMARIFUSIO |      |

Figure 20 • SF2\_MDDR\_Demo – Connection Status

### Performing a Single Data Transfer

For a single write or read operation, the AXI Master logic is configured to transfer a burst length of 1 (that is, 8 bytes). For a write operation, the utility sends a 32-bit address and 64-bit (8 bytes) data. The data is then written to the LPDDR SDRAM. For a read operation, the utility sends a 32-bit address and receives 64-bit data from LPDDR and is displayed in the utility.

To perform a single data transfer, follow the below mentioned steps:

- 1. Select the Data Transfer Type as Single (8 bytes).
- A 64-bit aligned address is required in the address field. Enter a 32-bit HEX Address in the range 0x00000000 - 0x03FFFF8. When a non 64-bit aligned address is provided, the GUI converts it to 64-bit aligned address and performs the write/read. Refer to "Appendix C: Performing Write/Read Operation When Non 64-Bit Aligned Address is Provided" on page 34 to perform write/read when non 64-bit aligned address is provided.
- 3. In the Data field, enter a 64-bit data in HEX format.
- 4. Click Write. The entered data is written to the LPDDR memory.



5. Figure 21 shows the **Address** and **Data** values entered for a Single Write operation.

| Serial Port Configuration | LFUU | R Burst Rea | D       |        |       |  |
|---------------------------|------|-------------|---------|--------|-------|--|
| COM Port COM7 -           |      | SI.No       | Address | Data   |       |  |
|                           | •    |             |         |        |       |  |
| Data Transfer Type        |      |             |         |        |       |  |
| Single (8 - byte)         |      |             |         |        |       |  |
| Burst (2048 - byte)       |      |             |         |        |       |  |
| LPDDR SDRAM               |      |             |         |        |       |  |
|                           |      |             |         |        |       |  |
| Address 00000028          |      |             |         |        |       |  |
| Data 0000A1B2C3D4E5F6 C   |      |             |         |        |       |  |
|                           |      |             |         |        |       |  |
|                           |      |             |         |        |       |  |
| Disconnect                | Read |             | Exit    | CE     |       |  |
| Disconnect                | Read |             | LAI     | SMARTF | USION |  |

#### Figure 21 • Single Write Operation

- 6. To verify the write operation, perform a read operation to the same address where the data was written.
- 7. Press C to clear the data present in the Data field. Figure 22 highlights the Clear button, C.

| Serial Port Configuration |      | R Burst Rea |         |      |                   |
|---------------------------|------|-------------|---------|------|-------------------|
| COM Port COM7             |      | SI.No       | Address | Data |                   |
| Data Transfer Type        |      |             |         |      |                   |
| Single (8 - byte)         |      |             |         |      |                   |
| Burst (2048 - byte)       |      |             |         |      |                   |
| LPDDR.SDRAM               |      |             |         |      |                   |
| Address 00000028          |      |             |         |      |                   |
| Address 0000028           |      |             |         |      |                   |
| Data                      | C    |             |         |      | -                 |
|                           |      |             |         |      |                   |
|                           |      |             |         |      | -                 |
| Disconnect Write          | Read |             | Exit    |      | on <sup>•</sup> 2 |

#### Figure 22 • Clear the Data Field

8. Click **Read** to read the data from the LPDDR SDRAM.



Figure 23 shows the data read from the LPDDR SDRAM.

|                         |      | Burst Rea |         |          |          |
|-------------------------|------|-----------|---------|----------|----------|
| COM Port COM7 -         |      | SI.No     | Address | Data     | <u>^</u> |
|                         |      |           |         |          |          |
| Data Transfer Type      |      |           |         |          |          |
| Single (8 - byte)       |      |           |         |          |          |
| Burst (2048 - byte)     |      |           |         |          |          |
| LPDDR SDRAM             |      |           |         |          |          |
|                         |      |           |         |          |          |
| Address 00000028 C      |      |           |         |          |          |
| Data 0000A1B2C3D4E5F6 C |      |           |         |          |          |
|                         |      |           |         |          |          |
|                         |      |           |         |          |          |
| Disconnect Write        | Read |           | Exit    | CE.      |          |
| Disconnect              | Read |           | EXIL    | SMARTFUS | ION° Z   |

#### Figure 23 • Single Read Operation

9. Compare the read and write data. The write and read data being same establishes that the write and read operations to the LPDDR SDRAM were successful.

### Performing Burst Data Transfer

For a burst write or read operation, the AXI Master logic is configured to transfer a burst length of 16 (that is, 128 bytes). In this demo, 16 transfers of 16-beat burst operations is implemented, that is, 16 (transfers) x 16-beat burst data = 2048 bytes data). For a write operation, the utility sends a 32-bit initial address and 64-bit (8 bytes) initial data. After the initial write operation, incremental data is written. For a read operation, the utility sends a 32-bit address and receives 2048 bytes of data from the LPDDR SDRAM and the data is displayed in the utility.

To perform a burst data transfer, follow the below mentioned steps:

- 1. Select the Data Transfer Type as Burst (2048 bytes).
- 2. A 64-bit aligned address is required in the address field. Enter a 32-bit HEX Address in the range 0x00000000 0x03FFF7F8. When a non 64-bit aligned address is provided, the GUI converts it into 64-bit aligned address and performs the write/read operation. Refer to "Appendix C: Performing Write/Read Operation When Non 64-Bit Aligned Address is Provided" on page 34 to perform write/read when non 64-bit aligned address is provided.
- 3. In the Data field, enter a 64-bit data in HEX format.
- 4. Click **Write**. The entered data is written to the Address location specified in the Address filed and then the data is incremented by 1 and written to the next address location. This is repeated 256 times to write all the 2048 bytes of data.



5. Figure 24 shows the Address and Data values entered for a Burst Write operation.

| Serial Port Configuration                | LPDDR Burst Re | ead     |           |                   |
|------------------------------------------|----------------|---------|-----------|-------------------|
| COM Port COM7 -                          | SI.No          | Address | Data      |                   |
| Data Transfer Type                       |                |         |           |                   |
| Single (8 - byte)                        |                |         |           |                   |
| Burst (2048 - byte)                      |                |         |           |                   |
| LPDDR SDRAM                              |                |         |           |                   |
| Address 0000000 C                        |                |         |           |                   |
| Address                                  |                |         |           |                   |
| Data 00000000000000000000000000000000000 |                |         |           |                   |
|                                          |                |         |           |                   |
|                                          |                |         |           |                   |
| Disconnect Write                         | Read           | Exit    | SMARTFUSI | on <sup>•</sup> 2 |
|                                          |                |         |           |                   |

#### Figure 24 • Burst Write operation

- 6. To verify the write operation, perform a read operation to the same address where the data was written.
- 7. Click **Read**. All the 2048 bytes of data that was written to the LPDDR was read and the read data was displayed in the LPDDR Burst Read panel. Figure 25 shows the burst read data.

| COM Port COM7                            | SI.No | Address | Data             |    |
|------------------------------------------|-------|---------|------------------|----|
|                                          | • 1   | 0000000 | 0000000000000001 |    |
| Data Transfer Type                       | 2     | 8000000 | 000000000000002  |    |
| Single (8 - byte)                        | 3     | 0000010 | 00000000000003   |    |
| Burst (2048 - byte)                      | 4     | 0000018 | 000000000000004  |    |
|                                          | 5     | 0000020 | 000000000000005  |    |
|                                          | 6     | 0000028 | 000000000000006  |    |
| Address 00000000 C                       | 7     | 0000030 | 000000000000007  |    |
| Data 00000000000000000000000000000000000 | 8     | 0000038 | 00000000000008   |    |
| Disconnect Write Re                      | ad    | Exit    |                  | N° |

Figure 25 • Burst Read Operation

8. Click **Exit** to exit the utility.



### Conclusion

This demo shows how to perform Read/Write operations to LPDDR SDRAM using SmartFusion2 SoC MDDR controller. Options are provided to simulate the design using a SmartDesign testbench and validate the design on the SmartFusion2 SoC Evaluation Kit using a GUI interface.

# **Appendix A: Configuring the MDDR Controller**

This section describes how to configure the MDDR Controller registers using Libero SoC. Configuration options for MDDR are available at the **MDDR** tab of the **Memories** tab in System Builder. Figure 26 shows the **MDDR** tab.

The SmartFusion2 SoC Evaluation Kit has the LPDDR memory from Micron. All values provided here are from the Micron datasheet, part number, MT46H32M16LF.

Note: The Automotive Mobile Low-Power DDR SDRAM datasheet is available for download from Micron website.

| System Builder - Memories                                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Device Features Memories Peripherals Configure you                                                                                               |
| DDR memory settling time (us): 200                                                                                                               |
| Import Configuration         Export Configuration         Restore Defaults           General         Memory Initialization         Memory Timing |
| Memory Settings<br>Memory Type                                                                                                                   |
| Data Width 16  SECDED Enabled ECC                                                                                                                |
| Arbitration Scheme     Type-0 ▼       Highest Priority ID     0                                                                                  |
| Address Mapping {ROW,BANK,COLUMN}                                                                                                                |

Figure 26 • System Builder - Memories - MDDR Tab

### **MDDR Configuration Tab**

When using an external memory, the memory controller must wait for the memory to initialize (settling time) before accessing it. Since the SmartFusion2 SoC Evaluation Kit is using the LPDDR memory, the DDR Controller has to wait at least 200us. Provide 200 as the value for the field, **DDR memory settling time (us)**.

Note: All the values provided here are from the Micron datasheet. The parameters can be configured according to the user's requirements.



#### General

This section shows the configurations of the **General** tab.

- Memory Type: LPDDR
- Data Width: 16

Figure 27 shows the General tab after configuration parameters are set.

| General Memory In   | itialization Memory Timing |
|---------------------|----------------------------|
| Memory Settings     |                            |
| Memory Type         | LPDDR                      |
| Data Width          | 16                         |
| SECDED Enabled ECC  |                            |
| Arbitration Scheme  | Type-0                     |
| Highest Priority ID | 0                          |
| Address Mapping     | {ROW,BANK,COLUMN}          |
| I/O Standard        |                            |
|                     | st Power)                  |
|                     |                            |
| IO Calibration      |                            |
| On                  | © Off                      |
|                     |                            |

Figure 27 • System Builder MDDR Configuration – General Tab



#### Memory Initialization

This section shows the configurations of the Memory Initialization tab.

- Burst length: 8
- Burst Order: Sequential
- Timing Mode: 1T
- CAS Latency: 3
- Self Refresh Enabled: NO
- Auto Refresh Burst Count: 8
- Power Down Enabled: YES
- Stop the clock: NO
- Deep Power Down enabled: NO
- No Activity clocks for Entry: 320

Figure 28 shows the Memory Initialization tab after configuration parameters are set.

| Import Configuration Ex | port Configuration Restore Defaults |        |
|-------------------------|-------------------------------------|--------|
| General Memory Init     | ialization Memory Timing            |        |
| Burst Length            | 8                                   | Bits   |
| Burst Order             | Sequential                          | ·      |
| Timing Mode             | 17                                  | •      |
| CAS Latency             | 3                                   | Clks   |
| Self Refresh Enabled    | NO                                  | Bursts |
| Auto Refresh Burst Coun | it 8                                | ·      |
| Powerdown Enabled       | YES                                 | •      |
| Stop the Clock          | NO                                  | •      |
| Deep Rowerdown Enable   | d NO •                              | ·      |
| Powerdown Entry Time    | 320                                 |        |
| Additive CAS Latency    |                                     | Clks   |
| CAS Write Latency       | 5                                   | Clks   |
| Zqinit                  | 0                                   | Clks   |
| ZQCS                    | 0                                   | Clks   |
| ZQCS Interval           | 0                                   | Clks   |

Figure 28 • System Builder MDDR Configuration – Memory Initialization Tab



#### Memory Timing:

This section shows the configurations of the Memory Timing tab.

- Time To Hold Reset Before INIT 0 clks
- MRD: 4 clks
- RAS (Min): 8 clks
- RAS (Max): 8192 clks
- RCD: 6 clks
- **RP**: 7 clks
- **REFI**: 3104 clks
- RC: 3 clks
- **XP**: 3 clks
- CKE: 3 clks
- **RFC**: 79 clks
- FAW: 0 clks

Figure 29 shows the Memory Timing tab after configuration parameters are set.



Figure 29 • System Builder MDDR Configuration – Memory Timing Tab

## Appendix B: Finding the Correct COM Port Number When Using the USB 3.0

FTDI USB to UART converter enumerates the four COM ports. In USB 3.0, the four available COM ports are in Location 0. Figure 30 shows the USB 3.0 Serial port properties.



Figure 30 • USB 3.0 Serial Port Properties



To find out the correct COM port, program the SmartFusion2 SoC Evaluation Kit board with provided programming file. Connect each available COM port and click **Write**. If wrong COM port is selected, the GUI displays the read error. Try with all four available COM ports until this message disappears. Figure 31 shows the read error message.



# Appendix C: Performing Write/Read Operation When Non 64-Bit Aligned Address is Provided

When a non 64-bit aligned address is provided in the GUI, the GUI converts it into the 64-bit aligned address (0, 8,10,18,20,28,30,38 ...) and performs the write/read operation.

- 1. Enter the non 64-bit aligned 32-bit address in HEX format.
- 2. Enter the 64-bit data in HEX format.

Figure 32 shows the non 64-bit aligned address entered in the GUI.



Figure 32 • Non 64-Bit Aligned Address





3. Click **Write** to perform write operation. GUI converts the address into 64-bit aligned address and performs the write operation.

Figure 33 shows the GUI pop up information message and converted 64-bit aligned address.

| Serial Port Configuration                | DDR SDRAM Address                                                                                                |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| COM Port COM7                            |                                                                                                                  |
| Data Tangén Tang                         | LPDDR SDRAM start address 0x00000015 is not 64-bit aligned<br>Writing to 64-bit aligned start address 0x00000010 |
| Oata Transfer Type     Single (8 - byte) |                                                                                                                  |
| <ul> <li>Burst (2048 - byte)</li> </ul>  | ОК                                                                                                               |
|                                          |                                                                                                                  |
| LPDDR SDRAM                              |                                                                                                                  |
| Address 00000010                         |                                                                                                                  |
| Data 0123456789AB                        | CDEF C                                                                                                           |
| 012040070070                             |                                                                                                                  |
|                                          | 64 bit aligned address                                                                                           |
| Discourse                                |                                                                                                                  |
| Disconnect Write                         |                                                                                                                  |
|                                          |                                                                                                                  |



3



# **Product Support**

Microsemi SoC Products Group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, electronic mail, and worldwide sales offices. This appendix contains information about contacting Microsemi SoC Products Group and using these support services.

### **Customer Service**

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, 408.643.6913

### **Customer Technical Support Center**

Microsemi SoC Products Group staffs its Customer Technical Support Center with highly skilled engineers who can help answer your hardware, software, and design questions about Microsemi SoC Products. The Customer Technical Support Center spends a great deal of time creating application notes, answers to common design cycle questions, documentation of known issues, and various FAQs. So, before you contact us, please visit our online resources. It is very likely we have already answered your questions.

### **Technical Support**

Visit the Customer Support website (www.microsemi.com/soc/support/search/default.aspx) for more information and support. Many answers available on the searchable web resource include diagrams, illustrations, and links to other resources on the website.

### Website

You can browse a variety of technical and non-technical information on the SoC home page, at www.microsemi.com/soc.

### **Contacting the Customer Technical Support Center**

Highly skilled engineers staff the Technical Support Center. The Technical Support Center can be contacted by email or through the Microsemi SoC Products Group website.

### Email

You can communicate your technical questions to our email address and receive answers back by email, fax, or phone. Also, if you have design problems, you can email your design files to receive assistance. We constantly monitor the email account throughout the day. When sending your request to us, please be sure to include your full name, company name, and your contact information for efficient processing of your request.

The technical support email address is soc\_tech@microsemi.com.



#### My Cases

Microsemi SoC Products Group customers may submit and track technical cases online by going to My Cases.

#### Outside the U.S.

Customers needing assistance outside the US time zones can either contact technical support via email (soc\_tech@microsemi.com) or contact a local sales office. Sales office listings can be found at www.microsemi.com/soc/company/contact/default.aspx.

### **ITAR Technical Support**

For technical support on RH and RT FPGAs that are regulated by International Traffic in Arms Regulations (ITAR), contact us via soc\_tech\_itar@microsemi.com. Alternatively, within My Cases, select **Yes** in the ITAR drop-down list. For a complete list of ITAR-regulated Microsemi FPGAs, visit the ITAR web page.

Interfacing SmartFusion2 SoC FPGA with External LPDDR Memory through MDDR Controller - Libero SoC v11.4August 2014



Microsemi Corporate Headquarters One Enterprise, Aliso Viejo CA 92656 USA Within 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.