# PrimeCell DDR2 Dynamic Memory Controller (PL341) Cycle Model

Version 9.1.0

**User Guide** 

Non-Confidential



# PrimeCell DDR2 Dynamic Memory Controller (PL341) Cycle Model User Guide

Copyright © 2017 ARM Limited. All rights reserved.

#### **Release Information**

The following changes have been made to this document.

**Change History** 

| Date          | Issue | Confidentiality  | Change          |
|---------------|-------|------------------|-----------------|
| February 2017 | A     | Non-Confidential | Restamp release |

#### **Non-Confidential Proprietary Notice**

This document is protected by copyright and other related rights and the practice or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of ARM Limited ("ARM"). No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether implementations infringe any patents.

THIS DOCUMENT IS PROVIDED "AS IS". ARM PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, ARM makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of, third party patents, copyrights, trade secrets, or other rights.

This document may include technical inaccuracies or typographical errors.

This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version shall prevail.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

This document consists solely of commercial items. You shall be responsible for ensuring that any use, duplication or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to ARM's customers is not intended to create or refer to any partnership relationship with any other company. ARM may make changes to this document at any time and without notice.

If any of the provisions contained in these terms conflict with any of the provisions of any signed written agreement specifically covering this document with ARM, then the signed written agreement prevails over and supersedes the conflicting provisions of these terms

Words and logos marked with ® or ™ are registered trademarks or trademarks of ARM Limited or its affiliates in the EU and/or elsewhere. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners. You must follow the ARM trademark usage guidelines http://www.arm.com/about/trademarks/guidelines/index.php.

Copyright © ARM Limited or its affiliates. All rights reserved. ARM Limited. Company 02557590 registered in England. 110 Fulbourn Road, Cambridge, England CB1 9NJ.

In this document, where the term ARM is used to refer to the company it means "ARM or any of its subsidiaries as appropriate".

#### **Confidentiality Status**

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by ARM and the party that ARM delivered this document to.

#### **Product Status**

The information in this document is final, that is for a developed product.

#### Web Address

http://www.arm.com

# Contents

| Preface                               |                 |
|---------------------------------------|-----------------|
|                                       | vii             |
|                                       | vii             |
|                                       | viii            |
|                                       | ix              |
| Glossary                              | x               |
| Chapter 1.                            |                 |
| Using the Cycle Model in SoC Designe  | r               |
| PL341 DDR2 Memory Controller Mode     | l Functionality |
| Fully Functional and Accurate Featu   | ıres            |
| Fully Functional and Approximate F    | Seatures        |
| Unsupported Hardware Features         |                 |
| Features Additional to the Hardware   |                 |
| Adding and Configuring the SoC Design | ner Component   |
| SoC Designer Component Files          | 4               |
| Adding the Cycle Model to the Com     | ponent Library5 |
| Adding the Component to the SoC I     | Designer Canvas |
| Available Component ESL Ports         |                 |
| Setting Component Parameters          |                 |
| Debug Features                        |                 |
| Register Information                  |                 |
| DMC Configuration Registers .         |                 |
| Visibility Registers/Signals          |                 |
| QoS Configuration Registers           |                 |
|                                       |                 |

| Chip Configuration Registers      | 13   |
|-----------------------------------|------|
| User Configuration Registers      | 13   |
| PrimeCell Configuration Registers | 13   |
| Memory Information                | . 14 |
| Available Profiling Data          | 14   |

# **Preface**

A Cycle Model component is a library developed from ARM intellectual property (IP) that is generated through Cycle Model Studio<sup>TM</sup>. The Cycle Model then can be used within a virtual platform tool, for example, SoC Designer.

#### **About This Guide**

This guide provides all the information needed to configure and use the Cycle Model in SoC Designer.

#### **Audience**

This guide is intended for experienced hardware and software developers who create components for use with SoC Designer. You should be familiar with the following products and technology:

- · SoC Designer
- Hardware design verification
- Verilog or SystemVerilog programming language

#### **Conventions**

This guide uses the following conventions:

| Convention        | Description                                                                                        | Example                                                                                  |
|-------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| courier           | Commands, functions, variables, routines, and code examples that are set apart from ordinary text. | <pre>sparseMem_t SparseMemCreate- New();</pre>                                           |
| italic            | New or unusual words or phrases appearing for the first time.                                      | Transactors provide the entry and exit points for data                                   |
| bold              | Action that the user performs.                                                                     | Click <b>Close</b> to close the dialog.                                                  |
| <text></text>     | Values that you fill in, or that the system automatically supplies.                                | <pre><place <="" <<="" place="" td=""></place></pre>                                     |
| [ text ]          | Square brackets [ ] indicate optional text.                                                        | <pre>\$CARBON_HOME/bin/modelstudio [ <filename> ]</filename></pre>                       |
| [ text1   text2 ] | The vertical bar   indicates "OR," meaning that you can supply text1 or text 2.                    | <pre>\$CARBON_HOME/bin/modelstudio [<name>.symtab.db   <name>.ccfg ]</name></name></pre> |

Also note the following references:

- References to C code implicitly apply to C++ as well.
- File names ending in .cc, .cpp, or .cxx indicate a C++ source file.

#### **Further reading**

This section lists related publications. The following publications provide information that relate directly to SoC Designer:

- SoC Designer Installation Guide
- SoC Designer User Guide
- SoC Designer Standard Component Library Reference Manual

The following publications provide reference information about ARM® products:

- AMBA 3 AHB-Lite Overview
- AMBA Specification (Rev 2.0)
- AMBA AHB Transaction Level Modeling Specification
- Architecture Reference Manual

See <a href="http://infocenter.arm.com/help/index.jsp">http://infocenter.arm.com/help/index.jsp</a> for access to ARM documentation.

The following publications provide additional information on simulation:

- IEEE 1666<sup>TM</sup> SystemC Language Reference Manual, (IEEE Standards Association)
- SPIRIT User Guide, Revision 1.2, SPIRIT Consortium.

#### Glossary

**AMBA** Advanced Microcontroller Bus Architecture. The ARM open standard on-chip bus specification that describes a strategy for the interconnection and management of functional blocks that make up a System-on-Chip (SoC). **AHB** Advanced High-performance Bus. A bus protocol with a fixed pipeline between address/control and data phases. It only supports a subset of the functionality provided by the AMBA AXI protocol. **APB** Advanced Peripheral Bus. A simpler bus protocol than AXI and AHB. It is designed for use with ancillary or general-purpose peripherals such as timers, interrupt controllers, UARTs, and I/O ports. **AXI** Advanced eXtensible Interface. A bus protocol that is targeted at high performance, high clock frequency system designs and includes a number of features that make it very suitable for high speed sub-micron interconnect. A software object created by the Cycle Model Studio (or Cycle Model Com-Cycle Model piler) from an RTL design. The Cycle Model contains a cycle- and registeraccurate model of the hardware design. Cycle Model Graphical tool for generating, validating, and executing hardware-accurate Studio software models. It creates a Cycle Model, and it also takes a Cycle Model as input and generates a component that can be used in SoC Designer, Platform Architect, or Accellera SystemC for simulation. **CASI** ESL API Simulation Interface, is based on the SystemC communication library and manages the interconnection of components and communication between components. **CADI** ESL API Debug Interface, enables reading and writing memory and register values and also provides the interface to external debuggers. **CAPI** ESL API Profiling Interface, enables collecting historical data from a component and displaying the results in various formats. Component Building blocks used to create simulated systems. Components are connected together with unidirectional transaction-level or signal-level connections. **ESL** Electronic System Level. A type of design and verification methodology that models the behavior of an entire system using a high-level language such as C or C++. **HDL** Hardware Description Language. A language for formal description of electronic circuits, for example, Verilog. RTL Register Transfer Level. A high-level hardware description language (HDL) for defining digital circuits. SoC Designer High-performance, cycle accurate simulation framework which is targeted at System-on-a-Chip hardware and software debug as well as architectural exploration. SystemC SystemC is a single, unified design and verification language that enables verification at the system level, independent of any detailed hardware and software implementation, as well as enabling co-verification with RTL design. Transactor Transaction adaptors. You add transactors to your component to connect your

form.

