

# **DDR Memory Controller IP Core**

IP Version: v2.7.0

## **User Guide**

FPGA-IPUG-02208-1.8

December 2025



#### **Disclaimers**

Lattice makes no warranty, representation, or guarantee regarding the accuracy of information contained in this document or the suitability of its products for any particular purpose. All information herein is provided AS IS, with all faults, and all associated risk is the responsibility entirely of the Buyer. The information provided herein is for informational purposes only and may contain technical inaccuracies or omissions, and may be otherwise rendered inaccurate for many reasons, and Lattice assumes no obligation to update or otherwise correct or revise this information. Products sold by Lattice have been subject to limited testing and it is the Buyer's responsibility to independently determine the suitability of any products and to test and verify the same. LATTICE PRODUCTS AND SERVICES ARE NOT DESIGNED, MANUFACTURED, OR TESTED FOR USE IN LIFE OR SAFETY CRITICAL SYSTEMS, HAZARDOUS ENVIRONMENTS, OR ANY OTHER ENVIRONMENTS REQUIRING FAIL-SAFE PERFORMANCE, INCLUDING ANY APPLICATION IN WHICH THE FAILURE OF THE PRODUCT OR SERVICE COULD LEAD TO DEATH, PERSONAL INJURY, SEVERE PROPERTY DAMAGE OR ENVIRONMENTAL HARM (COLLECTIVELY, "HIGH-RISK USES"). FURTHER, BUYER MUST TAKE PRUDENT STEPS TO PROTECT AGAINST PRODUCT AND SERVICE FAILURES, INCLUDING PROVIDING APPROPRIATE REDUNDANCIES, FAIL-SAFE FEATURES, AND/OR SHUT-DOWN MECHANISMS. LATTICE EXPRESSLY DISCLAIMS Vref ANY EXPRESS OR IMPLIED WARRANTY OF FITNESS OF THE PRODUCTS OR SERVICES FOR HIGH-RISK USES. The information provided in this document is proprietary to Lattice Semiconductor, and Lattice reserves the right to make any changes to the information in this document or to any products at any time without notice

#### **Inclusive Language**

This document was created consistent with Lattice Semiconductor's inclusive language policy. In some cases, the language in underlying tools and other items may not yet have been updated. Please refer to Lattice's inclusive language FAQ 6878 for a cross reference of terms. Note in some cases such as register names and state names it has been necessary to continue to utilize older terminology for compatibility.



## **Contents**

| Contents                                                 |    |
|----------------------------------------------------------|----|
| Abbreviations in This Document                           |    |
| 1. Introduction                                          | 9  |
| 1.1. Quick Facts                                         |    |
| 1.2. IP Support Summary                                  | 9  |
| 1.3. Features                                            | 10 |
| 1.3.1. DDR4                                              | 10 |
| 1.3.2. LPDDR4                                            |    |
| 1.4. Licensing and Ordering Information                  | 14 |
| 1.5. Hardware Support                                    |    |
| 1.6. Minimum Device Requirements                         | 14 |
| 1.7. Naming Conventions                                  | 14 |
| 1.7.1. Nomenclature                                      | 14 |
| 1.7.2. Signal Names                                      | 14 |
| 2. Functional Description                                | 15 |
| 2.1. IP Architecture                                     | 15 |
| 2.1.1. Memory Controller                                 | 15 |
| 2.1.2. DDRPHY Module                                     | 16 |
| 2.2. Clocking and Reset                                  | 18 |
| 2.3. User Interfaces                                     | 18 |
| 2.3.1. AXI4 Data Interface                               | 18 |
| 2.3.2. APB Configuration Interface                       | 19 |
| 2.4. Calibration                                         | 19 |
| 2.4.1. Initialization and Training Sequence              | 20 |
| 2.4.2. Initialization and Training without APB Interface | 20 |
| 2.5. Operation Descriptions                              | 21 |
| 2.5.1. DDR4                                              | 21 |
| 2.5.2. LPDDR4                                            | 21 |
| 3. IP Parameter Description                              | 23 |
| 3.1. DDR4                                                | 23 |
| 3.1.1. General                                           | 23 |
| 3.1.2. Memory Device Timing                              | 25 |
| 3.1.3. Training Settings                                 | 27 |
| 3.2. LPDDR4                                              | 29 |
| 3.2.1. General                                           | 29 |
| 3.2.2. Memory Device Timing                              | 31 |
| 3.2.3. Training Settings                                 | 33 |
| 3.2.4. Example Design                                    | 35 |
| 3.2.5. Bit Swizzle Settings                              | 35 |
| 4. Signal Description                                    | 38 |
| 4.1. Clock and Reset                                     | 38 |
| 4.2. Interrupts and Initialization/Training              | 39 |
| 4.3. APB Register Interface                              | 39 |
| 4.4. AXI4 Data Interface                                 | 40 |
| 4.4.1. AXI4 Address Mapping for DDR4 mode                | 41 |
| 4.4.2. AXI4 Address Mapping for LPDDR4 mode              | 41 |
| 4.5. Memory Interface Signals                            | 42 |
| 4.5.1. DDR4 Memory Interface                             | 42 |
| 4.5.2. LPDDR4 Memory Interface                           | 42 |
| 5. Register Description                                  | 43 |
| 6. Memory Controller Example Design                      | 44 |
| 6.1. Overview                                            | 44 |



|    | 6.2.      | Synthesis Example Design           | 44 |
|----|-----------|------------------------------------|----|
|    | 6.3.      | Simulation Example Design          | 45 |
|    | 6.3.1.    |                                    |    |
|    | 6.3.2.    | LPDDR4                             | 46 |
| 7. | Desig     | ning and Simulating the IP         |    |
|    |           | Generating the IP                  |    |
|    | 7.1.1.    |                                    |    |
|    | 7.1.2.    |                                    |    |
|    | 7.2.      | Design Implementation              |    |
|    | 7.2.1.    |                                    |    |
|    | 7.2.2.    | Constraints                        | 53 |
|    | 7.3.      | Example Design Hardware Evaluation | 54 |
|    | 7.3.1.    | •                                  |    |
|    | 7.3.2.    | Running on Hardware                | 55 |
|    | 7.4.      | Example Design Simulation          | 59 |
| Αı |           | A. Resource Utilization            |    |
| -  | -         | 3. Known Issues                    |    |
| Re | eferences | 5                                  | 65 |
|    |           | Support Assistance                 |    |
|    |           | istory                             |    |
|    |           |                                    |    |



## **Figures**

| Figure 2.1. Memory Controller IP Core Functional Diagram   | 15 |
|------------------------------------------------------------|----|
| Figure 2.2. DDRPHY                                         | 17 |
| Figure 6.1. Synthesis Example Design                       | 44 |
| Figure 7.1. Creating a New Radiant Project                 | 47 |
| Figure 7.2. New Project Settings                           | 48 |
| Figure 7.3. Project Device Settings                        | 48 |
| Figure 7.4. Project Synthesis Tool Selection               | 49 |
| Figure 7.5. IP Instance Settings                           | 50 |
| Figure 7.6. IP Generation Result                           | 51 |
| Figure 7.7. Add Existing File Dialog Box                   | 55 |
| Figure 7.8. Radiant Programmer                             | 56 |
| Figure 7.9. Serial Terminal Settings                       | 57 |
| Figure 7.10. Simulation Wizard                             | 60 |
| Figure 7.11. Adding and Reordering Simulation Source Files | 60 |
| Figure 7.12. Parsing Simulation HDL Files                  | 61 |
| Figure 7.13. Simulation Summary                            | 61 |
| Figure 7.14. Simulation Result Waveform                    |    |
|                                                            |    |



## **Tables**

| Table 1.1. Quick Facts                                             | 9  |
|--------------------------------------------------------------------|----|
| Table 1.2. LPDDR4 and DDR4 Memory Controller IP Support Readiness  |    |
| Table 1.3. DDR4 Features Overview                                  | 11 |
| Table 1.4. LPDDR4 Features Overview                                | 13 |
| Table 1.5. Minimum Device Requirements                             | 14 |
| Table 2.1. MCE Request Handling                                    | 16 |
| Table 2.2. Supported AXI4 Transactions                             | 19 |
| Table 3.1. DDR4 General Attributes                                 | 23 |
| Table 3.2. DDR4 Clock Settings Attributes                          | 23 |
| Table 3.3. DDR4 Memory Configuration Attributes                    | 24 |
| Table 3.4. DDR4 Local Data Bus Attributes                          |    |
| Table 3.5. DDR4 General Definitions                                | 24 |
| Table 3.6. DDR4 Memory Device Timing Setting Attributes            | 25 |
| Table 3.7. DDR4 Periodic Event Setting Attributes                  | 26 |
| Table 3.8. DDR4 Memory Device Timing Definitions                   | 26 |
| Table 3.9. DDR4 Training Settings Attributes                       | 27 |
| Table 3.10. DDR4 MC I/O Settings Attributes                        | 27 |
| Table 3.11. DDR4 Memory ODT Settings Attributes                    | 28 |
| Table 3.12. DDR4 Training Settings Definitions                     | 28 |
| Table 3.13. LPDDR4 General Attributes                              | 29 |
| Table 3.14. LPDDR4 Clock Settings Attributes                       | 29 |
| Table 3.15. LPDDR4 Memory Configuration Attributes                 | 29 |
| Table 3.16. LPDDR4 Local Data Bus Attributes                       | 30 |
| Table 3.17. LPDDR4 General Definitions                             | 30 |
| Table 3.18. LPDDR4 Memory Device Timing Setting Attributes         | 31 |
| Table 3.19. LPDDR4 Periodic Event Setting Attributes               | 31 |
| Table 3.20. LPDDR4 Memory Device Timing Definitions                | 32 |
| Table 3.21. LPDDR4 Training Settings Attributes                    | 33 |
| Table 3.22. LPDDR4 MC I/O Settings Attributes                      | 33 |
| Table 3.23. LPDDR4 Memory ODT Settings Attributes                  | 33 |
| Table 3.24. LPDDR4 Training Settings Definitions                   | 34 |
| Table 3.25. LPDDR4 Example Design Attributes                       |    |
| Table 3.26. LPDDR4 Example Design Attribute Definitions            | 35 |
| Table 3.27. LPDDR4 Bit Swizzle Attributes                          | 36 |
| Table 3.28. LPDDR4 Bit Swizzle Attribute Definitions               | 37 |
| Table 4.1. Clock and Reset Port Definitions                        | 38 |
| Table 4.2. Interrupts and Initialization/Training Port Definitions | 39 |
| Table 4.3. APB Interface Port Definitions                          | 39 |
| Table 4.4. AXI4 Interface Port Definitions                         | 40 |
| Table 4.5. AXI4 Address Mapping for DDR4 mode                      | 41 |
| Table 4.6. AXI4 Address Mapping Example for DDR4 mode              | 41 |
| Table 4.7. AXI4 Address Mapping for LPDDR4 mode                    | 41 |
| Table 4.8. AXI4 Address Mapping Example for LPDDR4 mode            | 42 |
| Table 4.9. DDR4 Interface Port Definitions                         | 42 |
| Table 4.10. LPDDR4 Interface Port Definitions                      | 42 |
| Table 6.1. Supported Example Design Configurations                 | 44 |
| Table 6.2. DDR4 Simulation Runtime Summary                         | 46 |
| Table 6.3. LPDDR4 Simulation Runtime Summary                       | 46 |
| Table 7.1. Memory Controller Attribute Guidelines                  | 50 |
| Table 7.2. Generated File List                                     | 51 |
| Table 7.3. Project Constraints                                     | 53 |
| Table 7.4. Contents of eval/traffic_gen                            | 54 |
|                                                                    |    |



| Table A.1.DDR4 Resource Utilization for IP Core v2.7.0   | 63 |
|----------------------------------------------------------|----|
| Table A 2 LPDDR4 Resource Utilization for IP Core v2 7 0 | 63 |



## **Abbreviations in This Document**

A list of abbreviations used in this document.

| Abbreviations | Definition                                |
|---------------|-------------------------------------------|
| APB           | Advanced Peripheral Bus                   |
| AXI4          | Advanced eXtensible Interface 4           |
| BL            | Burst Length                              |
| CA            | Command and Address                       |
| CS            | Chip Select                               |
| CBT           | Command Bus Training                      |
| DBI           | Data Bus Inversion                        |
| DDR           | Double Data Rate                          |
| DDRPHY        | Double Data Rate Physical Layer           |
| DM            | Data Mask                                 |
| DQ            | Data                                      |
| DQS           | Data Strobe                               |
| ECC           | Error Correction Code                     |
| ECLK          | Edge Clock                                |
| FPGA          | Field Programmable Gate Array             |
| I/F           | Interface                                 |
| JEDEC         | Joint Electron Device Engineering Council |
| LPDDR         | Low Power Double Data Rate                |
| LVSTL         | Low Voltage Swing Terminated Logic        |
| MC            | Memory Controller                         |
| MR            | Mode Register                             |
| MRS           | Mode Register Set                         |
| ODT           | On-Die Termination                        |
| PRBS          | Pseudorandom Binary Sequence              |
| PVT           | Process, Voltage, and Temperature         |
| RTL           | Register Transfer Level                   |
| SCLK          | System Clock                              |
| SDRAM         | Synchronous Dynamic Random Access Memory  |
| TCL           | Tool Command Language                     |
| VREF          | Voltage Reference                         |



## 1. Introduction

The Lattice Semiconductor DDR Memory Controller IP provides a turnkey solution consisting of a controller, DDRPHY, and associated clocking and training logic to interface with DDR4 and LPDDR4 SDRAM. The IP Core is implemented in System Verilog HDL using the Lattice Radiant<sup>TM</sup> software integrated with the Synplify Pro® synthesis tool. The Memory Controller simplifies the interfacing with external DDR4 and LPDDR4 memory for user applications.

## 1.1. Quick Facts

Table 1.1 summarizes the DDR Memory Controller IP.

**Table 1.1. Quick Facts** 

|                      | Supported Devices                   | Lattice Avant, Certus-N2                                                                                |  |  |
|----------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------|--|--|
| IP Requirements      | IP Changes <sup>1</sup>             | For a list of changes to the IP, refer to the DDR Memory<br>Controller IP Release Notes (FPGA-RN-02033) |  |  |
| Resource Utilization | Supported User Interfaces           | AXI4 for data access APB for configuration access                                                       |  |  |
|                      | Resources                           | Refer to Table A.1 and Table A.2                                                                        |  |  |
|                      | Lattice Implementation <sup>2</sup> | IP Core v2.7.0 – Lattice Radiant software 2025.2                                                        |  |  |
| Design Tool Support  | Synthesis                           | Synopsys® Synplify Pro for Lattice                                                                      |  |  |
|                      | Simulation                          | Questasim                                                                                               |  |  |
| Driver Support       | API Reference                       | Refer to the DDR Memory Controller Driver (FPGA-TN-02379)                                               |  |  |

#### Notes:

- 1. In some instances, the IP may be updated without changes to the user guide. This user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates.
- 2. Lattice Implementation indicates the IP version release coinciding with the software version release. Check the software for IP version compatibility with earlier or later software versions.

## 1.2. IP Support Summary

Table 1.2. LPDDR4 and DDR4 Memory Controller IP Support Readiness

| Device Family | IP     | Rank   | DDR<br>Width | Data Rate (Mbps) <sup>2</sup> | Hardware<br>Validated | Timing Model             |
|---------------|--------|--------|--------------|-------------------------------|-----------------------|--------------------------|
|               |        |        | x16          | 700 to 1,600                  | Yes                   |                          |
|               |        | Single | x32          | 700 to 1,600                  | Yes                   |                          |
|               |        |        | x64          | 700 to 1,600                  | No                    |                          |
|               |        |        | x16          | 1,866 to 2,400                | No                    |                          |
|               | LPDDR4 | Single | x32          | 1,866 to 2,400                | No                    |                          |
|               |        |        | x64          | 1,866 to 2,400                | No                    |                          |
|               |        |        | x16          | 700 to 2,400                  | No                    |                          |
| Avant         |        | Dual   | x32          | 700 to 2,400                  | No                    | Preliminary <sup>1</sup> |
|               |        |        | x64          | 700 to 2,400                  | No                    |                          |
|               |        |        | x16          | 1,333 to 2,400                | No                    |                          |
|               |        | Single | x32          | 1,333 to 2,400                | No                    |                          |
|               | DDR4   |        | x64          | 1,333 to 2,400                | No                    |                          |
|               | DDK4   |        | x16          | 1,333 to 2,400                | No                    |                          |
|               |        | Dual   | x32          | 1,333 to 2,400                | No                    |                          |
|               |        |        | x64          | 1,333 to 2,400                | No                    |                          |



| Device Family | IP     | Rank                | DDR<br>Width | Data Rate (Mbps) <sup>2</sup> | Hardware<br>Validated | Timing Model   |                          |      |      |      |      |      |      |  |  |     |                |    |
|---------------|--------|---------------------|--------------|-------------------------------|-----------------------|----------------|--------------------------|------|------|------|------|------|------|--|--|-----|----------------|----|
|               |        | Cinalo              | x16          | 700 to 2,400                  | No                    |                |                          |      |      |      |      |      |      |  |  |     |                |    |
|               |        |                     | Single       | x32                           | 700 to 2,400          | No             |                          |      |      |      |      |      |      |  |  |     |                |    |
| Certus N2     | LPDDR4 | Dual                | x16          | 700 to 2,400                  | No                    | Dualinain am 1 |                          |      |      |      |      |      |      |  |  |     |                |    |
|               |        | Dual                | x32          | 700 to 2,400                  | No                    |                |                          |      |      |      |      |      |      |  |  |     |                |    |
|               | DDR4   | Single<br>DDR4 Dual | C:l-         | x16                           | 1,333 to 2,400        | No             | Preliminary <sup>1</sup> |      |      |      |      |      |      |  |  |     |                |    |
|               |        |                     | DDR4         | DDR4                          | Single                | x32            | 1,333 to 2,400           | No   |      |      |      |      |      |  |  |     |                |    |
|               |        |                     |              |                               | DDK4                  | DDK4           | DDK4                     | DDK4 | DDK4 | DDK4 | DDK4 | DDK4 | DDK4 |  |  | x16 | 1,333 to 2,400 | No |
|               |        |                     |              | Dual                          | x32                   | 1,333 to 2,400 | No                       |      |      |      |      |      |      |  |  |     |                |    |

#### Notes:

- 1. Timing model is preliminary as the DDR characterization is not finalized.
- 2. For the following Lattice Avant devices, the maximum data rate is limited to 1600Mbps for DDR Width x16 and x32, and no support for DDR Width x64.

LAV-AT-E30B

LAV-AT-E30ES

LAV-AT-E70B

LAV-AT-E70ES1

LAV-AT-G70ES

LAV-AT-X70ES

### 1.3. Features

The DDR Memory Controller IP supports the following key features for DDR4 and LPDDR4 SDRAM.

#### 1.3.1. DDR4

The Memory Controller supports the following key features when configured in DDR4 mode:

- DDR4 SDRAM protocol, compliant to DDR4 JEDEC Standard
  - DDR4 SDRAM speeds of:
    - 666 MHz (1,333 Mbps)
    - 800 MHz (1,600 Mbps)
    - 933 MHz (1,866 Mbps)
    - 1,066 MHz (2,133 Mbps)
    - 1,200 MHz (2,400 Mbps)
- DDR4-Specific Memory Controller features
  - Component support for interface data widths of x16, x32, and x64
  - Up to 16 Gb density support
  - x8 and x16 DDR4 device support (8:1 DQ:DQS ratio)
  - Fixed burst length of BL8
  - 8:1 gearing mode (DDR4:FPGA logic interface clock ratio)
  - Dual-rank support (requires dual rank DRAM chip)
  - Configurable CAS latencies for Reads and Writes based on target interface speed
  - Configurable Address widths to support various memory densities
- Supports component (DRAM soldered on the board) and UDIMM.
- AXI4 data interface support:
  - INCR read/write operations
  - Unaligned transfer using byte strobes
  - Narrow transfers
  - AXI widths of 32, 64, 128 and 256
  - Aligned addressing to AxSIZE only



- APB configuration interface support:
  - Automatic DDR4 SDRAM initialization
  - Dynamic valid window optimization for Read/Write paths
  - DQ-DQS skew optimization for Write training
- Periodic training support feature:
  - ZQ calibration
- Polling and Out-of-band interrupt support for training error

#### **Table 1.3. DDR4 Features Overview**

| Key Features                | DDR4 Support Details <sup>1</sup> |  |
|-----------------------------|-----------------------------------|--|
| Device Format               | Component, UDIMM                  |  |
| Data Widths                 | x16, x32, x64                     |  |
| Data User Interface         | AXI4                              |  |
| Configuration Interface     | АРВ                               |  |
| Maximum Data Rate           | Refer to Table 1.5                |  |
| HW Managed Periodic Events  |                                   |  |
| Refresh                     | All bank auto refresh             |  |
| ZQ Calibration              | Yes                               |  |
| Low Power Features          | Not yet supported                 |  |
| Other Features              |                                   |  |
| Error Correction Code (ECC) | Not yet supported                 |  |
| Dual rank                   | Yes                               |  |
| Data Bus Inversion (DBI)    | No                                |  |
| On-Die Termination (ODT)    | Yes for DQ, No for CA             |  |
| Bit Swizzle                 | Not yet supported                 |  |
| Training                    |                                   |  |
| Initialization              | Yes                               |  |
| CS Training                 | Not yet supported                 |  |
| Write Leveling              | Yes                               |  |
| Read Training               | Yes                               |  |
| Write Training              | Yes                               |  |
| VREF Training               | Not yet supported                 |  |
| Self-Calibrating Logic      | Yes                               |  |
| Bit-Level Trim Sweep        | Not yet supported                 |  |
| 2-D Vref Training           | Not yet supported                 |  |

#### Note:

1. Yes implies that a configurable option exists to enable or disable the feature. No implies that the feature is currently not supported and will not be supported in the future.



#### 1.3.2. LPDDR4

The Memory Controller supports the following key features when configured in LPDDR4 mode:

- LPDDR4 SDRAM protocol, compliant to LPDDR4 JEDEC Standard
  - LPDDR4 SDRAM speeds of:
    - 350 MHz (700 Mbps)
    - 400 MHz (800 Mbps)
    - 533 MHz (1,066 Mbps)
    - 666 MHz (1,333 Mbps)
    - 800 MHz (1,600 Mbps)
    - 933 MHz (1,866 Mbps)
    - 1,066 MHz (2,133 Mbps)
    - 1,200 MHz (2,400 Mbps)
- LPDDR4-Specific Memory Controller features
  - Component support for interface data widths of x16, x32, and x64
  - Up to 16 Gb density support per channel
  - x16 LPDDR4 device support (8:1 DQ:DQS ratio)
  - Burst length of BL16 and BL32, including On-The-Fly (OTF)
  - 8:1 gearing mode (LPDDR4:FPGA logic interface clock ratio)
  - Dual-rank support (requires dual rank DRAM chip)
  - Read DBI support only
  - Configurable CAS latencies for Reads and Writes based on target interface speed
  - Configurable Address widths to support various memory densities
- AXI4 data interface support:
  - INCR read/write operations
  - Unaligned transfer using byte strobes
  - Narrow transfers
  - AXI widths of 32, 64, 128, and 256
  - Aligned addressing to AxSIZE only
- APB configuration interface support:
  - Automatic LPDDR4 SDRAM initialization
  - Dynamic valid window optimization for Read/Write paths
  - DQ-DQS skew optimization for Write training
