

# **Table of Contents**

| Purpose                                     |
|---------------------------------------------|
| Introduction                                |
| References                                  |
| Reference Design Requirements and Details   |
| Optimization Techniques                     |
| Frequency of Operation                      |
| Burst Length                                |
| AXI Master without Write Response State     |
| Read Address Queuing                        |
| Series of Writes or Reads                   |
| DDR Configuration Tuning                    |
| Implementation on IGLOO2 Device             |
| Design Description                          |
| Hardware Implementation                     |
| Running the Design                          |
| Setting up the Hardware                     |
| Running the Performance Measurement Utility |
| LPDDR SDRAM Bandwidth                       |
| Simulation Result                           |
| Board Test Result                           |
| Conclusion                                  |
| Appendix A – Design Files                   |

# **Purpose**

This application note describes the techniques for improving the efficiency of double data rate (DDR) controller using an example design for the IGLOO<sup>®</sup>2 Evaluation Kit board. It also provides details about implementing the DDR SDRAM simulation flow using the Micron low power DDR (LPDDR) SDRAM model and Microsemi<sup>®</sup> LPDDR SDRAM verification IP (VIP) model.

# Introduction

The IGLOO2 device has two high-speed hardened application-specific integrated circuit (ASIC) memory controllers such as memory subsystem DDR (MDDR) and fabric DDR (FDDR) for interfacing with the DDR2, DDR3, and LPDDR1 SDRAM memories. The MDDR and FDDR subsystems are used to access high-speed DDR memories for high-speed data transfer and code execution.

The DDR memory connected to the MDDR subsystem can be accessed by the high performance memory subsystem (HPMS) masters and the master logic implemented in the FPGA fabric (FPGA fabric master), whereas the DDR memory connected to the FDDR subsystem can be accessed only by a field programmable gate array (FPGA) fabric master. The FPGA fabric masters communicate with the MDDR and FDDR subsystems through the AXI or AHB interfaces. Figure 1 on page 2 shows the MDDR data path for advanced extensible Interface (AXI)/advanced high-performance bus (AHB) interfaces.



#### Figure 1 • MDDR Data Path for AXI/AHB Interfaces

The AXI interface is typically used for burst transfers that provide an efficient access path and high throughput. Though the throughput is dependent on many system level parameters, it can be improved by applying specific optimization techniques. This application note describes a few DDR SDRAM controller optimization techniques with an example design for IGLOO2 Evaluation Kit board. For more information on MDDR and FDDR subsystems, refer to *IGLOO2 FPGA High Speed DDR Interfaces User Guide*.

The sample design consists of an AXI master, LSRAM, counters for throughput measurement, and CoreUART interface logic. During the write operation, the AXI master reads the LSRAM and writes to the LPDDR memory and measures the throughput. During the read operation, the AXI master reads the LPDDR memory and writes to LSRAM and measures the throughput. The throughput values are displayed on the Host PC using the CoreUART interface.

There are two types of memory simulation models that can be used:



**Vendor-specific memory model:** Memory vendors such as Micron, Samsung, and Hynix provide downloadable simulation models for specific memory devices. The downloaded simulation model mustbe JEDEC compliant.

This application note also describes the DDR SDRAM simulation flow using the Micron LPDDR SDRAM model and Microsemi LPDDR SDRAM VIP model.



# References

The following list of references is used in this document. These references complement and help in understanding the relevant Microsemi IGLOO2 device features and flows that are described in this document:

- IGLOO2 FPGA High Speed DDR Interfaces User Guide
- Connecting User Logic to AXI Interfaces of High-Performance Communication Blocks-SmartFusion<sup>®</sup>2
- Connecting User Logic to the SmartFusion Microcontroller Subsystem
- DDR Controller and Serial High Speed Controller Initialization Methodology
- IGLOO2 Evaluation Kit User Guide
- IGLOO2 System Builder User Guide

# **Reference Design Requirements and Details**

Table 1 lists the reference design requirements and details.

#### Table 1 • Reference Design Requirements and Details

| Hardware Requirements                                                                        | Description                         |
|----------------------------------------------------------------------------------------------|-------------------------------------|
| IGLOO2 evaluation kit. Refer the IGLOO2 FPGA Evaluation Kit User Guide for more information. | Rev C or later                      |
| Desktop or Laptop                                                                            | Any 64-bit Windows Operating System |
| Software Requirements                                                                        |                                     |
| Libero SoC                                                                                   | 11.3                                |
| SoftConsole                                                                                  | 3.4                                 |
| Microsoft .NET Framework 4 Client Profile                                                    |                                     |

# **Optimization Techniques**

This section describes the following optimization techniques:

- Frequency of Operation
- Burst Length
- AXI Master without Write Response State
  - Read Address Queuing
- Series of Writes or Reads
- DDR Configuration Tuning

# Frequency of Operation

The MDDR and FDDR subsystems support clock management dividers directly inside the embedded block. The user can select the divider ratios from the Clock Configurator for DDR clocks (MDDR\_CLK/FDDR\_CLK) and DDR\_FIC clock. The best overall throughput ratio is 2:1, that is, half the DDR clock frequency. Many other ratios are possible to provide flexibility to the FPGA design. To show the optimal data throughput, this application note shows all examples using the 2:1 ratio. The design example uses 64-bit AXI as a FPGA fabric interface and configured to use 166 MHz as DDR clock frequency<sup>1</sup> and 83 MHz as AXI clock.

<sup>1.</sup> IGLOO2 MDDR subsystem supports maximum of 200 MHz as DDR clock frequency for LPDDR1 memory type. But LPDDR memory on IGLOO2 Evaluation Kit board supports 166 MHz only.



# **Burst Length**

The MDDR and FDDR subsystems support the DRAM burst lengths of 4, 8, or 16, depending on the configured bus-width and the DDR type. The AXI transaction controller in the MDDR and FDDR subsystem supports up to 16-beat burst read and writes. The AXI beat burst length (write and read) and burst length of DRAM affect the optimal performance, but by setting the maximum supported burst length for DDR SDRAM and AXI interface achieve the optimal performance. The design example uses a DDR SDRAM burst length of 16 and an AXI write and read beat burst length of 16.

# **AXI Master without Write Response State**