component directly to transaction level interface ports for your particular plat-

# Chapter 1

1

# Using the Cycle Model in SoC Designer

This chapter describes the functionality of the PL341 DDR2 Cycle Model, and how to use it in SoC Designer. It contains the following sections:

- PL341 DDR2 Memory Controller Model Functionality
- Adding and Configuring the SoC Designer Component
- Available Component ESL Ports
- Setting Component Parameters
- Debug Features
- Available Profiling Data

# 1.1 PL341 DDR2 Memory Controller Model Functionality

The PL341 memory controller is a high-performance, area-optimized DDR2 SDRAM memory controller compatible with the Advanced Microcontroller Bus Architecture (AMBA) AXI protocol. For a detailed description of the AXI protocol refer to the *AMBA AXI Protocol Specification*.

This section provides a summary of the functionality of the Cycle Model compared to that of the hardware, and the performance and accuracy of the Cycle Model.

- Fully Functional and Accurate Features
- Fully Functional and Approximate Features
- Unsupported Hardware Features
- Features Additional to the Hardware

For details of the functionality of the hardware that the Cycle Model represents, refer to the ARM PrimeCell DDR2 Dynamic Memory Controller (PL341) Technical Reference Manual.

## 1.1.1 Fully Functional and Accurate Features

The following features of the PL341 DDR2 Memory Controller hardware are fully implemented in the PL341 DDR2 Memory Controller Cycle Model:

• All features of the Cycle Model are both functionally and cycle accurate with the exception of those listed in Fully Functional and Approximate Features, below.

# 1.1.2 Fully Functional and Approximate Features

The following features of the PL341 DDR2 Memory Controller hardware are implemented in the PL341 DDR2 Memory Controller Cycle Model but the exact behavior of the hardware implementation is not accurately reproduced because some approximations and optimizations have been made for simulation performance:

• The self refresh logic is functionally correct but self refreshes may occur at slightly different times in the Cycle Model and in RTL

## 1.1.3 Unsupported Hardware Features

The following hardware features have not been implemented in the PL341 Cycle Model:

- Error Correction Code (ECC) and related registers
- DFT/ATPG (Automatic Test Pattern Generator) testing features
- AXI Low-power interface
- Memory clock ratio
- DFI Pad interface
- The following registers are not available to be read / written via debug transactions for example, in the SoC Designer Registers window, or by accessing them directly from RealView Debugger:
  - Integration test registers: int cfg, int inputs, int outputs
  - ECC registers: ecc info0, ecc status, ecc int clr, ecc control
  - DFI pad-related registers: update type, t rddata en, t wrlat diff
  - memc\_cmd and direct\_cmd. The Cycle Model-implemented registers
     memc\_cmd\_current\_value and direct\_cmd\_current\_value hold the values of these registers. Refer to Features Additional to the Hardware for more information.

The functionality of these registers, however, does exist and can be accessed by software running on the virtual platform.

- The *memory cfg2* register is read-only in the Cycle Model.
- The PL341 Technical Reference Manual shows multiple clocks: aclk, mclk, mclkn, mclkx2, and mclkx2n.
  - The Cycle Model has only clk-in.

#### 1.1.4 Features Additional to the Hardware

The following features that are implemented in the PL341 DDR2 Memory Controller Cycle Model to enhance usability do not exist in the PL341 DDR2 Memory Controller hardware:

- The PL341 memory controller Cycle Model has the memory built into the Cycle Model, so you do not need to provide a memory.
- Debug and profiling features. For further information about debug and profiling features, refer to "Debug Features" on page 1-10 and "Available Profiling Data" on page 1-14 respectively.
- The registers view includes two registers that are not defined in the *PL341Technical Reference Manual*:
  - memc\_cmd\_current\_value Holds the current value (read-only) of the register memc\_cmd.
  - direct\_cmd\_current\_value Holds the current value (read-only) of the register direct\_cmd.

# 1.2 Adding and Configuring the SoC Designer Component

The following topics briefly describe how to use the component. See the SoC Designer User Guide for more information.

- SoC Designer Component Files
- Adding the Cycle Model to the Component Library
- Adding the Component to the SoC Designer Canvas