- Periodic training support feature:
  - Temperature tracking
  - Adaptive/Derate refresh rate for extended temperature support
  - ZQ calibration (ZQCAL START and LATCH only)
- Automatic detection of idle triggering Self-Refresh with Power-down entry
- Polling and Out-of-band interrupt support for training error and extended temperature support
- Bit Swizzle (DQ bit swizzle within the DQS group)



#### **Table 1.4. LPDDR4 Features Overview**

| Key Features                                         | LPDDR4 Support Details <sup>1</sup>                |  |
|------------------------------------------------------|----------------------------------------------------|--|
| Device Format                                        | Component                                          |  |
| Data Widths                                          | x16, x32, x64                                      |  |
| Data User Interface                                  | AXI4                                               |  |
| Configuration Interface                              | АРВ                                                |  |
| Maximum Data Rate                                    | Refer to Table 1.5                                 |  |
| HW Managed Periodic Events                           |                                                    |  |
| Refresh                                              | All bank auto refresh                              |  |
| ZQ Calibration                                       | Yes for ZQ start and latch, No for ZQ reset        |  |
| Low Power Features                                   | Self-refresh with power-down                       |  |
| Other Features                                       |                                                    |  |
| Error Correction Code (ECC)                          | Not yet supported                                  |  |
| Dual rank                                            | Yes                                                |  |
| Data Bus Inversion (DBI)                             | Yes for reads, No for writes                       |  |
| Temperature Tracking                                 | Yes                                                |  |
| Refresh Adaptation (derate) to Temperature Variation | Yes                                                |  |
| On-Die Termination (ODT)                             | Yes, for DQ and CA                                 |  |
| Bit Swizzle                                          | Yes for DQ, Not yet supported for CA and DQS Group |  |
| Training                                             |                                                    |  |
| Initialization                                       | Yes                                                |  |
| Command Training                                     | Yes                                                |  |
| Write Leveling                                       | Yes                                                |  |
| Read Training                                        | Yes                                                |  |
| Write Training                                       | Yes                                                |  |
| Automatic VREF Training                              | Yes                                                |  |
| Self-Calibrating Logic                               | Yes                                                |  |
| Bit-Level Trim Sweep                                 | Yes                                                |  |
| 2-D Vref Training                                    | Yes                                                |  |
|                                                      |                                                    |  |

#### Note:

1. Yes implies that a configurable option exists to enable or disable the feature. No implies that the feature is currently not supported and will not be supported in the future.



## 1.4. Licensing and Ordering Information

The DDR Memory Controller IP is available with the Lattice Radiant Subscription software. To purchase the Lattice Radiant Subscription license, contact Lattice Sales or go to the Lattice Online Store.

## 1.5. Hardware Support

Refer to the Running on Hardware section for more information on the boards used.

## 1.6. Minimum Device Requirements

The DDR Memory Controller IP supports the below devices. Table 1.5 summarizes the minimum device requirements for the Memory Controller IP Core.

**Table 1.5. Minimum Device Requirements** 

| Device/Mode | DDR Data Width | DDR Ranks | Speed Grade | Max Supported Interface<br>Speed |
|-------------|----------------|-----------|-------------|----------------------------------|
| DDR4        |                |           |             |                                  |
|             |                | 1, 2      | 3           | 2,400 Mbps                       |
| Avant-E/G/X | x16, x32, x64  |           | 2           | 2,133 Mbps                       |
|             |                | 1         | 1           | 1,866 Mbps                       |
|             | x16, x32       | 1, 2      | 3           | 2,400 Mbps                       |
| Certus-N2   |                |           | 2           | 2,133 Mbps                       |
|             |                | 1         | 1           | 1,866 Mbps                       |
| LPDDR4      |                |           |             |                                  |
|             |                | 1.2       | 3           | 2,400 Mbps                       |
| Avant-E/G/X | x16, x32, x64  | 1, 2      | 2           | 2,133 Mbps                       |
|             |                | 1         | 1           | 1,866 Mbps                       |
| Certus-N2   |                | 4.2       | 3           | 2,400 Mbps                       |
|             | x16, x32       | 1, 2      | 2           | 2,133 Mbps                       |
|             |                | 1         | 1           | 1,866 Mbps                       |

## 1.7. Naming Conventions

This section provides information regarding terminology used within this document.

#### 1.7.1. Nomenclature

The nomenclature used in this document is based on Verilog HDL.

## 1.7.2. Signal Names

Signal Names that end with:

- \_n are active low
- \_i are input signals
- \_o are output signals
- \_io are bi-directional input/output signals



## 2. Functional Description

This section provides a detailed functional description of the DDR Memory Controller IP. It includes information regarding clock and reset handling, available user data and configuration interfaces, the calibration sequence, and operation descriptions.

## 2.1. IP Architecture

The DDR Memory Controller IP includes three main blocks: the Memory Controller, DDRPHY, and Training Engine. The following figure shows the memory controller submodules and their connectivity.



Figure 2.1. Memory Controller IP Core Functional Diagram

The data interface allows users to initiate command/address/control and read/write operations to external DDR4/LPDDR4 SDRAM. The configuration interface provides access to the Training Engine and the Configuration Set Registers (CSRs), which configure the Memory Controller and perform the DDR4/LPDDR4 training sequences. The memory interface allows the selected Lattice FPGA to communicate with the external DDR4/LPDDR4 memory. For more information on the data and configuration interfaces, refer to the User Interfaces section of this user guide.

#### 2.1.1. Memory Controller

The Memory Controller consists of the following submodules:

- Bus Interface Block
- Controller Engine
- Read Return Block

#### 2.1.1.1. Bus Interface Block

The Bus Interface Block accepts user-initiated operations on the selected data interface and translates them for processing within the Memory Controller. The data provided for the Controller Engine consists of:

- Address interface size: determined based on the selected SDRAM device density and DDR4/LPDDR4 data width
- Read and Write interface sizes: determined based on the selected DDR4/LPDDR4 data width



#### 2.1.1.2. Controller Engine

The Controller Engine accepts the requests from the Bus Interface and translates the address to row, column, rank, and bank format. The ordering queue queues for the address, command, and control information coming from the Bus Interface Block. It prioritizes executing commands targeting an already opened bank and maintains the correct order of execution when multiple requests target the same bank in DDR4/LPDDR4 SDRAM. The write data buffer buffers incoming data for write commands.

The Controller Engine supports outstanding writes and reads, which are write/read requests entered into a queue and arbitrated for processing. The following table describes the three types of requests and how they are processed.

**Table 2.1. MCE Request Handling** 

| Request type  | Prioritization and Definition                                                                                                  | Comments                                                                                                                                                |
|---------------|--------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read          | Varies depending on selected data interface protocol. Refer to the AXI4 Data Interface section of this user guide for details. | The read request size is equal to the supported DDR4/LPDDR4 burst length.                                                                               |
| Write         | Write requests are defined as a write, where the entire data needs to be written for the supported DDR4/LPDDR4 burst length.   | Example: For a 32-bit DDR4/LPDDR4 data bus width, with burst length 8 (BL8), a full write would be 8×4B = 32B.                                          |
| Partial write | Partial write requests are defined as a write, where the entire data is not written.                                           | Example: For a 32-bit DDR4/LPDDR4 data bus width, a partial write would be a write request that is less than 32B. This is equivalent to a masked write. |

All write requests may be processed out of order if data dependency is not present. For example, an incoming request tied to an already opened page in DDR4/LPDDR4 SDRAM can be prioritized if it is not dependent on the requests already in the queue. Read requests may also be processed out of order if a data dependency is not present, depending on the selected data interface protocol. Refer to the AXI4 Data Interface section of this user guide for information regarding outstanding write/read support.

The Controller Engine contains bank management logic to track all the open and closed pages within each bank, along with timers for each bank and rank. This allows issued memory commands to meet the operational sequence and timing requirements of the DDR4/LPDDR4 SDRAM. The last layer of logic within the Controller Engine handles handshaking between the PHY and external memory. The Controller Engine is also responsible for supporting periodic events compliant with the DDR4/LPDDR4 SDRAM requirements. For more information on supported periodic features, refer to the Operation Descriptions section of this user guide.

### 2.1.1.3. Read Return Block

The Read Return Block is responsible for responding to the Controller Engine issued read requests. Execution of commands can be out of order, so the Read Return Block handles the reordering to ensure that the read data is sent to the Bus Interface in order. The Read Return Block also handles Data Bus Inversion (DBI), which is an I/O signaling technique that reduces power consumption and improves signal integrity.

#### 2.1.2. DDRPHY Module

The DDRPHY Module implements the DFI 4.0 Specification (© Cadence Design Systems, Inc.). It instantiates the hardened DDRPHY Primitive and includes a dedicated PLL and quarter-rate clock generator. The DDRPHY Module implements 8:1 gearing and trains the DDR4/LPDDR4 interface. Figure 2.2 shows a high-level block diagram of the DDRPHY module.





Figure 2.2. DDRPHY

#### 2.1.2.1. Hardened DDRPHY Primitive

The PHY uses hardened logic, called I/O modules or hardware primitives, to implement clock synchronization logic and the command/address and data input/output paths. The clock synchronization logic handles Clock Domain Crossing (CDC) between the Edge Clock (ECLK) and System Clock (SCLK). ECLK is an internal clock that clocks the DDR primitives, and SCLK clocks the Memory Controller IP Core. Without proper synchronization, the bit order on individual elements might become desynchronized, causing the data bus to scramble.

The Memory Controller operates in 8:1 gearing mode, which means that ECLK operates at the same frequency as the DDR4/LPDDR4 interface and that SCLK operates at a quarter of the DDR4/LPDDR4 memory clock. In other words, for a 400 MHz DDR4/LPDDR4 interface, ECLK operates at 800 MHz and SCLK operates at 200 MHz. This clocking ratio and DDR transfer relationship mean the user data bus is eight times the width of the DDR4/LPDDR4 memory data bus. For example, a 32-bit DDR4/LPDDR4 memory interface requires a 256-bit write and read data bus on the DDR PHY (DFI) side, which is an interface protocol between the Memory Controller and PHY. For more information regarding the DDRPHY, hardware primitives, and clock synchronization logic, refer to the DDR Memory PHY Module (FPGA-IPUG-02195).

#### 2.1.2.2. Training Engine

The Training Engine initializes and trains the external DDR4/LPDDR4 memory. It provides a configuration interface from user logic to the Configuration Set Registers (CSR). You can issue commands to the Training Engine to perform reads and writes to these registers, allowing you to handle interrupts and obtain details during the memory training sequence. It consists of user-accessible registers, a RISC-V CPU subsystem, and a hardened PHY. For more information regarding the training engine, refer to the DDR Memory PHY Module (FPGA-IPUG-02195).



## 2.2. Clocking and Reset

The Memory Controller IP requires a differential input reference clock for DDR4 and LPDDR4 interfaces. You need to provide this clock (pll\_refclk\_i) via an external source and route it to an appropriate pin on the FPGA. Refer to the IP Parameter Description section of this user guide for a list of valid frequencies supported by the input reference clock.

The provided input clock is then routed through a dedicated PLL within the Memory Controller IP to generate the Edge Clock (ECLK) and System Clock (SCLK). The ECLK signal is used internally by the IP Core to clock the I/O modules, and SCLK is used to clock the IP Core. The Primary Clock (PCLK) signal is used to implement clock synchronization logic to synchronize SCLK and ECLK. For additional details regarding clock synchronization, refer to the DDR Memory PHY Module (FPGA-IPUG-02195).

The Memory Controller IP contains an asynchronous active low reset: rst\_n\_i. When asserted, the Memory Controller and SDRAM are reset to their default values. The IP Core contains internal logic to de-assert the internal reset signals synchronous to the clocks (sclk\_o, pclk\_i and aclk\_i) once rst\_n\_i is de-asserted, so users do not need to worry about implementing their own de-assertion logic. The rst\_n\_i also resets both the AXI4 Data Interface and the APB Configuration Interface, so please take note of the following:

- rst\_n\_i asserts during AXI4 transaction: You should assert the areset\_n\_i as well to prevent bus hang-up.
- rst\_n\_i asserts during AXI4 Bus Idle: No need to assert the areset\_n\_i.
- rst\_n\_i asserts during APB transaction: You should assert the preset\_n\_i as well to prevent bus hang-up.
- rst\_n\_i asserts during APB Bus Idle: No need to assert the areset\_n\_i.

The configuration interface for the Memory Controller operates off the pclk\_i signal and is reset via the preset\_n\_i signal. The clock for the configuration interface is the same one used to implement clock synchronization for SCLK and ECLK. The preset\_n\_i signal is an asynchronous active low reset, where users must ensure it is synchronously deasserted to pclk\_i. Refer to the AXI4 Data Interface section of this user guide for information regarding the clocks and resets for the Memory Controller supported data interfaces.

#### 2.3. User Interfaces

This section describes the supported protocols for data and configuration interfaces available to the user and supported by the Memory Controller.

#### 2.3.1. AXI4 Data Interface

The data interface allows you to initiate read and write operations to external SDRAM. The AXI4 I/F supports high-bandwidth and low-latency operation. The AXI4 I/F is a multi-channel bus consisting of five independent channels: write address, read address, write data, read data, and write response channels (read response is sent along with the read data). The AXI4 I/F operates off the aclk\_i signal when the *Enable Local Bus Clock* attribute is checked. When the *Enable Local Bus Clock* attribute is checked, the Bus Interface Block implements clock domain crossing logic to transfer the request from AXI4 Clock (aclk i) to the Memory Controller IP Core's System Clock (SCLK).

The AXI4 I/F is reset via the areset\_n\_i signal, which is an asynchronous active low reset where users must ensure it is synchronously de-asserted to aclk\_i.

The Memory Controller IP supports the following AXI4 types of burst transfers:

- Burst Type (AxBURST):
  - INCR: incrementing burst that does not wrap at address boundaries
- Burst Size (AxSIZE):
  - [1, 2, 3, 4, 8, 16, 32, 64] Bytes
- Burst Length (AxLEN):
  - 1-64 beat burst: when IP parameter MAX\_BURST\_LEN = 64
  - 1-128 beat burst: when IP parameter MAX\_BURST\_LEN = 128
  - 1-256 beat burst: when IP parameter MAX BURST LEN = 256
- Burst Address (AxADDR):
  - Unaligned addressing is not supported so all transfers must be aligned to AxSIZE
  - Unaligned transfer is supported by using byte strobes



- For addresses not aligned to BUS WIDTH × 16 / 8, the maximum allowable AxLEN is as defined below:
  - Burst Length Offset = (BUS\_WIDTH × 16) / AXI\_DATA\_WIDTH
  - Maximum Allowable AxLEN = MAX\_BURST\_LEN Burst Length Offset
- Example Use Case: Maximum Burst Length is 64, DDR Bus Width is 32 bits and AXI Data Width is 32 bits
  - Burst Length Offset: 32 × 16/32 = 16
  - Maximum Allowable AxLEN: 64 16 1 = 47
- Write Strobes (WSTRB):
  - Only the first and last beats of a burst can have incomplete byte strobes (WSTRB cannot go low in middle of burst)

The AXI4 protocol supports out-of-order transaction completion and supports multiple outstanding transactions per bus master. As a result, when AXI4 configures as the user data interface, the Memory Controller supports up to eight outstanding writes and eight outstanding reads, with both reads and writes having the same priority. For more information regarding the AXI4 protocol, refer to the AMBA AXI Protocol Specification.

**Table 2.2. Supported AXI4 Transactions** 

| Transaction Type | AxBURST | AxLEN[7:0]            | AxSIZE[2:0] 1         | Comment              |
|------------------|---------|-----------------------|-----------------------|----------------------|
| Write            | INCR    | [0 - MAX_BURST_LEN-1] | [0, 1, 2, 3, 4, 5, 6] | [1-4,096] Byte write |
| Read             | INCR    | [0 - MAX_BURST_LEN-1] | [0, 1, 2, 3, 4, 5, 6] | [1-4,096] Byte read  |

#### Notes:

1. For IP parameter AXI DATA WIDTH = 32, AxSIZE = [0, 1, 2] are supported.

For IP parameter AXI\_DATA\_WIDTH = 64, AxSIZE = [0, 1, 2, 3] are supported.

For IP parameter AXI\_DATA\_WIDTH = 128, AxSIZE = [0, 1, 2, 3, 4] are supported.

For IP parameter AXI\_DATA\_WIDTH = 256, AxSIZE = [0, 1, 2, 3, 4, 5] are supported.

For IP parameter AXI\_DATA\_WIDTH = 512, AxSIZE = [0, 1, 2, 3, 4, 5, 6] are supported.

You should only start AXI4 transactions when the Initialization and Training is done. Refer to Calibration section for more information.

#### 2.3.2. APB Configuration Interface

The configuration interface allows you to initialize and train the memory interface. The Memory Controller IP Core utilizes the APB protocol for its configuration interface. The APB I/F is a low-power protocol intended for accessing programmable control registers. It is not pipelined and operates synchronously with a single address bus and two data buses: write and read. For more information regarding the APB protocol, please refer to the AMBA APB Protocol Specification.

The Memory Controller leverages this protocol to initialize and train the interface between FPGA logic and SDRAM. The APB I/F operates off the pclk\_i signal and resets via the preset\_n\_i signal. Refer to the Clocking and Reset section of this user guide for more details.

The APB I/F is unavailable when the *Enable APB I/F* attribute is unchecked. For details on how to initialize and train SDRAM without the APB I/F, refer to the <u>Initialization</u> and <u>Training</u> without APB Interface section of this user guide. You should only start APB transaction when the PLL is locked (pll\_lock\_o==1).

#### 2.4. Calibration

To ensure proper device functionality, initialize and train the external SDRAM before the Memory Controller performs data accesses. Upon device power-up, the soft RISC-V CPU inside the Training Engine remains in reset. To start the initialization and training sequence of the SDRAM device, execute the following steps via the configuration interface:

- Ensure the DDRPHY Module's PLL is in the lock state by polling the PHY Clock Register (PHY\_CLOCK) until the pll lock signal is asserted (PHY\_CLOCK[1]=1).
- Enable initialization and training by writing to the Training Operation Register (TRN\_OP\_REG) as follows:
  - For 1,333 Mbps and below, set TRN\_OP\_REG=0x0DF. This enables initialization, command-bus training, write leveling, read training, write training, and 1D Vref training sequences to run.



- For 1,600 Mbps and 1,866 Mbps, set TRN\_OP\_REG=0x1DF to perform bit-level trim sweep in addition to the
  above.
- For 2,133 Mbps and 2,400 Mbps, set TRN\_OP\_REG=0x3DF to perform bit-level trim sweep and 2D Vref training in addition to the above. This is necessary for the two highest data rates.

For simulation purposes, shorten the initialization and training sequences (including command-bus training) by writing 0x01C to TRN OP REG. For more information, refer to the DDR Memory PHY Module (FPGA-IPUG-02195).

- Pull the training CPU out of reset by writing 1'b1 to the Reset Register (RESET\_REG). This begins the initialization and training sequence.
- Wait until initialization and training completes using one of the following methods:
  - Poll the Status Register (STATUS\_REG) until the write\_trn\_done signal asserts (STATUS\_REG[4]=1). This indicates that write training completes, which is the final stage in the initialization and training process.
  - Wait for the trn\_done\_int signal (INT\_STATUS\_REG[0]=1) or the trn\_error\_int signal (INT\_STATUS\_REG[1]=1) to assert in the Interrupt Status Register (INT\_STATUS\_REG). This method requires the trn\_done\_en signal (INT\_ENABLE\_REG[0]=1) and the trn\_err\_en signal (INT\_ENABLE\_REG[1]=1) to be asserted in the Interrupt Enable Register (INT\_ENABLE\_REG).

After completing the above steps, the PHY control transfers to the Memory Controller and you can now start accessing the SDRAM memory through the data interface. Once init\_done\_o asserts, the RISC-V CPU and Training Engine enter reset to save power.

## 2.4.1. Initialization and Training Sequence

The Memory Controller IP performs initialization according to the DDR4/LPDDR4 JEDEC standards. For more information on the stages that occur during the initialization and training sequence, refer to the DDR Memory PHY Module (FPGA-IPUG-02195).

## 2.4.2. Initialization and Training without APB Interface

The APB I/F is unavailable when the *Enable APB I/F* attribute is unchecked. In this case, the init\_start\_i and trn\_opr\_i signals start and configure the DDR4/LPDDR4 initialization and training. The trn\_opr\_i sets the value of the Training Operation Register (TRN\_OP\_REG), controlling which specific training steps to perform based on the asserted bits. For hardware implementation:

- For 1333Mbps and below, set trn\_opr\_i=0x0DF to perform command bus training, write leveling, read training, write training, and 1D Vref training procedures.
- For 1,600 Mbps and 1,866 Mbps, set trn\_opr\_i=0x1DF to perform Bit-Level trim sweep in addition to above.
- For 2,133 Mbps and 2,400 Mbps, set trn\_opr\_i=0x3DF to perform Bit-Level trim sweep and 2D Vref training, this is necessary for the highest two data rates.

For simulation purposes, shorten the initialization and training sequences (including command bus training) by setting trn\_opr\_i=0x01C. For more information regarding the initialization and training sequences and relevant registers, refer to the DDR Memory PHY Module (FPGA-IPUG-02195).

Execute the following steps to start the initialization and training sequence of the DDR4/LPDDR4 SDRAM:

- 1. Set init\_start\_i=0 while the Memory Controller IP is in reset or while pll\_lock\_o=0.
- 2. Wait until pll\_lock\_o=1 before setting init\_start\_i=1. Maintain this value until init\_done\_o asserts.
- 3. Once init\_done\_o=1, set init\_start\_i=0 to hold the training CPU in reset to save power.



## 2.5. Operation Descriptions

This section provides details on various operations and features supported by the Memory Controller IP.

#### 2.5.1. DDR4

The following section describes the operations supported in DDR4 mode.

#### 2.5.1.1. Write and Read Data Access

Once the init\_done\_o signal asserts, you can initiate write and read accesses. The types of data accesses supported by the Memory Controller IP depend on the selected data interface protocol. Refer to Table 2.2 for a list of all supported AXI4 data accesses.

The Memory Controller decodes the memory-mapped address to check if the row and bank addresses are already opened in the memory device. When a WRITE/READ command issues to DDR4 memory, the following commands issue:

- If the target row, bank, and bank group are not open, the Memory Controller issues an ACTIVE command to the DDR4 SDRAM to open the row. This is followed by the WRITE/READ command.
- If there is an open row in the current bank or bank group and the target row address is different from the open row, the Memory Controller issues a PRECHARGE command to close the open row. This is followed by an ACTIVATE command to open the target row, and then the WRITE/READ command.
- If the target row is already open, the Memory Controller issues only a WRITE/READ command.

The Memory Controller does not immediately close a row after issuing a WRITE/READ command. It issues a separate PRECHARGE command as needed.

#### 2.5.1.2. Auto Refresh Support

Ideally, issue REFRESH commands every refresh interval, as specified by the *Refresh Period* attribute. To improve efficiency in scheduling and switching between tasks, the DDR4 memory allows a maximum of eight REFRESH commands to be postponed throughout the DDR4 operation. The Memory Controller has an internal auto refresh generator that sends out a set of consecutive AUTO REFRESH commands to the memory once it reaches the time specified in the following calculation: *Refresh Period* × *No. of Outstanding Refresh*.

For high-performance applications, set the *Number of Outstanding Refresh* to the maximum value. This increases the DDR4 bus throughput by minimizing Memory Controller intervention.