When the AXI master sends the last data (D (A15)), the WLAST signal goes HIGH which indicates that the last transfer in the first write burst. When the AXI slave in DDR subsystem accepts all the data items, it drives a write response (BVALID) back to the master to indicate that the write transaction is complete. By AXI protocol, the AXI master should wait for the write response before initiating the next write transaction. However, the time spent waiting for the write response will waste clock cycles and reduce overall throughput. The AXI master can then send the second burst write address (B) without waiting for the write response of the first burst, which improves the write throughput.

This improves the write throughput by decreasing the wait states. This application note is focused on optimal throughput and therefore the write response channel is not verified. It is recommended that when using this technique, the write response channel is used concurrently with starting the next transfer to ensure that the previous write data has been fully accepted. The AXI protocol has a defined methodology on handling the termination of write burst transaction; this should be followed if the write response channel returns a non-OKAY value. Figure 2 shows the write transaction timing diagram without the write response state.



Figure 2 • Write Transaction Timing Diagram Without Write Response State

This technique is implemented in the example design. Comment or uncomment the following line of code in the AXI Master Interface (AXI\_IF.v) to validate this technique.

define WITHOUT\_WRITE\_RESPONSE /\* Comment this line to define With Write Response state \*/



# **Read Address Queuing**

The MDDR and FDDR subsystems support up to four outstanding read transactions. Figure 3 shows the burst read address queuing timing diagram. In 2:1 clock ratio, the MDDR controller starts the burst read transaction before command FIFO full which allows the AXI master to send 5 burst read address.



#### Figure 3 • Read Transaction Timing Diagram with Burst Read Address Queuing

The AXI master increments the burst read address as long as the AXI slave in the DDR subsystem asserts the ARREADY signal. The burst read address queuing significantly increases the read throughput compared to the normal AXI read sequence. Table 6 on page 29 and Table 7 on page 30 show this significant improvement. Read address queuing does not reduce the initial latency associated with a DDR memory read access. By issuing multiple reads in sequence the initial latency is only accounted for in the first read. After the first read data is returned the remainder of the requested data is returned in sequence without a large read access penalty associated with the first read.

This technique is implemented in the example design. Comment or uncomment the following line of code in the AXI Master Interface (AXI\_IF.v) to validate this technique.

define READ ADDRESS QUEUING /\* Comment this line to define Without Read Address Queuing \*/

### Series of Writes or Reads

The MDDR and FDDR subsystems' performance depends on the method of data transfer between the DDR SDRAM and AXI master. The following methods of data transfer reduce optimal performance:

- 1. Single beat burst read and write operation
- 2. Random read and write operation
- 3. Switching between read and write operation



The MDDR and FDDR subsystems' performance increases while performing a series of reads or writes from the same bank and row. Figure 4 shows the AXI to LPDDR address mapping for the LPDDR SDRAM on IGLOO2 Evaluation Kit board.



Figure 4 • AXI to LPDDR the Address Mapping

When the AXI address crosses 0x0800, the DDR subsystem activates Row 0 of Bank 1. Row 1 of Bank 0 is activated only when the AXI address crosses 0x2000. If a new row is accessed every time, it must be pre-charged first. This means that additional time is needed before a row can be accessed and this reduces the overall throughput. Understanding the internal memory layout of the DDR and how it maps to the AXI address enables the accesses to minimize the row changes and increase the overall throughput.

# **DDR Configuration Tuning**

The DDR SDRAM datasheet provides the timings parameters required for the proper operation in terms of time units. These timings should match with the configuration registers in the MDDR/FDDR Controller. The timing parameters are required as number of DDR clock cycles and these are entered in the DDR Configurator GUI. The selection of minimum write or read delay values can result in optimal performance. Implementing this approach requires extensive memory testing to ensure that the memory transfers are stable. The IGLOO2 Evaluation Kit LPDDR is supplied with a default configuration file to setup the MDDR controller which is available on its documentation web page.

Table 2 lists the tuned parameter for better performance than that default configuration file.

| Parameters | Default Values | Tuned Values |
|------------|----------------|--------------|
| MRD        | 4              | 2            |
| RAS min    | 8              | 7            |
| RAS max    | 8192           | 11264        |
| RCD        | 6              | 3            |
| RP         | 7              | 3            |
| REFI       | 3104           | 1280         |
| RC         | 3              | 10           |
| ХР         | 3              | 1            |
| CKE        | 3              | 1            |
| RFC        | 79             | 25           |
|            |                |              |

#### Table 2 • Tuned DDR Timing Parameters



# Implementation on IGLOO2 Device

The optimization techniques that are mentioned in the above section have been implemented and validated using the IGLOO2 Evaluation Kit board. This section describes the following:

- Design Description
- Hardware Implementation
- Running the Design

### **Design Description**

The design consists of HPMS, DDR initialization subsystem, AXI master (AXI\_IF), Command decoder (CMD\_Decoder), and a COM interface (COM\_Interface) block. Figure 5 shows the block diagram of the design.



Figure 5 • Top-Level Block Diagram of the Design

MDDR in the HPMS is configured to use the LPDDR interface and routed the AXI interface to the FPGA fabric. The DDR initialization subsystem consists of CoreConfigMaster and CoreConfigP IPs that initializes the MDDR controller. The initialization process consists of following actions:

- CoreConfigMaster (AHBL Master) accesses the DDR configuration data stored in eNVM through FIC\_0.
- The configuration data is then sent to CoreConfigP through the FIC\_2 master port.
- CoreConfigP sends the configuration data to advanced peripheral bus (APB) of the MDDR subsystem.



The command decoder receives the AXI transaction control from the COM interface block and generates write, read, write size, and read size signals. Figure 6 shows the command decoding.



#### Figure 6 • Command Decoding

The AXI master block consists of AXI read channel, AXI write channel, write throughput counter, read throughput counter, and 512x64 LSRAM. It performs the write or read operation<sup>2</sup> based on the input signals from the command decoder. During the write operation, the AXI master reads the LSRAM and writes into the LPDDR memory, and then measures the write throughput. During the read operation, the AXI master reads the LPDDR memory and writes into LSRAM, and then measures the read throughput. The write throughput counter counts the AXI clocks between AWVALID of first data and WLAST of last data. Similarly, the read throughput counter counts the AXI clocks between ARVALID of first data and RLAST of last data.

After triggering the write or read operation, the AXI master performs the write or read operation eight times to get the average throughput and to ACTIVATE all banks. During the write operation, the write address (AWADDR) starts from 0x00000000, and is incremented by 128 (16-beat burst). During the read operation, the read address (ARADDR) starts from 0x00000000, and is incremented by 128.