## 1.2.1 SoC Designer Component Files

The component files are the final output from the Cycle Model Studio compile and are the input to SoC Designer. There are two versions of the component; an optimized release version for normal operation, and a *debug* version.

On Linux the *debug* version of the component is compiled without optimizations and includes debug symbols for use with gdb. The *release* version is compiled without debug information and is optimized for performance.

On Windows the *debug* version of the component is compiled referencing the debug runtime libraries, so it can be linked with the debug version of SoC Designer. The release version is compiled referencing the release runtime library. Both release and debug versions generate debug symbols for use with the Visual C++ debugger on Windows.

The provided component files are listed below:

**Table 1-1 SoC Designer Component Files** 

| Platform | File                                              | Description                         |
|----------|---------------------------------------------------|-------------------------------------|
| Linux    | maxlib.lib <model_name>.conf</model_name>         | SoC Designer configuration file     |
|          | lib <component_name>.mx.so</component_name>       | SoC Designer component runtime file |
|          | lib <component_name>.mx_DBG.so</component_name>   | SoC Designer component debug file   |
| Windows  | maxlib.lib <model_name>.windows.conf</model_name> | SoC Designer configuration file     |
|          | lib <component_name>.mx.dll</component_name>      | SoC Designer component runtime file |
|          | lib <component_name>.mx_DBG.dll</component_name>  | SoC Designer component debug file   |

Additionally, this User Guide PDF file is provided with the component.

# 1.2.2 Adding the Cycle Model to the Component Library

The compiled Cycle Model component is provided as a configuration file (.conf). To make the component available in the Component Window in SoC Designer Canvas, perform the following steps:

- 1. Launch SoC Designer Canvas.
- 2. From the *File* menu, select **Preferences**.
- 3. Click on **Component Library** in the list on the left.
- 4. Under the Additional Component Configuration Files window, click Add.
- 5. Browse to the location where the SoC Designer Cycle Model is located and select the component configuration file:
  - maxlib.lib<model name>.conf (for Linux)
  - maxlib.lib<model name>.windows.conf (for Windows)
- 6. Click OK.
- 7. To save the preferences permanently, click the **OK & Save** button.

The component is now available from the SoC Designer Component Window.

# 1.2.3 Adding the Component to the SoC Designer Canvas

Locate the component in the *Component Window* and drag it out to the Canvas.

# 1.3 Available Component ESL Ports

The PL341 Cycle Model component has an APB transaction slave port, an AXI transaction slave port and additional signal slave ports as shown below. The APB port is for configuring the component, whereas the AXI port is for accessing the memory.

Table 1-2 describes the ESL ports that are exposed in SoC Designer. See the *ARM PrimeCell*® *DDR2 Dynamic Memory Controller (PL341) Technical Reference Manual* for more information.

**Table 1-2 ESL Component Ports** 

| ESL Port     | Description                                                                                                                                | Direction | Туре                  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------------|
| apb          | APB port for memory mapped register accesses. Refer to section A.4 of the <i>PL341 Technical Reference Manual</i> for the APB signal list. | slave     | APB transaction slave |
| axi          | AXI port for memory accesses. Refer to section A.3 of the <i>PL341 Technical Reference Manual</i> for the AXI signal list.                 | slave     | AXI transaction slave |
| pclken       | Clock enable for APB domain.                                                                                                               | slave     | Signal                |
| qos_override | Signal port to override Quality of Service (QoS).                                                                                          | slave     | Signal                |
| user_status  | General purpose APB-accessible input signals.                                                                                              | slave     | Signal                |
| clk-in       | Input clock port.                                                                                                                          | slave     | Clock slave           |
| user_config0 | General purpose APB-accessible output signals.                                                                                             | master    | Signal                |
| user_config1 | General purpose APB-accessible output signals.                                                                                             | master    | Signal                |

All pins that are not listed in this table have been either tied or disconnected for performance reasons.

Note: Some ESL component port values can be set using a component parameter. This includes the pclken and user\_status ports. In those cases, the parameter value will be used whenever the ESL port is not connected. If the port is connected, the connection value takes precedence over the parameter value.

# 1.4 Setting Component Parameters