#### 2.5.1.3. Periodic ZQ Calibration

ZQ Calibration calibrates the output driver impedance and On-Die Termination (ODT) values across PVT. The Memory Controller IP periodically performs ZQ Calibration as the voltage and temperature fluctuate during operation. You can configure the frequency at which ZQ Calibration is performed and its duration via the ZQ Calibration Period and attribute. Periodic ZQ calibration uses the DDR4 ZQ Calibration Short (ZQCS) command.

#### 2.5.2. LPDDR4

This section describes the operations supported in LPDDR4 mode.

#### 2.5.2.1. Write and Read Data Access

Once the init\_done\_o signal asserts, you can initiate write and read accesses. The types of data accesses supported by the Memory Controller IP depend on the selected data interface protocol. Refer to Table 2.2 for a list of all supported AXI4 data accesses.

The Memory Controller decodes the memory-mapped address to check if the row and bank addresses are already open in the memory device. When a WRITE/READ command issues to LPDDR4 memory, the following commands issue:

- If the target row and bank are not open, the Memory Controller issues an ACTIVATE command to the LPDDR4 SDRAM to open the row. This is followed by the WRITE/READ command.
- If there is an open row in the current bank and the target row address is different from the open row, the Memory Controller issues a PRECHARGE command to close the open row. This is followed by an ACTIVATE command to open the target row, and then the WRITE/READ command.
- If the target row is already open, the Memory Controller issues only a WRITE/READ command.



The Memory Controller does not immediately close a row after issuing a WRITE/READ command. It issues a separate PRECHARGE command as needed.

#### 2.5.2.2. Auto Refresh Support

Ideally, issue REFRESH commands every refresh interval, as specified by the *Refresh Period* attribute. To improve efficiency in scheduling and switching between tasks, the LPDDR4 memory allows a maximum of eight *REFRESH* commands to be postponed throughout the LPDDR4 operation. The Memory Controller has an internal auto refresh generator that sends out a set of consecutive AUTO REFRESH commands to the memory once it reaches the time specified in the following calculation: *Refresh Period* × *Number of Outstanding Refresh*.

For high-performance applications, set the *Number of Outstanding Refresh* to the maximum value. This increases the LPDDR4 bus throughput by minimizing Memory Controller intervention.

#### 2.5.2.3. Power Saving Feature

The Memory Controller supports power-saving when the *Enable Power Down* attribute is set. The Memory Controller IP tracks the period of inactivity on the local data bus by monitoring the System Clock (SCLK), the main clock used by the Memory Controller IP. When the period of inactivity on the bus reaches the value set in the *Number of SCLK to enter Self-Refresh from no traffic* attribute, the Memory Controller issues SELF REFRESH and Power-Down Entry commands. This puts the memory into Power-Down mode to save power until a new request is received on the local data bus, at which point the Memory Controller issues SELF REFRESH and Power-Down Exit commands, followed by an additional REFRESH command.

#### 2.5.2.4. Periodic ZQ Calibration

ZQ Calibration calibrates the output driver impedance across PVT. There are two ZQ Calibration modes initiated with the Multi-Purpose Command (MPC): ZQCAL START and ZQCAL LATCH. The ZQCAL START command initiates the SDRAM's calibration procedure, and the ZQCAL LATCH command captures the result and loads it into the SDRAM's drivers.

The Memory Controller IP periodically performs ZQ Calibration as the voltage and temperature may fluctuate during operation. You can configure the frequency at which ZQ Calibration is performed and its duration via the ZQ Calibration Period and ZQ Calibration Start to Latch attributes. Periodic ZQ calibration uses the LPDDR4 ZQ Calibration Short (ZQCS) command.

#### 2.5.2.5. Temperature Tracking and Extended Temperature Support

LPDDR4 SDRAM devices support temperature tracking, where the device's refresh rate can change based on the operational temperature. When the memory device's temperature is within normal operating conditions, the rate is set to 1x refresh, which is the default case. As the temperature fluctuates below or above the default case, the Memory Controller decreases or increases the frequency of refreshes, respectively. The required refresh rate according to temperature is specified in MR4 within LPDDR4 SDRAM. When the Temperature Update Flag (TUF) is set in MR4, it indicates that the refresh rate has changed from the last read issued to MR4. In this case, the Memory Controller waits for the completion of the current refresh cycle and updates the refresh period based on MR4 for the subsequent timing of the refresh.

LPDDR4 SDRAM devices also support operation at extended temperatures. When the operational temperature increases beyond normal operation conditions, the refresh frequency increases. When the refresh rate in MR4 is set to 3'b110, timing derating is required for certain commands, slowing performance. For more information regarding temperature derating timing requirements, refer to the LPDDR4 JEDEC Standard.

The Memory Controller IP periodically reads MR4 to track the temperature of the LPDDR4 memory device. Based on the refresh rate set in MR4, the Memory Controller IP issues REFRESH commands at the required frequency. Note that when the refresh rate in MR4 is set to either 3'b000 or 3'b111, the LPDDR4 memory may not work as expected due to exceeding the low/high temperature operating limits.

When the refresh rate is set to 3'b110 in MR4, the Memory Controller accommodates the temperature-derating timing requirements when issuing commands to the memory. You can change the frequency at which the memory's MR4 register is read through the *Temperature Check Period* attribute. For more information regarding supported LPDDR4 operations and relevant registers, refer to the DDR Memory PHY Module (FPGA-IPUG-02195).



## 3. IP Parameter Description

The following tables show and describe the configurable attributes of the DDR Memory Controller IP. You can configure these attributes through the IP Catalog's Module/IP Block Wizard of the Lattice Radiant software. Refer to the Designing and Simulating the IP section of this user guide for information on how to configure and generate the Memory Controller IP.

### 3.1. DDR4

This section describes the parameters available in DDR4 mode.

#### **3.1.1.** General

This section describes the parameters available in the General tab of the IP parameter editor.

Table 3.1. DDR4 General Attributes

| Attribute                                | Selectable Values         | Default   | Dependency on Other Attributes                                       |
|------------------------------------------|---------------------------|-----------|----------------------------------------------------------------------|
| Interface Type                           | DDR4                      | DDR4      | _                                                                    |
| I/O Buffer Type                          | POD12                     | POD12     | Display only                                                         |
| DDR Command Frequency (MHz) <sup>1</sup> | 666, 800, 933, 1066, 1200 | 800       | _                                                                    |
| Gearing Ratio                            | 8:1                       | 8:1       | Display only                                                         |
| Enable Sideband ECC                      | Checked, Unchecked        | Unchecked | Display only                                                         |
| Enable Power Down <sup>2</sup>           | Checked, Unchecked        | Unchecked | Display only                                                         |
|                                          | 10                        | 10        | DDR Command Frequency = 666MHz                                       |
|                                          | 10, 11, 12                | 12        | DDR Command Frequency = 800MHz                                       |
| Read Latency                             | 12, 13, 14                | 12        | DDR Command Frequency = 933MHz                                       |
|                                          | 14, 15, 16                | 14        | DDR Command Frequency = 1,066MHz                                     |
|                                          | 15, 16, 17, 18            | 16        | DDR Command Frequency = 1,200MHz                                     |
|                                          | 9                         | 9         | DDR Command Frequency = 666MHz                                       |
|                                          | 9, 11                     | 9         | DDR Command Frequency = 800MHz                                       |
| Write Latency                            | 10, 12                    | 10        | DDR Command Frequency = 933MHz                                       |
|                                          | 11, 14                    | 11        | DDR Command Frequency = 1,066MHz                                     |
|                                          | 12, 16                    | 12        | DDR Command Frequency = 1,200MHz                                     |
| Enable Internal RISC-V CPU               | Checked, Unchecked        | Checked   | Display only (Disabling of Internal RISC-V CPU is not yet supported) |

#### Notes:

**Table 3.2. DDR4 Clock Settings Attributes** 

| Attribute                            | Selectable Values | Default | Dependency on Other Attributes                                |
|--------------------------------------|-------------------|---------|---------------------------------------------------------------|
| Enable PLL                           | Checked           | Checked | Display only                                                  |
| Reference Clock Frequency (MHz)      | Integer           | 100.0   | _                                                             |
| DDR Memory Actual Frequency<br>(MHz) | Calculated        | N/A     | Display only Based on the selection for DDR Command Frequency |

Devices with speed grades of 2 and 3 support DDR command frequencies up to 1,066 MHz, while devices with a speed grade of 3 can support frequencies up to 1,200 MHz.

<sup>2.</sup> The Enable Power Down attribute is hidden due to the known issues mentioned in Appendix B.



## **Table 3.3. DDR4 Memory Configuration Attributes**

| Attribute                       | Selectable Values       | Default | Dependency on Other Attributes |
|---------------------------------|-------------------------|---------|--------------------------------|
| DDR Density (per Channel)       | 2 Gb, 4 Gb, 8 Gb, 16 Gb | 4 Gb    | _                              |
| DDR Bus Width (DDR_WIDTH)       | 16, 32, 64              | 32      | _                              |
| Configuration                   | x8, x16                 | x16     | _                              |
| Number of Ranks (CS_WIDTH) 1    | 1, 2                    | 1       | _                              |
| Number of DDR Clocks (CK_WIDTH) | 1, 2                    | 1       | _                              |

#### Note:

1. Devices with speed grades of 2 and 3 support Dual Rank.

#### **Table 3.4. DDR4 Local Data Bus Attributes**

| Attribute              | Selectable Values      | Default | Dependency on Other Attributes                             |
|------------------------|------------------------|---------|------------------------------------------------------------|
| Local Data Bus Type    | AXI4                   | AXI4    | Display only                                               |
| Address Width          | Calculated             | N/A     | Display only Calculated based on selection for DDR Density |
| Data Width             | 32, 64, 128, 256, 512  | 256     | Calculated based on the selection for <i>DDR Bus Width</i> |
| ID Width               | 1, 2, 3, 4, 5, 6, 7, 8 | 4       | _                                                          |
| Maximum Burst Length   | 64, 128, 256           | 64      | _                                                          |
| Write Ordering Queues  | 1, 2, 3, 4             | 2       | _                                                          |
| Read Ordering Queues   | 1, 2, 3, 4             | 2       | -                                                          |
| Enable Local Bus Clock | Checked, Unchecked     | Checked | -                                                          |
| Enable APB I/F         | Checked, Unchecked     | Checked | _                                                          |

## **Table 3.5. DDR4 General Definitions**

| Attribute                   | Description                                                                                                                                                                                      |  |  |  |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| General Group               |                                                                                                                                                                                                  |  |  |  |
| Interface Type              | Specifies the SDRAM Memory interface: DDR4                                                                                                                                                       |  |  |  |
| I/O Buffer Type             | I/O Standard for the memory interface signals This is fixed to POD12 for DDR4, but the command/address/control signals should be terminated to VTT on the board. Please see note 2 of Table 4.9. |  |  |  |
| DDR Command Frequency (MHz) | Speed at which the memory controller will issue commands to the memory device                                                                                                                    |  |  |  |
| Gearing Ratio               | Specifies the ratio relationship between the DDR data speed and the memory controller speed                                                                                                      |  |  |  |
| Enable Power Down           | Enables memory controller automatically placing the memory device into power-down mode after a specified number of idle controller clock cycles (not yet supported)                              |  |  |  |
| Enable DBI                  | Enables data bus inversion (DBI) for better signal integrity and read/write margins                                                                                                              |  |  |  |
| Read Latency                | Specifies the delay from issuing a read command to receiving of read data from SDRAM. Set this based on the target DRAM's datasheet.                                                             |  |  |  |
| Write Latency               | Specifies the delay from issuing a write command to providing of write data to SDRAM. Set this based on the target DRAM's datasheet.                                                             |  |  |  |
| Enable Internal RISC-V CPU  | Enables RISC-V subsystem to support initialization and training of the memory device (disabling is not yet supported)                                                                            |  |  |  |



| Attribute                        | Description                                                                                                                                                                                                                                                                                                             |  |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Clock Settings Group             |                                                                                                                                                                                                                                                                                                                         |  |
| Enable PLL                       | Enables PLL                                                                                                                                                                                                                                                                                                             |  |
| Reference Clock: Frequency (MHz) | Indicates the PLL reference clock speed                                                                                                                                                                                                                                                                                 |  |
| DDR Memory Actual Frequency      | Specifies the actual operating frequency of the memory interface (calculated by the PLL –                                                                                                                                                                                                                               |  |
| (MHz)                            | includes tolerance)                                                                                                                                                                                                                                                                                                     |  |
| Memory Configuration Group       |                                                                                                                                                                                                                                                                                                                         |  |
| DDR Density (per Channel)        | Density of SDRAM (number of chips on memory module). Only DDR Density with power of 2 is supported.                                                                                                                                                                                                                     |  |
| DDR Bus Width                    | Total number of data pins in memory interface                                                                                                                                                                                                                                                                           |  |
| Configuration                    | Specifies the DRAM's Configuration as x8 or x16. The x4 is not supported. Set this based on the target DRAM's datasheet.                                                                                                                                                                                                |  |
| Number of Ranks                  | Specifies number of ranks in memory interface                                                                                                                                                                                                                                                                           |  |
| Number of DDR Clocks             | Specifies the number of CK/CK# clock pairs to be driven to SDRAM                                                                                                                                                                                                                                                        |  |
| Local Data Bus Group             | openius the named of ory sim disampans to so annother solution.                                                                                                                                                                                                                                                         |  |
| Local Data Bus Type              | Indicates bus for local data interface: AXI4 or NATIVE                                                                                                                                                                                                                                                                  |  |
| Address Width                    | Specifies the number of address pins in memory interface, dependent on the SDRAM density                                                                                                                                                                                                                                |  |
| Data Width (AXI_DATA_WIDTH)      | Indicates data width for local data bus                                                                                                                                                                                                                                                                                 |  |
| ID Width                         | Indicates bit width of AXI4 ID                                                                                                                                                                                                                                                                                          |  |
| Maximum Burst Length             | Specifies the maximum AXI4 burst length. Recommended to set based on system requirements to save EBR resources.                                                                                                                                                                                                         |  |
| Local Data Bus Group             |                                                                                                                                                                                                                                                                                                                         |  |
| Write Ordering Queues            | The number of write/read ordering queues process write and read data requests. The                                                                                                                                                                                                                                      |  |
| Read Ordering Queues             | higher the value, the better bandwidth on the interface since gaps between accesses is lessened at the cost of consuming more LUTs.                                                                                                                                                                                     |  |
| Enable Local Bus Clock           | Enables clock domain crossing logic for the local data bus.                                                                                                                                                                                                                                                             |  |
| Enable APB I/F                   | Enables APB interface. Should be enabled if the target application includes a CPU. When disabled, initialization and training of SDRAM should be handled via init_start_i and trn_opr_i signals. Please refer to the Initialization and Training without APB Interface section of this User Guide for more information. |  |

## 3.1.2. Memory Device Timing

This section describes the parameters available in the Memory Device Timing tab of the IP parameter editor. The default value of the attributes listed under the Memory Device Timing Setting Group is different for each DDR Command Frequency value and is based on JESD79-4D SDRAM standard. These values may need to be manually adjusted based on the selected DDR4 device.

**Table 3.6. DDR4 Memory Device Timing Setting Attributes** 

| Attribute                   | Selectable Values | Default    | Dependency on Other Attributes          |
|-----------------------------|-------------------|------------|-----------------------------------------|
| Manual Timing Adjust Enable | Checked/Unchecked | Unchecked  | _                                       |
| TRCD (tCLK)                 | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRAS (tCLK)                 | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRPPB (tCLK)                | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TWR (tCLK)                  | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRTP (tCLK)                 | 8 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TCCD (tCLK)                 | 8 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRRD (tCLK)                 | 6 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRFC (tCLK)                 | 24 – 28,080       | Calculated | Enabled when Manually Adjust is Checked |
| TFAW (tCLK)                 | 40 – 65,536       | Calculated | Enabled when Manually Adjust is Checked |
| TZQCAL (tCLK)               | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |



| Attribute      | Selectable Values | Default    | Dependency on Other Attributes                 |
|----------------|-------------------|------------|------------------------------------------------|
| TMRD (tCLK)    | 10 – 65,536       | Calculated | Enabled when Manually Adjust is Checked        |
| TRPAB (tCLK)   | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked        |
| TDQSS (tCLK)   | Integer           | 0          | Enabled when Manually Adjust is Checked        |
| TRD2PRE (tCLK) | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked        |
| TWR2PRE (tCLK) | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked        |
| TXP (tCLK)     | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked        |
| TXPSR (tCLK)   | 4 – 65,536        | Calculated | Enabled when <i>Manually Adjust</i> is Checked |

## **Table 3.7. DDR4 Periodic Event Setting Attributes**

| Attribute                                               | Selectable Values   | Default    | Dependency on Other Attributes                                           |
|---------------------------------------------------------|---------------------|------------|--------------------------------------------------------------------------|
| Number of SCLK to enter Self<br>Refresh from no traffic | Integer             | 5,000      | Enabled when Enable Power Down is<br>Checked                             |
| Refresh Period (tSCLK)                                  | Calculated          | Calculated | Default value is calculated based on selection for DDR Command Frequency |
| Number of Outstanding Refresh                           | 1, 2, 3, 4, 5, 6, 7 | 7          | _                                                                        |
| ZQ Calibration Period (sec)                             | Integer             | 32         | _                                                                        |
| ZQ Calibration Start to Latch (usec)                    | Integer             | 1          | _                                                                        |
| Temperature Check Period (sec)                          | Integer             | 32         | _                                                                        |

### **Table 3.8. DDR4 Memory Device Timing Definitions**

| Attribute                                       | Description                                                                                                             |  |  |
|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|
| Memory Device Timing Setting Group <sup>1</sup> |                                                                                                                         |  |  |
| Manual Timing Adjust Enable                     | ning Adjust Enable Enables you to manually set any of the memory timing parameters                                      |  |  |
| TRCD                                            | Indicates the delay between the ACTIVATE command (RAS) and the internal access to data (CAS)                            |  |  |
| TRAS                                            | Indicates how long memory must wait after an ACTIVATE command before a PRECHARGE command can be issued to close the row |  |  |
| TRPPB                                           | Row PRECHARGE time for a single bank                                                                                    |  |  |
| TWR                                             | Specifies the amount of clock cycles needed to complete a WRITE before a PRECHARGE command can be issued                |  |  |
| TRTP                                            | Internal READ to PRECHARGE delay                                                                                        |  |  |
| TCCD                                            | Minimum time between two READ/WRITE (CAS) commands (burst length / 2)                                                   |  |  |
| TRRD                                            | Minimum time interval between two ACTIVATE commands to different banks                                                  |  |  |
| TRFC                                            | Indicates how long memory must wait after a REFRESH command before an ACTIVATE command can be accepted by memory        |  |  |
| TFAW                                            | Specifies the period duration during which only four banks can be active                                                |  |  |
| TZQCAL                                          | ZQ calibration time from START to LATCH command                                                                         |  |  |
| TMRD                                            | Minimum time between two MRS commands                                                                                   |  |  |
| TRPAB                                           | Row PRECHARGE time for all banks                                                                                        |  |  |
| TDQSS                                           | Describes skew between the output data strobe with respect to the memory clock for writes (DQS to CK)                   |  |  |
| TRD2PRE                                         | READ to PRECHARGE time                                                                                                  |  |  |
| TWR2PRE                                         | WRITE to PRECHARGE time                                                                                                 |  |  |
| TXP                                             | Power-down exit latency to next valid command                                                                           |  |  |
| TXPSR                                           | Power-down exit latency to next self-refresh                                                                            |  |  |



| Attribute                                                | Description                                                                                                                                     |  |  |  |  |
|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Periodic Event Setting Group                             | Periodic Event Setting Group                                                                                                                    |  |  |  |  |
| Number of SCLK to enter Self-<br>Refresh from no traffic | The memory controller puts the memory in self-refresh when there is no traffic for the specified number of SCLK cycles                          |  |  |  |  |
| Refresh Period                                           | Specifies the number of SCLK cycles between refresh commands                                                                                    |  |  |  |  |
| Number of Outstanding Refresh                            | Specifies the maximum number of outstanding refresh commands. Refer to the Auto Refresh Support section of this user guide for more information |  |  |  |  |
| ZQ Calibration Period                                    | Indicates period for performing ZQ Calibration in seconds                                                                                       |  |  |  |  |
| ZQ Calibration Start to Latch                            | Indicates time from start to latch during ZQ Calibration in microseconds                                                                        |  |  |  |  |
| Temperature Check Period                                 | Indicates period for reading the temperature register (MR4) in DDR4 memory in seconds                                                           |  |  |  |  |

#### Note:

 The memory device timing parameters listed under the Memory Device Timing tab are defined according to the JESD79-4D SDRAM standard. Refer to the memory device data sheet for detailed descriptions and allowed values for these parameters.

## 3.1.3. Training Settings

This section describes the parameters available in the Training Settings tab of the IP parameter editor.

**Table 3.9. DDR4 Training Settings Attributes** 

| Attribute                             | Selectable Values  | Default   | Dependency on Other Attributes         |
|---------------------------------------|--------------------|-----------|----------------------------------------|
| DDR Clock Delay Value                 | 0 - 20             | 15        | _                                      |
| DDR Clock Delay Value Incr/Decr       | Checked, Unchecked | Checked   | _                                      |
| CS Delay Value                        | 0-20               | 15        | _                                      |
| CS Delay Value Incr/Decr              | Checked/Unchecked  | Checked   | _                                      |
| Address Control Delay Value           | 0 - 20             | 4         | _                                      |
| Address Control Delay Value Incr/Decr | Checked, Unchecked | Unchecked | _                                      |
| Memory DQ_Vref Value for Rank0        | 0-114              | 90        | _                                      |
| Memory DQ_Vref Value for Rank1        | 0-114              | 90        | Enabled when Number of Ranks==2        |
| MC DQS Grp<0,1> Vref Value            | 0-127              | 80        | _                                      |
| MC DQS Grp<2,3> Vref Value            | 0-127              | 80        | Enabled when <i>DDR Bus Width</i> ≥ 32 |
| MC DQS Grp<4,7> Vref Value            | 0-127              | 80        | Enabled when <i>DDR Bus Width</i> ≥64  |

## Table 3.10. DDR4 MC I/O Settings Attributes

| Attribute                 | Selectable Values                             | Default | Dependency on Other Attributes |
|---------------------------|-----------------------------------------------|---------|--------------------------------|
| CK/CS Slew Rate           | Slow, Fast                                    | Fast    | _                              |
| Command Address Slew Rate | Slow, Fast                                    | Fast    | _                              |
| DQS Slew Rate             | Slow, Fast                                    | Fast    | _                              |
| DQ/DMI Slew Rate          | Slow, Fast                                    | Fast    | _                              |
| MC CA Output Impedance    | 240 Ω, 120 Ω, 68 Ω, 60 Ω,<br>48 Ω, 40 Ω, 34 Ω | 34 Ω    | _                              |
| MC DQ Output Impedance    | 240 Ω, 120 Ω, 68 Ω, 60 Ω,<br>48 Ω, 40 Ω, 34 Ω | 34 Ω    | _                              |
| MC ODT Value              | 240 Ω, 120 Ω, 68 Ω, 60 Ω,<br>48 Ω, 40 Ω, 34 Ω | 60 Ω    | _                              |



## **Table 3.11. DDR4 Memory ODT Settings Attributes**