After each write or read operation, the AXI master sends the throughput count value and an address starting from 0x0 to the COM interface block. Then, the COM interface block writes the throughput values into TPSRAM. The control logic in the COM interface block reads the values and sends to the host PC using the CoreUART interface.

For information on creating a custom AXI interface on user logic, refer to *Connecting User Logic to AXI* Interfaces of High-Performance Communication Blocks in the SmartFusion2 Devices application note.

<sup>2.</sup> The write or read operation depends on the size of the write or read data. For example, if the write size is selected as 2KB, then one AXI write operation equals to 16x16-beat burst (16x16x64).



# **Hardware Implementation**

The hardware implementation involves:

- Configuring the System Builder
- · Connecting with custom logic (AXI master, Command decoder and COM interface).

Figure 7 shows the top-level SmartDesign of the example design.



Figure 7 • Top-Level SmartDesign

~



### Configuring the System Builder

This section describes how to configure the MDDR and other device features and then build a complete system using the System Builder graphical design wizard in the Libero SoC Software. For details on how to launch the System Builder wizard and detailed information on how to use it, refer the *IGLOO2 System Builder User Guide*.

The following steps describe how to configure the MDDR and access it from AXI master in the FPGA fabric:

 Go to the System Builder - Device Features tab and check the HPMS External Memory (MDDR) check box and leave the rest of the check boxes unchecked. Figure 8 shows the System Builder - Device Features tab.

| System Builder - Device Features  Device Features  Memories                                                                                                                                                                                                                                                                                                       |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Memory<br>I HPMS External Memory<br>MDDR<br>Soft Memory Controller (SMC)<br>HPMS On-chip Flash Memory (eNVM)<br>HPMS On-chip SRAM (eSRAM)<br>HPMS High Performance DMA (HPDMA)<br>HPMS Peripheral DMA (PDMA)<br>Serial Peropheral Interface (SPI)<br>Fabric External DDR Memory (FDDR)<br>High Speed Serial Interfaces<br>System Services<br>HPMS System Services |  |

Figure 8 • System Builder - Device Features Tab



- 2. Configure the MDDR in **Memories** tab as shown in Figure 9. In this example, the design is created to access the LPDDR memory with a 16-bit data width and no ECC.
- Set the DDR memory settling time to 200 us and click Import Configuration file to initialize the DDR memory. The configuration file is stored in eNVM. The MDDR subsystem registers should be initialized before accessing DDR memory through the MDDR subsystem. The MDDR configuration register file is provided along with the design file (Refer to "Appendix A – Design Files" section on page 31) ..