You can change the settings of all the component parameters in SoC Designer Canvas, and of some of the parameters in SoC Designer Simulator. To modify the component's parameters:

- 1. In the Canvas, right-click on the component and select **Edit Parameters...**. You can also double-click the component. The *Edit Parameters* dialog box appears.
- 2. In the *Parameters* window, double-click the **Value** field of the parameter that you want to modify.
- 3. If it is a text field, type a new value in the *Value* field. If a menu choice is offered, select the desired option. The parameters are described in Table 1-3.

**Table 1-3 Component Parameters** 

| Parameter Name                 | Description                                                                                                                                                                       | Allowed<br>Values  | Default Value                                                 | Runtime <sup>1</sup> |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------------|----------------------|
| apb Base Address               | APB Region base address. The address must be on a 4KB boundary.                                                                                                                   | 0x0 -<br>0xFFFFFFF | 0x0                                                           | No                   |
| apb Enable Debug<br>Messages   | When set to <i>true</i> , APB debug messages are written into the SoC Designer output window.                                                                                     | true, false        | false                                                         | Yes                  |
| apb Size                       | APB region size.                                                                                                                                                                  | 0x0 -<br>0xFFFFFFF | 0x100000000                                                   | No                   |
| axi axi_size[0-5] <sup>2</sup> | These parameters are obsolete and should be left at their default values. <sup>3</sup>                                                                                            | 0x0 -<br>0xFFFFFFF | size0 default is<br>0x100000000,<br>size1-5 default is<br>0x0 | No                   |
| axi axi_start[0-5]             |                                                                                                                                                                                   | 0x0 -<br>0xFFFFFFF | 0x00000000                                                    | No                   |
| axi Enable Debug<br>Messages   | When set to <i>true</i> , AXI debug messages are written into the SoC Designer output window.                                                                                     | true, false        | false                                                         | Yes                  |
| Align Waveforms                | When set to <i>true</i> , waveforms dumped from the component are aligned with the SoC Designer simulation time. The reset sequence, however, is not included in the dumped data. | true, false        | true                                                          | No                   |
|                                | When set to <i>false</i> , the reset sequence is dumped to the waveform data, however, the component time is not aligned with the SoC Designer time.                              |                    |                                                               |                      |
| Carbon DB Path                 | Sets the directory path to the database file.                                                                                                                                     | Not used           | empty                                                         | No                   |

**Table 1-3 Component Parameters (continued)** 

| Parameter Name                           | Description                                                                                                                                                                                                                                                  | Allowed<br>Values        | Default Value                                               | Runtime <sup>1</sup> |
|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------------------------------------------------------------|----------------------|
| chip_start <n></n>                       | Initial start address, in each memory region < <i>n</i> >, that is used for program loading and debug access before the simulation is started. The number of <i>chip_start</i> parameters depends on the number of memory chips configured in AMBA Designer. | 0x0 -<br>0xFFFFFFF       | 0x00000000                                                  | No                   |
| Dump Waveforms                           | Whether SoC Designer dumps waveforms for this component.                                                                                                                                                                                                     | true, false              | false                                                       | Yes                  |
| Enable Debug<br>Messages                 | When set to <i>true</i> , debug messages are written into the SoC Designer output window.                                                                                                                                                                    | true, false              | false                                                       | Yes                  |
| Maximum amber read latency <sup>4</sup>  | Max value displayed as amber for read latency profiling; if latency exceeds this value, it is displayed as red.                                                                                                                                              | >0                       | 30                                                          | Yes                  |
| Maximum amber write latency <sup>3</sup> | Max value displayed as amber for write latency profiling; if latency exceeds this value, it is displayed as red.                                                                                                                                             | >0                       | 30                                                          | Yes                  |
| Maximum green read latency <sup>3</sup>  | Max value displayed as green for read latency profiling.                                                                                                                                                                                                     | >0                       | 20                                                          | Yes                  |
| Maximum green write latency <sup>3</sup> | Max value displayed as green for write latency profiling.                                                                                                                                                                                                    | >0                       | 20                                                          | Yes                  |
| pclken                                   | Clock enable for APB domain.                                                                                                                                                                                                                                 | 0, 1                     | 0x1                                                         | Yes                  |
| user_status                              | General purpose APB-accessible input pins.                                                                                                                                                                                                                   | 0x0 - 0xFF               | 0x0                                                         | Yes                  |
| Waveform File <sup>5</sup>               | Name of the waveform file.                                                                                                                                                                                                                                   | string                   | arm_cm_pl341_<br><component_name><br/>.vcd</component_name> | No                   |
| Waveform Timescale                       | Sets the timescale to be used in the waveform.                                                                                                                                                                                                               | Many values in drop-down | 1 ns                                                        | No                   |