| Attribute      | Selectable Values                                              | Default            | Dependency on Other Attributes |
|----------------|----------------------------------------------------------------|--------------------|--------------------------------|
| RTT_WR Value   | Dynamic ODT OFF, RZQ/1,<br>RZQ/2, RZQ/3, Hi-Z                  | Dynamic ODT<br>OFF | _                              |
| RTT_NOM Value  | Disable, RZQ/1, RZQ/2,<br>RZQ/3, RZQ/4, RZQ/5,<br>RZQ/6, RZQ/7 | RZQ/5              | _                              |
| RTT_PARK Value | Disable, RZQ/1, RZQ/2,<br>RZQ/3, RZQ/4, RZQ/5,<br>RZQ/6, RZQ/7 | Disable            |                                |

#### **Table 3.12. DDR4 Training Settings Definitions**

| Attribute <sup>1</sup>                   | Description                                                                                                                                                                                                                                                                                                    |  |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Training Settings                        |                                                                                                                                                                                                                                                                                                                |  |
| DDR Clock Delay Value                    | Specifies the DDR clock delay so that the first DQS toggle is at CK = 0 during write leveling. It is recommended to increase this value if write leveling fails                                                                                                                                                |  |
| DDR Clock Delay Value Incr/Decr          | Specifies the adjustment direction Checked: DDR Clock Delay Value is added to the ddr_ck_o signal Unchecked: DDR Clock Delay Value is subtracted from the ddr_ck_o signal                                                                                                                                      |  |
| CS Delay Value                           | Specifies the DDR CS delay value                                                                                                                                                                                                                                                                               |  |
| CS Delay Value Incr/Decr                 | Specifies the adjustment direction Checked: CS Delay Value is added to the ddr_cs_o signal Unchecked: CS Delay Value is subtracted from the ddr_cs_o signal                                                                                                                                                    |  |
| Address Control Delay Value              | Specifies the DDR address/control signals delay. It is recommended to increase this value if command bus training fails                                                                                                                                                                                        |  |
| Address Control Delay Value<br>Incr/Decr | Specifies the adjustment direction Checked: Address Control Delay Value is added to the DDR address/control signals Unchecked: Address Control Delay Value is subtracted from the DDR address/control signals                                                                                                  |  |
| Memory DQ_Vref Value for Rank<0,1>       | Specifies the DRAM DQ_Vref Value to be written to DDR4 DRAM's MR6 Vref DQ Training Value and Vref DQ Training Range for Rank0/Rank1. When the register field TRN_OP_REG.mem_vref_training_en=0, this will be used as the final DRAM DQ Vref. Please refer to DDR4 JEDEC Standard for the allowed values in MR6 |  |
| MC DQS Grp<0,1> Vref Value               | Specifies the MC DQ_Vref Value for each DQS group when DQ_Vref training is disabled by setting TRN_OP_REG.mc_vref_training_en=0.  The theoretical mV value is: Vref decimal value × 5mV                                                                                                                        |  |
| DDR4 MC I/O Settings                     |                                                                                                                                                                                                                                                                                                                |  |
| CK/CS Slew Rate                          | Specifies the CK/CS driver strength                                                                                                                                                                                                                                                                            |  |
| Command Address Slew Rate                | Specifies the CA driver strength                                                                                                                                                                                                                                                                               |  |
| DQS Slew Rate                            | Specifies the DQS driver strength                                                                                                                                                                                                                                                                              |  |
| DQ/DMI Slew Rate                         | Specifies the DQ/DMI driver strength                                                                                                                                                                                                                                                                           |  |
| MC CA Output Impedance                   | Memory controller CA I/O impedance to reach VDDQ threshold                                                                                                                                                                                                                                                     |  |
| MC DQ Output Impedance                   | Memory controller DQ I/O impedance to reach VDDQ threshold                                                                                                                                                                                                                                                     |  |
| MC ODT Value                             | Memory controller termination resistance value at FPGA                                                                                                                                                                                                                                                         |  |
| DDR4 Memory ODT Settings                 |                                                                                                                                                                                                                                                                                                                |  |
| RTT_WR Value                             | Specifies the RTT_WR value that is written to MR2 in DDR4 memory                                                                                                                                                                                                                                               |  |
| RTT_NOM Value                            | Specifies the RTT_NOM value that is written to MR1 in DDR4 memory                                                                                                                                                                                                                                              |  |
| RTT_PARK Value                           | Specifies the RTT_PARK value that is written to MR5 in DDR4 memory                                                                                                                                                                                                                                             |  |

#### Note:

1. These attributes should only be modified when an error is encountered during DDR4 memory training.



## 3.2. LPDDR4

This section describes the parameters available in LPDDR4 mode.

#### **3.2.1.** General

This section describes the parameters available in the General tab of the IP parameter editor.

**Table 3.13. LPDDR4 General Attributes** 

| Attribute                                | Selectable Values                           | Default   | Dependency on Other Attributes                                        |
|------------------------------------------|---------------------------------------------|-----------|-----------------------------------------------------------------------|
| Interface Type                           | LPDDR4                                      | LPDDR4    | Display only                                                          |
| I/O Buffer Type                          | LVSTL11_I, LVSTL11_II                       | LVSTL11_I | _                                                                     |
| DDR Command Frequency (MHz) <sup>1</sup> | 350, 400, 533, 666, 800,<br>933, 1066, 1200 | 800       | _                                                                     |
| Gearing Ratio                            | 8:1                                         | 8:1       | Display only                                                          |
| Enable Power Down <sup>2</sup>           | Checked, Unchecked                          | Unchecked | Display only                                                          |
| Enable Read DBI                          | Checked, Unchecked                          | Unchecked | Fixed to Enabled when <i>DDR Command</i> Frequency is 400 or less     |
| Read Latency                             | Calculated                                  | N/A       | Display only Calculated based off selection for DDR Command Frequency |
| Write Latency                            | Calculated                                  | N/A       | Display only Calculated based off selection for DDR Command Frequency |
| Enable Internal RISC-V CPU               | Checked, Unchecked                          | Checked   | Display only (Disabling of Internal RISC-V CPU is not yet supported)  |
| Enable Reveal Debug                      | Checked, Unchecked                          | Unchecked | _                                                                     |
| Enable Bit Swizzle                       | Checked, Unchecked                          | Unchecked | _                                                                     |

#### Notes:

#### **Table 3.14. LPDDR4 Clock Settings Attributes**

| Attribute                            | Selectable Values | Default | Dependency on Other Attributes                                |
|--------------------------------------|-------------------|---------|---------------------------------------------------------------|
| Enable PLL                           | Checked           | Checked | Display only                                                  |
| Reference Clock: Frequency (MHz)     | 25.0, 50.0, 100.0 | 100.0   | _                                                             |
| DDR Memory Actual Frequency<br>(MHz) | Calculated        | N/A     | Display only Based on the selection for DDR Command Frequency |

## **Table 3.15. LPDDR4 Memory Configuration Attributes**

| Attribute                       | Selectable Values       | Default | Dependency on Other Attributes |
|---------------------------------|-------------------------|---------|--------------------------------|
| DDR Density (per Channel)       | 2 Gb, 4 Gb, 8 Gb, 16 Gb | 4 Gb    | _                              |
| DDR Bus Width (DDR_WIDTH)       | 16, 32, 64              | 32      | _                              |
| Number of Ranks (CS_WIDTH) 1    | 1, 2                    | 1       | _                              |
| Number of DDR Clocks (CK_WIDTH) | 1, 2                    | 1       | _                              |

#### Note:

1. Devices with speed grades of 2 and 3 support Dual Rank.

<sup>1.</sup> Devices with speed grades of 2 and 3 support DDR command frequencies up to 1,066 MHz, while devices with speed grades of 3 support frequencies up to 1,200 MHz.

<sup>2.</sup> The Enable Power Down option is hidden due to the known issue mentioned in Appendix B.



#### **Table 3.16. LPDDR4 Local Data Bus Attributes**

| Attribute                   | Selectable Values      | Default | Dependency on Other Attributes                                 |
|-----------------------------|------------------------|---------|----------------------------------------------------------------|
| Local Data Bus Type         | AXI4                   | AXI4    | _                                                              |
| Address Width               | Calculated             | N/A     | Display only Calculated based on the selection for DDR Density |
| Data Width (AXI_DATA_WIDTH) | 32, 64, 128, 256       | 256     | _                                                              |
| ID Width                    | 1, 2, 3, 4, 5, 6, 7, 8 | 4       | _                                                              |
| Maximum Burst Length        | 64, 128, 256           | 64      | _                                                              |
| Write Ordering Queues       | 1, 2, 3, 4             | 2       | _                                                              |
| Read Ordering Queues        | 1, 2, 3, 4             | 2       | _                                                              |
| Enable Local Bus Clock      | Checked, Unchecked     | Checked | _                                                              |
| Enable APB I/F              | Checked, Unchecked     | Checked | _                                                              |

## **Table 3.17. LPDDR4 General Definitions**

| Attribute                            | Description                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General Group                        |                                                                                                                                                                                                                                                                                                                                              |
| Interface Type                       | Specifies the SDRAM Memory interface: LPDDR4                                                                                                                                                                                                                                                                                                 |
| I/O Buffer Type                      | I/O Standard for the memory interface signals                                                                                                                                                                                                                                                                                                |
| DDR Command Frequency (MHz)          | Speed at which the memory controller will issue commands to the memory device                                                                                                                                                                                                                                                                |
| Gearing Ratio                        | Specifies the ratio relationship between the DDR data speed and the memory controller speed                                                                                                                                                                                                                                                  |
| Enable Power Down                    | Enables memory controller automatically placing the memory device into power-down mode after a specified number of idle controller clock cycles (not yet supported)                                                                                                                                                                          |
| Enable DBI                           | Enables data bus inversion (DBI) for better signal integrity and read/write margins (not yet supported)                                                                                                                                                                                                                                      |
| Read Latency                         | Specifies the delay from issuing a read command to receiving of read data from SDRAM                                                                                                                                                                                                                                                         |
| Write Latency                        | Specifies the delay from issuing a write command to providing of write data to SDRAM                                                                                                                                                                                                                                                         |
| Enable Internal RISC-V CPU           | Enables RISC-V subsystem to support initialization and training of the memory device (disabling is not yet supported)                                                                                                                                                                                                                        |
| Enable Reveal Debug                  | Enables the Reveal debug tool to connect to the MC for improved training debug Please see the Reveal User Guide for Radiant Software for more information.                                                                                                                                                                                   |
| Enable Bit Swizzle                   | Enables Bit Swizzle feature. Once checked, the Bit Swizzle Tab will be shown in the IP GUI. You can enable this if swizzling the DQ bit connection on the board will improve the LPDDR4 signal routing on the board. Please refer to Bit Swizzle section of DDR Memory PHY Module (FPGA-IPUG-02195) for more information about this feature. |
| Clock Settings Group                 |                                                                                                                                                                                                                                                                                                                                              |
| Enable PLL                           | Enables PLL                                                                                                                                                                                                                                                                                                                                  |
| Reference Clock: Frequency (MHz)     | Indicates the PLL reference clock speed                                                                                                                                                                                                                                                                                                      |
| DDR Memory Actual Frequency<br>(MHz) | Specifies the actual operating frequency of the memory interface (calculated by the PLL – includes tolerance)                                                                                                                                                                                                                                |
| Memory Configuration Group           |                                                                                                                                                                                                                                                                                                                                              |
| DDR Density (per Channel)            | Density of SDRAM (number of chips on memory module). Only DDR Density with power of 2 is supported                                                                                                                                                                                                                                           |
| DDR Bus Width                        | Total number of data pins in memory interface                                                                                                                                                                                                                                                                                                |
| Number of Ranks                      | Specifies number of ranks in memory interface                                                                                                                                                                                                                                                                                                |
| Number of DDR Clocks                 | Specifies the number of CK/CK# clock pairs to be driven to SDRAM (multiple clocks is not yet supported)                                                                                                                                                                                                                                      |
| Local Data Bus Group                 |                                                                                                                                                                                                                                                                                                                                              |
| Local Data Bus Type                  | Indicates bus for local data interface: AXI4 or NATIVE                                                                                                                                                                                                                                                                                       |
| Address Width                        | Specifies number of address pins in memory interface, dependent on the SDRAM density                                                                                                                                                                                                                                                         |



| Attribute              | Description                                                                                                                                                                                                                                                                                                             |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Width             | Indicates data width for local data bus                                                                                                                                                                                                                                                                                 |
| ID Width               | Indicates bit width of AXI4 ID                                                                                                                                                                                                                                                                                          |
| Maximum Burst Length   | Specifies the maximum AXI4 burst length. Recommended to set based on system requirements to save EBR resources                                                                                                                                                                                                          |
| Write Ordering Queues  | The number of write/read ordering queues process write and read data requests. The higher the value, the better bandwidth on the interface since gaps between accesses is                                                                                                                                               |
| Read Ordering Queues   | lessened at the cost of consuming more LUTs                                                                                                                                                                                                                                                                             |
| Enable Local Bus Clock | Enables clock domain crossing logic for the local data bus                                                                                                                                                                                                                                                              |
| Enable APB I/F         | Enables APB interface. Should be enabled if the target application includes a CPU. When disabled, initialization and training of SDRAM should be handled via init_start_i and trn_opr_i signals. Please refer to the Initialization and Training without APB Interface section of this User Guide for more information. |

## 3.2.2. Memory Device Timing

This section describes the parameters available in the Memory Device Timing tab of the IP parameter editor. The default value for the attributes listed under Memory Device Timing Setting Group is different for each DDR Command Frequency value and is based on JESD209-4C SDRAM standard. These values may need to be manually adjusted based on the selected LPDDR4 device.

**Table 3.18. LPDDR4 Memory Device Timing Setting Attributes** 

| Attribute                   | Selectable Values | Default    | Dependency on Other Attributes          |
|-----------------------------|-------------------|------------|-----------------------------------------|
| Manual Timing Adjust Enable | Checked/Unchecked | Unchecked  | _                                       |
| TRCD (tCLK)                 | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRAS (tCLK)                 | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRPPB (tCLK)                | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TWR (tCLK)                  | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRTP (tCLK)                 | 8 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TCCD (tCLK)                 | 8 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| MWR2MWR (tCLK)              | 32 – 65,536       | Calculated | Enabled when Manually Adjust is Checked |
| TRRD (tCLK)                 | 6 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRFC (tCLK)                 | 24 – 28,080       | Calculated | Enabled when Manually Adjust is Checked |
| TFAW (tCLK)                 | 40 – 65,536       | Calculated | Enabled when Manually Adjust is Checked |
| TZQCAL (tCLK)               | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TMRR2WR (tCLK)              | 8 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TMRD (tCLK)                 | 10 – 65,536       | Calculated | Enabled when Manually Adjust is Checked |
| TRPAB (tCLK)                | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TRTW (tCLK)                 | 21 – 65,536       | Calculated | Enabled when Manually Adjust is Checked |
| TDQSS (tCLK)                | Integer           | 1          | Enabled when Manually Adjust is Checked |
| TRD2PRE (tCLK)              | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TWR2PRE (tCLK)              | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TXP (tCLK)                  | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |
| TXPSR (tCLK)                | 4 – 65,536        | Calculated | Enabled when Manually Adjust is Checked |

**Table 3.19. LPDDR4 Periodic Event Setting Attributes** 

| Attribute                                            | Selectable Values | Default    | Dependency on Other Attributes                                            |
|------------------------------------------------------|-------------------|------------|---------------------------------------------------------------------------|
| No. of SCLK to enter Self<br>Refresh from no traffic | Integer           | 5,000      | Enabled when Enable Power Down is<br>Checked                              |
| Refresh Period (tSCLK)                               | Calculated        | Calculated | Default value is calculated based off selection for DDR Command Frequency |



| Attribute                            | Selectable Values   | Default | Dependency on Other Attributes |
|--------------------------------------|---------------------|---------|--------------------------------|
| No. of Outstanding Refresh           | 1, 2, 3, 4, 5, 6, 7 | 7       | _                              |
| ZQ Calibration Period (sec)          | Integer             | 32      | _                              |
| ZQ Calibration Start to Latch (usec) | Integer             | 1       | _                              |
| Temperature Check Period (sec)       | Integer             | 32      | _                              |

#### **Table 3.20. LPDDR4 Memory Device Timing Definitions**

| Attribute                                                | Description                                                                                                                                      |  |  |
|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Memory Device Timing Setting Gro                         | up <sup>1</sup>                                                                                                                                  |  |  |
| Manual Timing Adjust Enable                              | Enables you to manually set any of the memory timing parameters                                                                                  |  |  |
| TRCD                                                     | Indicates the delay between the ACTIVATE command (RAS) and the internal access to data (CAS)                                                     |  |  |
| TRAS                                                     | Indicates how long memory must wait after an ACTIVATE command before a PRECHARGE command can be issued to close the row                          |  |  |
| TRPPB                                                    | Row PRECHARGE time for a single bank                                                                                                             |  |  |
| TWR                                                      | Specifies the amount of clock cycles needed to complete a WRITE before a PRECHARGE command can be issued                                         |  |  |
| TRTP                                                     | Internal READ to PRECHARGE delay                                                                                                                 |  |  |
| TCCD                                                     | Minimum time between two READ/WRITE (CAS) commands (burst length / 2)                                                                            |  |  |
| MWR2MWR                                                  | Masked WRITE to masked WRITE time                                                                                                                |  |  |
| TRRD                                                     | Minimum time interval between two ACTIVATE commands to different banks                                                                           |  |  |
| TRFC                                                     | Indicates how long memory must wait after a REFRESH command before an ACTIVATE command can be accepted by memory                                 |  |  |
| TFAW                                                     | Specifies the period duration during which only four banks can be active                                                                         |  |  |
| TZQCAL                                                   | ZQ calibration time from START to LATCH command                                                                                                  |  |  |
| TMRR2WR                                                  | Mode register READ command to Write command time                                                                                                 |  |  |
| TMRD                                                     | Minimum time between two MRS commands                                                                                                            |  |  |
| TRPAB                                                    | Row PRECHARGE time for all banks                                                                                                                 |  |  |
| TRTW                                                     | READ to WRITE command delay                                                                                                                      |  |  |
| TDQSS                                                    | Describes skew between the output data strobe with respect to the memory clock for writes (DQS to CK)                                            |  |  |
| TRD2PRE                                                  | READ to PRECHARGE time                                                                                                                           |  |  |
| TWR2PRE                                                  | WRITE to PRECHARGE time                                                                                                                          |  |  |
| TXP                                                      | Power-down exit latency to next valid command                                                                                                    |  |  |
| TXPSR                                                    | Power-down exit latency to next self-refresh                                                                                                     |  |  |
| Periodic Event Setting Group                             |                                                                                                                                                  |  |  |
| Number of SCLK to enter Self-<br>Refresh from no traffic | The memory controller puts the memory in self-refresh when there is no traffic for the specified number of SCLK cycles                           |  |  |
| Periodic Event Setting Group                             |                                                                                                                                                  |  |  |
| Refresh Period                                           | Specifies the number of SCLK cycles between refresh commands                                                                                     |  |  |
| Number of Outstanding Refresh                            | Specifies the maximum number of outstanding refresh commands. Refer to the Auto Refresh Support section of this User Guide for more information. |  |  |
| ZQ Calibration Period                                    | Indicates period for performing ZQ Calibration in seconds                                                                                        |  |  |
| ZQ Calibration Start to Latch                            | Indicates time from start to latch during ZQ Calibration in microseconds                                                                         |  |  |
| Temperature Check Period                                 | Indicates period for reading the temperature register (MR4) in LPDDR4 memory in seconds                                                          |  |  |

#### Note:

1. The memory device timing parameters listed under the Memory Device Timing tab are defined according to the JESD209-4C SDRAM standard. Refer to the memory device data sheet for detailed descriptions and allowed values for these parameters.



## 3.2.3. Training Settings

This section describes the parameters available in the Training Settings tab of the IP parameter editor.

**Table 3.21. LPDDR4 Training Settings Attributes** 

| Attribute                             | Selectable Values  | Default   | Dependency on Other Attributes        |
|---------------------------------------|--------------------|-----------|---------------------------------------|
| DDR Clock Delay Value                 | 0 – 20             | 0         | _                                     |
| DDR Clock Delay Value Incr/Decr       | Checked, Unchecked | Checked   | _                                     |
| CS Delay Value                        | 0-20               | 0         | _                                     |
| CS Delay Value Incr/Decr              | Checked/Unchecked  | Checked   | _                                     |
| Address Control Delay Value           | 0 – 20             | 0         | _                                     |
| Address Control Delay Value Incr/Decr | Checked, Unchecked | Unchecked | _                                     |
| Memory CA_Vref Value for Rank0        | 0-114              | 25        | _                                     |
| Memory CA_Vref Value for Rank1        | 0-114              | 25        | Enabled when Number of Ranks==2       |
| Memory DQ_Vref Value for Rank0        | 0-114              | 25        | _                                     |
| Memory DQ_Vref Value for Rank1        | 0-114              | 25        | Enabled when Number of Ranks==2       |
| MC DQS Grp<0,1> Vref Value            | 0-127              | 40        | _                                     |
| MC DQS Grp<2,3> Vref Value            | 0-127              | 40        | Enabled when <i>DDR Bus Width</i> ≥32 |
| MC DQS Grp<4,7> Vref Value            | 0-127              | 40        | Enabled when <i>DDR Bus Width</i> ≥64 |

## Table 3.22. LPDDR4 MC I/O Settings Attributes

| Attribute                 | Selectable Values                             | Default | Dependency on Other Attributes |
|---------------------------|-----------------------------------------------|---------|--------------------------------|
| CK/CS Slew Rate           | Slow, Fast                                    | Fast    | _                              |
| Command Address Slew Rate | Slow, Fast                                    | Fast    | _                              |
| DQS Slew Rate             | Slow, Fast                                    | Fast    | _                              |
| DQ/DMI Slew Rate          | Slow, Fast                                    | Fast    | _                              |
| MC CA Output Impedance    | 240 Ω, 120 Ω, 68 Ω, 60 Ω,<br>48 Ω, 40 Ω, 34 Ω | 34 Ω    | _                              |
| MC DQ Output Impedance    | 240 Ω, 120 Ω, 68 Ω, 60 Ω,<br>48 Ω, 40 Ω, 34 Ω | 34 Ω    | _                              |
| MC ODT Value              | 240 Ω, 120 Ω, 68 Ω, 60 Ω,<br>48 Ω, 40 Ω, 34 Ω | 48 Ω    | _                              |

**Table 3.23. LPDDR4 Memory ODT Settings Attributes** 

| Attribute                | Selectable Values                                       | Default   | Dependency on Other Attributes |
|--------------------------|---------------------------------------------------------|-----------|--------------------------------|
| CA_ODT Value             | Disable, RZQ/1, RZQ/2,<br>RZQ/3, RZQ/4, RZQ/5,<br>RZQ/6 | RZQ/2     | _                              |
| DQ_ODT Value             | Disable, RZQ/1, RZQ/2,<br>RZQ/3, RZQ/4, RZQ/5,<br>RZQ/6 | RZQ/4     | _                              |
| SoC_ODT Value            | Disable, RZQ/1, RZQ/2,<br>RZQ/3, RZQ/4, RZQ/5,<br>RZQ/6 | RZQ/6     | _                              |
| CK_ODT Override Enable   | Checked, Unchecked                                      | Unchecked | _                              |
| CS_ODT Override Enable   | Checked, Unchecked                                      | Unchecked | _                              |
| CA_ODT Override Disable  | Checked, Unchecked                                      | Unchecked | _                              |
| ODT-CS/CA/CLK Disable    | Checked, Unchecked                                      | Unchecked | _                              |
| Pull-Down Drive Strength | RZQ/1, RZQ/2, RZQ/3,<br>RZQ/4, RZQ/5, RZQ/6             | RZQ/6     | _                              |