| em Builder - Memories             |                  |
|-----------------------------------|------------------|
|                                   | Configure yo     |
| DR \<br>R memory settling time (i | us): 200         |
| Import Configuration E            |                  |
| Memory Settings                   |                  |
| Memory Type                       | LPDDR V          |
| Data Width                        | 16               |
| SECDED Enabled ECC                |                  |
| Arbitration Scheme                | Type-0           |
| Highest Priority ID               | 0                |
| Address Mapping                   | {ROW,BANK,COLUMN |
|                                   |                  |

#### Figure 9 • Memory Configuration

4. In the Peripherals tab, drag the Fabric AMBA Master and drop on to the HPMS DDR FIC Subsystem. The AMBA\_MASTER\_0 is added to the subsystem and configured the Interface Type as AXI. Figure 10 shows the Peripherals tab with the AMBA\_MASTER\_0 added.

| Version | HPMS FIC_0 - Fabric Master Subsystem |             |
|---------|--------------------------------------|-------------|
|         |                                      |             |
|         | Configure Quantity Name              |             |
|         | 1 ConfigMaster                       |             |
|         | HPMS DDR FIC Subsystem               |             |
|         | Configure Quantity Name              |             |
|         | 1 AMBA_MASTER_0                      |             |
|         | 1 HPMS_DDR_RAM                       |             |
|         |                                      |             |
|         |                                      |             |
| version |                                      |             |
|         |                                      |             |
|         |                                      |             |
|         |                                      |             |
|         |                                      |             |
|         | aster Cores<br>Version               | aster Cores |

*Figure 10* • Peripherals Tab with the Fabric AMBA Master Added



5. Configure the System Clock and Subsystem clocks in Clocks tab as listed in Table 3.

| Table 3 • | System and Subsystem Clocks |
|-----------|-----------------------------|
| 14010 0   |                             |

| Clock Name      | Frequency in MHz                |
|-----------------|---------------------------------|
| System Clock    | On-chip 25/50 MHz RC oscillator |
| HPMS_CLK        | 83                              |
| MDDR_CLK        | 166                             |
| DDR/SMC_FIC_CLK | 83                              |
| FIC_0_CLK       | 20.750                          |

Figure 11 shows the Clocks configuration dialog.

| ock     Fabric CCC     Chip Oscillators       System Clock                                                              |              | Crip Oscillators |                | lock     |
|-------------------------------------------------------------------------------------------------------------------------|--------------|------------------|----------------|----------|
| 50.0     MHz       On-chip 25/50 MHz RC Oscillator       HPMS Clock       HPMS_CLK       =       83.00       MDR Clocks |              |                  |                | L        |
| On-chip 25/50 MHz RC Oscillator                                                                                         |              | MHz              |                |          |
| HPMS_CLK = 83.00 MHz 83.000                                                                                             |              | RC Oscillator    | hip 25/50 MHz  | On-ch    |
| MDDR Clocks                                                                                                             |              |                  | Clock          | HPMS (   |
|                                                                                                                         | MHz 83.0     | = 83.00          | S_CLK          | HPMS     |
| MDDR_CLK = HPMS_CLK * 2 166.000                                                                                         |              |                  | Clocks         | MDDR     |
|                                                                                                                         | LK* 2 🔻 166. | = HPMS_C         | R_CLK          | MDDR     |
| DDR/SMC_FIC_CLK = MDDR_CLK / 2 83.000                                                                                   | цк / 2 83.0  | = MDDR_0         | SMC_FIC_CLK    | DDR/9    |
| Fabric Interface Clocks                                                                                                 |              | ks               | Interface Cloc | Fabric ! |

#### Figure 11 • System and Subsystem Clocks Configuration

- 6. Follow the rest of the steps with default settings and generate the design.
- 7. Instantiate the custom logic (AXI master, Command decoder, and COM interface) and make the connections as shown in Figure 7 on page 9.



Figure 12 shows the SmartDesign of the COM interface block. The COM\_interface SmartDesign component handles the UART communication between Host PC software utility and the AXI master logic.



#### Figure 12 • SmartDesign of the COM Interface Block

The COREUART\_0 IP receives the UART signals from the Host PC user interface. The Control\_Logic\_0 collects the command from the COREUART\_0 and sends to the AXI master through the Command decoder which triggers the write/read operation. After the write/read operation, the Control\_logic\_0 reads the throughput count values from TPSRAM\_0 and sends to the Host PC through COREUART\_0.

The configurations of CoreUART and TPSRAM are given below:

- CoreUART IP has the following configuration:
  - Baud Rate: 115200
  - Data Bits: 8
  - Parity: None.
  - PSRAM IP has the following configuration:
  - Write port depth: 8
    - Write port width: 16
    - Read port depth: 16
    - Read port width: 8



### Simulation using Micron LPDDR SDRAM model

#### Setting up the Simulation Model

Setting up and running the simulation involves the following steps:

- Obtain the Micron LPDDR SDRAM model files The IGLOO2 Evaluation Kit board has the LPDDR DRAM from Micron with the part number; MT46H32M16LFBF-6 IT:C TR. The memory model used in the example design supports this device (Refer to "Appendix A – Design Files" section on page 31).
- 2. Copy the dram.v and dram\_parameters.vh simulation model files to the \<Libero SoC project directory>\stimulus directory.
- 3. Instantiate and connect the LPDDR SDRAM memory model in the testbench as shown in Figure 13.



#### Figure 13 • Instantiation of Simulation Model

- 4. Ensure that dram.v file is included at the top of the testbench file. The example design uses one instance of LPDDR model with the device width sixteen.
- 5. Set the testbench in which LPDDR memory model is instantiated as active stimulus. Figure 14 shows the settings under Stimulus Hierarchy.

| Stimulus Hierarchy                                                                         | 8 ×                              |
|--------------------------------------------------------------------------------------------|----------------------------------|
| Show: Components -                                                                         | Show Root Testbenches            |
| <ul> <li>▲ ĵ  work</li> <li>▶ ➡ testbnch (testbnc)</li> </ul>                              | h.v)                             |
| <ul> <li>✓ Lestbench (testber</li> <li>✓ MDDR_TA_to</li> <li>Lestbench (dram.v)</li> </ul> | Open HDL File                    |
| <ul> <li>▷ ↓ testbench (testbench)</li> <li>▷ ↓ testbench (testbench)</li> </ul>           | Set as active stimulus           |
| <ul> <li>testbench (testbench)</li> <li>testbench (testbench)</li> </ul>                   | r [                              |
| testbench (testben     testbench (testben     testbench (testbench)                        | -                                |
| COREAHBLITE_LIB                                                                            | Properties                       |
|                                                                                            |                                  |
| •                                                                                          | •                                |
| Design Flow Design Hierarchy                                                               | Stimulus Hierarchy Catalog Files |

Figure 14 • Stimulus Settings



6. Click **Project > Project Settings > Simulation Options > Waveforms**. Figure 15 shows the Waveforms settings on the right.

| C | Project Settings                                    |                                           |
|---|-----------------------------------------------------|-------------------------------------------|
|   | Device I/O Settings                                 | Include DO file                           |
|   | Preferred HDL Type<br>Design Flow                   | wave.do                                   |
|   | <ul> <li>Simulation Options</li> </ul>              | Display waveforms for top_level testbench |
|   | DO File<br>Waveforms                                | Log all signals in the design             |
|   | Vsim commands                                       |                                           |
|   | <ul> <li>Simulation Libraries<br/>IGLOO2</li> </ul> |                                           |
|   | COREAHBLITE_LIB                                     |                                           |

#### Figure 15 • Waveforms Settings

7. Select the Include DO File check box and enter wave.do in the box as shown in Figure 15.

#### **Timing Diagrams**

The timing diagrams shown from Figure 16 through Figure 18 on page 16 illustrate the write operation. Figure 16 shows the control logic signals in the COM interface block.



#### Figure 16 • Control Logic Signals in the COM Interface Block for Write Operation

After reset de-asserted, the control logic receives the handshake (0x63) command through the CoreUART RX port. Then control logic sends the acknowledgment (0x61) through the CoreUART TX port and wait for the write command. Once the write command receives, the control logic sends the write command to the AXI master through the Command decoder which triggers the write operation. After the write operation, the control logic reads the throughput count values from TPSRAM and sends to the CoreUART TX port.



Figure 17 shows the MDDR signals. The AXI master reads 2 KB of data from LSRAM and writes to LPDDR SDRAM. The write operation is repeated eight times. The data is written into Row 0 and Row 1 of all banks (Bank 0 - Bank 3).



Figure 17 • MDDR Signals for Write Operation

Figure 18 shows the AXI master signals. The AXI master sends the throughput count value and an address starting from 0x0 to the COM interface block.



Figure 18 • AXI Master Signals for Write Operation



The timing diagrams shown from Figure 19 through Figure 21 on page 18 show the read operation. Figure 19 shows the control logic signals in the COM interface block.



Figure 19 • Control Logic Signals in the COM Interface Block for Read Operation

After the write operation, the control logic receives the handshake (0x63) command through the CoreUART RX port. Then control logic sends the acknowledgment (0x61) through the CoreUART TX port and wait for the read command. Once the read command receives, the control logic sends the read command to the AXI master through the Command decoder which triggers the read operation. After the read operation, the control logic reads the throughput count values from TPSRAM and sends to the CoreUART TX port.

Figure 20 shows the MDDR signals. The AXI master reads 2 KB of data from LPDDR SDRAM and writes to LSRAM. The read operation is repeated eight times. The data is read from Row 0 and Row 1 of all banks (Bank 0 - Bank 3).



Figure 20 • MDDR Signals for Read Operation



Figure 21 shows the AXI master signals. The AXI master sends the throughput count value and an address starting from 0x0 to the COM interface block.



Figure 21 • AXI Master Signals for Read Operation

### Simulation using Microsemi LPDDR SDRAM VIP Model

Libero SoC includes a generic DDR memory simulation model, also called Verification Intellectual Property (VIP). This VIP is attached to the pin side of the MDDR or FDDR subsystem, and simulates the functionality of a DDR memory device. It can be configured for DDR2, DDR3, and LPDDR SDRAM memories as well.

#### Setting up the Simulation Model

Setting up and running the simulation involves the followings steps:

- 1. Click Catalog tab in the Libero SoC.
- 2. Select the Simulation Mode check box.
- 3. Under **Memory and Controller**, select **Generic DDR Memory Simulation** model to drag into the SmartDesign testbench canvas. Figure 22 shows the Simulation model.

| Catalog                                                          |                                     | Β×              |
|------------------------------------------------------------------|-------------------------------------|-----------------|
|                                                                  | <ul> <li>Simulation Mode</li> </ul> | () <del>-</del> |
| Name                                                             | Version                             |                 |
| Clock & Management                                               |                                     |                 |
| Clock_Generator                                                  | 1.0.1                               |                 |
| Pulse_Generator                                                  | 1.0.1                               |                 |
| Reset_Generator                                                  | 1.0.1                               |                 |
| Memory & Controllers                                             |                                     |                 |
| Generic DDR Memory Simul                                         | ation 1.0.100                       |                 |
|                                                                  |                                     | J               |
| Description: A generic DDR memo<br>DDR3/DDR2/LPDDR DRAM non-timi |                                     | ılates          |
| Desig Design Hier St                                             | timulus Hie Catalog                 | Files           |

Figure 22 • Generic DDR Memory Simulation Model



 Enter the Generic DDR Memory Simulation model configuration details as shown in Figure 23. The example design uses one instance of SimDRAM (VIP model) with the device width size of sixteen.

| Memory Configur   | ation                           |                |            |  |
|-------------------|---------------------------------|----------------|------------|--|
|                   | DRAM Memory Type                | LPDDR 🔻        |            |  |
|                   | Data Width                      | 16 💌           | •          |  |
|                   | Self Refresh Enabled            | No 🔻           |            |  |
| Burst Configurati | on                              |                | $\equiv$ [ |  |
|                   | Burst Length (Bits              | ) 16 🔻         |            |  |
| Timing Configurat | tion                            |                |            |  |
| CAS Latency       | (Clks)                          | 3              |            |  |
| CAS Write La      | atency                          | 5              |            |  |
| Additive CAS      | S Latency (Clks)                | 0              |            |  |
| Write Recov       | ery (Clks)                      | 8              |            |  |
| RFC - Minimu      | um time from refresh to refresh | or activate 25 |            |  |
| Termination I     | Resistance (Ohm)                | 240            |            |  |

#### Figure 23 • Configuring SimDRAM

 Make the connections as described in "Simulation using Micron LPDDR SDRAM model" section on page 14. The connections are same as the Micron model. Figure 24 Shows the SmartDesign testbench for the example design with Microsemi LPDDR SDRAM VIP model.



#### Figure 24 • SmartDesign Testbench for Example Design with Microsemi LPDDR SDRAM VIP

6. Generate the design by clicking **SmartDesign > Generate Component** or by clicking **Generate Component** on the SmartDesign tool bar.



7. Open the generated SmartDesign testbench file, LPDDR\_VIP\_Simulation.v. Figure 25 shows the SmartDesign generated testbench file under **Files** tab.





```
@(posedge LPDDR VIP Simulation.MDDR TA top 0.AXI IF 0.CLK);
   repeat (2000)
     begin
        #(BRCLK PERIOD / 2.0) BRCLK <= !BRCLK;
     end
end
initial
begin
   $display ("Loading LSRAM from lsram.mem file");
   $display ("");
$readmemh("lsram 512x64.mem",LPDDR VIP Simulation.MDDR TA top 0.AXI IF 0.Rdata mem);
   $display (" Completed Loading LSRAM");
    @(posedge LPDDR VIP Simulation.MDDR TA top 0.AXI IF 0.RESETn);
force LPDDR VIP Simulation.MDDR TA top 0.COM Interface 0.COREUART 0.DATA_OUT 8'b1100011; /* Handshaking Commmand 'c' */
    @(posedge
LPDDR VIP Simulation.MDDR TA top 0.COM Interface 0.Control Logic 0.RX RDY);
   repeat(5) @(posedge BRCLK);
    force LPDDR VIP Simulation.MDDR TA top 0.COM Interface 0.COREUART 0.DATA OUT
8'b00100101; /* 2KB Write */
   @(posedge fsm en);
   repeat(40) @ (posedge BRCLK);
    force LPDDR_VIP_Simulation.MDDR_TA_top_0.COM_Interface_0.COREUART_0.DATA_OUT
8'b1100011; /* Handshaking Commmand 'c'
    @(posedge
LPDDR VIP Simulation.MDDR TA top 0.COM Interface 0.Control Logic 0.RX RDY);
   repeat(5) @(posedge BRCLK);
force LPDDR_VIP_Simulation.MDDR_TA_top_0.COM_Interface_0.COREUART_0.DATA_OUT
8'b00100110; /* 2KB_Read */
end
always @ (posedge LPDDR VIP Simulation.MDDR TA top 0.AXI IF 0.CLK)
begin
 if(fsm == 4'b1001)
  begin
    fsm en <= 1'b1
  end
 else (
  begin
    fsm en
            <= 1'b0;
   end
```



10. Under the **Stimulus Hierarchy** tab, set the SmartDesign testbench as **Set as active stimulus**. Figure 26 shows the **Stimulus Hierarchy** settings.

| Stimulus Hie | ierarchy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Ē                               | P × |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-----|
| Show:        | Components 🔻                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Show Root Testbenche            | es  |
|              | <ul> <li>work</li> <li>testbnch (testbnch.v)</li> <li>testbench (testbench</li> <li>MDDR_TA_top</li> <li>dram (dram.v)</li> <li>testbench (testbench.v)</li> </ul> | h.v)<br>)<br>)                  |     |
| Design Fl    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | timulus Hierarchy Catalog Files |     |

### Figure 26 • Stimulus Settings

11. Change the default DO file name to wave\_vip.do file in Project > Project Settings > Simulation Options > Waveforms. Figure 27 shows the Waveforms settings.

| Project Settings         Device         Device I/O Settings         Preferred HDL Type         Design Flow         Simulation Options         DO File         Waveforms         Vsim commands         Simulation Libraries         IGLOO2         COREAHBLITE_LIB |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Figure 27 • Waveforms Settings



#### **Timing Diagrams**

The timing diagrams shown from Figure 28 through Figure 30 on page 24 show the write operation. Figure 28 shows the control logic signals in the COM interface block.



Figure 28 • Control Logic Signals in the COM Interface Block for Write Operation

After reset de-asserted, the control logic receives the handshake (0x63) command through the CoreUART RX port. Then control logic sends the acknowledgment (0x61) through the CoreUART TX port and wait for the write command. Once the write command receives, the control logic sends the write command to the AXI master through the Coremand decoder which triggers the write operation. After the write operation, the control logic reads the throughput count values from TPSRAM and sends to the CoreUART TX port.

Figure 29 shows the MDDR signals. The AXI master reads 2KB of data from LSRAM and writes to LPDDR SDRAM. The write operation is repeated eight times. The data is written into Row 0 and Row 1 of all banks (Bank 0 - Bank 3).

| Wave                                                                     | i mant i                    |                   | d. the re                |                                       |            |                                                                                                                 | a summer   | August 10       |                |       | d thread     | -             |                  |              |              |        | _           |
|--------------------------------------------------------------------------|-----------------------------|-------------------|--------------------------|---------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------|------------|-----------------|----------------|-------|--------------|---------------|------------------|--------------|--------------|--------|-------------|
| e <u>E</u> dit <u>V</u> iew <u>A</u> dd F <u>o</u> rmat <u>T</u> ools Bo | o <u>k</u> marks <u>W</u> i | ndow <u>H</u> elp |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
| Wave - Default                                                           |                             |                   |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        | - 1         |
| ) • 🖌 🖬 🏷 🎒 🔰 🐂 🛍 🗅 🖄                                                    | () - M •                    | : 🛛 🗳 🛗           | 2 🕺 🖄 🗍                  | <b>B</b> 1 (=                         | 👐   📑      | 100 ps                                                                                                          | ÷ 1 1      | 14 🕺 💲          | 1 월 🖞          | . 🖗 🛛 | <b>* * †</b> | 1             | 1                | • 🐴 • 🔗      | 🖷 <b>-</b> 🥵 |        |             |
| k → → - → - Search:                                                      | <b>•</b> /10                | *                 | 1                        | TT                                    | <b>#</b> 5 | ⊁કાર                                                                                                            | 7. F 4     | F   📐 [         | <b>1</b> , 💠 1 | 1 🗉   | 0 0          | 9 <b>Q</b> 19 | 18 🖉             |              |              |        |             |
| •                                                                        | Msgs                        |                   |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
| - MDDR Signals                                                           |                             |                   |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
| /LPDDR_VIP_Simulation/MDDR_CLK                                           | 0                           |                   |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
| /LPDDR_VIP_Simulation/MDDR_CKE                                           | 1                           |                   |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
| /LPDDR_VIP_Simulation/MDDR_CS_N                                          | 0                           |                   |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
| A /LPDDR_VIP_Simulation/COMMAND                                          |                             | VRITE             | WRITE                    |                                       | WRITE      |                                                                                                                 | WRITE      |                 | A              | WRITE | ĮWR          | ITE           | X                | <b>VRITE</b> | χ.           | /RITE  |             |
| - /LPDDR_VIP_Simulation/MDDR_ADDR                                        | 0                           |                   |                          | i i i i i i i i i i i i i i i i i i i | ÷÷         | i fili li fi fili li fi | -+         | -iffiti⊷+iffiti | —++) <b>i</b>  |       | ++- <u>-</u> | itiii+—titii  | H <b></b> +#+₩++ |              | ***          |        | <u>{</u> }} |
| - APDDR_VIP_Simulation/MDDR_BA                                           | 0                           |                   |                          |                                       | 2          |                                                                                                                 | <u>)</u> 3 |                 | ) <b>(</b> 1   | 0     | Ĵ1           |               | ja ja            |              | (3           |        |             |
| /LPDDR_VIP_Simulation/MDDR_DM_RDQS                                       | z                           |                   |                          |                                       |            | - { {                                                                                                           |            |                 | <u>{{}</u>     |       |              | -             |                  |              |              |        |             |
|                                                                          | z                           |                   |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
| - /LPDDR_VIP_Simulation/MDDR_DQ                                          | z                           |                   | يعلينه له يبيد و يبتدك ا |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
|                                                                          |                             |                   |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
| ≅ • Now                                                                  |                             | 0000000 fs        |                          | 4150000                               | 000000 fs  |                                                                                                                 | 41         | 6000000000      | ) fs           |       | 417000       | 0000000 fs    |                  |              | 4180000000   | 000 fs |             |
| Cursor 1                                                                 | 108000 fs                   |                   |                          |                                       |            |                                                                                                                 |            |                 |                |       |              |               |                  |              |              |        |             |
|                                                                          | • •                         | (                 |                          |                                       |            |                                                                                                                 |            |                 | 1              |       |              |               |                  |              |              |        |             |
| 9342437 ps to 4185449261 p sim:/LPDDR_VIP                                |                             |                   |                          |                                       |            |                                                                                                                 |            |                 | _              |       |              |               |                  |              |              |        | _           |

Figure 29 • MDDR Signals for Write Operation



Figure 30 shows the AXI master signals. The AXI master sends the throughput count value and an address starting from 0x0 to the COM interface block.



Figure 30 • AXI Master Signals for Write Operation

The timing diagrams shown from Figure 31 through Figure 33 on page 25 show the read operation. Figure 31 shows the control logic signals in the COM interface block.



Figure 31 • Control Logic Signals in the COM Interface Block for Read Operation

After the write operation, the control logic receives the handshake (0x63) command through the CoreUART RX port. Then control logic sends the acknowledgment (0x61) through the CoreUART TX port and wait for the read command. Once the read command receives, the control logic sends the read command to the AXI master through the Command decoder which triggers the read operation. After the read operation, the control logic reads the throughput count values from TPSRAM and sends to the CoreUART TX port.



Figure 32 shows the MDDR signals. The AXI master reads 2 KB of data from LPDDR SDRAM and writes to LSRAM. The read operation is repeated eight times. The data is read from Row 0 and Row 1 of all banks (Bank 0 - Bank 3).



#### Figure 32 • MDDR Signals for Read Operation

Figure 33 shows the AXI master signals. The AXI master sends the throughput count value and an address starting from 0x0 to the COM interface block.



Figure 33 • AXI Master Signals for Read Operation



# **Running the Design**

3

The design example is designed to run on the IGLOO2 Evaluation Kit board. For more detailed board information, refer to www.microsemi.com/products/fpga-soc/design-resources/dev-kits/igloo2/igloo2-evaluation-kit.

### Setting up the Hardware

Use the following steps to setup the hardware:

1. Connect the jumpers on the IGLOO2 Evaluation Kit board as listed in Table 4.

#### Table 4 • IGLOO2 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 PROG HEADER J5 connector of the IGLOO2 Evaluation Kit board.
- 4. Connect the Host PC USB port to the IGLOO2 Evaluation Kit board's J18 (FTDI) USB connector using the USB mini-B cable.
- 5. Ensure that the USB to UART bridge drivers are automatically detected. This can be verified in the Device Manager of the Host PC.

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.

6. Program the IGLOO2 Evaluation Kit board with the generated or provided \*.stp file (Refer to "Appendix A – Design Files" section on page 31) using FlashPro.



# **Running the Performance Measurement Utility**

The example design provides performance measurement utility, IGL2\_LPDDR\_BW that runs on the Host PC to communicate with the IGLOO2 Evaluation Kit board. The UART protocol is used as the underlying communication protocol between the Host PC and the IGLOO2 Evaluation Kit board. Figure 34 shows initial screen of the IGL2\_LPDDR\_BW Utility.



#### Figure 34 • IGL2\_LPDDR\_BW Utility

The IGL2\_LPDDR\_BW utility consists of following sections:

- Transfer Type: Write or Read
- Data Size: Write data size or Read data size can be selected from the drop down box. The data size varies from 2 KB to 16 KB.
- LPDDR Throughput: It displays the number of AXI clocks and corresponding throughput values in MB/s
- Buttons:
  - Connect button for to connect or disconnect the serial port communication between the Host PC and the IGLOO2 Evaluation Kit board.
  - Start button for to start the performance measurement.
  - Exit button to exit the application.





### Steps to Run the Utility

- 1. Launch the utility. The default location is: <download\_folder>\M2GL\_AC424\_DF\Windows\_Utility\IGL2\_LPDDR\_BW.exe
- 2. Click **Connect** and wait for few seconds to connect the proper FDTI COM port. The connection status along with the COM Port and Baud rate is shown in the left bottom corner of the screen. Figure 35 shows the connection status of the utility.

| Transfer Type | LPDDF | R Through | put        |                  |
|---------------|-------|-----------|------------|------------------|
| Write         |       | SI.No     | AXI Clocks | Throughput(MBps) |
| Read          | •     |           |            |                  |
| Data Size     |       |           |            |                  |
| Write 2KB 🔻   |       |           |            |                  |
|               |       |           |            |                  |
| Read 2KB 🔻    |       |           |            |                  |
|               |       |           |            |                  |
| Disconnect    |       |           |            |                  |
| Exit          |       |           |            |                  |
| Start         |       |           |            |                  |

#### Figure 35 • IGL2\_LPDDR\_BW Connection Status

- 3. Select Write or Read as Transfer Type.
- 4. Select Write data size or Read data size from the drop down box and click Start. Figure 36 shows the write throughput measurement for 2 KB data transfer.

| Transfer Type | LPDD | R Through | put        |                  |
|---------------|------|-----------|------------|------------------|
| Write         |      | SI.No     | AXI Clocks | Throughput(MBps) |
| Read          |      | 1         | 477        | 356              |
| Data Size     | 1    | 2         | 547        | 310              |
| Write 2KB -   |      | 3         | 477        | 356              |
|               |      | 4         | 477        | 356              |
| Read 2KB 🔻    |      | 5         | 477        | 356              |
|               |      | 6         | 477        | 356              |
| Disconnect    |      | 7         | 477        | 356              |
| Exit          |      | 8         | 477        | 356              |
| Start         |      |           |            |                  |

#### Figure 36 • Write Throughput Measurement

The number of AXI clocks may differ for different run. It is due to PRE-CHARGE, ACTIAVTE or REFRESH cycle which runs between the memory transactions.

Table 7 lists the write and read bandwidth for data size varies from 2 KB to 16 KB.



# LPDDR SDRAM Bandwidth

Table 5 provides the total number of 16 beat bursts corresponding to the write or read size.

#### Table 5 • Total Number of 16 Beat Bursts

| Write or Read Data Size | Total Number of 16 Beat Bursts |
|-------------------------|--------------------------------|
| 2 КВ                    | 16                             |
| 4 KB                    | 32                             |
| 8 KB                    | 64                             |
| 16 KB                   | 128                            |

The following equation is applied to calculate the throughput:

Bandwidth (MB/s) = (16 ÷ (Total number of AXI clocks ÷ Total number of 16 beat bursts))×8×AXI Clock (MHz)

# **Simulation Result**

Table 6 lists the write and read bandwidth of LPDDR SDRAM simulation. The incremental pattern of size varies from 2 KB to 16 KB, which is transferred from LSRAM to LPDDR SDRAM and vice-versa.

Table 6 • LPDDR SDRAM Bandwidth

|       |                                             |              |                | Write                 |                              | Read                  |                      |                     |
|-------|---------------------------------------------|--------------|----------------|-----------------------|------------------------------|-----------------------|----------------------|---------------------|
| SI No | Optimization<br>Techniques                  | Size<br>(KB) | No of<br>cycle | Bandwidth<br>(MB/Sec) | No of<br>cy <mark>cle</mark> | Bandwidth<br>(MB/Sec) | Write<br>Improvement | Read<br>Improvement |
| Base  | AXI CLK 80 MHz.                             | 2            | 507            | 323                   | 721                          | 227                   | avg:320              | avg:225             |
|       |                                             | 4            | 1019           | 321                   | 1450                         | 225                   |                      |                     |
|       |                                             | 8            | 2043           | 320                   | 2904                         | 225                   |                      |                     |
|       |                                             | 16           | 4091           | 320                   | 5809                         | 225                   |                      |                     |
| 1     | 1) AXI CLK 83 MHz.                          | 2            | 507            | 335                   | 721                          | 235                   | avg:332              | avg:234             |
|       |                                             | 4            | 1019           | 333                   | 1450                         | 234                   | 3.75%                | 4%                  |
|       |                                             | 8            | 2043           | <mark>3</mark> 32     | 2905                         | 234                   |                      |                     |
|       |                                             | 16           | 4091           | 332                   | 5800                         | 234                   |                      |                     |
| 2     | 1) AXI CLK 83 MHz.                          | 2            | 477            | 356                   | 721                          | 235                   | avg:354              | avg:234             |
|       | 2) Without Write<br>Response State          | 4            | 957            | 355                   | 1450                         | 234                   | 10.6%                | 4%                  |
|       |                                             | 8            | 1917           | 354                   | 2905                         | 234                   |                      |                     |
|       |                                             | 16           | 3837           | 354                   | 5809                         | 234                   |                      |                     |
| 3     | 1) AXI CLK 83 MHz.                          | 2            | 477            | 356                   | 719                          | 236                   | avg:354              | avg:235             |
|       | 2) Without Write<br>Response State          | 4            | 957            | 355                   | 1440                         | 236                   | 10.6%                | 4.4%                |
|       | 3) Tuned DDR                                | 8            | 1917           | 354                   | 2886                         | 235                   |                      |                     |
|       | Configuration                               | 16           | 3906           | 348                   | 5883                         | 231                   |                      |                     |
| 4     | 1) AXI CLK 83 MHz                           | 2            | 477            | 356                   | 526                          | 323                   | avg:354              | avg:322             |
|       | 2) Without Write<br>Response State          | 4            | 957            | 355                   | 1054                         | 322                   | 10.6%                | 43%                 |
|       | 3) Tuned DDR                                | 8            | 1917           | 354                   | 2110                         | 322                   |                      |                     |
|       | Configuration<br>4) Read Command<br>Queuing | 16           | 3907           | 348                   | 4317                         | 315                   |                      |                     |