<sup>1.</sup> Yes means the parameter can be dynamically changed during simulation, No means it can be changed only when building the system.

<sup>2.</sup> The square brackets used in parameter names specify a range of numbers that are available for the Cycle Model. The parameter name for the start addresses "axi axi\_start[0-5]" for example will be expanded to 6 possible parameter name combinations that range from "axi axi\_start0" to "axi axi\_start5". The size of a memory region depends on the "axi axi\_start[M]" and "axi axi\_size[M]" parameters. The end address is calculated as StartAddr +Size -1. The size of the memory region must not exceed the value of 0x100000000. If the sum of StartAddr+Size is greater than 0x100000000, the size of the memory region is reduced to the difference: 0x100000000-StartAddr.

- 3. ARM recommends using the Memory Map Editor (MME) in SoC Designer, which provides centralized viewing and management of the memory regions available to the components in a system. For information about migrating existing systems to use the MME, refer to Chapter 9 of the SoC Designer User Guide.
- 4. See "Available Profiling Data" on page 1-14 for more information about Read and Write latency profiling.
- 5. When enabled, SoC Designer writes accumulated waveforms to the waveform file in the following situations: when the waveform buffer fills, when validation is paused and when validation finishes, and at the end of each validation run.

# 1.5 Debug Features

The PL341 DDR2 Memory Controller Cycle Model has a debug interface (CADI) that allows the user to view, manipulate and control the registers and memory in the SoC Designer Simulator or any debugger that supports the CADI, for example, Model Debugger. A view can be accessed in the SoC Designer Simulator or an instance of the Model Debugger can be attached by right clicking on the Cycle Model and choosing the appropriate menu entry. The views shown in this section are for the SoC Designer Simulator.

- Register Information
- Memory Information

# 1.5.1 Register Information

Figure 1-3 shows the register view of the PL341 DDR2 Memory Controller Cycle Model in the SoC Designer Simulator. Registers are grouped into different sets according to functional area.

The registers are described briefly in this section. See the ARM PrimeCell DDR2 Dynamic Memory Controller (PL341) Technical Reference Manual for complete information.

The following Registers are supported:

- DMC Configuration Registers
- Visibility Registers/Signals
- QoS Configuration Registers
- Chip Configuration Registers
- User Configuration Registers
- PrimeCell Configuration Registers

#### 1.5.1.1 DMC Configuration Registers

Table 1-4 shows the DMC Configuration registers. This tab shows the registers that configure the entire memory controller, including timing and ID registers.

**Table 1-4 DMC Configuration Registers** 

| Name        | Description                                                                                                                     | Туре       |
|-------------|---------------------------------------------------------------------------------------------------------------------------------|------------|
| memc_status | The Memory Controller Status register provides information on the configuration and the current state of the memory controller. | read-only  |
| memory_cfg  | The Memory Configuration register controls the operation of the DDR2 DMC. It should be configured with the following values:    | read-write |
|             | row_bits - 14<br>column_bits - 10                                                                                               |            |
| refresh_prd | The Refresh Period register sets the memory refresh period in memory clock cycles.                                              | read-write |
| cas_latency | The CAS Latency register controls the CAS latency time in memory clock cycles.                                                  | read-write |

Table 1-4 DMC Configuration Registers (continued)