## **Table 3.24. LPDDR4 Training Settings Definitions**

| Attribute <sup>1</sup>             | Description                                                                                                                                                                                                                                                                         |  |  |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| LPDDR4 Training Settings           |                                                                                                                                                                                                                                                                                     |  |  |
| DDR Clock Delay Value              | Specifies the DDR clock delay so that the first DQS toggle is at CK = 0 during write leveling. It is recommended to increase this value if write leveling fails                                                                                                                     |  |  |
| DDR Clock Delay Value Incr/Decr    | Specifies the adjustment direction Checked: DDR Clock Delay Value is added to the ddr_ck_o signal Unchecked: DDR Clock Delay Value is subtracted from the ddr_ck_o signal                                                                                                           |  |  |
| CS Delay Value                     | Specifies the DDR CS delay value                                                                                                                                                                                                                                                    |  |  |
| CS Delay Value Incr/Decr           | Specifies the adjustment direction Checked: CS Delay Value is added to the ddr_cs_o signal Unchecked: CS Delay Value is subtracted from the ddr_cs_o signal                                                                                                                         |  |  |
| Address Control Delay Value        | Specifies the DDR address/control signals delay. It is recommended to increase this value if command bus training fails                                                                                                                                                             |  |  |
| Address Control Delay Incr/Decr    | Specifies the adjustment direction. Checked: Address Control Delay Value is added to the DDR address/control signals Unchecked: Address Control Delay Value is subtracted from the DDR address/control signals                                                                      |  |  |
| Memory CA_Vref Value for Rank<0,1> | Specifies the DRAM CA_Vref Value to be written to LPDDR4 DRAM's MR12 VR-CA and VREF(CA) for Rank0/Rank1. This should be set based on SI/PI simulation for the target board design.  Please refer to LPDDR4 JEDEC Standard for allowed values in MR12.                               |  |  |
| Memory DQ_Vref Value for Rank<0,1> | Specifies the DRAM DQ_Vref Value to be written to LPDDR4 DRAM's MR14 VR(DQ) and VREF(DQ) for Rank0/Rank1. When the register field TRN_OP_REG.mem_vref_training_en=0, this will be used as the final DRAM DQ Vref. Please refer to LPDDR4 JEDEC Standard for allowed values in MR14. |  |  |
| MC DQS Grp<0,1> Vref Value         | Specifies the MC DQ_Vref Value for each DQS group when DQ_Vref training is disabled by setting the register field TRN_OP_REG.mc_vref_training_en=0.                                                                                                                                 |  |  |
|                                    | The theoretical mV value is: Vref decimal value * 5mV.                                                                                                                                                                                                                              |  |  |
| LPDDR4 MC I/O Settings             |                                                                                                                                                                                                                                                                                     |  |  |
| CK/CS Slew Rate                    | Specifies the CK/CS driver strength                                                                                                                                                                                                                                                 |  |  |
| Command Address Slew Rate          | Specifies the CA driver strength                                                                                                                                                                                                                                                    |  |  |
| DQS Slew Rate                      | Specifies the DQS driver strength                                                                                                                                                                                                                                                   |  |  |
| DQ/DMI Slew Rate                   | Specifies the DQ/DMI driver strength                                                                                                                                                                                                                                                |  |  |
| MC CA Output Impedance             | Memory controller CA I/O impedance to reach VDDQ threshold                                                                                                                                                                                                                          |  |  |
| MC DQ Output Impedance             | Memory controller DQ I/O impedance to reach VDDQ threshold                                                                                                                                                                                                                          |  |  |
| MC ODT Value                       | Memory controller termination resistance value at FPGA                                                                                                                                                                                                                              |  |  |
| LPDDR4 Memory ODT Settings         |                                                                                                                                                                                                                                                                                     |  |  |
| CA_ODT Value                       | Memory side CA ODT resistance value                                                                                                                                                                                                                                                 |  |  |
| DQ_ODT Value                       | Memory side DQ ODT resistance value                                                                                                                                                                                                                                                 |  |  |
| SoC_ODT Value                      | Memory controller ODT resistance value correlating to ZQ calibration                                                                                                                                                                                                                |  |  |
| CK_ODT Override Enable             | Overrides the default CK ODT value for the non-terminating rank when option is checked. Refer to MR22 in LPDDR4 device datasheet for more details                                                                                                                                   |  |  |
| CS_ODT Override Enable             | Overrides the default CS ODT value for the non-terminating rank when option is checked. Refer to MR22 in LPDDR4 device datasheet for more details                                                                                                                                   |  |  |
| CA_ODT Override Disable            | Disable termination for CA when option is checked. Refer to MR22 in LPDDR4 device datasheet for more details                                                                                                                                                                        |  |  |
| ODT-CS/CA/CLK Disable              | Disable ODT for CS/CA/CLK when option is checked                                                                                                                                                                                                                                    |  |  |
| Pull-Down Drive Strength           | Memory side pull-down drive strength value                                                                                                                                                                                                                                          |  |  |

#### Note:

1. These attributes should only be modified when an error is encountered during LPDDR4 memory training.



## 3.2.4. Example Design

This section describes the parameters available in the Example Design tab of the IP parameter editor. Use these options when implementing the LPDDR4 Example Design to a Lattice board for Avant-E/G/X70.

Table 3.25. LPDDR4 Example Design Attributes

| Attribute                            | Selectable Values                                                                                                                                                                                               | Default    | Dependency on Other Attributes                                                                                                                                 |
|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Select Development Board             | None, Avant-E_Evaluation_Board, Avant-E_Development_Board, Avant-G/X_Versa_Board                                                                                                                                | None       | If Avant E/G/X70 device                                                                                                                                        |
|                                      | None                                                                                                                                                                                                            |            | If not Avant E/G/X70 device                                                                                                                                    |
| Use internal OSC for Eval PLL        | Checked, Unchecked                                                                                                                                                                                              | Checked    | If Select Development Board == None                                                                                                                            |
| Refclk                               | Checked, Offichecked                                                                                                                                                                                            | Unchecked  | If Select Development Board != None                                                                                                                            |
| Eval PLL Refclk I/O Buffer Type      | LVDS, SUBLVDS, SLVS, HSTL15_I, HSTL15D_I, LVSTL11D_I, LVTTL33, LVCMOS33, LVCMOS25, 'LVCMOS18', 'LVCMOS18H', 'HSTL15D_I', 'LVCMOS15', 'LVCMOS15H', 'LVCMOS12', 'LVCMOS12H', 'LVCMOS10H', 'LVCMOS10', 'LVCMOS10R' | Calculated | Available when <i>Use internal OSC for Eval PLL Refclk</i> is Unchecked The default value is calculated based on the <i>Select Development Board</i> attribute |
| Eval PLL Refclk Frequency (MHz)      | 50, 125                                                                                                                                                                                                         | 50         | If Select Development Board == None                                                                                                                            |
|                                      | 125                                                                                                                                                                                                             | 125        | If Select Development Board != None                                                                                                                            |
| Eval Local Bus Clock Frequency (MHz) | 80, 250                                                                                                                                                                                                         | 250        | Available when <i>Enable Local Bus Clock</i> is Checked                                                                                                        |

Table 3.26. LPDDR4 Example Design Attribute Definitions

| Attribute                               | Description                                                                                                                                                                                                                                                                     |
|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Select Development Board                | Specifies the Lattice board where the LPDDR4 Example design will be implemented. The pin assignments for the target board will be automatically added to the eval/constraint.pdc (see Table 7.2). When implementing the LPDDR4 Example Design to your board, please select None |
| Use internal OSC for Eval PLL<br>Refclk | Specifies the source of the PLL reference clock in the LPDDR4 Example Design. Only 50 MHz and 125 MHz are available now. If your board has either of this, uncheck this option, otherwise, please check this option                                                             |
| Eval PLL Refclk I/O Buffer Type         | Specifies the I/O buffer type of the PLL reference clock for the LPDDR4 Example Design                                                                                                                                                                                          |
| Eval PLL Refclk Frequency (MHz)         | Specifies the frequency of the PLL reference clock for the LPDDR4 Example Design                                                                                                                                                                                                |
| Eval Local Bus Clock Frequency (MHz)    | Specifies the frequency of the local AXI4 bus clock for the LPDDR4 Example Design                                                                                                                                                                                               |

## 3.2.5. Bit Swizzle Settings

This section describes the attributes for swapping the DQ bits within the DQS group. This is only shown when you check the *Enable Bit Swizzle* attribute. You may use this when swapping the DQ bits will help you improve the routing on the board.

Please refer to Bit Swizzle section of DDR Memory PHY Module (FPGA-IPUG-02195) for more information about this feature.



#### **Table 3.27. LPDDR4 Bit Swizzle Attributes**

| Attribute                                                  | Selectable Values            | Default                  | Dependency on Other Attributes                           |
|------------------------------------------------------------|------------------------------|--------------------------|----------------------------------------------------------|
| DQS0 Bit Swizzle                                           |                              |                          |                                                          |
| MC's<br>DQ<00,01,02,03,04,05,06,07><br>connects to DRAM DQ | 0, 1, 2, 3, 4, 5, 6, 7       | 0/1/2/3/<br>4/5/6/7      | If Enable Bit Swizzle is Checked                         |
| DQS0 DQ Bit Swizzle                                        | Calculated                   | 0x76543210               | If Enable Bit Swizzle is Checked                         |
| DQS1 Bit Swizzle                                           |                              |                          |                                                          |
| MC's<br>DQ<08,09,10,11,12,13,14,15><br>connects to DRAM DQ | 8, 9, 10, 11, 12, 13, 14, 15 | 8/9/10/11/<br>12/3/14/15 | If Enable Bit Swizzle is Checked                         |
| DQS1 DQ Bit Swizzle                                        | Calculated                   | 0x76543210               | If Enable Bit Swizzle is Checked                         |
| DQS2 Bit Swizzle                                           |                              |                          |                                                          |
| MC's<br>DQ<16,17,18,19,20,21,22,23><br>connects to DRAM DQ | 0, 1, 2, 3, 4, 5, 6, 7       | 0/1/2/3/<br>4/5/6/7      | If Enable Bit Swizzle is Checked and DDR Bus Width >= 32 |
| DQS2 DQ Bit Swizzle                                        | Calculated                   | 0x76543210               | If Enable Bit Swizzle is Checked and DDR Bus Width >= 32 |
| DQS3 Bit Swizzle                                           |                              |                          |                                                          |
| MC's<br>DQ<24,25,26,27,28,29,30,31><br>connects to DRAM DQ | 8, 9, 10, 11, 12, 13, 14, 15 | 8/9/10/11/<br>12/3/14/15 | If Enable Bit Swizzle is Checked and DDR Bus Width >= 32 |
| DQS3 DQ Bit Swizzle                                        | Calculated                   | 0x76543210               | If Enable Bit Swizzle is Checked and DDR Bus Width >= 32 |
| DQS4 Bit Swizzle                                           |                              |                          |                                                          |
| MC's<br>DQ<32,33,34,35,36,37,38,39><br>connects to DRAM DQ | 0, 1, 2, 3, 4, 5, 6, 7       | 0/1/2/3/<br>4/5/6/7      | If Enable Bit Swizzle is Checked and DDR Bus Width == 64 |
| DQS4 DQ Bit Swizzle                                        | Calculated                   | 0x76543210               | If Enable Bit Swizzle is Checked and DDR Bus Width == 64 |
| DQS5 Bit Swizzle                                           |                              |                          |                                                          |
| MC's<br>DQ<40,41,42,43,44,45,46,47><br>connects to DRAM DQ | 8, 9, 10, 11, 12, 13, 14, 15 | 8/9/10/11/<br>12/3/14/15 | If Enable Bit Swizzle is Checked and DDR Bus Width == 64 |
| DQS5 DQ Bit Swizzle                                        | Calculated                   | 0x76543210               | If Enable Bit Swizzle is Checked and DDR Bus Width == 64 |
| DQS6 Bit Swizzle                                           |                              |                          |                                                          |
| MC's<br>DQ<48,49,50,51,52,53,54,55><br>connects to DRAM DQ | 0, 1, 2, 3, 4, 5, 6, 7       | 0/1/2/3/<br>4/5/6/7      | If Enable Bit Swizzle is Checked and DDR Bus Width == 64 |
| DQS6 DQ Bit Swizzle                                        | Calculated                   | 0x76543210               | If Enable Bit Swizzle is Checked and DDR Bus Width == 64 |
| DQS7 Bit Swizzle                                           |                              |                          |                                                          |
| MC's<br>DQ<56,57,58,59,60,61,62,63><br>connects to DRAM DQ | 8, 9, 10, 11, 12, 13, 14, 15 | 8/9/10/11/<br>12/3/14/15 | If Enable Bit Swizzle is Checked and DDR Bus Width == 64 |
| DQS7 DQ Bit Swizzle                                        | Calculated                   | 0x76543210               | If Enable Bit Swizzle is Checked and DDR Bus Width == 64 |



### **Table 3.28. LPDDR4 Bit Swizzle Attribute Definitions**

| Attribute                               | Description                                                                                                                                                                                          |  |  |  |  |
|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| DQS<0,2,4,6> Bit Swizzle <sup>1,2</sup> | DQS<0,2,4,6> Bit Swizzle <sup>1,2</sup>                                                                                                                                                              |  |  |  |  |
| MC's DQ* connects to DRAM DQ            | Specifies how the DQ bits of the DQS groups 0, 2, 4, and 6 will be connected to the lower byte of the LPDDR4 DRAM channel on the board. You can swap around the bits within the DQS group (DQ byte). |  |  |  |  |
| DQS<0,2,4,6> DQ Bit Swizzle             | This is the actual parameter used in MC's RTL. This is calculated based on the DQ connection settings.                                                                                               |  |  |  |  |
| DQS<1,3,5,7> Bit Swizzle <sup>1,2</sup> |                                                                                                                                                                                                      |  |  |  |  |
| MC's DQ* connects to DRAM DQ            | Specifies how the DQ bits of the DQS groups 0, 2, 4, and 6 will be connected to the upper byte of the LPDDR4 DRAM channel on the board. You can swap around the bits within the DQS group (DQ byte). |  |  |  |  |
| DQS<0,2,4,6> DQ Bit Swizzle             | This is the actual parameter used in MC's RTL. This is calculated based on the DQ connection settings.                                                                                               |  |  |  |  |

#### Notes:

- These DQS group pairs should be connected to the same DRAM channel: (DQS0, DQS1), (DQS2, DQS3), (DQS4, DQS5), and (DQS6, DQS7)
- 2. Swapping the DQS group with another DQS group is not yet supported.

The DDRPHY Hard IP's connection to the I/O is a dedicated path. The Bit Swizzle feature will not affect the pin mapping in Radiant. This means the following:

- The Radiant Report Browser > Place & Route Reports -> Signal/Pad report will still show the dedicated pin locations.
- If you want to add the pin assignment constraint (Idc\_set\_location) in the Radiant project Post-Synthesis
   Constraint Files, you should still use the dedicated pin locations.

For consistency, we recommend that your schematic show the swizzled connection for easy cross-checking with the *Bit Swizzle* settings in the IP GUI.



# 4. Signal Description

The input and output signals of the DDR Memory Controller IP are covered in this section. The signals available are based on the selected configuration of the Memory Controller IP.

# 4.1. Clock and Reset

**Table 4.1. Clock and Reset Port Definitions** 

| Port Name    | I/O | Width                                                                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|-----|--------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pll_refclk_i | In  | 1                                                                                                      | PLL reference clock input. It is recommended to use 100 MHz for better clock performance. Please refer to Design Rules and Guidelines section of Avant High Speed IO and External Memory Interface User-Guide (FPGA-TN-02300) for more information.                                                                                                                                                                                                                                                                                                                                |
| pll_rst_n_i  | In  | 1                                                                                                      | PLL reset active low. The minimum reset pulse width is 5 µs. This will cause pll_lock_o to de-assert and sclk_o to stop. If you assert this signal, you should assert the main reset, rst_n_i as well. You can assert the rst_n_i at the same time as pll_rst_n_i or after pll_rst_n_i deasserts.                                                                                                                                                                                                                                                                                  |
| pclk_i       | In  | 1                                                                                                      | Clock for APB interface, training CPU and control logic of the internal PLL. This clock is independent of sclk_o, since sclk_o stops during clock frequency changes.  Supports 50 MHz to 150MHz in simulation, but the upper limit for implementation may be less than 150 MHz, depending on the Radiant timing analysis report.                                                                                                                                                                                                                                                   |
| preset_n_i   | In  | Asynchronous active low reset for APB interface. This reset must be de asserted synchronous to pclk_i. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| aclk_i       | In  | 1                                                                                                      | Clock for AXI4 interface. The fmax is limited by the Radiant timing analysis report.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| sclk_o       | Out | 1                                                                                                      | System clock. This is ¼ of the DDR clock frequency and is the main clock of the Memory Controller IP.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| rst_n_i      | In  | 1                                                                                                      | Asynchronous active low reset. When asserted, output ports, including the AXI4 Data Interface and the APB Configuration Interface and registers are forced to their reset values. The Memory Controller IP implements logic to de-assert the internal reset synchronous to the internal clocks (sclk_o, pclk_i and aclk_i) after rst_n_i de-asserts. After rst_n_i deassertion, wait for a minimum of 5 pclk_i before accessing the registers.  If you assert this reset signal, you need to perform the full initialization and training as described in the Calibration section. |
| areset_n_i   | In  | 1                                                                                                      | Asynchronous active low reset for AXI4 I/F.  This reset must be de-asserted synchronous to aclk_i.  This is only available when <i>Enable Local Bus Clock</i> attribute is checked.                                                                                                                                                                                                                                                                                                                                                                                                |



# 4.2. Interrupts and Initialization/Training

This section describes the interface ports for interrupts and initialization/training control in the Memory Controller IP.

Table 4.2. Interrupts and Initialization/Training Port Definitions

| Port Name    | 1/0 | Width | Description                                                                                                                                                              |
|--------------|-----|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| irq_o        | Out | 1     | Interrupt signal Reset value is 1'b0                                                                                                                                     |
| init_start_i | In  | 1     | Starts the memory initialization and training according to trn_opr_i.  This signal is available when <i>Enable APB I/F</i> attribute is unchecked.                       |
| init_done_o  | Out | 1     | Indicates completion of initialization and training and the memory is available for access through the data interface.                                                   |
| pll_lock_o   | Out | 1     | PLL lock output indicating when PLL is locked.  Do not access the Memory Controller IP in any bus I/F or init_start_i when the PLL is not locked.                        |
| trn_opr_i    | in  | 10    | Sets the Training Operation Register (TRN_OP_REG), which specifies the training steps to perform. Refer to the DDR Memory PHY Module (FPGA-IPUG-02195) for more details. |
| trn_err_o    | Out | 1     | Indicates memory training has failed when asserted (1'b1)                                                                                                                |

# 4.3. APB Register Interface

This section describes the configuration interface port when the *Enable APB I/F* attribute is checked in the Memory Controller IP. Refer to the AMBA APB Protocol Specification for a description of these signals.

**Table 4.3. APB Interface Port Definitions** 

| Port Name     | 1/0 | Width | Description                                                                                                                  |
|---------------|-----|-------|------------------------------------------------------------------------------------------------------------------------------|
| apb_psel_i    | In  | 1     | APB Select signal Indicates that the subordinate device is selected, and a data transfer is required                         |
| apb_paddr_i   | In  | 12    | APB Address signal                                                                                                           |
| apb_pwdata_i  | In  | 32    | APB Write data signal Bits [31:8] are not used                                                                               |
| apb_pwrite_i  | In  | 1     | APB Direction signal 1 = Write, 0 = Read                                                                                     |
| apb_penable_i | In  | 1     | APB Enable signal Indicates the second and subsequent cycles of an APB transfer                                              |
| apb_pready_o  | Out | 1     | APB Ready signal Indicates transfer completion. Subordinates use this signal to extend an APB transfer. Reset value is 1'b0. |
| apb_pslverr_o | Out | 1     | APB Error signal Indicates a transfer failure. This signal is tied to 1'b0.                                                  |
| apb_prdata_o  | Out | 32    | APB Read data signal                                                                                                         |



## 4.4. AXI4 Data Interface

This section describes the AXI4 data interface ports in the Memory Controller IP. Refer to the AMBA AXI Protocol Specification for a description of these signals. The transactions allowed on the AXI4 interface to the Memory Controller are described in Table 2.2.

**Table 4.4. AXI4 Interface Port Definitions** 

| Port Name                   | 1/0 | Width            | Description                                                                          |
|-----------------------------|-----|------------------|--------------------------------------------------------------------------------------|
| axi_arid_i                  | In  | AXI_ID_WIDTH     | AXI4 read address channel: Read address ID signal                                    |
| axi_araddr_i <sup>1,2</sup> | In  | AXI_ADDR_WIDTH   | AXI4 read address channel: Read address signal                                       |
|                             |     |                  | AXI4 read address channel: Burst length signal                                       |
| axi_arlen_i                 | In  | 8                | Supports up to burst length 64 only, it is prohibited to issue more than this        |
| axi_arsize_i                | In  | 3                | AXI4 read address channel: Burst size signal                                         |
| axi_arburst_i               | In  | 2                | AXI4 read address channel: Burst type signal Only INCR is supported                  |
| axi_arqos_i                 | In  | 4                | AXI4 read address channel: Quality of service signal This signal is currently unused |
| axi arvalid i               | In  | 1                | AXI4 read address channel: Read address valid signal                                 |
| axi_arready_o               | Out | 1                | AXI4 read address channel: Read address ready signal                                 |
| axi rid o                   | Out | AXI_ID_WIDTH     | AXI4 read data channel: Read ID tag signal                                           |
| axi_rdata_o <sup>1</sup>    | Out | AXI_DATA_WIDTH   | AXI4 read data channel: Read data signal                                             |
| axi_rresp_o                 | Out | 2                | AXI4 read data channel: Read response signal                                         |
| axi rlast o                 | Out | 1                | AXI4 read data channel: Read last signal                                             |
| axi rvalid o                | Out | 1                | AXI4 read data channel: Read valid signal                                            |
| axi_rready_i                | In  | 1                | AXI4 read data channel: Read ready signal                                            |
| axi_awid_i                  | In  | AXI_ID_WIDTH     | AXI4 write address channel: Write address ID signal                                  |
| axi_awaddr_i <sup>1,2</sup> | In  | AXI_ADDR_WIDTH   | AXI4 write address channel: Write address signal                                     |
| axi_awlen_i                 | In  | 8                | AXI4 write address channel: Burst length signal                                      |
| axi_awsize_i                | In  | 3                | AXI4 write address channel: Burst size signal                                        |
| axi_awburst_i               | In  | 2                | AXI4 write address channel: Burst type signal                                        |
| axi_awqos_i                 | In  | 4                | AXI4 write address channel: Quality of service signal                                |
| axi_awvalid_i               | In  | 1                | AXI4 write address channel: Write address valid signal                               |
| axi_awready_o               | Out | 1                | AXI4 write address channel: Write address ready signal                               |
| axi_wdata_i¹                | In  | AXI_DATA_WIDTH   | AXI4 write data channel: Write data signal                                           |
| axi_wstrb_i <sup>1</sup>    | In  | AXI_DATA_WIDTH/8 | AXI4 write data channel: Write strobe signal                                         |
| axi_wlast_i                 | In  | 1                | AXI4 write data channel: Write last signal                                           |
| axi_wvalid_i                | In  | 1                | AXI4 write data channel: Write valid signal                                          |
| axi_wready_o                | Out | 1                | AXI4 write data channel: Write ready signal                                          |
| axi_bid_o                   | Out | AXI_ID_WIDTH     | AXI4 write response channel: Response ID tag signal                                  |
| axi_bresp_o                 | Out | 2                | AXI4 write response channel: Write response signal                                   |
| axi_bvalid_o                | Out | 1                | AXI4 write response channel: Write response valid signal                             |
| axi_bready_i                | In  | 1                | AXI4 write response channel: Response ready signal                                   |

#### Notes:

- 1. The bit width of axi\_araddr\_i/axi\_rdata\_o/axi\_awaddr\_i/axi\_wdata\_i/axi\_wstrb\_i are calculated based on the DDR density and DDR Bus Width attributes in Table 3.3.
- 2. Refer to the DDR Memory PHY Module (FPGA-IPUG-02195) for the address mapping.



## 4.4.1. AXI4 Address Mapping for DDR4 mode

In DDR4 mode, the Bank Group is mapped within the burst address mapping so that sequential writes and sequential reads can be executed in the DDR side without gap. This causes the column address bits to split into two, namely, Column High and Column Low.

Table 4.5. AXI4 Address Mapping for DDR4 mode

| Memory Address | Size                                                                                                        | Local Address Map                                   |                       |
|----------------|-------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----------------------|
| Rank           | If Number of Ranks == 2: RANKW = 1 If Number of Ranks == 1: Not available                                   | Local address mapping within each                   | rank remains the same |
| Row            | ROWW = refer to memory device data sheet                                                                    | ROW_H = ROW_L + ROWW - 1<br>ROW_L = BANK_H + 1      | Addr[ROW_H: ROW_L]    |
| Bank           | BANKW = 2                                                                                                   | BANK_H = BANK_L + BANKW - 1<br>BANK_L = COL_H_H + 1 | Addr[BANK_H: BANK_L]  |
| Column High    | COLHW = 7                                                                                                   | COLH_H = COLH_L + COLHW - 1<br>COLH_L = BG_H + 1    | Addr[COLH_H: COLH_L]] |
| Bank Group     | BGW = 2                                                                                                     | BG_H = BG_L + BG_L - 1<br>BG_L = COLL_H + 1         | Addr[BG_H: BG_L]      |
| Column Low     | COLLW = 3                                                                                                   | COLL_H = COLL_L + COLLW - 1<br>COLL_L = OFFSET_W    | Addr[COLL_H: COLL_L]  |
| Offset         | If DDR Bus Width == 64: OFFSETW = 3 If DDR Bus Width == 32: OFFSETW = 2 If DDR Bus Width == 16: OFFSETW = 1 | N/A                                                 |                       |