|       |                                                                               |              | Write Read     |                       |                |                       |                      |                     |
|-------|-------------------------------------------------------------------------------|--------------|----------------|-----------------------|----------------|-----------------------|----------------------|---------------------|
| SI No | Optimization<br>Techniques                                                    | Size<br>(KB) | No of<br>cycle | Bandwidth<br>(MB/Sec) | No of<br>cycle | Bandwidth<br>(MB/Sec) | Write<br>Improvement | Read<br>Improvement |
| 5     | 5 1) AXI CLK 100 MHz<br>(MDDR CLK 200<br>MHZ)                                 | 2            | 477            | 429                   | 526            | 389                   | avg:428              | avg:388             |
|       |                                                                               | 4            | 957            | 428                   | 1054           | 388                   | 33.75 %              | 72%                 |
|       | 2) Without Write                                                              | 8            | 1917           | 427                   | 2110           | 388                   |                      |                     |
|       | Response State<br>3) Tuned DDR<br>Configuration<br>4) Read Command<br>Queuing | 16           | 3907           | 419                   | 4317           | 379                   |                      |                     |

#### Table 6 • LPDDR SDRAM Bandwidth (continued)

### **Board Test Result**

Table 7 lists the write and read bandwidth of LPDDR SDRAM on IGLOO2 Evaluation kit board. The incremental pattern of size varies from 2 KB to 16 KB, which is transferred from LSRAM to LPDDR SDRAM and vice-versa.