| Name          | Description                                                                                               | Туре       |
|---------------|-----------------------------------------------------------------------------------------------------------|------------|
| write_latency | The Write Latency register returns the write latency in memory clock cycles.                              | read-only  |
| t_mrd         | The t_mrd register controls the MODEREG to command delay in memory clock cycles.                          | read-write |
| t_ras         | The t_ras register controls the ACTIVE to PRECHARGE delay in memory clock cycles.                         | read-write |
| t_rc          | The t_rc register controls the ACTIVE bank x to ACTIVE bank x delay in memory clock cycles.               | read-write |
| t_rcd         | The t_rcd register controls the RAS to CAS minimum delay in memory clock cycles.                          | read-write |
| t_rfc         | The t_rfc register controls the AUTO REFRESH to command delay in memory clock cycles.                     | read-write |
| t_rp          | The t_rp register controls the PRECHARGE to RAS delay in memory clock cycles.                             | read-write |
| t_rrd         | The t_rrd register controls the ACTIVE bank x to ACTIVE bank y delay in memory clock cycles.              | read-write |
| t_wr          | The t_wr register controls the Write to PRECHARGE delay in memory clock cycles.                           | read-write |
| t_wtr         | The t_wtr register controls the Write to Read delay in memory clock cycles.                               | read-write |
| t_xp          | The t_xp register controls exit power-down command delay in memory clock cycles.                          | read-write |
| t_xsr         | The t_xsr register controls exit self-refresh command delay in memory clock cycles.                       | read-write |
| t_esr         | The t_esr register controls self-refresh command delay in memory clock cycles.                            | read-write |
| memory_cfg2   | The Memory Configuration 2 register displays the operating state of the memory controller and the memory. | read-only  |
| memory_cfg3   | The Memory Configuration 3 register controls the refresh timeout setting.                                 | read-write |
| t_faw         | The Four Activate Window Timing register controls the four bank activate time in memory clock cycles.     | read-write |

# 1.5.1.2 Visibility Registers/Signals

Table 1-5 shows the registers/signals on the Visibility tab. These have been added to improve visibility into the design. They are not defined in the *PrimeCell DDR2 Dynamic Memory Controller (PL341) Technical Reference Manual*.

Note: memc\_cmd\_current\_value and direct\_cmd\_current\_value display transient values as values are written by a bus access to the memc\_cmd and direct\_cmd registers of the PL341. The values displayed may not be retained in this view. You may observe the value as it is being written but the display value may return to zero after the bus write has completed.

Table 1-5 Visibility Registers/Signals

| Name                     | Description                                               | Туре             |
|--------------------------|-----------------------------------------------------------|------------------|
| memc_cmd_current_value   | Holds the current value of the register <i>memc_cmd</i> . | read-only signal |
| direct_cmd_current_value | Holds the current value of the register direct_cmd.       | read-only signal |

## 1.5.1.3 QoS Configuration Registers

Table 1-6 shows the Quality of Service (QoS) Configuration registers.

**Table 1-6 ID Configuration Registers** 

| Name      | Description                                             | Туре       |
|-----------|---------------------------------------------------------|------------|
| id_0_cfg  | These 16 registers set the QoS (Quality of Service) and | read-write |
| id_1_cfg  | span address locations 0x100-0x13C.                     | read-write |
| id_2_cfg  |                                                         | read-write |
| id_3_cfg  |                                                         | read-write |
| id_4_cfg  |                                                         | read-write |
| id_5_cfg  |                                                         | read-write |
| id_6_cfg  |                                                         | read-write |
| id_7_cfg  |                                                         | read-write |
| id_8_cfg  |                                                         | read-write |
| id_9_cfg  |                                                         | read-write |
| id_10_cfg |                                                         | read-write |
| id_11_cfg |                                                         | read-write |
| id_12_cfg |                                                         | read-write |
| id_13_cfg |                                                         | read-write |
| id_14_cfg |                                                         | read-write |
| id_15_cfg |                                                         | read-write |

#### 1.5.1.4 Chip Configuration Registers

Table 1-7 shows the CHIP\_CFG Chip Configuration registers. The number of *chip\_cfg* registers depends on the number of memory chips configured in AMBA Designer.

**Table 1-7 Chip Configuration Registers** 