Table 4.6. AXI4 Address Mapping Example for DDR4 mode

| Memory Address                | Example User Value  | Actual Line Size | Local Address Map |
|-------------------------------|---------------------|------------------|-------------------|
| Offset                        | DDR Bus Width = 32  | 2                | *addr_i[1:0]      |
| Column Low Width (COLLW)      | 3 (Fixed for DDR4)  | 3                | *addr_i[4:2]      |
| Bank Group Width (BGW)        | 2 (Fixed for DDR4)  | 2                | *addr_i[6:5]      |
| Column High Width (COLHW)     | 7 (Fixed for DDR4)  | 7                | *addr_i[13:7]     |
| Bank Width (BANKW)            | 2 (Fixed for DDR4)  | 2                | *addr_i[15:14]    |
| Row Width (ROWW)              | DDR Density = 4     | 15               | *addr_i[30:16]    |
| Rank Width (RANKW)            | Number of Ranks = 1 | 0                |                   |
| Total Local Address Line Size |                     | 31               | *addr_i[30:0]     |

## 4.4.2. AXI4 Address Mapping for LPDDR4 mode

Table 4.7. AXI4 Address Mapping for LPDDR4 mode

| Memory Address | Size                                                                                                        | Local Address Map                                 |                       |
|----------------|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------|-----------------------|
| Rank           | If Number of Ranks == 2: RANKW = 1 If Number of Ranks == 1: RANKW = 0                                       | Local address mapping within each                 | rank remains the same |
| Row            | ROWW = refer to memory device data sheet                                                                    | ROW_H = ROW_L + ROWW - 1<br>ROW_L = BANK_H + 1    | Addr[ROW_H: ROW_L]    |
| Bank           | BANKW = 3                                                                                                   | BANK_H = BANK_L + BANKW - 1<br>BANK_L = COL_H + 1 | Addr[BANK_H: BANK_L]  |
| Column         | COLW = 10                                                                                                   | COL_H = COL_L + COLW - 1<br>COL_L = OFFSET_W      | Addr[COL_H: COL_L]]   |
| Offset         | If DDR Bus Width == 64: OFFSETW = 3 If DDR Bus Width == 32: OFFSETW = 2 If DDR Bus Width == 16: OFFSETW = 1 | N/A                                               |                       |



Table 4.8. AXI4 Address Mapping Example for LPDDR4 mode

| Memory Address                | Example User Value    | Actual Line Size | Local Address Map |
|-------------------------------|-----------------------|------------------|-------------------|
| Offset                        | DDR Bus Width = 32    | 2                | *addr_i[1:0]      |
| Column Width (COLW)           | 10 (Fixed for LPDDR4) | 10               | *addr_i[11:2]     |
| Bank Width (BANKW)            | 3 (Fixed for LPDDR4)  | 3                | *addr_i[14:12]    |
| Row Width (ROWW)              | DDR Density = 4       | 15               | *addr_i[29:15]    |
| Rank Width (RANKW)            | Number of Ranks = 1   | 0                |                   |
| Total Local Address Line Size |                       | 30               | *addr_i[29:0]     |

# 4.5. Memory Interface Signals

## 4.5.1. DDR4 Memory Interface

This section describes the interface ports for DDR4 SDRAM.

**Table 4.9. DDR4 Interface Port Definitions** 

| Port Name                  | I/O    | Width      | Description         |
|----------------------------|--------|------------|---------------------|
| ddr_ck_o <sup>1,2</sup>    | Out    | CK_WIDTH   | DDR4 CK signal      |
| ddr_cke_o <sup>1,2</sup>   | Out    | CK_WIDTH   | DDR4 CKE signal     |
| ddr_cs_o <sup>1,2</sup>    | Out    | CS_WIDTH   | DDR4 CS signal      |
| ddr_ca_o²                  | Out    | CA_WIDTH   | DDR4 CA signal      |
| ddr_we_n_o <sup>2</sup>    | Out    | 1          | DDR4 WE signal      |
| ddr_cas_n_o <sup>2</sup>   | Out    | 1          | DDR4 CAS signal     |
| ddr_ras_n_o <sup>2</sup>   | Out    | 1          | DDR4 RAS signal     |
| ddr_act_n_o <sup>2</sup>   | Out    | 1          | DDR4 ACT_n signal   |
| ddr_ba_o²                  | Out    | BANK_WIDTH | DDR4 BA signal      |
| ddr_bg_o <sup>2</sup>      | Out    | BG_WIDTH   | DDR4 BG signal      |
| ddr_odt_o²                 | Out    | ODT_WIDTH  | DDR4 ODT signal     |
| ddr_reset_n_o <sup>2</sup> | Out    | 1          | Memory reset signal |
| ddr_dq_io1                 | In/Out | BUS_WIDTH  | DDR4 DQ signal      |
| ddr_dqs_io <sup>1</sup>    | In/Out | DQS_WIDTH  | DDR4 DQS signal     |
| ddr_dmi_io1                | In/Out | DQS_WIDTH  | DDR4 DMI signal     |

#### Notes:

- 1. The bit width of SDRAM Memory Interface signals is defined based on the attributes listed in Table 3.3.
- 2. For component, the command, address and control signals should be terminated to VTT on the board. This is not needed for UDIMM because it already has the termination within UDIMM.

## 4.5.2. LPDDR4 Memory Interface

This section describes the interface ports for LPDDR4 SDRAM.

**Table 4.10. LPDDR4 Interface Port Definitions** 

| Port Name               | I/O    | Width     | Description         |
|-------------------------|--------|-----------|---------------------|
| ddr_ck_o <sup>1</sup>   | Out    | CK_WIDTH  | LPDDR4 CK signal    |
| ddr_cke_o <sup>1</sup>  | Out    | CK_WIDTH  | LPDDR4 CKE signal   |
| ddr_cs_o <sup>1</sup>   | Out    | CS_WIDTH  | LPDDR4 CS signal    |
| ddr_ca_o                | Out    | 6         | LPDDR4 CA signal    |
| ddr_reset_n_o           | Out    | 1         | Memory reset signal |
| ddr_dq_io <sup>1</sup>  | In/Out | BUS_WIDTH | LPDDR4 DQ signal    |
| ddr_dqs_io <sup>1</sup> | In/Out | DQS_WIDTH | LPDDR4 DQS signal   |
| ddr_dmi_io <sup>1</sup> | In/Out | DQS_WIDTH | LPDDR4 DMI signal   |

#### Note:

1. The bit width of the SDRAM Memory Interface signal is defined based on the attributes listed in Table 3.12.



# 5. Register Description

The Memory Controller IP contains user-accessible registers. For a description of these registers, refer to the DDR Memory PHY Module (FPGA-IPUG-02195).



# 6. Memory Controller Example Design

This section describes the Memory Controller Example Design, which you can use for synthesis and simulation after generating the IP.

## 6.1. Overview

Table 6.1 summarizes the IP parameter configurations in the Memory Controller Example Design. To generate the Memory Controller IP Core, refer to the Designing and Simulating the IP section of this user guide.

**Table 6.1. Supported Example Design Configurations** 

| Attribute                             | Supported Setting  |
|---------------------------------------|--------------------|
| I/O Buffer Type                       | All                |
| DDR Command Frequency                 | All                |
| Enable Power Down                     | Checked, Unchecked |
| Enable DBI                            | Checked, Unchecked |
| PLL Reference Clock from Pin          | Checked, Unchecked |
| DDR Bus Width                         | 16, 32, 64         |
| Local Data Bus Type                   | AXI4               |
| ID Width                              | All                |
| Number of Outstanding Writes/Reads    | All                |
| Write/Read Ordering Queues            | All                |
| Enable Local Bus Clock                | Checked, Unchecked |
| Enable APB I/F                        | Checked, Unchecked |
| Memory Device Timing Tab <sup>1</sup> | All                |
| Training Settings Tab <sup>1</sup>    | All                |

#### Note:

# 6.2. Synthesis Example Design

After generating the DDR Memory Controller IP, you can access a synthesizable example design. This design includes a test program for evaluating the Memory Controller IP on hardware. Figure 6.1 represents a block diagram of the Memory Controller Example Design.



Figure 6.1. Synthesis Example Design

<sup>1.</sup> The DDR Clock Delay Value and Address Control Delay Value are not supported/reflected in Memory Controller Simulation Example Design. All other configurable attributes are supported in the Memory Controller Example Design.



The main blocks that make up the synthesizable example design include the following:

- RISC-V CPU subsystem handles initialization and training of the DDR4/LPDDR4 interface and performs data access checks.
- System Memory (SYS\_MEM) stores the instruction code for the example design test program.
- AHBL2APB bridge converts the CPU data interface (AHB-Lite) to the configuration interface (APB).
- **UART block** allows you to interface with the test program and prints out results via a serial terminal connection.
- GPIO block allows you to verify the result of the DDR4/LPDDR4 training sequences and the functionality of pclk\_i
  and aclk\_i clock signals.
- **Traffic generator block** implements a series of pseudo-random (PRBS) writes and reads, and compares the read data to the expected data, displaying the result over a UART connection.
- Memory Controller IP provides an interface to external DDR4/LPDDR4 memory to issue reads and writes.
- Oscillator (OSC) generates a 50 MHz clock for the PLL.
- PLL takes the oscillator output as an input reference clock to the PLL. The PLL generates both the configuration interface clock (pclk i = 100 MHz) and the user data interface AXI clock (aclk i = 250 MHz).

The synthesizable example design includes a test program stored in system memory, fetched by the CPU instruction port. The CPU data port accesses system memory and connects to Configuration Set Registers (CSRs), UART, GPIO, traffic generator, and Memory Controller. The test program associated with the example design performs the following tasks:

- Waits for user input over a serial terminal connection upon asserting the reset signal: rstn i
- Configures the Memory Controller to perform a complete reset, initialization, and training of the DDR4/LPDDR4 interface.
  - If data rate ≤ 1,333 Mbps : TRN OP REG = 0x0DF during training
  - If data rate in [1,600 Mbps, 1866Mbps]: TRN\_OP\_REG = 0x1DF during training
  - If data rate > 2,133 Mbps: TRN\_OP\_REG = 0x3DF during training
- Performs a series of loop-back data access checks
- Calculates the performance of the DDR4/LPDDR4 interface

The top-level example design wrapper file, eval\_top.sv, provides ports for a PLL reference clock, DDR4/LPDDR4 interface, UART interface, and a 10-bit LED output. LED[7:0] corresponds to bits STATUS\_REG[8:1], whereas toggling on LED[8] indicates aclk\_i is functioning and toggling on LED[9] indicates pclk\_i is functioning. For information on the example design test program and instructions on generating and performing hardware evaluation of the Memory Controller Example Design, refer to the Designing and Simulating the IP section of this user guide.

# 6.3. Simulation Example Design

The simulation example design is similar to the synthesizable example design, apart from the following changes:

- Disables UART connection
- External DDR4/LPDDR4 memory is replaced with DDR4/LPDDR4 memory model

The UART connection is disabled in simulation since it takes a long time to simulate. The DDR4/LPDDR4 memory model allows simulation of user-initiated operations to DDR4/LPDDR4 SDRAM. For instructions on simulating the Memory Controller, including the example design, refer to the Designing and Simulating the IP section of this user guide.



#### 6.3.1. DDR4

Table 6.2 summarizes the simulation runtime of the DDR4 Memory Controller for various configurations.

**Table 6.2. DDR4 Simulation Runtime Summary** 

| DDR4 Configuration           | Typical Initialization Time | Typical Training Time |
|------------------------------|-----------------------------|-----------------------|
| x32, 1,066 MHz (single rank) | 46.014 μs                   | 30.753 μs             |
| x16, 933 MHz (single rank)   | 48.289 μs                   | 30.853 μs             |
| x32, 933 MHz (single rank)   | 48.169 μs                   | 30.853 μs             |
| x64, 933 MHz (single rank)   | 47.899 μs                   | 30.853 μs             |
| x16, 800 MHz (single rank)   | 50.807 μs                   | 35.475 μs             |
| x32, 666 MHz (single rank)   | 55.387 μs                   | 37.278 μs             |
| x64, 666 MHz (single rank)   | 55.087 μs                   | 37.278 μs             |
| x16, 1,066 MHz (dual rank)   | 46.134 μs                   | 60.735 μs             |

Initialization time is measured from the moment the CPU and Controller Engine are pulled out of reset (RESET\_REG) to the assertion of the DDR4 Clock Enable signal (ddr\_cke\_o). Training time is measured from the ddr\_cke\_o assertion to the assertion of init\_done\_o, indicating the completion of the initialization and training sequence. For more details on the initialization and training sequences, refer to the Calibration section of this user guide.

#### 6.3.2. LPDDR4

Table 6.3 summarizes the simulation runtime of the LPDDR4 Memory Controller for various configurations.

**Table 6.3. LPDDR4 Simulation Runtime Summary** 

| LPDDR4 Configuration         | Typical Initialization Time | Typical Training Time |
|------------------------------|-----------------------------|-----------------------|
| x32, 1,066 MHz (single rank) | 53.019 μs                   | 102.459 μs            |
| x16, 933 MHz (single rank)   | 54.281 μs                   | 106.248 μs            |
| x32, 933 MHz (single rank)   | 54.311 μs                   | 106.998 μs            |
| x64, 933 MHz (single rank)   | 54.191 μs                   | 108.468 μs            |
| x16, 800 MHz (single rank)   | 54.981 μs                   | 109.709 μs            |
| x32, 666 MHz (single rank)   | 58.288 μs                   | 114.854 μs            |
| x64, 533 MHz (single rank)   | 63.128 μs                   | 128.906 μs            |
| x16, 1,066 MHz (dual rank)   | 52.989 μs                   | 162.369 μs            |

Initialization time is measured from the moment the CPU and Controller Engine are pulled out of reset (RESET\_REG) to the assertion of the LPDDR4 Clock Enable signal (ddr\_cke\_o). Training time is measured from the ddr\_cke\_o assertion to the assertion of init\_done\_o, indicating the completion of the initialization and training sequence. For more details on the initialization and training sequences, refer to the Calibration section of this user guide.



# 7. Designing and Simulating the IP

This section describes the steps required within Lattice Radiant software to configure and generate the DDR Memory Controller IP. It also provides information on the design implementation and hardware evaluation of the synthesizable example design. The screenshots provided are for reference only. The details may vary depending on the version of the IP or software being used.

# 7.1. Generating the IP

This section describes the steps required to create, configure, and generate an instance of the DDR Memory Controller IP.

# 7.1.1. Creating a Radiant Project

In order to generate an instance of the Memory Controller IP, a Lattice Radiant project must first be created.

 Launch the Lattice Radiant software and select File > New > Project. This action opens the New Project dialog box. Click Next.



Figure 7.1. Creating a New Radiant Project

2. Specify a name (<project\_name>) for the Lattice Radiant project, a directory (<project\_directory>) to store the project files, and a top-level design implementation name (<top level instance name>). Click **Next** twice.





Figure 7.2. New Project Settings

3. Under Family, select Avant. Under Device, Package, Operating Condition, and Performance Grade, make the appropriate selections representative of the selected device part number. Click Next.



Figure 7.3. Project Device Settings



4. Specify the desired synthesis tool for the implementation of the Lattice Radiant project. Click Next and Finish.



Figure 7.4. Project Synthesis Tool Selection

## 7.1.2. Configuring and Generating the IP

The following steps illustrate how to generate the Memory Controller IP Core in Lattice Radiant software.

- 1. Under the IP Catalog (Tools > IP Catalog), locate and double-click on the desired Memory Controller IP listed under IP > Processors\_Controllers\_and\_Peripherals.
  - a. If no Memory Controller IPs are installed on the system, select the IP on Server tab within the IP Catalog.
  - b. Click the **Download from Lattice IP Server** icon next to the desired Memory Controller IP for installation. This will open an **IP License Agreement** dialog box.
  - c. Click **Accept**, then click on the **Refresh IP Catalog** icon.
  - d. Locate the installed Memory Controller IP under the IP on Local tab within the IP Catalog and double-click.
    - IP Core v2.x.x = Memory Controller (DDR4/LPDDR4 mode)





Figure 7.5. IP Instance Settings

3. The Memory Controller IP editor contains multiple tabs that need to be configured according to the desired DDR4/LPDDR4 memory interface implementation. The following table provides high-level guidance for configuring the tabs in the Memory Controller IP editor. For detailed information on the individual attributes, refer to the IP Parameter Description section of this user guide.

**Table 7.1. Memory Controller Attribute Guidelines** 

| Memory Controller IP Attribute Tab                                                                                                                                                                                                                                                                                                                                                  | Guidelines                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| DDR4                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| General                                                                                                                                                                                                                                                                                                                                                                             | <ul> <li>Ensure that the Memory clock frequency (DDR Command Frequency) is entered correctly.</li> <li>Refer to the datasheet for the selected DDR4 memory device to ensure the channel density (DDR Density per Channel) is set correctly.</li> </ul>                                                                                                                                      |  |  |
| Memory Device Timing                                                                                                                                                                                                                                                                                                                                                                | Refer to the datasheet for the selected DDR4 memory device to modify the default timing parameters as needed.                                                                                                                                                                                                                                                                               |  |  |
| Training Settings                                                                                                                                                                                                                                                                                                                                                                   | <ul> <li>You should perform signal integrity analysis with the system IBIS model, using a tool such as HyperLynx, to determine the optimal I/O and ODT settings for custom boards.</li> <li>Modify the DDR Clock Delay value only if an error occurs during write leveling.</li> <li>Modify the Address Control Delay value only if an error occurs during command bus training.</li> </ul> |  |  |
| LPDDR4                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| General                                                                                                                                                                                                                                                                                                                                                                             | <ul> <li>Ensure that the Memory clock frequency (DDR Command Frequency) is entered correctly.</li> <li>Refer to the datasheet for the selected LPDDR4 memory device to ensure the channel density (DDR Density per Channel) is set correctly.</li> </ul>                                                                                                                                    |  |  |
| Memory Device Timing                                                                                                                                                                                                                                                                                                                                                                | Refer to the datasheet for the selected LPDDR4 memory device to modify the default timing parameters as needed.                                                                                                                                                                                                                                                                             |  |  |
| <ul> <li>You should perform signal integrity analysis with system IBIS model, using such as HyperLynx, to determine the optimal I/O and ODT settings for compared to boards.</li> <li>Modify the DDR Clock Delay value only if an error occurs during write less to Modify the Address Control Delay value only if an error has occurred during to command bus training.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                             |  |  |



4. Click **Generate**. The Check Generating Result dialog box opens, showing design block messages and results as shown in Figure 7.6. Click **Finish**.



Figure 7.6. IP Generation Result

5. All the generated files are placed under the <instance\_directory>/<instance\_name> directory path. The generated files in the <instance\_directory>/<instance\_name> directory are listed in the following table.

**Table 7.2. Generated File List** 

| File Name                                        | Description                                                                                                                                                                                                                |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| component.xml                                    | Contains the ipxact:component information of the IP.                                                                                                                                                                       |
| design.xml                                       | Lists the set parameters of the IP in IP-XACT 2014 format.                                                                                                                                                                 |
| <instance_name>.cfg</instance_name>              | Lists only the configured/changed parameter values set during IP configuration.                                                                                                                                            |
| <instance_name>.ipx</instance_name>              | Lists the files associated with IP generation.                                                                                                                                                                             |
| constraints/ <instance_name>.ldc</instance_name> | Defines the I/O standard for DDR4/LPDDR4 memory interface signals.                                                                                                                                                         |
| constraints/constraints.sdc                      | Pre-Synthesis and Pre-Map constraints for the IP.                                                                                                                                                                          |
| eval/apb2init.sv                                 | Implements handshaking between APB accesses and internal RISC-V CPU for initialization of DDR4/LPDDR4 memory in the Memory Controller Example Design.                                                                      |
| eval/assign_pins.py                              | Add the pin assignment to eval constraint.pdc based on the <i>Select Development Board</i> settings.                                                                                                                       |
| eval/async_reset_sync_deassert.v                 | Synchronize the reset de-assertion to the rising edge of the clock.                                                                                                                                                        |
| eval/blink_led.v                                 | Drives LEDs on and off to indicate that internal clocks (pclk and aclk_i) are active in the Memory Controller Example Design.                                                                                              |
| eval/clock_constraint.sdc                        | Pre-synthesis constraint for setting the PLL reference clock frequency of the Memory Controller Example Design.                                                                                                            |
| eval/constraint.pdc                              | Post-synthesis constraints for the Memory Controller Example Design. When the attribute Select Development Board is set (not None) in the IP GUI, this file will contain the pin assignments for the target Lattice board. |
| eval/dut_inst.v                                  | Instantiation of generated IP core in eval_top.sv for the Memory Controller Example Design.                                                                                                                                |
| eval/dut_params.v                                | Defines local parameters for eval_top based on parameter values set during IP configuration for the Memory Controller Example Design.                                                                                      |
| eval/eval_top.sv                                 | Top-level RTL file for the Memory Controller Example Design.                                                                                                                                                               |