Table 7 • LPDDR SDRAM Bandwidth

|       |                                                                |              | ,              | Write                 |                | Read                  |                      |                     |
|-------|----------------------------------------------------------------|--------------|----------------|-----------------------|----------------|-----------------------|----------------------|---------------------|
| SI No | Optimization<br>Techniques                                     | Size<br>(KB) | No of<br>cycle | Bandwidth<br>(MB/Sec) | No of<br>cycle | Bandwidth<br>(MB/Sec) | Write<br>Improvement | Read<br>Improvement |
| Base  | AXI CLK 80 MHz.                                                | 2            | 507            | 323                   | 721            | 227                   | avg:320              | avg:225             |
|       |                                                                | 4            | 1019           | 321                   | 1450           | 225                   |                      |                     |
|       |                                                                | 8            | 2043           | 320                   | 2905           | 225                   |                      |                     |
|       |                                                                | 16           | 4091           | 320                   | 5812           | 225                   |                      |                     |
| 1     | 1) AXI CLK 83                                                  | 2            | 507            | 335                   | 721            | 235                   | avg:332              | avg:234             |
|       | MHz.                                                           | 4            | 1019           | 333                   | 1450           | 234                   | 3.75%                | 4%                  |
|       |                                                                | 8            | 2043           | 332                   | 2905           | 234                   |                      |                     |
|       |                                                                | 16           | 4091           | 332                   | 5809           | 234                   |                      |                     |
| 2     | 1) AXI CLK 83                                                  | 2            | 477            | 356                   | 721            | 235                   | avg:354              | avg:234             |
|       | MHz.<br>2) Without Write                                       | 4            | 957            | 355                   | 1450           | 234                   | 10.6%                | 4%                  |
|       | Response State                                                 | 8            | 1917           | 354                   | 2905           | 234                   |                      |                     |
|       |                                                                | 16           | 3837           | 354                   | 5809           | 234                   |                      |                     |
| 3     | 1) AXI CLK 83                                                  | 2            | 477            | 356                   | 719            | 236                   | avg:354              | avg:235             |
|       | MHz.<br>2) Without Write                                       | 4            | 957            | 355                   | 1444           | 235                   | 10.6%                | 4.4%                |
|       | Response State                                                 | 8            | 1917           | 354                   | 2886           | 235                   |                      |                     |
|       | 3) Tuned DDR<br>Configuration                                  | 16           | 3907           | 348                   | 5883           | 231                   |                      |                     |
| 4     | 1)AXI CLK 83                                                   | 2            | 477            | 356                   | 526            | 323                   | avg:354              | avg:322             |
|       | MHz<br>2) Without Write                                        | 4            | 957            | 355                   | 1054           | 322                   | 10.6%                | 43%                 |
|       | Response State                                                 | 8            | 1917           | 354                   | 2110           | 322                   |                      |                     |
|       | 3) Tuned DDR<br>Configuration<br>4) Read<br>Command<br>Queuing | 16           | 3907           | 348                   | 4313           | 315                   |                      |                     |



# Conclusion

This application note describes the DDR SDRAM bandwidth optimization techniques with an example design on IGLOO2 Evaluation Kit board. It also shows the LPDDR SDRAM simulation flow using the Micron LPDDR SDRAM model and Microsemi LPDDR SDRAM VIP model.

# Appendix A – Design Files

The design files can be downloaded from the Microsemi SoC Products Group website: http://soc.microsemi.com/download/rsc/?f=M2GL\_AC424\_DF

The design file consists of Libero SoC Verilog project, MDDR Configuration files, Simulation model files and programming files (\*.stp) for IGLOO2 Evaluation Kit board. Refer to the Readme.txt file included in the design file for the directory structure and description.



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.