| Name      | Description                                                                                                                                                          | Туре       |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| chip_cfg0 | ration. The number of external chips supported, and therefore the number of these registers, depends on your configuration. They span address locations 0x200-0x20C. | read-write |
| chip_cfg1 |                                                                                                                                                                      | read-write |
| chip_cfg2 |                                                                                                                                                                      | read-write |
| chip_cfg3 |                                                                                                                                                                      | read-write |

Note: Component parameter values are used for debug access before the start of simulation, so program loading will use the "chip\_startx" parameter values. Once the simulation starts (when cycle count is greater than 0), debug access will always use the register values. Note that debug access is invalid during the CONFIG state as register values can change.

#### 1.5.1.5 User Configuration Registers

Table 1-4 shows the USER CFG User Configuration registers.

**Table 1-8 User Configuration Registers** 

| Name         | Description                                                                                       | Туре       |
|--------------|---------------------------------------------------------------------------------------------------|------------|
| user_status  | This register returns the state of the <i>user_status</i> primary inputs.                         | read-only  |
| user_config0 | This register sets the value of the <i>user_config0</i> primary outputs.                          | read-write |
| user_config1 | This register sets the value of the <i>user_config1</i> primary outputs.                          | read-write |
| feature_ctrl | The Feature Control register controls the early write response behavior and write burst behavior. | read-write |

#### 1.5.1.6 PrimeCell Configuration Registers

Table 1-4 shows the PRIMECELL\_CFG Configuration registers. The Peripheral Identification registers provide information about the configuration and version of the peripheral.

**Table 1-9 PrimeCell Configuration Registers** 

| Name        | Description                                                | Туре      |
|-------------|------------------------------------------------------------|-----------|
| periph_id_0 | Identifies the part number of the peripheral.              | read-only |
| periph_id_1 | Identifies the part number and designer of the peripheral. | read-only |
| periph_id_2 | Identifies the revision and designer of the peripheral.    | read-only |
| periph_id_3 | Identifies the configuration of the peripheral.            | read-only |

Table 1-9 PrimeCell Configuration Registers (continued)

| Name       | Description                                                                                                                                                 | Туре      |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| pcell_id_0 | that span address locations 0xFF0-0xFFC. The registers can be treated conceptually as a single register that holds a 32-bit PrimeCell identification value. | read-only |
| pcell_id_1 |                                                                                                                                                             | read-only |
| pcell_id_2 |                                                                                                                                                             | read-only |
| pcell_id_3 |                                                                                                                                                             | read-only |

# 1.5.2 Memory Information

DDR2 with legacy pad interface is the only supported memory type. It can be configured for up to 4 chips, and the size of each chip depends on the defined memory data width and number of banks.

Note: The Memory view does not display any values when the PL341 is in the CONFIG state, and it will use the CHIP\_CFG register values for displaying the Memory view once the simulation starts (when cycle count is greater than 0).

# 1.6 Available Profiling Data

Profiling data is enabled, and can be viewed using the Profiling Manager, which is accessible via the Debug menu in the SoC Designer Simulator. The profiling events are the ones that can be monitored in the hardware using counters. The PL341 Cycle Model profiles the events shown in Table 1-10.

Table 1-10 PL341 Profiling Streams and Events

| Stream         | Events            | X axis | Y axis         |
|----------------|-------------------|--------|----------------|
| Memory Command | Activate          | Cycle  | Memory command |
|                | Read              |        |                |
|                | Write             |        |                |
|                | Precharge         |        |                |
|                | Precharge all     |        |                |
|                | Self-refresh      |        |                |
|                | Self-refresh exit |        |                |
|                | Auto refresh      |        |                |
|                | Mode reg          |        |                |
| Read Latency   | Green             | Cycle  | Read latency   |
|                | Amber             |        |                |
|                | Red <sup>1</sup>  |        |                |
| Write Latency  | Green             | Cycle  | Write latency  |
|                | Amber             |        |                |
|                | Red <sup>1</sup>  |        |                |

<sup>1.</sup> The Red bin is incremented when latency is greater than the Amber and Green thresholds.

Note: Write Latency is measured from the time of the write request on the AW channel to the time of the response on the B channel. Read Latency is measured in the same way, using the AR and R channels.

Latency values are assigned to buckets based on thresholds you can set using component parameters. See "Component Parameters" on page 1-7.