©2023-2025 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.
All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
FPGA-IPUG-02208-1.8



| File Name                                                                                      | Description                                                                                                     |
|------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| eval/measure_trn.sv                                                                            | May be used to measure the training time on silicon/board and observe the result via reveal.                    |
| eval/pll0.v                                                                                    | PLL responsible for generating APB clock (pclk) and AXI4 (aclk_i) in the Memory                                 |
| eval/pll0_refclk125.v                                                                          | Controller Example Design.                                                                                      |
| eval/select_protocol.py                                                                        | Script that defines DDR4/LPDDR4 protocol for eval_top and tb_top files in the Memory Controller Example Design. |
| eval/axi_bridge/                                                                               | Contains RTL for AXI bus interface to Native I/F.                                                               |
| eval/traffic_gen/                                                                              | Contains RTL files for the Memory Controller Example Design.                                                    |
| misc/ <instance_name>_tmpl.v<br/>misc/<instance_name>_tmpl.vhd</instance_name></instance_name> | These files provide instance templates for the IP core.                                                         |
| rtl/ <instance_name>.sv</instance_name>                                                        | Example RTL top-level file that instantiates the IP core.                                                       |
| rtl/ <instance_name>_bb.v</instance_name>                                                      | Example synthesizable RTL black box file that instantiates the IP core.                                         |
| testbench/debug_c_code.sv                                                                      |                                                                                                                 |
| testbench/delay_1dir.sv                                                                        | For internal debugging use only.                                                                                |
| testbench/dqs_grp_delay.sv                                                                     |                                                                                                                 |
| testbench/dq_bit_swizzle.vh                                                                    | Specifies the MC to DRAM connection based on the Bit Swizzle settings.                                          |
| testbench/dut_inst.v                                                                           | Template instance files.                                                                                        |
| testbench/dut_params.v                                                                         | List of parameters based on user IP configurations.                                                             |
| testbench/tb_top.sv                                                                            | Top level testbench file.                                                                                       |
| testbench/ddr4/                                                                                | Contains DDR4/LPDDR4 memory model and instances for simulation.                                                 |
| testbench/lpddr4/                                                                              | Contains DDN4/LFDDN4 memory moder and instances for simulation.                                                 |

# 7.2. Design Implementation

This section outlines the steps to properly run a Memory Controller for Avant IP design on hardware.

#### 7.2.1. Pin Placement

Typically, all external memory interfaces require the following FPGA resources:

- Data, data mask, and data strobe signals
- · Command, address, and control signals
- PLL and clock network signals
- RZQ signals
- Other FPGA resources

In Lattice Avant FPGA devices, the DDRPHY supports external memory interfaces. Each DDRPHY consists of three High Performance I/O (HPIO) banks, labeled as HIGHSPEED in the device pinout tables. Since Avant leverages a hardened PHY, the external memory interface pinouts are in fixed locations. Each pin location is specified under DDRPHY in the device pinout tables. Dedicated clock routing within HPIO banks is represented as PLL or PCLK, and dedicated reference voltage pins are represented as VREF in the device pinout tables. Refer to the Avant High-Speed I/O and External Memory Interface User Guide (FPGA-TN-02300) and Pinout files located on the Avant-E, Avant-G, and Avant-X web pages.

Observe the following guidelines when placing pins for external memory interfaces:

- Ensure that pins for external memory interfaces reside within a DDRPHY.
- You must assign the input reference clock to the PLL must to use dedicated clock routing (PLL or PCLK). It is strongly recommended to place the input reference clock on the pin closest to the dedicated PLL within each DDRPHY (labeled as PLL under DDRPHY in device pinout tables). This ensures better performance by minimizing jitter/routing.

Always test proposed pinouts in Lattice Radiant software with the correct I/O standards before finalizing. Note that unused pins within a DDRPHY can be used as general-purpose I/O under certain conditions. Refer to the Avant High-Speed I/O and External Memory Interface User Guide (FPGA-TN-02300) for more details.



#### 7.2.2. Constraints

To ensure proper design coverage and hardware functionality, you must include the following necessary constraints in their Memory Controller for the Avant IP project.

**Table 7.3. Project Constraints** 

| File Name                                                                       | Description                                                                                               | Action Required                                                                                                                                                                                                             |
|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory Controller IP LDC file: constraints/ <instance_name>.ldc</instance_name> | Sets the I/O type for each of the ports necessary to interface with the DDR4/LPDDR4 SDRAM                 | No. These constraints are automatically propagated                                                                                                                                                                          |
| Memory Controller IP SDC file: constraints/constraints.sdc                      | Pre-synthesis and pre-map IP timing constraints                                                           | No. These constraints are automatically propagated                                                                                                                                                                          |
| Clock Constraint SDC file:<br>eval/clock_constraint.sdc                         | Contains an example constraint for the input PLL reference clock                                          | Yes – you need to include a create_clock constraint based on the frequency of the input PLL reference clock. This should be placed in a user-created SDC file                                                               |
| Example Design PDC file:<br>eval/constraint.pdc                                 | Contains generated clock uncertainty constraints and example design constraints based on IP configuration | Yes – you need to copy the clock uncertainty constraints listed in this file directly into your top-level PDC file. You need to copy the example design constraints to run the LPDDR4/DDR4 memory Controller Example Design |

The Memory Controller IP constraints do not define the input and output delay on the DDR I/O since the routing from the DDRPHY primitive to/from the I/O is a dedicated path. Additionally, the Memory Controller calibration sequence compensates for the controller to DRAM end-to-end skew, making it unnecessary to specify I/O timing constraints by design.

#### 7.2.2.1. Reference Clock SDC

The provided clock\_constraint.sdc file contains a single create\_clock constraint for the PLL reference clock (pll\_refclk\_i). This constraint is necessary for the PLL to generate the constraint for its output clock. You should copy this constraint into the Radiant Project SDC file (not in PDC file) to allow the synthesis tool to optimize the logic for the target clock.

## 7.2.2.2. Example Design PDC

The provided constraint.pdc file contains two or three sets of constraints:

- Clock Uncertainty defines the clock name for sclk\_o and specifies its clock uncertainty based on the measured clock jitter during HW validation.
- Eval constraints specific to the Memory Controller Example Design.
- Pinouts specifies the pin assignment for the selected board in the *Select Development Board* attribute. This is only available for LPDDR4, Avant-E/G/X70 devices, and the *Select Development Board* attribute is not set to *None*.

If you implement your own Memory Controller design, you need to copy the clock uncertainty constraints into the top-level user PDC file.

The eval constraints composed of set\_false\_path, set\_max\_delay, and ldc\_create\_group constraints, should only be copied if running the provided Memory Controller Example Design. Eval constraints are located below the following comment in the provided constraint.pdc file:

Refer to the Lattice Radiant Timing Constraints Methodology (FPGA-AN-02059) for details regarding the implementation of constraints.



# 7.3. Example Design Hardware Evaluation

After successfully configuring and generating the Memory Controller IP Core, you can use the included synthesis example design for hardware evaluation of the Memory Controller. For a detailed description of the Memory Controller Example Design, refer to the Synthesis Example Design section of this user guide. The traffic generator file set is located under the eval/traffic\_gen directory and is described in the Table 7.4.

Table 7.4. Contents of eval/traffic\_gen

| File List                | Description                                                                       |  |  |  |
|--------------------------|-----------------------------------------------------------------------------------|--|--|--|
| ahbl0.v                  | AHBL_1x2. It routes CPU data access to SYS_MEM or AHBL2APB                        |  |  |  |
| ahbl2apb0.v              | AHBL to APB bridge                                                                |  |  |  |
| apb0.v                   | APB_1x4. It routes CPU data access via AHBL2APB going to each module's CSR        |  |  |  |
| cpu0.v                   | RISC-V CPU                                                                        |  |  |  |
| gpio0.v                  | GPIO module                                                                       |  |  |  |
| ctrl_fifo.v              |                                                                                   |  |  |  |
| lscc_axi4_traffic_gen.sv |                                                                                   |  |  |  |
| lscc_axi4_m_csr.sv       |                                                                                   |  |  |  |
| lscc_axi4_m_rd.sv        | RTL files for AXI4 traffic generator                                              |  |  |  |
| lscc_axi4_m_wr.sv        |                                                                                   |  |  |  |
| lscc_axi4_perf_calc.sv   |                                                                                   |  |  |  |
| lscc_lfsr.v              |                                                                                   |  |  |  |
| mc_axi4_traffic_gen.v    |                                                                                   |  |  |  |
| lscc_osc.v               | RTL files for OSC module                                                          |  |  |  |
| osc0.v                   | RTL files for OSC filodule                                                        |  |  |  |
| lscc_ram_dp_true.v       | Copy of Lattice Radiant RAM_DP_True Foundational IP (needed by SYS_MEM)           |  |  |  |
| memc_apb.v               | RTL file for APB configuration interface                                          |  |  |  |
| sysmem0.v                | The SYS_MEM for hardware validation, enabled when eval_top.SIM=0 (Implementation) |  |  |  |
| uart0.v                  | The UART module                                                                   |  |  |  |

## 7.3.1. Preparing the Bitstream

After configuring and generating the Memory Controller IP Core, all associated example design files are created under the eval directory. Refer to Table 7.2 for more details. The following steps illustrate how to prepare the Memory Controller Example Design project and generate the associated bitstream.

- After generating the Memory Controller IP Core, the Radiant project should contain <instance\_name>.ipx under the project's input files. If not, right-click on Input Files and select Add > Existing File under the File List tab in the lower-left corner of the Radiant window. This action opens the Add Existing File dialog box. Navigate to the <instance\_directory>/<instance\_name> directory and select the <instance\_name>.ipx file. Ensure the Copy file to directory option is unchecked. Click Add.
- 2. To add the top-level example design file to the project, right-click on **Input Files** and select **Add > Existing File**. This action opens the **Add Existing File** dialog box. Navigate to the eval directory and select the eval\_top.sv file. Ensure the **Copy file to directory** option is unchecked. Click **Add**.





Figure 7.7. Add Existing File Dialog Box

- 3. To add the pre-synthesis constraint file to the project, right-click on Pre-Synthesis Constraint Files and select Add > Existing File. In the Add Existing File dialog box, check the Copy file to directory option. This ensures any user modifications are not overwritten when the Memory Controller IP Core is regenerated. Navigate to the eval directory and select the clock constraint.sdc file. Click Add.
- 4. To add the post-synthesis constraint file to the project, right-click on Post-Synthesis Constraint Files and select Add > Existing File. In the Add Existing File dialog box, check the Copy file to directory option. Navigate to the eval directory and select the constraint.pdc file. Click Add.
- 5. Modify the constraint.pdc to add the pin assignment for the Avant-E/G/X board. You can do this by either modifying the constraint.pdc file directly or first synthesizing the Radiant project by clicking on the synthesize Design button and then adding pinouts via the Device Constraint Editor under Tools > Device Constraint Editor. Note that when assigning the UART pins, the UART TX signal connects to the UART RX on the FPGA side, and the UART RX signal connects to the UART TX signal on the FPGA side.

  You can skip this step when implementing the LPDDR4 Example design to a Lattice board and the board is chosen in the Select Development Board attribute in IP GUI.
- 6. Before running the example design on hardware, you need to generate a bitstream. You can do this by clicking on the button. This will generate a <project\_name>\_<top\_level\_instance\_name>.bit file under the <project\_directory>/<project\_name>/<top\_level\_instance\_name> directory specified in Step 2 of the Configuring and Generating the IP section of this user guide.

Sometimes you may encounter timing failures during Place and Route due to unconstrained paths specific to their design. For details on implementing constraints, refer to the Constraints section of this user guide.

### 7.3.2. Running on Hardware

To perform a hardware evaluation of the Memory Controller Example Design, the following are needed:

- Avant-E/G/X FPGA board with UART connection
- Associated power supply and programming cable
- Personal computer running Lattice Radiant software 2024.1 or later
- Lattice Propel™ software 1.0 or later, or any terminal that supports serial communication



To run the example design on hardware, you need a bitstream file. To generate the .bit file, refer to the Preparing the Bitstream section of this user guide. The following steps illustrate how to program the FPGA board with the example design.

- 1. Connect the FPGA board to the computer and power on the board.
- 2. Run the Lattice Radiant Programmer by clicking the button. This launches the Lattice Radiant Programmer, which scans for devices and configures the programmer automatically.



Figure 7.8. Radiant Programmer

- 3. Click under the **File Name** field, and then click on ... to the right of the field to launch the **Open File** dialog box. Navigate to the bitstream file generated in Step 6 of the Preparing the Bitstream section of this user guide and click **Open**.
  - To run the example design, you need to launch a serial terminal. If you wish to use your own serial communication terminal, skip to Step 6. If you wish to use the Lattice Propel terminal, continue with Step 4.
- 4. Launch the Lattice Propel software and select Launch. This action opens the default workspace.
- 5. To open the terminal, click on the Dutton.
- 6. Configure the terminal settings to be a **Serial Terminal** with the appropriate **Baud rate**, **Data size**, **Parity**, **Stop bits**, **and Encoding**. Click **OK** to launch the **Terminal** pane at the bottom of the Propel window. Note that the **Serial port** will vary depending on the computer setup.





Figure 7.9. Serial Terminal Settings

- 7. Program the Lattice FPGA device by clicking the 🏶 button. Upon successful programming, assert the rstn i signal to run the example design, resulting in the following prompt appearing in the terminal.
  - If no message is received, close the current serial terminal, click Detect Cable in the programmer window, and repeat steps 3-7 in the Running on Hardware section of this user guide with a different Serial port.

```
______
DDR Memory Controller Example Design
Select Test to Run (press corresponding key)
0 = Print Memory Training Stages and Data Access Pattern Definition
1 = Run Memory Training and Data Access Check
2 = Run Memory Training and Data Access In a loop With Reset
```

Pressing 0 prints a series of definitions correlating to the memory training and data access test pattern:

```
Memory Training Stage Definitions
A sequence of letters will print out to indicate which training stages were successfully
completed.
I = Initialization
C = Command Bus Training
L = Write Leveling
R = Read Training
W = Write Training
S = SCL Training
B = Bit-Level Trim Sweep Training
Memory Data Access Pattern Definitions
```

A sequence of number will print out to indicate which data access patterns were successful.

- 0 = INCR2: 2-beat incrementing burst write followed by 10 burst reads with no delay between transactions
- 1 = INCR2: 2-beat incrementing 10 burst writes followed by 10 burst reads with no delay between transactions

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice. FPGA-IPUG-02208-1.8



- 2 = INCR4: 4-beat incrementing burst write followed by 10 burst reads with no delay between transactions
- 3 = INCR4: 4-beat incrementing 10 burst writes followed by 10 burst reads with no delay between transactions
- 4 = INCR8: 8-beat incrementing burst write followed by burst read with no delay between transactions
- 5 = INCR8: 8-beat incrementing burst write followed by a delay before issuing burst read
- 6 = INCR64: 64-beat incrementing burst write followed by burst read with no delay between transactions
- 7 = INCR128: 128-beat incrementing burst write followed by burst read with no delay between transactions
- 8 = INCR256: 256-beat incrementing burst write followed by burst read with no delay between transactions
- p = INCR64 Performance Test: 64-beat incrementing parallel burst write and burst read with no delay between transactions

Pressing 1 starts the training sequence, followed by 7-9 (based on Maximum Burst Length) different data access checks:

```
Starting Memory Training
Ι
 C
    W
     S
RESULT: Training passed with STATUS REG ADDR value: 0x3007F
VREF has been trained to the following values:
MC DQS Grp Vref [DQS0 -> DQS3] : 45,45,47,41
Starting Data Access Check
1
 2
  3
   4
    5
     6
      p
Starting Performance Test
The Performance Test measures the throughput of the MC and calculates efficiency via the
        Total number of wr_rd transactions / Duration of the MC clock (sclk)
BUS EFFICIENCY in %: 80
Performance in Mbps : 55482
Ran : 20000 transactions across sequential address
RESULT: All transaction types have PASSED.
```

©2023-2025 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal.

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.

FPGA-IPUG-02208-1.8



The bus efficiency value represents the efficiency percentage of the DDR4/LPDDR4 bus utilization, while the performance value represents the bandwidth of the DDR4/LPDDR4 interface. The following formulas are used to calculate efficiency and bandwidth:

Efficiency = (Total number of bytes transferred) / (number of DDR clock cycles × (DDR\_WIDTH / 8) × gearing ratio)
Bandwidth = (Total number of bytes transferred) / (number of DDR clock cycles × DDR clock period)

The bandwidth can also be calculated using the following equation: DDR4/LPDDR4 Data Width  $\times$  DDR4/LPDDR4 Data Rate  $\times$  (DDR4/LPDDR4 Bus Efficiency / 100), where the DDR4/LPDDR4 Data Rate is in Mbps.

Pressing 2 performs the Test 1 mentioned above, followed by a reset input to the DDR MC, it will repeat many times as specified in the input prompt. In the example below, Test 1 will be repeated 100 times.

Enter Number of Iterations: 100

If a failure occurs during training, a message is sent over the serial connection notifying you of the particular stage that has failed. This also aborts the loop-back data access checks.



# 7.4. Example Design Simulation

After successfully configuring and generating the Memory Controller IP Core, you can use the included example design to simulate the Memory Controller. All associated simulation files are located in the testbench directory. Refer to Table 7.2 for more details.

The following steps illustrate how to prepare the Memory Controller Example Design project for simulation.

- Before simulating the example design, complete steps 1-2 under the Preparing the Bitstream section of this user
  guide. To add the top-level testbench file to the project, select File > Add > Existing Simulation File. This action
  opens the Add Existing Simulation File dialog box. Navigate to the testbench directory and select the tb\_top.sv file.
  In the Add Existing File dialog box, ensure that the Copy file to directory option is unchecked. Click Add.
- 2. Before creating the simulation environment, set the SIM parameter in eval\_top.sv to 1 and uncomment the RTL\_SIM macro definition in tb\_top.sv. These parameters and macro shortens the initialization sequence of the DDR4/LPDDR4 interface and disables the UART interface for simulation. Do not modify the SIM parameter for hardware implementation.

When you enable the macro, it programs 0x01C to the Training Operation Register (TRN\_OP\_REG) to speed up the simulation runtime by reducing the reset and CKE initialization times.

Note that the memory model in the example design simulation requires a minimum simulation timescale of 1 ps, as defined by the memory manufacturer. To ensure proper functionality, generate the PLL reference clock with a minimum timescale of 1 ps. We recommended skipping the training sequences (including command-bus training) by writing 8'h1C to TRN\_OP\_REG/trn\_opr\_i. This will reduce simulation time by programming the verified trained values into the PHY. Refer to the Simulation Example Design section of this user guide for more details.



To create the simulation environment to simulate the Memory Controller Example Design, the following steps should be taken:

Launch the simulation wizard in Radiant by selecting Tools > Simulation Wizard. This action opens the Simulation
Wizard dialog box. Click Next and provide a name (<sim\_name>) and directory (<sim\_directory>) for the simulation
project, where the default directory is set to <project\_directory>/<project\_name>. Click Next.



Figure 7.10. Simulation Wizard

2. In the **Add and Reorder Source** window, notice that the **Source Files** only contain the top-level evaluation (eval\_top.sv) and top-level testbench (tb\_top.sv) files. Click **Next**.



Figure 7.11. Adding and Reordering Simulation Source Files



3. In the Parse HDL files for simulation window, notice that the Simulation Top Module is set to eval top. Click Next.



Figure 7.12. Parsing Simulation HDL Files

The following error message is expected during the parsing of the HDL files using the Simulation Wizard. These messages are due to the DDR4 simulation models being encrypted and will not affect the simulation behavior since Questasim is able to decrypt the DDR4 memory model.

ERROR <1009990> - key keyowners are not support. Must have "Lattice Semiconductor".

4. This action opens the **Summary** window. By default, the simulation runs for 100 μs, allowing you to configure the waveform to log signals of interest in the QuestaSim simulator before continuing. You can then enter the following TCL command in QuestaSim to run the simulation until completion: **run -all**. Alternatively, if you want to run the simulation with the default top-level signals, change the 100 μs value to 0 μs to execute the simulation completely.



Figure 7.13. Simulation Summary

5-1.8



The results of the Memory Controller IP simulation design are shown in Figure 7.14.



Figure 7.14. Simulation Result Waveform

The following error messages are expected in the QuestaSim simulation log and should be disregarded. These messages are due to the violation of timing requirements regarding the DDR4/LPDDR4 simulation model as a consequence of shortening the reset and CKE ini=tialization:

```
# tb top.LP4MEM 00.mem x16 00.ins 1ch.cred> 26083125000 : ###
                                                                 lpddr4 debug
RESET_n high input
# tb top.LP4MEM 01.mem_x16_01.ins_1ch.cprotected> 26083125000 : ###
                                                                lpddr4 debug
RESET n high input
# Error: tb top.LP4MEM 01.mem x16 01.ins 1ch.<protected>.<protected> 26083125000 tINIT1
# Error: tb_top.LP4MEM_00.mem_x16_00.ins_1ch.ofteted>..cted>26083125000
                                                                            tINIT1
# tb top.LP4MEM 00.mem x16 00.ins 1ch.cted> 32804075000 : ###
                                                                lpddr4 debug CKE
high input
# tb_top.LP4MEM_01.mem_x16_01.ins_1ch.cted> 32804075000 : ### lpddr4_debug CKE
high input
# Error: tb_top.LP4MEM_01.mem_x16_01.ins_1ch.cted>...cted> 32804075000
                                                                            tINIT3
Error.
# Error: tb_top.LP4MEM_00.mem_x16_00.ins_1ch.ofteted>...cted>32804075000
Error.
```



# **Appendix A. Resource Utilization**

The following table shows the configuration and resource utilization for LAV-AT-E70ES1-3LFG1156C using Synplify Pro of Lattice Radiant software 2025.2.

Table A.1.DDR4 Resource Utilization for IP Core v2.7.0

| Configuration                                                            | aclk_i Fmax<br>(MHz) | sclk_o Fmax¹<br>(MHz) | Registers | LUT4 Logic | EBR | DSP |
|--------------------------------------------------------------------------|----------------------|-----------------------|-----------|------------|-----|-----|
| DDR Command Frequency = 1066,<br>Others = Default                        | 334.225              | 300.120               | 7196      | 6160       | 25  | 0   |
| DDR Command Frequency = 1066,<br>DDR Bus Width = 16,<br>Others = Default | 332.336              | 300.120               | 5719      | 5778       | 21  | 0   |
| DDR Command Frequency = 1066,<br>DDR Bus Width = 64,<br>Others = Default | 296.472              | 300.120               | 10,222    | 7064       | 33  | 0   |

#### Note:

1. The sclk\_o Fmax is generated using the top-level example design wrapper file, eval\_top.sv, that is described in the Synthesis Example Design section of this user guide. These values may increase when the IP Core is used with the user logic.

Table A.2.LPDDR4 Resource Utilization for IP Core v2.7.0

| Configuration                                                            | aclk_i Fmax<br>(MHz) | sclk_o Fmax¹<br>(MHz) | Registers | LUT4 Logic | EBR | DSP |
|--------------------------------------------------------------------------|----------------------|-----------------------|-----------|------------|-----|-----|
| DDR Command Frequency = 1066,<br>Others = Default                        | 325.098              | 300.120               | 8098      | 6677       | 25  | 0   |
| DDR Command Frequency = 1066,<br>DDR Bus Width = 16,<br>Others = Default | 335.909              | 300.120               | 6538      | 6103       | 21  | 0   |
| DDR Command Frequency = 1066,<br>DDR Bus Width = 64,<br>Others = Default | 310.174              | 300.120               | 11244     | 7675       | 33  | 0   |

#### Note:

1. The sclk\_o Fmax is generated using the top-level example design wrapper file, eval\_top.sv, that is described in the Synthesis Example Design section of this user guide. These values may increase when the IP Core is used with the user logic.



# **Appendix B. Known Issues**

- 1. LPDDR4/DDR4 with Dual Rank configuration may encounter simulation failures when switching between R0 and R1. This issue will be fixed in future releases.
- 2. Enabling the power down feature is known to cause hardware failures. This issue will be fixed in future releases.
- 3. Achieving timing closure is difficult when using the DDR Memory Controller IP Core with each speed grade's maximum supported interface speed on DDR4.
- 4. Some DQ swizzle settings on DQS group 1 may encounter a CBT error due to the initialization values of the DDRPHY Hard IP's input DQ, making it appear that the CBT pattern is already matching at the very start of CBT. This issue will only occur in simulation and will not occur on hardware, since the real default input DQ value in silicon will be zero, due to the DQ signal being in a high-impedance state, and the termination pulling it down to zero. The simulation model issue occurs when using Lattice Radiant 2025.2 or earlier.



# References

#### For more information refer to:

- DDR Memory Controller IP Release Notes (FPGA-RN-02033)
- DDR Memory Controller Driver (FPGA-TN-02379)
- DDR Memory PHY Module (FPGA-IPUG-02195)
- Avant-E web page
- Avant-G web page
- Avant-X web page
- Certus-N2 web page
- Lattice Propel Design Environment web page
- AMBA AXI Protocol Specification
- AMBA APB Protocol Specification
- DDR4 JEDEC Standard
- LPDDR4 JEDEC Standard
- Lattice Radiant Software 2024.1 User Guide
- Lattice Propel 2024.1 Builder User Guide (FPGA-UG-02212)
- Lattice Radiant Timing Constraints Methodology User Guide (FPGA-AN-02059)
- Lattice Radiant FPGA design software
- Lattice Insights for Lattice Semiconductor training courses and learning plans
- Avant High Speed IO and External Memory Interface User-Guide (FPGA-TN-02300)



# **Technical Support Assistance**

Submit a technical support case through www.latticesemi.com/techsupport. For frequently asked questions, please refer to the Lattice Answer Database at www.latticesemi.com/Support/AnswerDatabase.



# **Revision History**

**Note:** In some instances, the IP may be updated without changes to the user guide. The user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates.

### Revision 1.8, IP v2.7.0, December 2025

| Section                          | Change Summary                                                                                                                                                                                                                                                                                   |  |  |
|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| All                              | Updated IP version from 2.6.1 to 2.7.0.                                                                                                                                                                                                                                                          |  |  |
| Introduction                     | Updated Table 1.1. Quick Facts.                                                                                                                                                                                                                                                                  |  |  |
|                                  | <ul> <li>Added notes 1 and 2.</li> </ul>                                                                                                                                                                                                                                                         |  |  |
|                                  | Added <i>Driver Support</i> .                                                                                                                                                                                                                                                                    |  |  |
|                                  | Added Bit Swizzle in the LPDDR4 features section.                                                                                                                                                                                                                                                |  |  |
|                                  | <ul> <li>Added Bit Swizzle and 2-D Vref Training in Table 1.3. DDR4 Features Overview and Table<br/>1.4. LPDDR4 Features Overview.</li> </ul>                                                                                                                                                    |  |  |
|                                  | Reworked the Licensing and Ordering Information section.                                                                                                                                                                                                                                         |  |  |
| Functional Description           | Updated the Clocking and Reset section.                                                                                                                                                                                                                                                          |  |  |
|                                  | <ul> <li>Minor updates at the end of AXI4 Data Interface and APB Configuration Interface<br/>sections.</li> </ul>                                                                                                                                                                                |  |  |
|                                  | • Updated the steps to start the initialization and training sequence of the SDRAM device in the Calibration section.                                                                                                                                                                            |  |  |
|                                  | Updated the Initialization and Training without APB Interface section.                                                                                                                                                                                                                           |  |  |
|                                  | <ul> <li>Minor updates added in Temperature Tracking and Extended Temperature Support<br/>section.</li> </ul>                                                                                                                                                                                    |  |  |
| IP Parameter Description         | <ul> <li>Added Enable Bit Swizzle attribute in Table 3.13. LPDDR4 General Attributes and Table<br/>3.17. LPDDR4 General Definitions.</li> </ul>                                                                                                                                                  |  |  |
|                                  | Table 3.21. LPDDR4 Training Settings Attributes.                                                                                                                                                                                                                                                 |  |  |
|                                  | Updated the DDR Clock Delay Value.                                                                                                                                                                                                                                                               |  |  |
|                                  | <ul> <li>Updated the Address Control Delay Value Incr/Decr to Unchecked.</li> </ul>                                                                                                                                                                                                              |  |  |
|                                  | <ul> <li>Updated the Eval Local Bus Clock Frequency (MHz) attribute in Table 3.25. LPDDR4         Example Design Attributes and Table 3.26. LPDDR4 Example Design Attribute         Definitions.     </li> </ul>                                                                                 |  |  |
|                                  | Added Bit Swizzle Settings section.                                                                                                                                                                                                                                                              |  |  |
| Signal Description               | <ul> <li>Updated description of pll_refclk_i, pll_rst_n_i, and rst_n_i signals in Table 4.1. Clock<br/>and Reset Port Definitions.</li> </ul>                                                                                                                                                    |  |  |
|                                  | <ul> <li>Updated description of pll_lock_o signal in Table 4.2. Interrupts and<br/>Initialization/Training Port Definitions.</li> </ul>                                                                                                                                                          |  |  |
| Memory Controller Example        | Updated the Synthesis Example Design section.                                                                                                                                                                                                                                                    |  |  |
| Design                           | <ul> <li>Updated data rate from ≤ 1,866 Mbps to ≤ 1,333 Mbps.</li> </ul>                                                                                                                                                                                                                         |  |  |
|                                  | <ul> <li>Added a bullet stating, If data rate in [1,600 Mbps, 1866Mbps]: TRN_OP_REG =         0x1DF during training.</li> </ul>                                                                                                                                                                  |  |  |
| Designing and Simulating the IP  | Updated Table 7.2. Generated File List to add the new generated files.                                                                                                                                                                                                                           |  |  |
|                                  | Updated the Example Design Simulation section.                                                                                                                                                                                                                                                   |  |  |
|                                  | <ul> <li>Reworked Step no. 2 on how to prepare the Memory Controller Example Design<br/>project for simulation.</li> </ul>                                                                                                                                                                       |  |  |
|                                  | Updated the 3rd paragraph.                                                                                                                                                                                                                                                                       |  |  |
|                                  | Replaced set SIM to 1 to enable the macro.                                                                                                                                                                                                                                                       |  |  |
|                                  | <ul> <li>Removed, You can configure the simulation of reset and the initialization and<br/>training sequences by forcing the value of TRN_OP_REG by locating the<br/>following line in tb_top.sv: force</li> <li>`DUT_INST_NAME.lscc_mc_avant_inst.u_ddrphy.i_csr.trn_operation_reg =</li> </ul> |  |  |
|                                  | 10'h01C;                                                                                                                                                                                                                                                                                         |  |  |
| Appendix A. Resource Utilization | Updated the values in Table A.1.DDR4 Resource Utilization for IP Core v2.7.0 and Table A.2.LPDDR4 Resource Utilization for IP Core v2.7.0.                                                                                                                                                       |  |  |
| Appendix B. Known Issues         | Added a known issue simulation issue with DQ Swizzle settings on DQS Group 1.                                                                                                                                                                                                                    |  |  |



| Section          | Change Summary                                                                                                                                                                                                                                                           |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| References       | Added the Avant High Speed IO and External Memory Interface User-Guide (FPGA-TN-02300) in this section.                                                                                                                                                                  |
| Revision history | Added a note, In some instances, the IP may be updated without changes to the user guide. The user guide may reflect an earlier IP version but remains fully compatible with the later IP version. Refer to the IP Release Notes for the latest updates to this section. |

### Revision 1.7, IP v2.6.1, October 2025

| Section                   | Change Summary                                                                        |  |
|---------------------------|---------------------------------------------------------------------------------------|--|
| All                       | Updated IP version from 2.6.0 to 2.6.1.                                               |  |
| Introduction              | Added note for limitation on support in Table 1.2.                                    |  |
| Functional Description    | Updated TRN_OP_REG value in Calibration section.                                      |  |
|                           | Updated trn_opr_i value in Initialization and Training without APB Interface section. |  |
| IP Parameter Description  | Updated DDR Clock Delay Value in LPDDR4 Training Settings section.                    |  |
| Memory Controller Example | Updated TRN_OP_REG value in Synthesis Example Design section.                         |  |
| Design                    |                                                                                       |  |

#### Revision 1.6, IP v2.6.0, June 2025

| Section                  | Change Summary                                                                             |
|--------------------------|--------------------------------------------------------------------------------------------|
| All                      | Minor editorial fixes.                                                                     |
|                          | Updated IP version from 2.5.2 to 2.6.0.                                                    |
| Introduction             | Updated Supported Devices and removed Target Devices in Table 1.1.                         |
|                          | Updated DDR4 Features:                                                                     |
|                          | Removed read DBI                                                                           |
|                          | <ul> <li>Added component (DRAM soldered on the board) and UDIMM support.</li> </ul>        |
|                          | Added note on dual rank support                                                            |
|                          | Updated LPDDR4 Feature: Added note on dual rank support                                    |
|                          | Updated Table 1.3.                                                                         |
|                          | <ul> <li>Updated Key Feature Device Format to Component, UDIMM.</li> </ul>                 |
|                          | <ul> <li>Updated VREF Training to Not yet supported.</li> </ul>                            |
| IP Parameter Description | Updated <i>Read Latency</i> options and default values in Table 3.1.                       |
|                          | • Updated I/O Buffer Type, Read Latency and Write Latency description in Table 3.5.        |
|                          | Updated Slew Rate settings default value in Table 3.10 and Table 3.22.                     |
|                          | • Added training settings attributes in Table 3.9, Table 3.12, Table 3.21, and Table 3.24. |
|                          | Updated RTT_WR Value default value in Table 3.11.                                          |
|                          | • Updated the DDR Clock Delay default value from 4 to 2 in Table 3.21.                     |
| Signal Description       | Updated descriptions of pll_refclk_i, pclk_i, aclk_i, rst_n_i in Table 4.1.                |
|                          | • Removed DDR4 in table label for Table 4.1, Table 4.2, Table 4.3, and Table 4.4.          |
|                          | Added note 2 in Table 4.9.                                                                 |
| Appendix B               | Added a known issue for dual rank.                                                         |

# Revision 1.5. IP v2.5.2. March 2025

| CVISION 1.5, II V2.5.2, WIGHEN 2025 |                                                                                      |
|-------------------------------------|--------------------------------------------------------------------------------------|
| Section                             | Change Summary                                                                       |
| All                                 | Minor editorial fixes.                                                               |
|                                     | • Updated IP version from 2.4.0 to 2.5.2.                                            |
| Introduction                        | Updated the Targeted Devices in Table 1.1. Quick Facts.                              |
| Functional Description              | Updated the AXI Data Interface section.                                              |
|                                     | Modified the AxADDR description.                                                     |
|                                     | Added WSTRB description.                                                             |
|                                     | • Updated the recommended value for TRN_OP_REG/trn_opr_i in the Calibration section. |

All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice. FPGA-IPUG-02208-1.8



| Section                         | Change Summary                                                                                                             |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| IP Parameter Description        | Added <i>Pull-Down Drive Strength</i> in the LPDDR4 Training Settings section, Table 3.23 and Table 3.24.                  |
|                                 | Added the Example Design section under LPDDR4.                                                                             |
| Signal Description              | Unified the following sections for both DDR4 and LPDDR4.                                                                   |
|                                 | Clock and Reset                                                                                                            |
|                                 | Interrupts and Initialization/Training                                                                                     |
|                                 | APB Register Interface                                                                                                     |
|                                 | AXI4 Data Interface                                                                                                        |
|                                 | • Updated the <i>width</i> of <i>trn_opr_i</i> in Table 4.2. DDR4 Interrupts and Initialization/Training Port Definitions. |
|                                 | Added the following subsections under AXI Data Interface section:                                                          |
|                                 | AXI4 Address Mapping for DDR4 mode                                                                                         |
|                                 | AXI4 Address Mapping for LPDDR4 mode                                                                                       |
| Memory Controller Example       | • Updated the TRN_OP_REG value in the Synthesis Example Design section.                                                    |
| Design                          | • Updated Table 6.2 and Table 6.3 in the Simulation Example Design section.                                                |
| Designing and Simulating the IP | Updated the Pin Placement section to remove VREF pin.                                                                      |
|                                 | Added <i>Pinouts</i> in the Example Design PDC section.                                                                    |
|                                 | • Updated <i>Step 5</i> in the Preparing the Bitstream section.                                                            |
|                                 | • Updated <i>Step 3</i> in the Example Design Simulation section to show the expected error message for DDR4.              |
|                                 | Updated the serial port print outs in the Running on Hardware section.                                                     |
| Appendix B                      | Removed the pll lock issue.                                                                                                |
| References                      | Added DDR Memory Controller Driver (FPGA-TN-02379) in this section.                                                        |

## Revision 1.4, IP v2.4.0, December 2024

| Section                         | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                             | <ul> <li>Changed the document title from Memory Controller IP Core for Avant Devices to DDR Memory Controller IP Core.</li> <li>Minor editorial fixes.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Abbreviations in This Document  | Changed Acronyms to Abbreviations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Introduction                    | <ul> <li>Updated Table 1.1. Quick Facts.</li> <li>Added Lattice Nexus 2 to the supported FPGA family.</li> <li>Added LAV-AT-E30 and LN2-CT-20 to the targeted device.</li> <li>Added the IP Support Summary section.</li> <li>Added Certus-N2 in Table 1.5. Ordering Part Number.</li> <li>Added the Hardware Support section.</li> <li>Removed the IP Validation Summary section.</li> <li>Added Certus-N2 in Table 1.5. Minimum Device Requirements.</li> </ul>                                                                                                                                                                                                                                                                                                    |
| IP Parameter Description        | <ul> <li>Updated Table 3.1. DDR4 General Attributes.</li> <li>Updated the Read Latency attribute and Write Latency attribute.</li> <li>Added table note 1 – Only devices with speed grades of 2 and 3 can support dual rank to Table 3.3, and Table 3.15.</li> <li>Updated Table 3.4. DDR4 Local Data Bus Attributes.         <ul> <li>ID Width – added 1 as the selectable value.</li> </ul> </li> <li>Updated Table 3.5 and Table 3.17.         <ul> <li>Removed, only single rank is supported under Number of Ranks attribute.</li> </ul> </li> <li>Removed Avant E/G/X in table note 1 of Table 3.13. LPDDR4 General Attributes.</li> <li>Updated Table 3.16. LPDDR4 Local Data Bus Attributes.</li> <li>ID Width – added 1 as the selectable value.</li> </ul> |
| Designing and Simulating the IP | <ul> <li>Reworked Constraints section.</li> <li>Updated Table 7.3. Project Constraints.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



| Section    | Change Summary                                                                    |
|------------|-----------------------------------------------------------------------------------|
| Appendix B | Added this section.                                                               |
| References | Added the DDR Memory Controller IP Release Notes (FPGA-RN-02033) in this section. |

### Revision 1.3, August 2024

| Section                          | Change Summary                                                                                                  |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------|
| All                              | Minor editorial fixes                                                                                           |
|                                  | Replaced ModelSim with QuestaSim                                                                                |
|                                  | Replaced Avant-AT-E/Avant-AT-G/Avant-AT-E with Avant-E/Avant-G/Avant-X                                          |
| Introduction                     | Updated Features subsection                                                                                     |
|                                  | <ul> <li>Updated Avant-E DDR4/LPDDR4 SDRAM speeds</li> </ul>                                                    |
|                                  | Added Dual-rank support                                                                                         |
|                                  | Added DDR4 VREF Training                                                                                        |
|                                  | Updated IP Validation Summary subsection                                                                        |
|                                  | Added Dual rank to Table 1.5.                                                                                   |
|                                  | Updated Minimum Device Requirements subsection                                                                  |
|                                  | Updated Table 1.6.                                                                                              |
| Functional Description           | Renamed section 2.1.1 Hardened Memory Controller to Memory Controller                                           |
|                                  | <ul> <li>Renamed section 2.1.2 Hardened DDRPHY to DDRPHY Module</li> </ul>                                      |
|                                  | <ul> <li>Renamed section 2.1.2.1 DDRPHY Primitive to 2.1.2.1 Hardened DDRPHY Primitive</li> </ul>               |
|                                  | Updated AXI4 Data Interface subsection                                                                          |
|                                  | Removed write strobe limitation                                                                                 |
|                                  | <ul> <li>Updated supported AXI4 transactions</li> </ul>                                                         |
|                                  | Updated Calibration subsection                                                                                  |
|                                  | Added polling for PLL lock signal                                                                               |
|                                  | Updated Periodic ZQ Calibration subsection                                                                      |
|                                  | Updated Operation Descriptions subsection                                                                       |
| IP Parameter Description         | <ul> <li>Updated subsections based off Memory Controller IP Core for Avant Devices version<br/>2.1.0</li> </ul> |
| Signal Description               | Updated signal name reset_n_i to areset_n_i                                                                     |
|                                  | Updated Table 4.2 and Table 4.7.                                                                                |
| Designing and Simulating the IP  | Updated Figure 7.5.                                                                                             |
|                                  | Updated Table 7.1                                                                                               |
|                                  | Updated Pin Placement subsection                                                                                |
|                                  | Recommend dedicated PLL reference clock                                                                         |
|                                  | Updated Constraints subsection                                                                                  |
| Appendix A. Resource Utilization | Reworked section contents.                                                                                      |
|                                  | l .                                                                                                             |

# Revision 1.2, December 2023

| Section                   | Change Summary                                                                                                                                                                                                                                                                                                                                 |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                       | <ul> <li>Changed the document title from Lattice Avant Memory Controller IP Core - Lattice Radiant Software to Memory Controller IP for Avant Devices.</li> <li>Reworked document content and structure for clarity.</li> </ul>                                                                                                                |
| Acronyms in this document | Reworked section contents.                                                                                                                                                                                                                                                                                                                     |
| Introduction              | <ul> <li>Reworked section contents.</li> <li>Reworked section 4 Ordering Part Number and renamed to subsection 1.3 Licensing and Ordering Information. Added IP Validation Summary and Minimum Device Requirements subsection.</li> <li>Reworked subsection 1.3 Naming Conventions and renamed to subsection 1.6 Naming Conventions</li> </ul> |



| Section                             | Change Summary                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Functional Description              | <ul> <li>Reworked subsection 2.1. Overview and renamed to subsection 2.1 IP Architecture.</li> <li>Added subsection 2.2 Clocking and Reset.</li> <li>Reworked subsection 2.2.1 AXI4 Interface and moved under added subsection 2.3 User Interfaces.</li> <li>Reworked subsection 2.5. Initialization and Training and renamed to subsection 2.4 Calibration.Reworked subsection 2.6. Operations Details and renamed to subsection 2.5 Operation Descriptions.</li> </ul> |
| IP Parameter Description            | Reworked <i>subsection 2.3 Attributes Summary</i> and moved this under IP Parameter Description section.                                                                                                                                                                                                                                                                                                                                                                 |
| Signal Description                  | Reworked subsection 2.2 Signal Description and converted it to Signal Description section.                                                                                                                                                                                                                                                                                                                                                                               |
| Register Description                | Reworked <i>subsection 2.4 Register Description</i> and converted it to Register Description section.                                                                                                                                                                                                                                                                                                                                                                    |
| Memory Controller Example<br>Design | Added this section.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Designing and Simulating the IP     | Reworked section 3 IP Generation, Simulation, and Verification and renamed to this main section.                                                                                                                                                                                                                                                                                                                                                                         |
| Appendix A. Resource Utilization    | Reworked section contents.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| References                          | Reworked section contents.                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# Revision 1.1, September 2023

| Section                                   | Change Summary                                                                                                                                                                                                                                         |
|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| All                                       | <ul> <li>Changed the document title from 'Avant Memory Controller IP Core - Lattice Radiant Software' to 'Lattice Avant Memory Controller IP Core - Lattice Radiant Software'.</li> <li>Updated the document to JESD209-4C</li> </ul>                  |
| Introduction                              | <ul> <li>Updated Lattice Radiant Version to 2023.1 in Table 1.1. Quick Facts.</li> <li>Removed 933 MHz and BL32 from the Features section.</li> </ul>                                                                                                  |
| Functional Description                    | <ul> <li>Added AXI4 Interface section under Signal Description.</li> <li>Updated Table 2.2. Supported AXI4 Transactions, Table 2.3. Attributes Table, and Table 2.4. Attributes Descriptions.</li> </ul>                                               |
| IP Generation, Simulation, and Validation | <ul> <li>Added Creating a Radiant Project section.</li> <li>Updated Configuring and Generating the IP section for the new IP GUI.</li> <li>Added Figure 3.7 in the IP Evaluation section.</li> <li>Updated the Hardware Validation section.</li> </ul> |
| Ordering Part Number                      | Updated this section.                                                                                                                                                                                                                                  |
| Appendix A. Resource Utilization          | Updated this section.                                                                                                                                                                                                                                  |
| References                                | Updated this section.                                                                                                                                                                                                                                  |
| Technical Support Assistance              | Added reference link to the Lattice Answer Database.                                                                                                                                                                                                   |

## Revision 1.0, November 2022

| Section                | Change Summary                                                                                           |
|------------------------|----------------------------------------------------------------------------------------------------------|
| All                    | Changed document title to Avant Memory Controller IP Core - Lattice Radiant Software.                    |
| Introduction           | Updated Table 1.1. Quick Facts.                                                                          |
|                        | Added 266 and 933 MHz in the Features section.                                                           |
| Functional Description | Updated rst_n_i description and added Note 6 in Table 2.1. Memory Controller IP Core Signal Description. |
|                        | Updated Table 2.3 Attributes Table.                                                                      |
|                        | <ul> <li>Updated DDR Command Frequency and Write/Read Ordering Queue.</li> </ul>                         |
|                        | <ul> <li>Added note on supporter frequency per speed grade.</li> </ul>                                   |
|                        | Improved Enable DBI description in Table 2.4. Attributes Descriptions.                                   |
|                        | Updated Initialization and Training section.                                                             |



| Section                                      | Change Summary                                                                                                                                                                                  |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IP Generation, Simulation, and<br>Validation | <ul> <li>Updated subsections in the IP Generation, Simulation, and Validation section.</li> <li>Updated the IP Evaluation section.</li> <li>Updated the Hardware Validation section.</li> </ul> |
| Ordering Part Number                         | Updated this section.                                                                                                                                                                           |
| Appendix A. Resource Utilization             | Updated this section.                                                                                                                                                                           |
| References                                   | Updated this section.                                                                                                                                                                           |

## Revision 0.80, September 2022

| Section | Change Summary      |
|---------|---------------------|
| All     | Preliminary release |



www.latticesemi.com