PrimeCell® AHB SRAM/NOR Memory Controller (PL241)

Revision: r0p1

PrimeCell AHB SRAM/NOR Memory Controller (PL241)

Copyright © 2006 ARM Limited. All rights reserved.

Release Information

The following changes have been made to this book.

<table>
<thead>
<tr>
<th>Date</th>
<th>Issue</th>
<th>Confidentiality</th>
<th>Change</th>
</tr>
</thead>
<tbody>
<tr>
<td>17 March 2006</td>
<td>A</td>
<td>Non-Confidential</td>
<td>First release for r0p0.</td>
</tr>
<tr>
<td>20 December 2006</td>
<td>B</td>
<td>Non-Confidential</td>
<td>Updated for r0p1.</td>
</tr>
</tbody>
</table>

Proprietary Notice

Words and logos marked with ® or ™ are registered trademarks or trademarks of ARM Limited in the EU and other countries, except as otherwise stated below in this proprietary notice. Other brands and names mentioned herein may be the trademarks of their respective owners.

Neither the whole nor any part of the information contained in, or the product described in, this document may be adapted or reproduced in any material form except with the prior written permission of the copyright holder.

The product described in this document is subject to continuous developments and improvements. All particulars of the product and its use contained in this document are given by ARM Limited in good faith. However, all warranties implied or expressed, including but not limited to implied warranties of merchantability, or fitness for purpose, are excluded.

This document is intended only to assist the reader in the use of the product. ARM Limited shall not be liable for any loss or damage arising from the use of any information in this document, or any error or omission in such information, or any incorrect use of the product.

Where the term ARM is used 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
About this manual ................................................................................................. x
Feedback .............................................................................................................. xiv

Chapter 1 Introduction
1.1 About the AHB MC ...................................................................................... 1-2
1.2 Supported devices ...................................................................................... 1-5

Chapter 2 Functional Overview
2.1 Functional description ............................................................................... 2-2
2.2 SMC .......................................................................................................... 2-4
2.3 Functional operation .................................................................................. 2-7
2.4 SMC functional operation .......................................................................... 2-15

Chapter 3 Programmer’s Model
3.1 About the programmer’s model ............................................................... 3-2
3.2 Register summary ...................................................................................... 3-3
3.3 Register descriptions .................................................................................. 3-6
### Contents

**Chapter 4**  
**Programmer’s Model for Test**  
4.1 SMC integration test registers ................................................. 4-2

**Chapter 5**  
**Device Driver Requirements**  
5.1 Memory initialization .......................................................... 5-2

**Appendix A**  
**Signal Descriptions**  
A.1 About the signals list ........................................................... A-2  
A.2 Clocks and resets ................................................................. A-3  
A.3 AHB signals ........................................................................ A-4  
A.4 SMC memory interface signals ............................................ A-5  
A.5 SMC miscellaneous signals .................................................. A-6  
A.6 Low-power interface ............................................................. A-7  
A.7 Configuration signal ............................................................ A-8  
A.8 Scan chains .......................................................................... A-9

**Glossary**
List of Tables

<table>
<thead>
<tr>
<th>Table</th>
<th>Description</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Table 2-1</td>
<td>Static memory clocking options</td>
<td>2-12</td>
</tr>
<tr>
<td>Table 2-2</td>
<td>Asynchronous read opmode chip register settings</td>
<td>2-28</td>
</tr>
<tr>
<td>Table 2-3</td>
<td>Asynchronous read SRAM cycles register settings</td>
<td>2-28</td>
</tr>
<tr>
<td>Table 2-4</td>
<td>Asynchronous read in multiplexed-mode opmode chip register settings</td>
<td>2-29</td>
</tr>
<tr>
<td>Table 2-5</td>
<td>Asynchronous read in multiplexed-mode SRAM cycles register settings</td>
<td>2-29</td>
</tr>
<tr>
<td>Table 2-6</td>
<td>Asynchronous write opmode chip register settings</td>
<td>2-30</td>
</tr>
<tr>
<td>Table 2-7</td>
<td>Asynchronous write SRAM cycles register settings</td>
<td>2-30</td>
</tr>
<tr>
<td>Table 2-8</td>
<td>Asynchronous write in multiplexed-mode opmode chip register settings</td>
<td>2-31</td>
</tr>
<tr>
<td>Table 2-9</td>
<td>Asynchronous write in multiplexed-mode SRAM cycles register settings</td>
<td>2-31</td>
</tr>
<tr>
<td>Table 2-10</td>
<td>Page read opmode chip register settings</td>
<td>2-31</td>
</tr>
<tr>
<td>Table 2-11</td>
<td>Page read SRAM cycles register settings</td>
<td>2-31</td>
</tr>
<tr>
<td>Table 2-12</td>
<td>Synchronous burst read opmode chip register settings</td>
<td>2-32</td>
</tr>
<tr>
<td>Table 2-13</td>
<td>Synchronous burst read SRAM cycles register settings</td>
<td>2-32</td>
</tr>
<tr>
<td>Table 2-14</td>
<td>Synchronous burst read in multiplexed-mode opmode chip register settings</td>
<td>2-34</td>
</tr>
<tr>
<td>Table 2-15</td>
<td>Synchronous burst read in multiplexed-mode read SRAM cycles register settings</td>
<td>2-34</td>
</tr>
<tr>
<td>Table 2-16</td>
<td>Synchronous burst write opmode chip register settings</td>
<td>2-35</td>
</tr>
<tr>
<td>Table 2-17</td>
<td>Synchronous burst write SRAM cycles register settings</td>
<td>2-35</td>
</tr>
<tr>
<td>Table 2-18</td>
<td>Synchronous burst write in multiplexed-mode opmode chip register settings</td>
<td>2-36</td>
</tr>
<tr>
<td>Table 2-19</td>
<td>Synchronous burst write in multiplexed-mode SRAM cycles register settings</td>
<td>2-36</td>
</tr>
<tr>
<td>Table 2-20</td>
<td>Synchronous read and asynchronous write opmode chip register settings</td>
<td>2-37</td>
</tr>
</tbody>
</table>
Table 2-21 Synchronous read and asynchronous write opmode chip register settings ............ 2-37
Table 3-1 Register summary .................................................................................................. 3-4
Table 3-2 smc_memc_status Register bit assignments ............................................................ 3-6
Table 3-3 smc_memif_cfg Register bit assignments ............................................................... 3-7
Table 3-4 smc_memc_cfg_set Register bit assignments ......................................................... 3-9
Table 3-5 smc_memc_cfg_clr Register bit assignments .......................................................... 3-9
Table 3-6 smc_direct_cmd Register bit assignments ............................................................. 3-10
Table 3-7 smc_set_cycles Register bit assignments .............................................................. 3-11
Table 3-8 smc_set_opmode Register bit assignments ........................................................... 3-13
Table 3-9 smc_refresh_period_0 Register bit assignments ..................................................... 3-15
Table 3-10 smc_sram_cycles Register bit assignments ............................................................ 3-16
Table 3-11 smc_opmode Register bit assignments ................................................................. 3-17
Table 3-12 smc_user_status Register bit assignments ............................................................ 3-18
Table 3-13 smc_user_config Register bit assignments ............................................................ 3-19
Table 3-14 smc_periph_id Register bit assignments .............................................................. 3-19
Table 3-15 smc_periph_id_0 Register bit assignments ........................................................... 3-20
Table 3-16 smc_periph_id_1 Register bit assignments ........................................................... 3-21
Table 3-17 smc_periph_id_2 Register bit assignments ........................................................... 3-21
Table 3-18 smc_periph_id_3 Register bit assignments ........................................................... 3-21
Table 3-19 smc_pcell_id Register bit assignments ................................................................. 3-22
Table 3-20 smc_pcell_id_0 Register bit assignments .............................................................. 3-23
Table 3-21 smc_pcell_id_1 Register bit assignments .............................................................. 3-23
Table 3-22 smc_pcell_id_2 Register bit assignments .............................................................. 3-24
Table 3-23 smc_pcell_id_3 Register bit assignments .............................................................. 3-24
Table 4-1 SMC test register summary ...................................................................................... 4-2
Table 4-2 smc_int_cfg Register bit assignments ...................................................................... 4-3
Table 4-3 smc_int_inputs Register bit assignments ............................................................... 4-3
Table 4-4 smc_int_outputs Register bit assignments ............................................................ 4-4
Table A-1 Clocks and resets .................................................................................................. A-3
Table A-2 AHB signals ........................................................................................................... A-4
Table A-3 SMC memory interface signals ............................................................................ A-5
Table A-4 SMC miscellaneous signals .................................................................................. A-6
Table A-5 Low-power interface signals ................................................................................. A-7
Table A-6 Configuration signal ............................................................................................. A-8
Table A-7 Scan chain signals ............................................................................................... A-9
<table>
<thead>
<tr>
<th>Figure</th>
<th>Description</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Figure 1-1</td>
<td>AHB MC (PL241) configuration</td>
<td>1-2</td>
</tr>
<tr>
<td>Figure 2-1</td>
<td>AHB MC (PL241) configuration</td>
<td>2-2</td>
</tr>
<tr>
<td>Figure 2-2</td>
<td>AHB MC (PL241) clock domains</td>
<td>2-3</td>
</tr>
<tr>
<td>Figure 2-3</td>
<td>SMC block diagram</td>
<td>2-4</td>
</tr>
<tr>
<td>Figure 2-4</td>
<td>SMC SRAM pad interface external connections</td>
<td>2-6</td>
</tr>
<tr>
<td>Figure 2-5</td>
<td>Big-endian implementation</td>
<td>2-10</td>
</tr>
<tr>
<td>Figure 2-6</td>
<td>AHBC memory map</td>
<td>2-11</td>
</tr>
<tr>
<td>Figure 2-7</td>
<td>Request to enter low-power mode</td>
<td>2-13</td>
</tr>
<tr>
<td>Figure 2-8</td>
<td>AHB domain denying a low-power request</td>
<td>2-13</td>
</tr>
<tr>
<td>Figure 2-9</td>
<td>Accepting requests</td>
<td>2-14</td>
</tr>
<tr>
<td>Figure 2-10</td>
<td>SMC aclk domain FSM</td>
<td>2-15</td>
</tr>
<tr>
<td>Figure 2-11</td>
<td>Chip configuration registers</td>
<td>2-23</td>
</tr>
<tr>
<td>Figure 2-12</td>
<td>Device pin mechanism</td>
<td>2-25</td>
</tr>
<tr>
<td>Figure 2-13</td>
<td>Software mechanism</td>
<td>2-26</td>
</tr>
<tr>
<td>Figure 2-14</td>
<td>Asynchronous read</td>
<td>2-29</td>
</tr>
<tr>
<td>Figure 2-15</td>
<td>Asynchronous read in multiplexed-mode</td>
<td>2-29</td>
</tr>
<tr>
<td>Figure 2-16</td>
<td>Asynchronous write</td>
<td>2-30</td>
</tr>
<tr>
<td>Figure 2-17</td>
<td>Asynchronous write in multiplexed-mode</td>
<td>2-31</td>
</tr>
<tr>
<td>Figure 2-18</td>
<td>Page read</td>
<td>2-32</td>
</tr>
<tr>
<td>Figure 2-19</td>
<td>Synchronous burst read</td>
<td>2-33</td>
</tr>
</tbody>
</table>

Key to timing diagram conventions ........................................................................... xii
List of Figures

Figure 2-20  Synchronous burst read in multiplexed-mode ........................................ 2-34
Figure 2-21  Synchronous burst write ................................................................. 2-35
Figure 2-22  Synchronous burst write in multiplexed-mode ................................ 2-36
Figure 2-23  Synchronous read and asynchronous write ..................................... 2-38
Figure 3-1   SMC register map ......................................................................... 3-2
Figure 3-2   SMC configuration register map ....................................................... 3-3
Figure 3-3   SMC chip configuration register map ............................................... 3-3
Figure 3-4   SMC user configuration register map ............................................... 3-4
Figure 3-5   SMC peripheral and PrimeCell identification configuration register map 3-4
Figure 3-6   smc_memc_status Register bit assignments ........................................ 3-6
Figure 3-7   smc_memif_cfg Register bit assignments ............................................ 3-7
Figure 3-8   smc_memc_cfg_set Register bit assignments ...................................... 3-8
Figure 3-9   smc_memc_cfg_clr Register bit assignments ....................................... 3-9
Figure 3-10  smc_direct_cmd Register bit assignments ........................................ 3-10
Figure 3-11  smc_set_cycles Register bit assignments ......................................... 3-11
Figure 3-12  smc_set_opmode Register bit assignments ....................................... 3-12
Figure 3-13  smc_refresh_period_0 Register bit assignments .............................. 3-15
Figure 3-14  smc_sram_cycles Register bit assignments ....................................... 3-15
Figure 3-15  smc_opmode Register bit assignments ............................................. 3-16
Figure 3-16  smc_user_status Register bit assignments ....................................... 3-18
Figure 3-17  smc_user_config Register bit assignments ........................................ 3-19
Figure 3-18  smc_periph_id Register bit assignments ........................................... 3-20
Figure 3-19  smc_pcell_id Register bit assignments ............................................. 3-22
Figure 4-1   SMC integration test register map ..................................................... 4-2
Figure 4-2   smc_int_cfg Register bit assignments ................................................ 4-2
Figure 4-3   smc_int_inputs Register bit assignments ........................................... 4-3
Figure 4-4   smc_int_outputs Register bit assignments ......................................... 4-4
Figure 5-1   SMC and memory initialization sheet 1 of 3 ....................................... 5-3
Figure 5-2   SMC and memory initialization sheet 2 of 3 ....................................... 5-4
Figure 5-3   SMC and memory initialization sheet 3 of 3 ....................................... 5-5
Figure A-1  AHB MC PL241 grouping of signals .................................................. A-2
Preface

This preface introduces the *PrimeCell AHB SRAM/NOR Memory Controller (MC) (PL241) Technical Reference Manual*. It contains the following sections:

- *About this manual* on page x
- *Feedback* on page xiv.
About this manual

This is the Technical Reference Manual (TRM) for the PrimeCell AHB SRAM/NOR Memory Controller.

Product revision status

The rn pn identifier indicates the revision status of the product described in this manual, where:

rn Identifies the major revision of the product.

pn Identifies the minor revision or modification status of the product.

Intended audience

This manual is written for system designers, system integrators, and verification engineers who are designing a System-on-Chip (SoC) device that uses the AHB MC. The manual describes the external functionality of the AHB MC.

Using this manual

This manual is organized into the following chapters:

Chapter 1 Introduction

Read this chapter for a high-level view of the AHB MC and a description of its features.

Chapter 2 Functional Overview

Read this chapter for a description of the major components of the AHB MC and how they operate.

Chapter 3 Programmer's Model

Read this chapter for a description of the AHB MC registers.

Chapter 4 Programmer's Model for Test

Read this chapter for a description of the additional logic for integration testing.

Chapter 5 Device Driver Requirements

Read this chapter for a description of device driver requirements for the Static Memory Controller (SMC).
Appendix A Signal Descriptions
Read this appendix for a description of the AHB MC input and output signals.

Glossary Read the Glossary for definitions of terms used in this manual.

Conventions
Conventions that this manual can use are described in:
• Typographical
• Timing diagrams on page xii
• Signals on page xii
• Numbering on page xiii.

Typographical
The typographical conventions are:

italic Highlights important notes, introduces special terminology, denotes internal cross-references, and citations.

bold Highlights interface elements, such as menu names. Denotes signal names. Also used for terms in descriptive lists, where appropriate.

monospace Denotes text that you can enter at the keyboard, such as commands, file and program names, and source code.

monospace Denotes a permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name.

monospace italic Denotes arguments to monospace text where the argument is to be replaced by a specific value.

monospace bold Denotes language keywords when used outside example code.

< and > Angle brackets enclose replaceable terms for assembler syntax where they appear in code or code fragments. They appear in normal font in running text. For example:
• MRC p15, 0 <Rd>, <CRn>, <CRm>, <Opcode_2>
• The Opcode_2 value selects the register that is accessed.
Note

Angle brackets can also enclose a permitted range of values. The example, <0-3>, shows that in name extensions, only one of the values 0, 1, 2, or 3 is valid.

Timing diagrams

The figure named Key to timing diagram conventions explains the components used in timing diagrams. Variations, when they occur, have clear labels. You must not assume any timing information that is not explicit in the diagrams.

Shaded bus and signal areas are undefined, so the bus or signal can assume any value within the shaded area at that time. The actual level is unimportant and does not affect normal operation.

Key to timing diagram conventions

Signals

The signal conventions are:

Signal level  The level of an asserted signal depends on whether the signal is active-HIGH or active-LOW. Asserted means HIGH for active-HIGH signals and LOW for active-LOW signals.

Lower-case n  Denotes an active-LOW signal.

Prefix A  Denotes global Advanced eXtensible Interface (AXI) signals.

Prefix AR  Denotes AXI read address channel signals.

Prefix AW  Denotes AXI write address channel signals.
Prefix B  Denotes AXI write response channel signals.
Prefix C  Denotes AXI low-power interface signals.
Prefix H  Denotes Advanced High-performance Bus (AHB) signals.
Prefix P  Denotes Advanced Peripheral Bus (APB) signals.
Prefix R  Denotes AXI read data channel signals.
Prefix W  Denotes AXI write data channel signals.

Numbering

The Verilog numbering convention is:

<size in bits>'<base><number>

This is a Verilog method of abbreviating constant numbers. For example:

- 'h7B4 is an unsized hexadecimal value.
- 'o7654 is an unsized octal value.
- 8'd9 is an eight-bit wide decimal value of 9.
- 8'h3F is an eight-bit wide hexadecimal value of 0x3F. This is equivalent to b00111111.
- 8'b1111 is an eight-bit wide binary value of b00001111.

Further reading

This section lists publications by ARM Limited, and by third parties.

ARM Limited periodically provides updates and corrections to its documentation. See http://www.arm.com for current errata sheets, addenda, and the Frequently Asked Questions list.

ARM publications

This manual contains information that is specific to the AHB MC. See the following documents for other relevant information:

- PrimeCell AHB SRAM/NOR Memory Controller (PL241) Integration Manual (ARM DII 0151)
- PrimeCell AHB SRAM/NOR Memory Controller (PL241) Implementation Guide (ARM DDI 0144)
- AMBA™ Specification (Rev 2.0) (ARM IHI 0011)
Feedback

ARM Limited welcomes feedback on the AHB MC and its documentation.

Feedback on this product

If you have any comments or suggestions about this product, contact your supplier giving:
- the product name
- a concise explanation of your comments.

Feedback on this manual

If you have any comments on this manual, send email to errata@arm.com giving:
- the title
- the number
- the relevant page number(s) to which your comments apply
- a concise explanation of your comments.

ARM Limited also welcomes general suggestions for additions and improvements.
Chapter 1
Introduction

This chapter introduces the AHB MC. It contains the following sections:

- *About the AHB MC* on page 1-2
- *Supported devices* on page 1-5.
1.1 About the AHB MC

The AHB MC is an Advanced Microcontroller Bus Architecture (AMBA) compliant System-on-Chip (SoC) peripheral. It is developed, tested, and licensed by ARM Limited.

The AHB MC takes advantage of the newly developed Static Memory Controller (SMC). The AHB MC has an AHB port with access to the external memory. The AHB port has a bridge interface to the memory controller. There is a separate AHB port to configure the memory controller. Specific configurations of the SMC are instantiated to target specific memory devices. Figure 1-1 shows the AHB MC (PL241) configuration.

This section describes:

- AHB interface on page 1-3
- AHB to APB bridge on page 1-3
- SMC on page 1-4
- Clock domains on page 1-4
- Low-power interfaces on page 1-4.
1.1.1 AHB interface

The interface converts the incoming AHB transfers to the protocol used internally by the AHB MC.

The interface has the following features:

- all AHB fixed length burst types are directly translated to fixed length bursts
- all undefined length INCR bursts are converted to INCR4 bursts
- broken bursts are supported
- the bufferable bit of the **HPROT** signal determines if the interface must wait for a write transfer to complete internally
- a **Read After Write** (RAW) hazard detection buffer avoids RAW hazards
- AHB response signals are registered to improve timing
- locked transfers are supported within a 512MB region
- **HWDATA** is registered to improve internal timing paths
- a big-endian 32-bit mode option is implemented
- AHB error response logic is removed as no internal components generate errors.

This interface is a fully validated component. This ensures that it obeys both the AHB protocol and the internal protocol that the interconnect uses.

See Chapter 2 *Functional Overview* for more information.

1.1.2 AHB to APB bridge

This bridge converts AHB transfers from the configuration port to the APB transfers that the internal memory controllers require.

See Chapter 2 *Functional Overview* for more information.
1.1.3 SMC

The SMC is a high-performance, area-optimized SRAM memory controller.

The SMC is pre-configured and validated for:
- the SRAM memory type
- the number of SRAM memory devices
- the maximum SRAM memory width.

The SRAM memory interface type is defined as supporting:
- synchronous or asynchronous SRAM
- Pseudo Static Random Access Memory (PSRAM)
- NOR flash
- NAND flash devices with an SRAM interface.

The SMC block offers the following features:
- it is configured to support the maximum SRAM memory data width of 32-bit
- programmable cycle timings, and memory width per chip select
- atomic switching of memory device and controller operating modes
- support for the PL220 External Bus Interface (EBI) PrimeCell, enabling sharing of external address and data bus pins between memory controller interfaces
- support for a low-power interface
- support for a remap signal
- support for clock domains to be synchronous or asynchronous

See Chapter 2 Functional Overview for more information.

1.1.4 Clock domains

The memory controller has two clock domains:
- AHB clock domain
- static memory clock domain.

See Chapter 2 Functional Overview for more information.

1.1.5 Low-power interfaces

The memory controller has two low-power interfaces, one for each clock domain.

See Chapter 2 Functional Overview for more information.
1.2 Supported devices

The SMC supports SRAM/NOR, see SMC on page 1-4. The Release Note provides a specific list of memory devices tested with each configuration.

Some memory devices or series of memory devices have specific requirements:

**Intel W18 series NOR FLASH, for example 28f128W18td**

These devices, when in synchronous operation, use a WAIT pin. However non-array operations when in synchronous mode do not use the WAIT pin and it is always asserted. The controller cannot differentiate between array and non-array accesses and therefore cannot support these non-array accesses.

Therefore, W18 devices can only carry out non-array operations such as Read Status in asynchronous modes of operation.

**Cellular RAM 1.0, 64MB PSRAM, for example mt45w4mw16bfb_701_1us**

You can program these devices using a CRE pin or by software access. Whenever you program these devices through software access, using a sequence of two reads followed by two writes, ensure that the third access, that is, the first write is a CE# controlled write.

SMC only does WE# controlled writes. This is to simplify the design of the SMC by having fewer timing registers and simpler timing controls.

Therefore, you can only program these devices by using the CRE pin method of access.

--- Note ---

Because the memory controller maps INCR transfers into INCR4 transfers, it does not support memory mapped FIFO components.
Chapter 2

Functional Overview

This chapter describes the major components of the AHB MC and how they operate. It contains the following sections:

- *Functional description* on page 2-2
- *SMC* on page 2-4
- *Functional operation* on page 2-7.
2.1 Functional description

Figure 2-1 shows an AHB MC (PL241) configuration.

This section is divided into:
- AHB interface
- AHB to APB bridge
- Clock domains on page 2-3
- Low-power interface on page 2-3
- SMC on page 2-4.

2.1.1 AHB interface

The AHB MC fully supports the AMBA AHB 2.0 specification. This interface component converts the incoming AHB transfers to the required transfers of the internal interconnect protocol. Because of the design of the internal interconnect, some optimizations are made in the interface to improve performance.

See AHB interface operation on page 2-7 for more information.

2.1.2 AHB to APB bridge

The internal memory controllers of the AHB MC use the AMBA3 APB protocol for their configuration ports. To enable the AHB MC to externally function as an AHB device, the APB configuration ports are connected to an AHB to APB bridge. The bridge converts incoming AHB transfers from the configuration port to the APB transfers that the internal memory controller requires. This bridge is part of the PrimeCell infrastructure components, part BP127.

See AHB to APB bridge operation on page 2-10 for more information.
2.1.3 Clock domains

The memory controller has two clock domains:

**AHB clock domain**

This is clocked by *hclk*, *smc_aclk* and reset by *hresetn*.

**Static memory clock domain**

This is clocked by *smc_mclk0*, *smc_mclk0n* and reset by *smc_mreset0n*.

Figure 2-2 shows the two clock domains.

Figure 2-2 AHB MC (PL241) clock domains

The memory controller supports many different options for clocking the different domains.

See *Clock domain operation* on page 2-11 for more information.

2.1.4 Low-power interface

The memory controller has two low-power interfaces, one for each clock domain. These operate with a simple three signal protocol. It is expected that a system clock controller drives these interfaces and associated clocks. Each domain has individual control to enable independent handshaking with the system clock controller.

See *Low-power interface operation* on page 2-12 for more information.
2.2 SMC

Figure 2-3 shows a block diagram of the SMC.

The main blocks of the SMC are:

- *SMC interface* on page 2-5
- *APB slave interface* on page 2-5
- *Format* on page 2-5
- *Memory manager* on page 2-5
- *Memory interface* on page 2-5
- *Pad interface* on page 2-6
- *Interrupts* on page 2-6.
2.2.1 SMC interface

The SMC interface processes the incoming AHB transfers and sends them to the command format block.

2.2.2 APB slave interface

The SMC has 4KB of memory allocated to it.

The APB slave interface accesses the SMC registers to program the memory system configuration parameters and to provide status information. See Chapter 3 *Programmer’s Model* and *APB slave interface operation* on page 2-19 for more information.

2.2.3 Format

The format block receives memory accesses from the SMC interface and the memory manager. Read and write requests are arbitrated on a round robin basis. Requests from the manager have the highest priority. The format block also maps AHB memory transfers onto appropriate memory transfers and passes these to the memory interface through the command FIFO.

See *Format block* on page 2-19 for more information.

2.2.4 Memory manager

The memory manager tracks and controls the current state of **smc_aclk** domain logic. The block is responsible for:

- updating timing registers and controlling direct commands issued to memory
- controlling entry-to and exit-from low-power mode through the APB interface
- the low-power interface.

See *Memory manager operation* on page 2-22 for more information.

2.2.5 Memory interface

The SRAM memory interface consists of command, read data and write data FIFOs, plus a control FSM. To support an EBI, the memory interface also contains an EBI FSM. This controls interaction with the EBI and prevents the memory interface FSM from issuing commands until it has been granted the external bus.

See *Memory interface operation* on page 2-27 for more information.
2.2.6 Pad interface

The pad interface module provides a registered I/O interface for data and control signals. It also contains interrupt generation logic.

Figure 2-4 shows the SRAM pad interface external signals. Clock and reset signals are omitted.

![Figure 2-4 SMC SRAM pad interface external connections](image)

2.2.7 Interrupts

The SRAM memory interface support interrupts. The interrupt is triggered on the rising edge of the `smc_int_0` input for the SRAM memory interface.

See *Interrupts operation* on page 2-27 for more information.
2.3 Functional operation

This section is divided into:
- AHB interface operation
- AHB to APB bridge operation on page 2-10
- Clock domain operation on page 2-11
- Low-power interface operation on page 2-12
- SMC functional operation on page 2-15.

2.3.1 AHB interface operation

This section describes:
- AHB fixed burst types
- Undefined length INCR bursts on page 2-8
- Broken bursts on page 2-8
- Bufferable bit of the HPROT signal on page 2-8
- Read after write hazard detection buffer on page 2-9
- AHB response signals on page 2-9
- Locked transfers on page 2-9
- Registered HWDATA on page 2-10
- Big-endian 32-bit mode on page 2-10
- Removal of AHB error response logic on page 2-10.

AHB fixed burst types

All AHB fixed length bursts directly map to burst types that the internal interconnect uses. The internal interconnect and the memory controller are based on transferring bursts of data. The larger the burst size, the more efficient the transfer and overall performance. The standard AHB fixed length burst types are directly mapped to the internal protocol.

Burst operation has performance benefits because when the first beat of a burst is accepted, it contains data about the remaining beats. For example, from the first beat of a read burst, all the data required to complete the transfer can be read from memory. This first transfer has some delay before data is returned. Subsequent beats of the burst can have less delay because the data they require might have already been read from the memory.
Undefined length INCR bursts

All undefined length INCR bursts are converted to INCR bursts of length four. Many AHB masters rely on using undefined length INCR bursts to access data. If each INCR transfer is processed as a single transfer by the internal protocol then the performance is significantly degraded.

The bridge converts the incoming INCR transfers to INCR transfers of length four, INCR4. This mean that the bridge speculatively requests data from the internal interconnect, before it knows it is going to require it. If the AHB master continues the burst, then the data can be returned quickly because it has already been requested. When the INCR burst finishes, the bridge disregards any data requested from the internal interconnect that is not required.

Any INCR burst of less than four beats results in a broken INCR4. Undefined length INCR bursts of more than four beats are split into an appropriate number of INCR4s plus a broken INCR4, if required.

Broken bursts

To fully support the AMBA AHB 2.0 specification, the bridge supports all broken AHB bursts. Although bursts cannot be broken by an AHB master, if the AHB system has multiple masters then the AHB system arbitration can break a burst. Also, because the bridge converts INCR to INCR4, broken INCR4s occur when undefined length INCRs of a length not equal to a multiple of four are performed.

To support broken bursts, the bridge must keep track of how many beats of a burst have been performed and ensure it obeys the protocol of the interconnect. For read bursts, this means draining the interconnect of any requested data that is not required. For write bursts this means artificially extending write data with enough beats to obey the protocol. The interconnect uses write strobes to indicate the bytes of the data bus that are valid. When extending broken bursts, these strobes are deasserted so that the artificial data does not corrupt the actual memory.

Bufferable bit of the HPROT signal

The bufferable bit of the HPROT signal determines whether the bridge must wait for a write transfer to complete internally. The AHB protection control bits support the concept of bufferable data accesses. The HPROT[2] signal determines this. The internal interconnect supports the concept of a write response to indicate when data has actually been written to memory. The bridge exploits these features by not waiting for the write response if the access is described as bufferable. This enables numerous bufferable writes to occur with minimum latency. These are accepted by the interconnect and queued in the memory controller.
If transfers are described as non-bufferable then the bridge must wait for the write response to indicate that the transfer has been completed to memory. If numerous bufferable writes are performed, followed by a non-bufferable write, then the bridge must wait until it receives the write response associated with the final write.

**Read after write hazard detection buffer**

A RAW hazard detection buffer avoids potential RAW hazards. The protocol used internally to AHB MC does not perform memory coherency checks to catch Write After Read (WAR) or RAW hazards.

Because of the nature of the AHB protocol, WAR hazards never occur because the read must have completed before the write can be accepted.

Because the bridge permits writes to be buffered internally, there is a potential for a RAW hazard to occur. If you perform a bufferable write then it might not complete immediately. If a read to that same memory location is performed then both transfers can be in the queue and the internal memory controller can reorder these transactions for performance reasons so that the read occurs before the write. This means that the data read might be the value before the most recent write. The bridge has to detect these potential cases and stall the read transfer until any buffered writes that might cause a RAW hazard have been completed.

The bridge contains logic to monitor up to four outstanding write addresses. If an incoming read occurs to a 4KB region that has been written to, then it is stalled. If four bufferable writes occur then the AHB is stalled until a response is seen for the first of the four writes in the buffer.

**AHB response signals**

The interconnect used within the AHB MC contains many combinatorial paths that link different AHB input ports. To improve the synthesis timing, the AHB responses are registered to limit these paths to within the design.

**Locked transfers**

AHB MC supports locked transfers, within a 512MB region. This is because of the way the interconnect processes locked transfers. There is a significant performance penalty in using locked transfers. Transfers that are locked together wait for all other ports to complete any outstanding transfers before they can begin. While a locked sequence occurs to a specific 512MB memory region, all other access to that region is stalled. All locked writes are processed as non-bufferable writes and so have to wait for the appropriate write response before indicating their completion.
Registered HWDATA

The interconnect used within the AHB MC contains combinatorial paths for the write data. To improve the synthesis timing, HWDATA is registered and makes these paths internal to the design.

Big-endian 32-bit mode

The AHB MC supports the option of storing data to memory in big-endian 32-bit mode. Each bridge contains the logic to implement this data mapping depending on the big_endian input tie-off. Figure 2-5 shows that if the tie off is asserted then the data buses are reordered.

![Figure 2-5 Big-endian implementation](image)

Removal of AHB error response logic

The internal protocol used within AHB MC supports the concept of errors. However none of the components used ever generate errors. This means that the bridge does not require any logic to generate AHB errors because there are no circumstances when errors can be generated.

2.3.2 AHB to APB bridge operation

The internal memory controller has an APB configuration port. The AHB configuration port is mapped to it using an AHB to APB bridge. Figure 2-6 on page 2-11 shows that each internal memory controller configuration port has a 4KB address space.
Figure 2-6 AHBC memory map

The other fourteen 4KB regions are read as zero. The lower 16 bits of the AHB address decode the memory controller that is being used. An external AHB decoder determines where in the system memory map, this 64KB region is located. See About the programmer’s model on page 3-2 for information on the internal memory controller configuration registers. The configuration port of the internal memory controller is APB, so only word reads and writes are supported.

2.3.3 Clock domain operation

The memory controller supports two clock domains:
- the AHB clock domain
- the static memory clock domain.

The hclk input drives the AHB clock domain. This clock drives the AHB interfaces and bus matrix. The static memory controller has a separate clock input in this domain. This is called smc_aclk. This signal is separated to enable the clock to be stopped independently of hclk for low-power operation, see Low-power interface operation on page 2-12. These two clocks must always be driven from the same clock source. The input signal hresetn resets this clock domain.

The static memory clock domain controls the memory interface logic of the SMC. The input signal smc_mclk0 and its inverse smc_mclk0n drive this domain. Each external static memory chip is driven by a gated smc_mclk0 signal, these are called smc_clk_out_0[3:0]. Clocks are only driven out to chips that require them. The static memory interface has a fed back clock input, smc_fbclk_in_0, to help with clock skews on the external pads.

The memory controller supports many different options for clocking the different domains:
Static memory clocking options

Table 2-1 lists the static memory clocking options.

<table>
<thead>
<tr>
<th>Options</th>
<th>Tie-off values</th>
</tr>
</thead>
</table>
| Fully synchronous | hclk = smc_mclk0  
| | smc_async0 = smc_msync0 = 1  
| | smc_a_gt_m0_sync = 0 |
| Synchronous multiples | hclk = n x smc_mclk0  
| | where: n = integer value  
| | m x hclk = smc_mclk0  
| | where: m = integer value  
| Asynchronous | Extra registers are used to avoid metastability when crossing the asynchronous clock boundary.  
| | smc_async0 = smc_msync0 = 0  
| | smc_a_gt_m0_sync = 0 |

2.3.4 Low-power interface operation

The memory controller has two low-power interfaces. These interfaces indicate whether the clock for a specific domain can be switched off to reduce power consumption. It is expected that these interfaces are controlled by a system clock controller. One interface controls each of the following domains:

- AHB clock domain
- Static memory clock domain.

Each domain uses a simple three signal interface to indicate whether the clocks are required. The signals consist of:

a request input

<domain>_csyreq

an acknowledge output

<domain>_csysack
an active output

<domain>_cactive

Where:

<domain> is ahb or smc.

Figure 2-7 explains the protocol for the interface by showing a request to enter low-power mode.

The memory controller receives a request to enter low-power mode, indicated by <domain>_csysreq being driven LOW by the system clock controller, as shown at T1. The memory controller then has the chance to perform any required operations to prepare for the clock to be switched off. The memory controller acknowledges the request by asserting <domain>_csysack LOW, as shown at T2. At this point the <domain>_cactive signal is used to indicate whether the request has been accepted or denied. If the request is accepted, <domain>_cactive is LOW, as shown in Figure 2-7. If the request is denied, <domain>_cactive is HIGH. If the request is accepted, then the clock to that domain can be switched off. The peripheral is brought out of low-power state by restarting the clock and driving <domain>_csysreq HIGH, as shown at T4. The memory controller completes the handshake by driving <domain>_csysack HIGH, as shown at T5. Figure 2-8 shows the AHB domain denying a low-power request.

When ahb_csysack is asserted LOW, the ahb_cactive signal is HIGH, as shown at T3, indicating the AHB domain is busy and the clock cannot be switched off. The handshake must be completed.
The AHB domain accepts or denies requests based on whether it is busy performing any transfers. Figure 2-9 shows that static memory controllers always accept requests after they have performed the required operations to prepare the external memory for the clock to be switched off.

![Figure 2-9 Accepting requests](image)

The low-power request `smc_csreq` is driven LOW at time T1. When the memory controller is happy for the clock to be switched off, the `smc_csack` signal is driven LOW to acknowledge the request, as shown at T2. `smc_cactive` is driven LOW, so the system clock controller knows the request has been accepted. When acknowledged, the system clock controller can disable both the `smc_aclk` and `smc_mclk0` signals.

The two domains have separate interfaces to enable individual handshaking with the system clock controller. The only usage model is to switch off both domains. Each individual low-power interface protocol must be observed before all the clocks can be disabled.
2.4 SMC functional operation

This section describes:
* Operating states
* Clocking and resets on page 2-16
* Miscellaneous signals on page 2-18
* APB slave interface operation on page 2-19
* Format block on page 2-19
* Memory manager operation on page 2-22
* Interrupts operation on page 2-27
* Memory interface operation on page 2-27.

2.4.1 Operating states

The operation of the SMC is based on three operating states. In this section, each state is described. Figure 2-10 shows the state machine.

![Figure 2-10 SMC aclk domain FSM](image)

The SMC states are as follows:

**Reset**

Power is applied to the device, and hresetn is held LOW.

**Ready**

Normal operation of the device. You can access the SMC register bank through the AHB configuration port and external memory devices accessed through the SMC interface.

**Low-power**

The device does not accept new AHB transfers, and only certain registers are accessible through the APB interface. You can stop the SMC clocks to reduce power consumption.
The state transitions are:

**Ready to Reset**
When reset is asserted to the smc_aclk domain, it enters the Reset state.

**Reset to Ready**
When reset is deasserted to the smc_aclk domain, it enters the Ready state.

**Ready to Low-power**
The Low-power state is entered when the SMC next becomes idle after either:
- the SMC receives a low-power request through the APB smc_memc_cfg_set Register
- the SMC receives a low-power request through the SMC low-power interface.

**Low-power to Ready**
The SMC exits the Low-power state back to Ready when either:
- the SMC low-power request bit is cleared in the APB smc_memc_cfg_clr Register
- the SMC low-power interface negates the low-power request.

**Low-power to Reset**
When Reset is asserted to the smc_aclk reset domain, it enters the Reset state.

### 2.4.2 Clocking and resets

This section describes:
- Clocking
- Resets on page 2-17.

**Clocking**
All configurations of the SMC support at least two clock domains, and have the following clock inputs:
- smc_aclk
- smc_mclk0
- smc_mclk0n.
These clocks can be grouped into two clock domains:

**AHB domain**  
`sme_aclk` is in this domain. You can only stop the `sme_aclk` domain signals when the SMC is in low-power mode.

**Memory clock domain**

The `sme_mclk0` and `sme_mclk0n` are in this domain.  
`sme_mclk0n` is an inverted version of `sme_mclk0`. `sme_mclk0` is used for timing and control signals.

You can tie off the `sme_async` and `sme_msync` pins so that the `sme_aclk` and `sme_mclk0` clock domains can operate synchronously or asynchronously with respect to each other.

**Synchronous clocking**

The benefit of synchronous clocking is that you can reduce the read and write latency by removing the synchronization registers between clock domains. However, because of the integer relationship of the clocks, you might not be able to get the maximum performance from the system because of constraints placed on the bus frequency by the external memory clock speed. In synchronous mode, the handshaking between the `sme_aclk` and `sme_mclk0` domains enables synchronous operation of the two clocks at multiples of each other, that is, ratios of n:1 and 1:m.

**Asynchronous clocking**

The main benefit of asynchronous clocking is that you can maximize the system performance, while running the memory interface at a fixed system frequency. Additionally, in sleep-mode situations when the system is not required to do much work, you can lower the frequency to reduce power consumption.

**Output clocks**

A clock output is provided for every external memory device on the SRAM memory interface type.

**Resets**

The SMC has two reset inputs:

- `hresetn` This is the reset signal for the `sme_aclk` domain.
- `sme_mreset0n` This is the reset signal for the `sme_mclk0` domain.
You can change both reset signals asynchronously to their respective clock domain. Internally to the SMC the deassertion of the \texttt{hresetn} signal is synchronized to \texttt{smc\_aclk}. The deassertion of \texttt{smc\_mreset0n} is synchronized internally to \texttt{smc\_mclk0} and \texttt{smc\_mclk0n}.

### 2.4.3 Miscellaneous signals

You can use the following signals as general-purpose control signals for logic external to the SMC:

\texttt{smc\_user\_config}[7:0]

General purpose output ports that are driven directly from the write-only APB register. If you do not require these ports leave them unconnected. See also the \textit{SMC User Configuration Register at 0x1204} on page 3-19.

\texttt{smc\_user\_status}[7:0]

General purpose input ports that are readable from the APB interface through the \texttt{smc\_user\_status} Register. If you do not require these ports then tie them either HIGH or LOW. These ports are connected directly to the APB interface block. Therefore, if they are driven from external logic that is not clocked by the SMC \texttt{smc\_aclk} signal, then you require external synchronization registers. See also the \textit{SMC User Status Register at 0x1200} on page 3-18.

You can use the following miscellaneous signals as tie-offs to change the operational behavior of the SMC:

\texttt{smc\_a\_gt\_m0\_sync}

When HIGH, indicates that \texttt{smc\_aclk} is greater than and synchronous to \texttt{smc\_mclk0}.

\texttt{smc\_async0}

When HIGH, indicates \texttt{smc\_aclk} is synchronous to \texttt{smc\_mclk0}. Otherwise they are asynchronous. Ensure that \texttt{smc\_async0} is tied to the same value as \texttt{smc\_msync0}.

\texttt{smc\_dft\_en\_clk\_out}

Use this signal for \textit{Automatic Test Pattern Generator} (ATPG) testing only. Tie it LOW for normal operation.
smc_msync0

When HIGH, indicates smc_mclk0 is synchronous to smc_aclk. Otherwise they are asynchronous. Ensure that smc_msync0 is tied to the same value as smc_async0.

smc_rst_bypass

Use this signal for ATPG testing only. Tie it LOW for normal operation.

smc_use_ebi

When HIGH, indicates that the SMC must operate with a PrimeCell EBI. See the ARM PrimeCell External Bus Interface (PL220) Technical Reference Manual.

2.4.4 APB slave interface operation

To enable a clean registered interface to the external infrastructure, the APB interface always adds a wait state for all reads and writes by driving pready LOW during the first cycle of the access phase.

In two instances, a delay of more than one wait state can be generated:

- when a direct command is received and there are outstanding commands that prevent a new command being stored in the command FIFO
- when an APB access is received and a previous direct command has not completed.

2.4.5 Format block

This section describes:

- Hazard handling
- SRAM memory accesses on page 2-20.

Hazard handling

There are four types of hazard:

- Read After Read (RAR)
- Write After Write (WAW)
- Read After Write (RAW)
- Write After Read (WAR).

The AHB interface deals with RAW hazards. WAR hazards do not occur in the AHB.
The SMC ensures the ordering of read transfers from a single port is maintained RAR, and additionally that the ordering of write transfers from a single master is maintained WAW.

**SRAM memory accesses**

This section describes:

- *Standard SRAM access*
- *Memory address shifting*
- *Memory burst alignment*
- *Memory burst length* on page 2-21
- *Booting using the SRAM* on page 2-21.

**Standard SRAM access**

The programmer’s view is a flat area of memory.

The base addresses of external memory devices are defined by the `smc_address_match0_<0-3>[7:0]` and `smc_address_mask0_<0-3>[ 7:0]` tie-off pins. You can read the values of these tie-off pins through the opmode registers.

**Memory address shifting**

To produce the address presented to the memory device, the AHB address is aligned to the memory width. This is done because the AHB address is a byte-aligned address, while the memory address is a memory-width-aligned address.

--- **Note** ---

During initial configuration of a memory device, the memory mode register can be accessed with a sequence of transfers to specific addresses. You must take into consideration the shifting performance by the SMC when accessing memory mode registers.

---

**Memory burst alignment**

The SMC provides a programmable option for controlling the formatting of memory transfers with respect to memory burst boundaries, through the burst_align bit of the opmode registers.

When set, the burst_align bit causes memory bursts to be aligned to a memory burst boundary. This setting is intended for use with memories that use the concept of internal pages. This can be an asynchronous page mode memory, or a synchronous PSRAM. If a burst crosses a memory burst boundary, the SMC partitions the transfer into multiple
memory bursts, terminating a memory transfer at the burst boundary. Also ensure the page size is an integer multiple of the burst length, to avoid a memory burst crossing a page boundary.

When the burst_align bit is not set, the SMC ignores the memory burst boundary when mapping commands onto memory commands. This setting is intended for use with devices such as NOR flash. These devices have no concept of pages.

**Memory burst length**

The SMC enables you to program the memory burst length on an individual chip basis, from length 1 to 32 beats, or a continuous burst. However, the length of memory bursts are limited by the size of the read and write data FIFOs, and the programmed memory burst must not exceed this upper limit.

For read transfers, the maximum memory burst length is the depth of the read data FIFO, and it is four. For writes, the burst length is the depth of the write FIFO, and is four.

**Booting using the SRAM**

The SMC enables the lowest SRAM chip select, normally chip 0, to be bootable. To enable SRAM memory to be bootable, the SRAM interface does not require any special functionality, other than knowing the memory width of the memory concerned. This is indicated by a top-level tie-off. To enable the SMC to work with the slowest memories the timing registers reset to the worst case values. When the `smc_remap_0` port signal is HIGH, the memory with the bootable chip select is set by the `smc_sram_mw_0[1:0]` tie-off port signal.

Additionally, while the SMC input `smc_remap_0` is HIGH, the bootable chip is aliased to base address 0x0.
2.4.6 Memory manager operation

The memory manager module is responsible for controlling the state of the SMC and the updating of chip configuration registers.

This subsection describes:

- *Low-power operation*
- *Chip configuration registers*
- *Direct commands* on page 2-24.

**Low-power operation**

The SMC accepts requests to enter the Low-power state through either the SMC low-power interface or the APB register interface.

The SMC does not enter the power-down state until it has received an idle indication from all areas of the peripheral, that is:

- there is no valid transfer held in the Format block
- there are no valid transfers held in the SMC interface
- all FIFOs are empty
- all memory interface blocks are IDLE.

When the Low-power state is entered, no new memory transfers are accepted until the SMC has been moved out of Low-power state. The SMC does not request to move out of Low-power state, and never refuses a power-down request.

**Chip configuration registers**

The SMC provides a mechanism for synchronizing the switching of operating modes of the SMC with that of the memory device.

The *smc_set_cycles* Register and *smc_set_opmode* Register act as holding registers for new operating parameters until the SMC detects the memory device has switched modes.

Figure 2-11 on page 2-23 shows the memory manager containing a bank of registers for each memory chip supported by the SMC. The manager register bank consists of all the timing parameters *smc_sram_cycles0_<0-3>* and *smc_opmode0_<0-3>* that are required for the controller to correctly time any type of access to a supported memory type.
The APB registers `smc_set_cycles` and `smc_set_opmode` act as holding registers, the configuration registers within the manager are only updated if either:

- the `smc_direct_cmd` Register indicates only a register update is taking place
- the `smc_direct_cmd` Register indicates either a modereg operation or an memory access has taken place, and is complete.

The chip configuration registers are available as read only registers in the address map of the APB interface.

![Diagram](image-url)  
**Figure 2-11 Chip configuration registers**
Direct commands

The SMC enables code to be executed from the memory while simultaneously, from the software perspective, moving the same chip to a different operating mode. This is achieved by synchronizing the update of the chip configuration registers from the holding registers with the dispatch of the memory configuration register write.

The SMC provides two mechanisms for simultaneously updating the controller and memory configuration registers.

Device pin mechanism

For memories that use an input pin to indicate that a write is intended for the configuration register, for example in some PSRAM devices, the write mechanism can be done through the APB direct command register. Figure 2-12 on page 2-25 shows the sequence of events.

Software mechanism

For memories that require a sequence of read and write commands, for example, most NOR Flash devices use the SMC interface, with the write data bus indicating when the last transfer has completed and when it is safe for the SMC to update the chip configuration registers. Figure 2-13 on page 2-26 shows the sequence of events.
Figure 2-12 Device pin mechanism

Start

Write timing parameters and operating mode to the memory controller holding registers.

Write required external chip select number and required mode register value to the Direct Command Register.

The memory controller passes this mode register command to the memory interface and sets a request \textit{req} signal. The memory controller does not accept any more configuration port commands until \textit{req} is cleared.

When the memory interface issues the mode \textit{req} command to memory, it responds to the \textit{req} signal with an \textit{ack} response signal. The memory interface blocks any more accesses to that chip select until \textit{req} is cleared.

The memory controller detects the \textit{ack} signal and updates the mode and timing registers of the relevant chip select and negates \textit{req}.

The memory interface detects the negation of \textit{req}, clears \textit{ack}, and re-enables accesses to the updated chip select memory.

End
Start

- Write timing parameters and operating mode to the memory controller holding registers.

- Write required external chip select number and required mode register value to the Direct Command Register.

The memory controller passes this mode register command to the memory interface and sets a request req signal. The memory controller does not accept any more configuration port commands until req is cleared.

When the memory interface detects the req signal it tries to match all commands issued to the required chip select with the match value.

- Write the required memory mode register value(s).

When the memory interface matches the required chip select and match value to the data bus, using byte lane strobes to determine validity, it asserts ack, and blocks any more accesses to that chip select until req is cleared.

End

A

The memory controller detects the ack signal and updates the mode and timing registers of the relevant chip select and negates req.

The memory interface detects the negation of req, clears ack, and re-enables accesses to the updated chip select memory.

Figure 2-13 Software mechanism
2.4.7 Interrupts operation

The next read to any chip select on the appropriate memory interface clears the interrupt.

The interrupt outputs are generated through a combinational path from the relevant input pin. This enables you to place the SMC in Low-power state, and to stop the clocks while waiting for an interrupt.

When interrupts are disabled, a synchronized version of the interrupt input is still readable through the APB interface.

2.4.8 Memory interface operation

The memory interface issues commands to the memory from the command FIFO, and controls the cycle timings of these commands. A new command is only issued when the previous command is complete and any turn-around times have been met. Additionally, a read command is not issued unless there is space for all the impending data in the read data FIFO.

——— Note ————

You must not set the rd_b1 parameter in the smc_opmode Register to a value greater than the read data FIFO depth of four.

———

If enabled, the EBI can prevent commands being issued when the SMC is not granted the external bus.

Figure 2-14 on page 2-29 to Figure 2-23 on page 2-38 show the timing parameters. They are divided into SRAM timing tables and diagrams.

The internal signal read_data is included in the read transfer waveforms to indicate the clock edge on which data is registered by the SMC.

SRAM timing tables and diagrams

All address, control, and write data outputs of the SMC are registered on the rising edge of smc_mclk0n, equivalent to the falling edge of smc_mclk0, for both synchronous and asynchronous accesses. The clock output to memory, smc_elk_out, is driven directly by smc_mclk0, but gated to prevent toggling during asynchronous accesses, or when no transfers are occurring.
Read data output by the memory device is also registered on the rising edge of \texttt{smc\_mclk0n}, equivalent to the falling edge of \texttt{smc\_mclk0}, for asynchronous reads. For synchronous reads, read data is registered using the fed back clock, \texttt{smc\_fbclk\_in}. For synchronous and asynchronous accesses, the data is then pushed onto the read data FIFO to be returned by the SMC interface.

This subsection describes:

- Asynchronous read
- Asynchronous read in multiplexed-mode on page 2-29
- Asynchronous write on page 2-30
- Asynchronous write in multiplexed-mode on page 2-31
- Asynchronous page mode read on page 2-31
- Synchronous burst read on page 2-32
- Synchronous burst read in multiplexed-mode on page 2-34
- Synchronous burst write on page 2-35
- Synchronous burst write in multiplexed-mode on page 2-36
- Synchronous read and asynchronous write on page 2-37.

**Asynchronous read**

Table 2-2 and Table 2-3 list the smc\_opmode0\_<0-3> and SRAM Register settings. See Register summary on page 3-3.

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b0</td>
<td>b000</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>b0011</td>
<td>-</td>
<td>b001</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Figure 2-14 on page 2-29 shows a single asynchronous read transfer with an initial access time, \(t_{RC}\), of three cycles and an output enable assertion delay, \(t_{CEOE}\), of one cycle.
Asynchronous read in multiplexed-mode

Table 2-4 and Table 2-5 list the smc_opmode0_<0-3> and SRAM Register settings.

**Table 2-4 Asynchronous read in multiplexed-mode opmode chip register settings**

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b0</td>
<td>b000</td>
<td>-</td>
<td>-</td>
<td>b1</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

**Table 2-5 Asynchronous read in multiplexed-mode SRAM cycles register settings**

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>b011</td>
<td>-</td>
<td>b101</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Figure 2-15 shows a single asynchronous read transfer in multiplexed-SRAM mode, with \( t_{RC} = 7 \), and \( t_{CEOE} = 5 \).
Note

In multiplexed-mode, both address and data are output by the SMC on the `smc_data_out_0[31:0]` output bus. Read data is accepted on the `smc_data_in_0[31:0]` bus.

Asynchronous write

Table 2-6 and Table 2-7 list the `smc_opmode0_<0-3>` and SRAM Register settings.

Table 2-6 Asynchronous write opmode chip register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>b0</td>
<td>b000</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Table 2-7 Asynchronous write SRAM cycles register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b010</td>
<td>-</td>
<td>b010</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Figure 2-16 shows an asynchronous write with a write cycle time `tWC` of four cycles and a `smc_we_n_0` assertion duration, `tWP`, of two cycles.

Note

The timing parameter `tWC` is controlling the deassertion of `smc_we_n_0`. You can use it to vary the hold time of `smc_cs_n_0[3:0]`, `smc_add_0[31:0]` and `smc_data_out_0[31:0]`. This differs from the read case where the timing parameter `tCEOE` controls the delay in the assertion of `smc_oe_n_0`. Additionally, `smc_we_n_0` is always asserted one cycle after `smc_cs_n_0[3:0]` to ensure the address bus is valid.

Figure 2-16 Asynchronous write
**Asynchronous write in multiplexed-mode**

Table 2-8 and Table 2-9 list the smc_opmode0_<0-3> and SRAM Register settings.

### Table 2-8 Asynchronous write in multiplexed-mode opmode chip register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>b0</td>
<td>b000</td>
<td>b0</td>
<td>b0</td>
<td>b0</td>
<td>-</td>
</tr>
</tbody>
</table>

### Table 2-9 Asynchronous write in multiplexed-mode SRAM cycles register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b0111</td>
<td>-</td>
<td>b100</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Figure 2-17 shows an asynchronous write in multiplexed-mode. $t_{WC}$ is seven cycles. $t_{WP}$ is four cycles, and is extended by two cycles for the address phase of the transaction.

![Figure 2-17 Asynchronous write in multiplexed-mode](image)

### Asynchronous page mode read

Table 2-10 and Table 2-11 list the smc_opmode0_<0-3> and SRAM Register settings.

### Table 2-10 Page read opmode chip register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b0</td>
<td>&lt;page length&gt;</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>b1</td>
</tr>
</tbody>
</table>

### Table 2-11 Page read SRAM cycles register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>b0111</td>
<td>-</td>
<td>b010</td>
<td>-</td>
<td>b001</td>
<td>-</td>
</tr>
</tbody>
</table>
Figure 2-18 shows a page read access, with an initial access time, $t_{RC}$, of three cycles, an output enable assertion delay, $t_{CEOE}$, of two cycles and a page access time, $t_{PC}$, of one cycle.

Page mode is enabled in the SMC by setting the opmode Register for the relevant chip to asynchronous reads and the burst length to the page size.

--- Note ---

Multiplexed-mode page accesses are not supported.

![Figure 2-18 Page read](image)

**Synchronous burst read**

Table 2-12 and Table 2-13 list the smc_opmode0_<0-3> and SRAM Register settings.

**Table 2-12 Synchronous burst read opmode chip register settings**

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b1</td>
<td>&lt;burst length&gt;</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>b1</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

**Table 2-13 Synchronous burst read SRAM cycles register settings**

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>b0100</td>
<td>-</td>
<td>b010</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>
Figure 2-19 shows a burst read with the `smc_wait_0` output of the memory used to delay the transfer.

Note

- Synchronous memories have a configuration register enabling `smc_wait_0` to be asserted either on the same clock cycle as the delayed data or a cycle earlier. The SMC only supports `smc_wait_0` being asserted one cycle early, enabling `smc_wait_0` to be initially sampled with the fed back clock and then with `smc_mclk0` before being used by the FSM. This enables the easiest timing closure. Additionally, you must configure the memory for `smc_wait_0` to be active LOW.

- In synchronous operation, the SMC relies on the `smc_wait_0` signal being deasserted HIGH to indicate that the memory can finish the transfer. When in synchronous mode some memories do not deassert the `smc_wait_0` signal during non-array read transfers. Non-array read transfers are typically status register reads. To avoid stalling the system with these memories, in synchronous mode you must not perform non-array read transfers with the memory and SMC.
**Synchronous burst read in multiplexed-mode**

Table 2-14 and Table 2-15 list the \texttt{smc\_opmode0\_<0-3>} and SRAM Register settings.

**Table 2-14 Synchronous burst read in multiplexed-mode opmode chip register settings**

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b1</td>
<td>\textless burst length&gt;</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

**Table 2-15 Synchronous burst read in multiplexed-mode read SRAM cycles register settings**

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>b0100</td>
<td>-</td>
<td>b010</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Figure 2-20 shows the same synchronous read burst transfer as Figure 2-19 on page 2-33, but in multiplexed-mode.
Synchronous burst write

Table 2-16 and Table 2-17 list the smc_opmode0_<0-3> and SRAM Register settings.

### Table 2-16 Synchronous burst write opmode chip register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>&lt;burst length&gt;</td>
<td>-</td>
<td>b1</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

### Table 2-17 Synchronous burst write SRAM cycles register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b0100</td>
<td>-</td>
<td>b001</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Figure 2-21 shows a synchronous burst write transfer that is delayed by the smc_wait_0 signal. You must configure the memory to assert smc_wait_0 one cycle early and with an active LOW priority. The smc_wait_0 signal is again registered with the fed back clock and smc_mclk0 before being used. The smc_wait_0 signal is used in the smc_mclk0 domain to the memory interface FSM.

![Figure 2-21 Synchronous burst write]
Synchronous burst write in multiplexed-mode

Table 2-18 and Table 2-19 list the smc_opmode0_<0-3> and SRAM Register settings.

Table 2-18 Synchronous burst write in multiplexed-mode opmode chip register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>-</td>
<td>b1</td>
<td>&lt;burst length&gt;</td>
<td>b1</td>
<td>-</td>
<td>b1</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Table 2-19 Synchronous burst write in multiplexed-mode SRAM cycles register settings

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b0100</td>
<td>-</td>
<td>b001</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>

Figure 2-22 shows the same synchronous burst write as Figure 2-21 on page 2-35, but in multiplexed-mode.
**Synchronous read and asynchronous write**

Table 2-20 and Table 2-21 list the smc_opmode0_<0-3> and SRAM Register settings.

**Table 2-20 Synchronous read and asynchronous write opmode chip register settings**

<table>
<thead>
<tr>
<th>Field</th>
<th>mw</th>
<th>rd_sync</th>
<th>rd_bl</th>
<th>wr_sync</th>
<th>wr_bl</th>
<th>baa</th>
<th>adv</th>
<th>bls</th>
<th>ba</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>-</td>
<td>b1</td>
<td>b001</td>
<td>b0</td>
<td>b000</td>
<td>b0</td>
<td>b1</td>
<td>b0</td>
<td>-</td>
</tr>
</tbody>
</table>

**Table 2-21 Synchronous read and asynchronous write opmode chip register settings**

<table>
<thead>
<tr>
<th>Field</th>
<th>t_rc</th>
<th>t_wc</th>
<th>t_ceoe</th>
<th>t_wp</th>
<th>t_pc</th>
<th>t_tr</th>
</tr>
</thead>
<tbody>
<tr>
<td>Value</td>
<td>b0100</td>
<td>b0110</td>
<td>b010</td>
<td>b001</td>
<td>-</td>
<td>b011</td>
</tr>
</tbody>
</table>

Figure 2-23 on page 2-38 shows the turnaround time $t_{TR}$, enforced between synchronous read and asynchronous write. The turnaround time is enforced between:

- Reads followed by writes
- Writes followed by reads
- Read following a read from a different chip select.
Programming \( t_{RC} \) and \( t_{WC} \) when the controller operates in synchronous mode

For \( t_{RC} \):

- when using memory devices that are not wait-enabled, you must program \( t_{RC} \) to be the number of clock cycles required before valid data is available following the assertion of \( cs_n \)
- when using memory devices that are wait-enabled, you must program \( t_{RC} \) to be the number of clock cycles required before wait is active and stable, following the assertion of \( cs_n \). That is:
  \[
  t_{RC} = 3 + t_{CEOE}
  \]

Note

\( t_{CEOE} \) is only required if \textbf{wait} is asserted when \textbf{oe_n} goes LOW.
For tWC:

- when using memory devices that are not wait-enabled, you must program tWC to be the number of clock cycles required before the first data is written, following the assertion of cs_n

- when using memory devices that are wait-enabled, you must program tWC to be the number of clock cycles required before wait is active and stable, following the assertion of cs_n. That is:

\[ t_{WC} = 3 \]

--- Note ---

If a memory device is configured so that there are two or less clock cycles between the assertion of wait and data being required then you must program tWC as if the memory device is not wait-enabled.
Chapter 3
Programmer’s Model

This chapter describes the registers of the SMC and provides information for programming the device. It contains the following sections:

- *About the programmer’s model* on page 3-2
- *Register summary* on page 3-3
- *Register descriptions* on page 3-6.
3.1 About the programmer’s model

The SMC has 4KB of memory allocated to it from a base address of 0x1000 to a maximum address of 0x1FFF. Figure 3-1 shows that the register map address range is split into the following regions:

**SMC configuration registers**

Use these registers for the global configuration, and control of operating state, of the SMC.

**SMC chip select configuration registers**

These registers hold the operating parameters of each chip select.

**SMC user configuration registers**

These registers provide general purpose I/O for user specific applications.

**SMC integration test registers**

Use these registers to verify correct integration of the SMC within a system, by enabling non-AMBA ports to be set and read.

**SMC PrimeCell Id registers**

These registers enable the identification of system components by software.

![Figure 3-1 SMC register map](image-url)
3.2 Register summary

Figure 3-2 shows the SMC configuration register map.

```
<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>smc_refresh_period_0</td>
<td>0x1020</td>
</tr>
<tr>
<td>smc_set_opmode</td>
<td>0x1018</td>
</tr>
<tr>
<td>smc_set_cycles</td>
<td>0x1014</td>
</tr>
<tr>
<td>smc_direct_cmd</td>
<td>0x1010</td>
</tr>
<tr>
<td>smc_memc_cfg_clr</td>
<td>0x100C</td>
</tr>
<tr>
<td>smc_memc_cfg_set</td>
<td>0x1008</td>
</tr>
<tr>
<td>smc_memif_cfg</td>
<td>0x1004</td>
</tr>
<tr>
<td>smc_memc_status</td>
<td>0x1000</td>
</tr>
</tbody>
</table>
```

Figure 3-2 SMC configuration register map

Figure 3-3 shows the SMC chip<0-3> configuration register map:

```
<table>
<thead>
<tr>
<th>Register</th>
<th>Offset</th>
</tr>
</thead>
<tbody>
<tr>
<td>opmode</td>
<td>0x1004</td>
</tr>
<tr>
<td>sram_cycles</td>
<td>0x1000</td>
</tr>
</tbody>
</table>
```

SRAM chip configuration

```
Chip 3
  smc_opmode0_3          0x1164
  smc_sram_cycles0_3     0x1160

Chip 2
  smc_opmode0_2          0x1144
  smc_sram_cycles0_2     0x1140

Chip 1
  smc_opmode0_1          0x1124
  smc_sram_cycles0_1     0x1120

Chip 0
  smc_opmode0_0          0x1104
  smc_sram_cycles0_0     0x1100
```

Figure 3-3 SMC chip configuration register map
Note

Figure 3-3 on page 3-3 shows the maximum number of supported chips. If you intend to use fewer, then the highest chip configuration blocks of the correct type are read back as zero.

Figure 3-4 shows the SMC user configuration memory register map.

Figure 3-5 shows the SMC peripheral and PrimeCell configuration register map.

Table 3-1 lists the SMC Registers.

<table>
<thead>
<tr>
<th>Name</th>
<th>Base offset</th>
<th>Type</th>
<th>Reset value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>smc_memc_status</td>
<td>0x1000</td>
<td>RO</td>
<td>0x00000000</td>
<td>See SMC Memory Controller Status Register at 0x1000 on page 3-6.</td>
</tr>
<tr>
<td>smc_memif_cfg</td>
<td>0x1004</td>
<td>RO</td>
<td>0x0000020</td>
<td>See SMC Memory Interface Configuration Register at 0x1004 on page 3-7.</td>
</tr>
<tr>
<td>smc_memc_cfg_set</td>
<td>0x1008</td>
<td>WO</td>
<td>N/A</td>
<td>See SMC Set Configuration Register at 0x1008 on page 3-8.</td>
</tr>
<tr>
<td>smc_memc_cfg_clr</td>
<td>0x1010</td>
<td>WO</td>
<td>N/A</td>
<td>See SMC Clear Configuration Register at 0x1010 on page 3-9.</td>
</tr>
</tbody>
</table>
### Table 3-1 Register summary (continued)

<table>
<thead>
<tr>
<th>Name</th>
<th>Base offset</th>
<th>Type</th>
<th>Reset value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>smc_set_cycles</td>
<td>0x1014</td>
<td>WO</td>
<td>N/A</td>
<td>See SMC Set Cycles Register at 0x1014 on page 3-11.</td>
</tr>
<tr>
<td>smc_set_opmode</td>
<td>0x1018</td>
<td>WO</td>
<td>N/A</td>
<td>See SMC Set Opmode Register at 0x1018 on page 3-12.</td>
</tr>
<tr>
<td>smc_refresh_period_0</td>
<td>0x1020</td>
<td>R/W</td>
<td>0x00000000</td>
<td>See SMC Refresh Period 0 Register at 0x1020 on page 3-15.</td>
</tr>
<tr>
<td>smc_sram_cycles0_&lt;0-3&gt;</td>
<td>0x1000 + chip configuration base address</td>
<td>RO</td>
<td>0x0002B3CC</td>
<td>smc_sram_cycles configuration where: See SMC SRAM Cycles Registers &lt;0-3&gt; at 0x1100, 0x1120, 0x1140, 0x1160 on page 3-15.</td>
</tr>
<tr>
<td>smc_opmode0_&lt;0-3&gt;</td>
<td>0x1004 + chip configuration base address</td>
<td>RO</td>
<td>0x00000802</td>
<td>opmode configuration where: See SMC Opmode Registers &lt;0-3&gt; at 0x1104, 0x1124, 0x1144, 0x1164 on page 3-16.</td>
</tr>
<tr>
<td>smc_user_status</td>
<td>0x1200</td>
<td>RO</td>
<td>0x00000000</td>
<td>See SMC User Status Register at 0x1200 on page 3-18.</td>
</tr>
<tr>
<td>smc_user_config</td>
<td>0x1204</td>
<td>WO</td>
<td>-</td>
<td>See SMC User Configuration Register at 0x1204 on page 3-19.</td>
</tr>
<tr>
<td>smc_int_cfg</td>
<td>0x1E00</td>
<td>R/W</td>
<td>0x00000000</td>
<td>See SMC Integration Configuration Register at 0x1E00 on page 4-2.</td>
</tr>
<tr>
<td>smc_int_inputs</td>
<td>0x1E04</td>
<td>RO</td>
<td>-</td>
<td>See Integration Inputs Register at 0x1E04 on page 4-3.</td>
</tr>
<tr>
<td>smc_int_outputs</td>
<td>0x1E08</td>
<td>WO</td>
<td>-</td>
<td>See Integration Outputs Register at 0x1E08 on page 4-4.</td>
</tr>
<tr>
<td>smc_periph_id_&lt;0-3&gt;</td>
<td>0x1FE0-0x1FEC</td>
<td>RO</td>
<td>See registers</td>
<td>See SMC Peripheral Identification Registers &lt;0-3&gt; at 0x1FE0-0x1FEC on page 3-19.</td>
</tr>
<tr>
<td>smc_pcell_id_&lt;0-3&gt;</td>
<td>0x1FF0-0x1FFC</td>
<td>RO</td>
<td>See registers</td>
<td>See SMC PrimeCell Identification Registers &lt;0-3&gt; at 0x1FF0-0x1FFC on page 3-22.</td>
</tr>
</tbody>
</table>
3.3 Register descriptions

This section describes the SMC registers.

3.3.1 SMC Memory Controller Status Register at 0x1000

The read-only smc_memc_status Register provides information on the configuration of the SMC and also the current state of the SMC. This register cannot be read in the Reset state. Figure 3-6 shows the register bit assignments.

![Figure 3-6 smc_memc_status Register bit assignments](image)

Table 3-2 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:6]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[5]</td>
<td>raw_int_status0</td>
<td>Current raw interrupt status for interface 0</td>
</tr>
<tr>
<td>[4]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[3]</td>
<td>int_status0</td>
<td>Current interrupt status for interface 0</td>
</tr>
<tr>
<td>[2]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[1]</td>
<td>int_en0</td>
<td>Status of memory interface 0 interrupt enable</td>
</tr>
<tr>
<td>[0]</td>
<td>state</td>
<td>b0 indicates that the SMC is in Ready state</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b1 indicates that the SMC is in Low-power state.</td>
</tr>
</tbody>
</table>
3.3.2 SMC Memory Interface Configuration Register at 0x1004

The read-only smc_memif_cfg Register provides information on the configuration of the memory interface. This register cannot be read in the Reset state. Figure 3-7 shows the register bit assignments.

Table 3-3 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:18]</td>
<td>-</td>
<td>Reserved, read undefined.</td>
</tr>
<tr>
<td>[17:16]</td>
<td>exclusive_monitors</td>
<td>Returns the number of exclusive access monitor resources that are implemented in the SMC:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b00 = 0 monitors</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b01 = 1 monitors</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b10 = 2 monitors</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b11 = 4 monitors.</td>
</tr>
<tr>
<td>[6]</td>
<td>remap0</td>
<td>Returns the value of the smc_remap0 input.</td>
</tr>
<tr>
<td>[5:4]</td>
<td>memory_width0</td>
<td>Returns the maximum width of the SMC memory data bus for interface 0:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b00 = 8 bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b01 = 16 bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b10 = 32 bits</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b11 = Reserved.</td>
</tr>
</tbody>
</table>
3.3.3 SMC Set Configuration Register at 0x1008

The write-only smc_memc_cfg_set Register enables the memory controller to be changed to Low-power state, and interrupts enabled. This register cannot be written to in the Reset state. Figure 3-8 shows the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[3:2]</td>
<td>memory_chips0</td>
<td>Returns the number of different chip selects that the memory interface 0 supports:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b00 = 1 chip</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b01 = 2 chips</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b10 = 3 chips</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b11 = 4 chips.</td>
</tr>
<tr>
<td>[1:0]</td>
<td>memory_type0</td>
<td>Returns the memory interface 0 type:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b00 = reserved</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b01 = SRAM</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b10 = NAND</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b11 = reserved.</td>
</tr>
</tbody>
</table>

Figure 3-8 smc_memc_cfg_set Register bit assignments
Table 3-4 lists the register bit assignments.

### Table 3-4 smc_memc_cfg_set Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:3]</td>
<td>-</td>
<td>Reserved, undefined. Write as zero.</td>
</tr>
<tr>
<td>[2]</td>
<td>low_power_req</td>
<td>b0 = no effect</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b1 = request the SMC to enter Low-power state when it next becomes idle.</td>
</tr>
<tr>
<td>[0]</td>
<td>int_enable0</td>
<td>b0 = no effect</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b1 = interrupt enable, memory interface 0.</td>
</tr>
</tbody>
</table>

#### 3.3.4 SMC Clear Configuration Register at 0x100C

The write-only smc_memcCfg_clr Register enables the memory controller to be moved out of the Low-power state, and the interrupts disabled. This register cannot be written to in the Reset state. Figure 3-9 shows the register bit assignments.

![Figure 3-9 smc_memc_cfg_clr Register bit assignments](image)

Table 3-5 lists the register bit assignments.

### Table 3-5 smc_memc_cfg_clr Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:3]</td>
<td>-</td>
<td>Reserved, undefined. Write as zero.</td>
</tr>
<tr>
<td>[2]</td>
<td>low_power_exit</td>
<td>b0 = no effect</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b1 = request the SMC to exit Low-power state.</td>
</tr>
<tr>
<td>[0]</td>
<td>int_disable0</td>
<td>b0 = no effect</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b1 = interrupt disable, memory interface 0.</td>
</tr>
</tbody>
</table>
3.3.5 SMC Direct Command Register at 0x1010

The write-only smc_direct_cmd Register passes commands to the external memory, and controls the updating of the chip configuration registers with values held in the set_opmode and set_cycles registers.

This register cannot be written to in either the Reset or Low-power state. Figure 3-10 shows the register bit assignments.

Table 3-6 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:26]</td>
<td>-</td>
<td>Reserved, undefined. Write as zero.</td>
</tr>
</tbody>
</table>
| [25:23] | chip_select | Selects chip configuration register bank to update and enables chip mode register access depending on cmd_type. The encoding is:  
  b000-b011 = chip selects 1-4 on interface 0  
  b100-b111 = reserved.                        |
| [22:21] | cmd_type   | Determines the current command. The encoding is:                         
  b00 = UpdateRegs and AHB command             
  b01 = ModeReg access                         
  b10 = UpdateRegs                             
  b11 = ModeReg and UpdateRegs.               |
| [20]   | set_cre    | Maps to configuration register enable, smc_cre, output, when a ModeReg command is issued. The encoding is:  
  b0 = smc_cre is LOW                          
  b1 = smc_cre is HIGH when ModeReg write occurs. |
| [19:0] | addr       | Bits mapped to external memory address bits [19:0] when command is ModeReg access.  
  Addr[19:16] are undefined.  
  Addr[15:0] matches wdata[15:0] when the commands are UpdateRegs and AHB command access. |
3.3.6 SMC Set Cycles Register at 0x1014

This is the holding register for the smc_set_cycles\(0\)\(_{<n>\}. The write-only smc_set_cycles Register enables the time interval to be set for holding registers before data can be written to the memory manager specific registers. This register cannot be written to in either the Reset or Low-power state. Figure 3-11 shows the register bit assignments.

--- Note ---

Table 3-7 describes register holding, see Memory manager operation on page 2-22 for more information.

---

Figure 3-11 smc_set_cycles Register bit assignments

Table 3-7 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[19:17]</td>
<td>Set_t5</td>
<td>Holding register for value to be written to the specific chip Register t_TR field.</td>
</tr>
<tr>
<td>[16:14]</td>
<td>Set_t4</td>
<td>Holding register for value to be written to the specific chip Register t_PC field.</td>
</tr>
<tr>
<td>[13:11]</td>
<td>Set_t3</td>
<td>Holding register for value to be written to the specific chip Register t_WP field.</td>
</tr>
<tr>
<td>[10:8]</td>
<td>Set_t2</td>
<td>Holding register for value to be written to the specific chip Register t_CEOE field.</td>
</tr>
<tr>
<td>[7:4]</td>
<td>Set_t1</td>
<td>Holding register for value to be written to the specific chip Register t_WC field.</td>
</tr>
<tr>
<td>[3:0]</td>
<td>Set_t0</td>
<td>Holding register for value to be written to the specific chip Register t_RC field.</td>
</tr>
</tbody>
</table>
3.3.7 SMC Set Opmode Register at 0x1018

This register is the holding register for the smc_opmode0_<n> working registers. The write-only smc_set_opmode Register cannot be written to in either the Reset or Low-power state. Figure 3-12 shows the register bit assignments.

——— Note ————

Table 3-8 on page 3-13 describes register holding, see Memory manager operation on page 2-22 for more information.

```
| 31 |   |   | 16 | 15 | 13 | 12 | 11 | 10 | 9 | 7 | 6 | 5 | 3 | 2 | 1 | 0 |
|----|---|---|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|
|    |   |   | Undefined |    |    |    |    |    |    |    |    |    |    |    |

set_burst_align
set_bls
set_adv
set_baa
set_wr_bl
set_wr_sync
set_rd_bl
set_rd_sync
set_mw
```

Figure 3-12 smc_set_opmode Register bit assignments
Table 3-8 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:16]</td>
<td>-</td>
<td>Reserved, undefined, write as zero.</td>
</tr>
<tr>
<td>[15:13]</td>
<td>set_burst_align</td>
<td>Holding register for value to be written to the specific SRAM chip opmode Register burst_align field. These bits determine whether memory...</td>
</tr>
<tr>
<td></td>
<td></td>
<td>burst split on memory burst boundary, that is, 32 beats for continuous</td>
</tr>
<tr>
<td></td>
<td></td>
<td>010 = burst split on 64 beat boundary</td>
</tr>
<tr>
<td></td>
<td></td>
<td>011 = burst split on 128 beat boundary</td>
</tr>
<tr>
<td></td>
<td></td>
<td>100 = burst split on 256 beat boundary</td>
</tr>
<tr>
<td></td>
<td></td>
<td>others = reserved.</td>
</tr>
</tbody>
</table>

___ Note _______

For asynchronous transfers:
- the AHB MC always aligns read bursts to the memory burst boundary, when set_rd_sync = 0
- the AHB MC always aligns write bursts to the memory burst boundary, when set_wr_sync = 0.

<table>
<thead>
<tr>
<th>[12]</th>
<th>set_bls</th>
<th>Holding register for value to be written to the specific SRAM chip smc_opmode Register byte lane strobe (bls) field. This bit affects the assertion...</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>b0 = bls timing equals chip select timing. This is the default setting.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>b1 = bls timing equals smc_we_n_0 timing. This setting is used for eight bit wide memories that have no smc_bls_n_0[3:0] inputs. In this case...</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>[11]</th>
<th>set_adv</th>
<th>Holding register for the value to be written to the specific SRAM chip smc_opmode Register address valid (adv) field. The memory uses the address...</th>
</tr>
</thead>
</table>

| [10]         | set_baa          | Holding register for value to be written to the specific SRAM chip smc_opmode Register Burst Address Advance (baa) field. The memory uses the smc_baa_n_0 signal when set. |
### Table 3-8 smc_set_opmode Register bit assignments (continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
</table>
| [9:7] | set_wr_bl   | Holding register for value to be written to the specific SRAM chip smc_opmode Register bls field.  
|       |             | Encodes the memory burst length:  
|       |             | b000 = 1 beat  
|       |             | b001 = 4 beats  
|       |             | b010 = 8 beats  
|       |             | b011 = 16 beats  
|       |             | b100 = 32 beats  
|       |             | b101 = continuous  
|       |             | b110-b111 = reserved.  
| [6]   | set_wr_sync | Holding register for value to be written to the specific SRAM chip smc_opmode Register wr_sync field. The memory writes are synchronous when set. This bit is reserved for a NAND memory interface.  
| [5:3] | set_rd_bl   | Holding register for value to be written to the specific SRAM chip smc_opmode Register bls field.  
|       |             | Encodes the memory burst length:  
|       |             | b000 = 1 beat  
|       |             | b001 = 4 beats  
|       |             | b010 = 8 beats  
|       |             | b011 = 16 beats  
|       |             | b100 = 32 beats  
|       |             | b101 = continuous  
|       |             | b110-b111 = reserved.  
| [2]   | set_rd_sync | Holding register before being written to the specific SRAM chip smc_opmode Register rd_sync field. Memory in sync mode when set.  
| [1:0] | set_mw      | Holding register for value to be written to the specific SRAM chip smc_opmode Register memory width (mw) field.  
|       |             | Encodes the memory data bus width:  
|       |             | b00 = 8 bits  
|       |             | b01 = 16 bits  
|       |             | b10 = 32 bits  
|       |             | b11 = reserved.  
|       |             | You can program this to the configured width or half that width. See SMC Memory Interface Configuration Register at 0x1004 on page 3-7. |
3.3.8 SMC Refresh Period 0 Register at 0x1020

The read/write smc_refresh_period_0 Register enables the AHB MC to perform refresh cycles for PSRAM devices that you connect to memory interface 0. You cannot access this register in either the Reset or low-power states. Figure 3-13 shows the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
</table>
| [3:0] | period   | Sets the number of consecutive memory bursts that are permitted, prior to the AHB MC deasserting chip select to enable the PSRAM to initiate a refresh cycle. The options are: b0000 = disable the insertion of idle cycles between consecutive bursts b0001 = an idle cycle occurs after each burst b0010 = an idle cycle occurs after 2 consecutive bursts b0011 = an idle cycle occurs after 3 consecutive bursts b0100 = an idle cycle occurs after 4 consecutive bursts . . b1111 = an idle cycle occurs after 15 consecutive bursts.

Figure 3-13 smc_refresh_period_0 Register bit assignments

Table 3-9 lists the register bit assignments.

3.3.9 SMC SRAM Cycles Registers <0-3> at 0x1100, 0x1120, 0x1140, 0x1160

There is an instance of this register for each SRAM chip supported. The read-only smc_sram_cycles Register cannot be read in the Reset state. Figure 3-14 shows the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:0]</td>
<td>t_tr, t_pc, t_wp, t_ceoe, t_wc, t_rc</td>
<td>t_tr, t_pc, t_wp, t_ceoe, t_wc, t_rc</td>
</tr>
</tbody>
</table>

Figure 3-14 smc_sram_cycles Register bit assignments
Table 3-10 lists the register bit assignments.

### Table 3-10 smc_sram_cycles Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:20]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[19:17]</td>
<td>t_tr</td>
<td>Turnaround time for SRAM chip configuration</td>
</tr>
<tr>
<td>[16:14]</td>
<td>t_pc</td>
<td>Page cycle time for SRAM chip configuration</td>
</tr>
<tr>
<td>[13:11]</td>
<td>t_wp</td>
<td>\texttt{smc_we_n} assertion delay</td>
</tr>
<tr>
<td>[10:8]</td>
<td>t_ceoe</td>
<td>\texttt{smc_oe_n} assertion delay for SRAM chip configurations</td>
</tr>
<tr>
<td>[7:4]</td>
<td>t_wc</td>
<td>Write cycle time</td>
</tr>
<tr>
<td>[3:0]</td>
<td>t_rc</td>
<td>Read cycle time</td>
</tr>
</tbody>
</table>

#### 3.3.10 SMC Opmode Registers <0-3> at 0x1104, 0x1124, 0x1144, 0x1164

There is an instance of the smc_opmode Register for each chip supported. This register is read-only and cannot be read in the Reset state.

The reset values of these registers are configuration-dependent. You can set the memory width for the chip select 0 of each memory interface with a tie off to enable booting from that chip. The reset value of memory width for all other chip selects is the configured width. You must set all other bits to 0x0, apart from address_match and address_mask. These are set by tie-offs at the top level.

Figure 3-15 shows the register bit assignments.

![Figure 3-15 smc_opmode Register bit assignments](image-url)
Table 3-11 lists the register bit assignments.

### Table 3-11 smc_opmode Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:24]</td>
<td>address_match</td>
<td>Returns the value of this tie-off. This is the comparison value for address bits [31:24] to determine the chip that is selected.</td>
</tr>
<tr>
<td>[23:16]</td>
<td>address_mask</td>
<td>Returns the value of this tie-off. This is the mask for address bits [31:24] to determine the chip that must be selected. A logic 1 indicates the bit is used for comparison.</td>
</tr>
<tr>
<td>[15:13]</td>
<td>burst_align</td>
<td>These bits determine whether memory bursts are split on memory burst boundaries: 000 = bursts can cross any address boundary 001 = burst split on memory burst boundary, that is, 32 beats for continuous 010 = burst split on 64 beat boundary 011 = burst split on 128 beat boundary 100 = burst split on 256 beat boundary others = reserved.</td>
</tr>
<tr>
<td></td>
<td></td>
<td><strong>Note</strong></td>
</tr>
<tr>
<td></td>
<td></td>
<td>For asynchronous transfers:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• the AHB MC always aligns read bursts to the memory burst boundary, when rd_sync = 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>• the AHB MC always aligns write bursts to the memory burst boundary, when wr_sync = 0</td>
</tr>
<tr>
<td>[12]</td>
<td>bls</td>
<td>This bit affects the assertion of the byte-lane strobe outputs: b0 = bls timing equals chip select timing. This is the default setting. b1 = bls timing equals smc_we_n_0 timing. This setting is used for 8-bit memories that have no Byte Lane Strobe inputs. In this case, the smc_bls_n_0[3:0] output of the memory controller is connected to the smc_we_n_0 memory input.</td>
</tr>
<tr>
<td>[11]</td>
<td>adv</td>
<td>The memory uses the address advance signal smc_adv_n_0 when set.</td>
</tr>
<tr>
<td>[10]</td>
<td>baa</td>
<td>The memory uses the burst advance signal smc_baa_n_0 when set.</td>
</tr>
<tr>
<td>[9:7]</td>
<td>wr_bl</td>
<td>Determines the memory burst length for writes: b000 = 1 beat b001 = 4 beats b010 = 8 beats b011 = 16 beats b100 = 32 beats b101 = continuous b110-b111 = reserved.</td>
</tr>
</tbody>
</table>
The `smc_user_status` Register is a general purpose read-only register that returns the state on the `smc_user_status[7:0]` primary inputs. The `smc_user_status` Register can be read in all states. Figure 3-16 shows the register bit assignments.

![Figure 3-16 smc_user_status Register bit assignments](image_url)

Table 3-12 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[7:0]</td>
<td><code>smc_user_status</code></td>
<td>The value returns the state of the <code>smc_user_status[7:0]</code> primary input pins</td>
</tr>
</tbody>
</table>
3.3.12 SMC User Configuration Register at 0x1204

The smc_user_config Register is a general purpose write-only register. This register sets the value of the smc_user_config[7:0] primary outputs. The smc_user_config Register can be written in all states. Figure 3-17 shows the register bit assignments.

Figure 3-17 smc_user_config Register bit assignments

Table 3-13 lists the register bit assignments.

Table 3-13 smc_user_config Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, undefined. Write as zero.</td>
</tr>
<tr>
<td>[7:0]</td>
<td>smc_user_config</td>
<td>This value sets the state of the smc_user_config[7:0] primary output pins.</td>
</tr>
</tbody>
</table>

3.3.13 SMC Peripheral Identification Registers <0-3> at 0x1FE0-0x1FEC

The smc_periph_id Registers are four 8-bit read-only registers, that span address locations 0xFE0-0xFEC. The registers can conceptually be treated as a single register that holds a 32-bit peripheral ID value. They are read by an external master to determine what version of the device the SMC is. None of the registers 0-3 can be read in the Reset state.

Table 3-14 lists the register bit assignments.

Table 3-14 smc_periph_id Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>[24]</td>
<td>integration_cfg</td>
<td>Configuration options are peripheral-specific.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>See SMC Peripheral Identification Register 3 on page 3-21.</td>
</tr>
<tr>
<td>[23:20]</td>
<td>-</td>
<td>The peripheral revision number is revision-dependent.</td>
</tr>
<tr>
<td>[19:12]</td>
<td>designer</td>
<td>Designer’s ID number. This is 0x41 for ARM.</td>
</tr>
<tr>
<td>[11:0]</td>
<td>part_number</td>
<td>Identifies the peripheral. The part number for the SMC is 0x352.</td>
</tr>
</tbody>
</table>
Figure 3-18 shows the correspondence between bits of the smc_periph_id registers and the conceptual 32-bit Peripheral ID Register.

The following section describe the smc_periph_id Registers

- **SMC Peripheral Identification Register 0**
- **SMC Peripheral Identification Register 1** on page 3-21
- **SMC Peripheral Identification Register 2** on page 3-21
- **SMC Peripheral Identification Register 3** on page 3-21.

### SMC Peripheral Identification Register 0

The smc_periph_id_0 Register is hard-coded and the fields within the register indicate the value. Table 3-15 lists the register bit assignments.

#### Table 3-15 smc_periph_id_0 Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[7:0]</td>
<td>part_number_0</td>
<td>These bits read back as 0x52</td>
</tr>
</tbody>
</table>
SMC Peripheral Identification Register 1

The smc_periph_id_1 Register is hard-coded and the fields within the register indicate the value. Table 3-16 lists the register bit assignments.

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[7:4]</td>
<td>designer_0</td>
<td>These bits read back as 0x1</td>
</tr>
<tr>
<td>[3:0]</td>
<td>part_number_1</td>
<td>These bits read back as 0x3</td>
</tr>
</tbody>
</table>
```

SMC Peripheral Identification Register 2

The smc_periph_id_2 Register is hard-coded and the fields within the register indicate the value. Table 3-17 lists the register bit assignments.

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[7:4]</td>
<td>revision</td>
<td>These bits read back as 0x3</td>
</tr>
<tr>
<td>[3:0]</td>
<td>designer_1</td>
<td>These bits read back as 0x4</td>
</tr>
</tbody>
</table>
```

SMC Peripheral Identification Register 3

The smc_periph_id_3 Register is hard-coded and the fields within the register indicate the value of 0x0. Table 3-18 lists the register bit assignments.

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, read undefined.</td>
</tr>
<tr>
<td>[0]</td>
<td>integration_cfg</td>
<td>When set, the integration test register map at address offset 0xE00 is present for reading and writing. If clear, the integration test registers have not been implemented.</td>
</tr>
</tbody>
</table>
```
3.3.14 SMC PrimeCell Identification Registers <0-3> at 0x1FF0-0x1FFC

The smc_pcell_id Registers are four 8-bit wide registers, that span address locations 0xFF0-0xFFC. The registers can conceptually be treated as a single register that holds a 32-bit PrimeCell ID value. You can use the register for automatic BIOS configuration. The smc_pcell_id Register is set to 0xB105F00D. The register can be accessed with one wait state. Table 3-19 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Value</th>
<th>Register</th>
<th>Bits</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:24]</td>
<td>0xB1</td>
<td>smc_pcell_id_3</td>
<td>[7:0]</td>
<td>These bits read back as 0xB1</td>
</tr>
<tr>
<td>[23:16]</td>
<td>0x05</td>
<td>smc_pcell_id_2</td>
<td>[7:0]</td>
<td>These bits read back as 0x05</td>
</tr>
<tr>
<td>[15:8]</td>
<td>0xF0</td>
<td>smc_pcell_id_1</td>
<td>[7:0]</td>
<td>These bits read back as 0xF0</td>
</tr>
<tr>
<td>[7:0]</td>
<td>0x0D</td>
<td>smc_pcell_id_0</td>
<td>[7:0]</td>
<td>These bits read back as 0x0D</td>
</tr>
</tbody>
</table>

Figure 3-19 shows the register bit assignments.
The following sections describe the smc_pcell_id Registers:

- **SMC PrimeCell Identification Register 0**
- **SMC PrimeCell Identification Register 1**
- **SMC PrimeCell Identification Register 2** on page 3-24
- **SMC PrimeCell Identification Register 3** on page 3-24.

--- Note ---

These registers cannot be read in the Reset state.

---

**SMC PrimeCell Identification Register 0**

The smc_pcell_id_0 Register is hard-coded and the fields within the register indicate the value. Table 3-20 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[7:0]</td>
<td>smc_pcell_id_0</td>
<td>These bits read back as 0x0D</td>
</tr>
</tbody>
</table>

**SMC PrimeCell Identification Register 1**

The smc_pcell_id_1 Register is hard-coded and the fields within the register indicate the value. Table 3-21 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[7:0]</td>
<td>smc_pcell_id_1</td>
<td>These bits read back as 0xF0</td>
</tr>
</tbody>
</table>
SMC PrimeCell Identification Register 2

The smc_pcell_id_2 Register is hard-coded and the fields within the register indicate the value. Table 3-22 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[7:0]</td>
<td>smc_pcell_id_2</td>
<td>These bits read back as 0x5</td>
</tr>
</tbody>
</table>

SMC PrimeCell Identification Register 3

The smc_pcell_id_3 Register is hard-coded and the fields within the register indicate the value. Table 3-23 lists the register bit assignments.

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:8]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[7:0]</td>
<td>smc_pcell_id_3</td>
<td>These bits read back as 0x81</td>
</tr>
</tbody>
</table>
Chapter 4
Programmer’s Model for Test

This chapter describes the additional logic for functional verification and production testing. It contains the following section:

- *SMC integration test registers* on page 4-2.
4.1 SMC integration test registers

Test registers are provided for integration testing.

Figure 4-1 shows the SMC integration test register map.

![Figure 4-1 SMC integration test register map](image)

Table 4-1 lists the SMC integration test registers.

<table>
<thead>
<tr>
<th>Name</th>
<th>Base offset</th>
<th>Type</th>
<th>Reset value</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>smc_int_cfg</td>
<td>0x1E00</td>
<td>R/W</td>
<td>0x0</td>
<td>SMC Integration Configuration Register at 0x1E00</td>
</tr>
<tr>
<td>smc_int_inputs</td>
<td>0x1E04</td>
<td>RO</td>
<td>-</td>
<td>Integration Inputs Register at 0x1E04 on page 4-3</td>
</tr>
<tr>
<td>smc_int_outputs</td>
<td>0x1E08</td>
<td>WO</td>
<td>-</td>
<td>Integration Outputs Register at 0x1E08 on page 4-4</td>
</tr>
</tbody>
</table>

4.1.1 SMC Integration Configuration Register at 0x1E00

The read/write smc_int_cfg Register selects the integration test registers. This register is only for test. This register cannot be read or written to in the Reset state.

Figure 4-2 shows the register bit assignments.

![Figure 4-2 smc_int_cfg Register bit assignments](image)
Table 4-2 lists the register bit assignments.

### Table 4-2 smc_int_cfg Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:1]</td>
<td>Undefined</td>
<td>Read undefined. Write as zero.</td>
</tr>
<tr>
<td>[0]</td>
<td>int_test_en</td>
<td>When set, outputs are driven from the integration test registers and tied-off, and inputs can change for integration testing.</td>
</tr>
</tbody>
</table>

#### 4.1.2 Integration Inputs Register at 0x1E04

The read-only smc_int_inputs Register enables an external master to access the inputs of the SMC using the APB interface. This register is only for test. This register cannot be read in the Reset state.

Figure 4-3 shows the register bit assignments.

![Figure 4-3 smc_int_inputs Register bit assignments](image)

Table 4-3 lists the register bit assignments.

### Table 4-3 smc_int_inputs Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:6]</td>
<td>-</td>
<td>Reserved, read undefined</td>
</tr>
<tr>
<td>[5]</td>
<td>smc_msync0</td>
<td>Returns the value of this top-level tie-off</td>
</tr>
<tr>
<td>[4]</td>
<td>smc_async0</td>
<td>Returns the value of this top-level tie-off</td>
</tr>
<tr>
<td>[3]</td>
<td>smc_ebibackoff0</td>
<td>Returns the value of the smc_ebibackoff0 input</td>
</tr>
</tbody>
</table>
Table 4-3 smc_int_inputs Register bit assignments (continued)

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[2]</td>
<td>smc_ebign0</td>
<td>Returns the value of the smc_ebigrant0 input</td>
</tr>
<tr>
<td>[1]</td>
<td>smc_use_ebi</td>
<td>Returns the value of the smc_use_ebi input</td>
</tr>
<tr>
<td>[0]</td>
<td>smc_csysreq</td>
<td>Returns value of this external input</td>
</tr>
</tbody>
</table>

4.1.3 Integration Outputs Register at 0x1E08

The write-only smc_int_outputs Register enables an external master to access the outputs of the SMC using the APB interface. This register cannot be read in the Reset state.

Figure 4-4 shows the register bit assignments.

Table 4-4 lists the register bit assignments.

Table 4-4 smc_int_outputs Register bit assignments

<table>
<thead>
<tr>
<th>Bits</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>[31:3]</td>
<td>-</td>
<td>Reserved, undefined, write as zero</td>
</tr>
<tr>
<td>[2]</td>
<td>smc_ebireq0</td>
<td>Sets the value of the smc_ebireq0 output when in integration test mode</td>
</tr>
<tr>
<td>[1]</td>
<td>smc_csysack</td>
<td>Sets the value of this external output when in integration test mode</td>
</tr>
<tr>
<td>[0]</td>
<td>smc_cactive</td>
<td>This value is driven onto the external output when int_test_en is set HIGH</td>
</tr>
</tbody>
</table>
Chapter 5

Device Driver Requirements

This chapter contains various flow diagrams to aid in the development of a software driver for the SMC. It contains the following section:

- *Memory initialization* on page 5-2.
5.1 Memory initialization

Figure 5-1 on page 5-3 and Figure 5-3 on page 5-5 shows the sequence of events that a device driver must carry out to initialize the memory controller and a memory device to ensure the configuration of both is synchronized.

Typically, PSRAM devices can have the mode register programmed using the address bus only. NOR flash memory devices are examples of memory that requires mode register accesses to be carried out using a sequence of accesses using the address and data buses. Check the data sheet for the specific memory device you are configuring to determine the configuration method.
Figure 5-1 SMC and memory initialization sheet 1 of 3

// Pseudo-Code for 'smc_set_cycles' Subroutine
int set_cycles (t6, t5, t4, t3, t2, t1, t0) {
    // Shift each parameter to the correct bit position,
    // for example:
    set_cycles_val = (t6 << 20) | (t5 << 17) | (t4 << 14) |
    (t3 << 11) | (t2 << 8) | (t1 << 4) | (t0);
    // Update the SMC's set_cycles holding register,
    // for example:
    pl240_ahbmc->smc_set_cycles = set_cycles_val;
    return 0;
}

// Pseudo-Code for 'smc_set_opmode' Subroutine
int smc_set_opmode (set_burst_align, set_byte_lane_strobe,
                    etc...) {
    // Shift each parameter to the correct bit position,
    // for example:
    set_opmode_options = (set_burst_align    << 13) |
                         (set_byte_lane_strobe  << 12) | ...;
    // Update the SMC's set_opmode holding register,
    // for example:
    pl240_ahbmc->smc_set_opmode = set_opmode_options;
    return 0;
}
Figure 5-2 SMC and memory initialization sheet 2 of 3
Figure 5-3 SMC and memory initialization sheet 3 of 3

Where:

x = denotes the appropriate chip select.
Appendix A
Signal Descriptions

This appendix lists and describes the processor signals. It contains the following sections:

- *About the signals list* on page A-2
- *Clocks and resets* on page A-3
- *AHB signals* on page A-4
- *SMC memory interface signals* on page A-5
- *SMC miscellaneous signals* on page A-6
- *Low-power interface* on page A-7
- *Configuration signal* on page A-8
- *Scan chains* on page A-9.
A.1 About the signals list

This appendix lists the PL241 signals. Figure A-1 shows how the signals are grouped.

![AHB MC PL241 grouping of signals](image)

where:

AHBC = AHB Configuration signals
A.2  Clocks and resets

Table A-1 lists the clock and reset signals.

<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Source/destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>hclk</td>
<td>Input</td>
<td>Clock source</td>
<td>AHB clock</td>
</tr>
<tr>
<td>hresetn</td>
<td>Input</td>
<td>Reset source</td>
<td>AHB clock domain reset</td>
</tr>
<tr>
<td>smc_aclk</td>
<td>Input</td>
<td>Clock source</td>
<td>SMC AHB clock</td>
</tr>
<tr>
<td>smc_mclk0</td>
<td>Input</td>
<td>Clock source</td>
<td>SMC memory clock</td>
</tr>
<tr>
<td>smc_mclk0n</td>
<td>Input</td>
<td>Clock source</td>
<td>SMC inverted memory clock</td>
</tr>
<tr>
<td>smc_mreset0n</td>
<td>Input</td>
<td>Reset source</td>
<td>SMC memory clock domain reset</td>
</tr>
</tbody>
</table>
A.3 AHB signals

Table A-2 lists the AHB signals.

<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Source/destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>hsel&lt;x&gt;</td>
<td>Input</td>
<td>AHB</td>
<td>Transfer is to this port</td>
</tr>
<tr>
<td>haddr&lt;x&gt;[31:0]</td>
<td>Input</td>
<td>AHB</td>
<td>Address of transfer</td>
</tr>
<tr>
<td>htrans&lt;x&gt;[1:0]</td>
<td>Input</td>
<td>AHB</td>
<td>Transfer type</td>
</tr>
<tr>
<td>hwrite&lt;x&gt;</td>
<td>Input</td>
<td>AHB</td>
<td>Transfer is write or read</td>
</tr>
<tr>
<td>hsize&lt;x&gt;[2:0]</td>
<td>Input</td>
<td>AHB</td>
<td>Size of transfer</td>
</tr>
<tr>
<td>hburst&lt;x&gt;[2:0]</td>
<td>Input</td>
<td>AHB</td>
<td>Burst type of transfer</td>
</tr>
<tr>
<td>hprot&lt;x&gt;[3:0]</td>
<td>Input</td>
<td>AHB</td>
<td>Protection of transfer</td>
</tr>
<tr>
<td>hwdata&lt;x&gt;[31:0]</td>
<td>Input</td>
<td>AHB</td>
<td>Write data</td>
</tr>
<tr>
<td>hmastlock&lt;x&gt;</td>
<td>Input</td>
<td>AHB</td>
<td>Locked transfer</td>
</tr>
<tr>
<td>hready&lt;x&gt;</td>
<td>Input</td>
<td>AHB</td>
<td>System ready</td>
</tr>
<tr>
<td>hrdatal&lt;x&gt;[31:0]</td>
<td>Output</td>
<td>AHB</td>
<td>Read data</td>
</tr>
<tr>
<td>hreadyout&lt;x&gt;</td>
<td>Output</td>
<td>AHB</td>
<td>Slave ready</td>
</tr>
<tr>
<td>hresp&lt;x&gt;[1:0]</td>
<td>Output</td>
<td>AHB</td>
<td>Slave response</td>
</tr>
</tbody>
</table>

where:

<x> = 0 or C, where C = Configuration.
### A.4 SMC memory interface signals

Table A-3 lists the SMC memory interface signals.

<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Source/destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>smc_fbclk_in_0</td>
<td>Input</td>
<td>Memory</td>
<td>Fed back clock</td>
</tr>
<tr>
<td>smc_data_in_0[31:0]</td>
<td>Input</td>
<td>Memory</td>
<td>Data in</td>
</tr>
<tr>
<td>smc_wait_0</td>
<td>Input</td>
<td>Memory</td>
<td>Wait</td>
</tr>
<tr>
<td>smc_int_0</td>
<td>Input</td>
<td>Memory</td>
<td>Interrupt</td>
</tr>
<tr>
<td>smc_clk_out_0[3:0]</td>
<td>Output</td>
<td>Memory</td>
<td>Clock</td>
</tr>
<tr>
<td>smc_add_0[31:0]</td>
<td>Output</td>
<td>Memory</td>
<td>Address</td>
</tr>
<tr>
<td>smc_cs_n_0[3:0]</td>
<td>Output</td>
<td>Memory</td>
<td>Chip select</td>
</tr>
<tr>
<td>smc_we_n_0</td>
<td>Output</td>
<td>Memory</td>
<td>Write enable</td>
</tr>
<tr>
<td>smc_we_n_0</td>
<td>Output</td>
<td>Memory</td>
<td>Write enable</td>
</tr>
<tr>
<td>smc_we_n_0</td>
<td>Output</td>
<td>Memory</td>
<td>Write enable</td>
</tr>
<tr>
<td>smc_we_n_0</td>
<td>Output</td>
<td>Memory</td>
<td>Write enable</td>
</tr>
<tr>
<td>smc_adv_n_0</td>
<td>Output</td>
<td>Memory</td>
<td>Address advance signal</td>
</tr>
<tr>
<td>smc_baa_n_0</td>
<td>Output</td>
<td>Memory</td>
<td>Bank address</td>
</tr>
<tr>
<td>smc_cre_0</td>
<td>Output</td>
<td>Memory</td>
<td>Configuration register enable</td>
</tr>
<tr>
<td>smc_bls_n_0[3:0]</td>
<td>Output</td>
<td>Memory</td>
<td>Byte lane strobes</td>
</tr>
<tr>
<td>smc_data_out_0[31:0]</td>
<td>Output</td>
<td>Memory</td>
<td>Data out</td>
</tr>
<tr>
<td>smc_data_en_0</td>
<td>Output</td>
<td>Memory</td>
<td>Data enable</td>
</tr>
<tr>
<td>smc_use_ebi</td>
<td>Input</td>
<td>Memory</td>
<td>Use EBI tie-off</td>
</tr>
<tr>
<td>smc_ebigrant0</td>
<td>Input</td>
<td>Memory</td>
<td>EBI grant</td>
</tr>
<tr>
<td>smc_ebibackoff0</td>
<td>Input</td>
<td>Memory</td>
<td>EBI back off</td>
</tr>
<tr>
<td>smc_ebireq0</td>
<td>Output</td>
<td>Memory</td>
<td>EBI request</td>
</tr>
</tbody>
</table>
### A.5 SMC miscellaneous signals

Table A-4 lists the SMC miscellaneous signals.

<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Source/destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>smc_async0</td>
<td>Input</td>
<td>Tie-off</td>
<td>AHB clock synchronous to memory clock</td>
</tr>
<tr>
<td>smc_msync0</td>
<td>Input</td>
<td>Tie-off</td>
<td>Memory clock synchronous to AHB clock</td>
</tr>
<tr>
<td>smc_a_gt_m0_sync</td>
<td>Input</td>
<td>Tie-off</td>
<td>When HIGH, indicates that smc_aclk is greater than and synchronous to smc_mclk0</td>
</tr>
<tr>
<td>smc_address_mask0_0[7:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>Address mask for chip select 0</td>
</tr>
<tr>
<td>smc_address_match0_0[7:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>Address match for chip select 0</td>
</tr>
<tr>
<td>smc_address_mask0_1[7:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>Address mask for chip select 1</td>
</tr>
<tr>
<td>smc_address_match0_1[7:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>Address match for chip select 1</td>
</tr>
<tr>
<td>smc_address_mask0_2[7:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>Address mask for chip select 2</td>
</tr>
<tr>
<td>smc_address_match0_2[7:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>Address match for chip select 2</td>
</tr>
<tr>
<td>smc_address_mask0_3[7:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>Address mask for chip select 3</td>
</tr>
<tr>
<td>smc_address_match0_3[7:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>Address match for chip select 3</td>
</tr>
<tr>
<td>smc_remap_0</td>
<td>Input</td>
<td>Tie-off</td>
<td>Remap</td>
</tr>
<tr>
<td>smc_mux_mode_0</td>
<td>Input</td>
<td>Tie-off</td>
<td>Multiplexor mode</td>
</tr>
<tr>
<td>smc_sram_mw_0[1:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>Memory width tie-off</td>
</tr>
<tr>
<td>smc_user_status[7:0]</td>
<td>Input</td>
<td>Tie-off</td>
<td>User signals to the configuration port</td>
</tr>
<tr>
<td>smc_user_config[7:0]</td>
<td>Output</td>
<td>System</td>
<td>User signals from the configuration port</td>
</tr>
<tr>
<td>smc_int</td>
<td>Output</td>
<td>System</td>
<td>Interrupt</td>
</tr>
</tbody>
</table>
A.6 Low-power interface

Table A-5 lists the low-power interface signals.

<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Source/destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ahb_csysreq</td>
<td>Input</td>
<td>System controller</td>
<td>AHB interfaces low-power mode request</td>
</tr>
<tr>
<td>smc_csysreq</td>
<td>Input</td>
<td>System controller</td>
<td>SMC low-power mode request</td>
</tr>
<tr>
<td>ahb_csysack</td>
<td>Output</td>
<td>System controller</td>
<td>AHB interfaces low-power mode acknowledge</td>
</tr>
<tr>
<td>ahb_cactive</td>
<td>Output</td>
<td>System controller</td>
<td>AHB interfaces active</td>
</tr>
<tr>
<td>smc_csysack</td>
<td>Output</td>
<td>System controller</td>
<td>SMC low-power mode acknowledge</td>
</tr>
<tr>
<td>smc_cactive</td>
<td>Output</td>
<td>System controller</td>
<td>SMC active</td>
</tr>
</tbody>
</table>
A.7 Configuration signal

Table A-6 lists the configuration signal.

<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Source/destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>big_endian</td>
<td>Input</td>
<td>Tie-off</td>
<td>Big-endian mode configuration tie-off</td>
</tr>
</tbody>
</table>
A.8 Scan chains

Table A-7 lists the scan chain signals.

<table>
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Source/destination</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>se</td>
<td>Input</td>
<td>Scan chains</td>
<td>Scan enable for all clock domains</td>
</tr>
<tr>
<td>ahb_rst_bypass</td>
<td>Input</td>
<td>Scan chains</td>
<td>AHB reset bypass</td>
</tr>
<tr>
<td>smc_rst_bypass</td>
<td>Input</td>
<td>Scan chains</td>
<td>SMC reset bypass</td>
</tr>
<tr>
<td>smc_dft_en_clk_out</td>
<td>Input</td>
<td>Scan chains</td>
<td>SMC DFT enable for clock out</td>
</tr>
<tr>
<td>si_hclk</td>
<td>Input</td>
<td>Scan chains</td>
<td>Scan in for hclk domain</td>
</tr>
<tr>
<td>smc_si_aclk</td>
<td>Input</td>
<td>Scan chains</td>
<td>SMC scan in for smc_aclk domain</td>
</tr>
<tr>
<td>smc_si_mclk0</td>
<td>Input</td>
<td>Scan chains</td>
<td>SMC scan in for smc_mclk0 domain</td>
</tr>
<tr>
<td>smc_si_mclk0n</td>
<td>Input</td>
<td>Scan chains</td>
<td>SMC scan in for smc_mclk0n domain</td>
</tr>
<tr>
<td>smc_si_fbclk_in_0</td>
<td>Input</td>
<td>Scan chains</td>
<td>SMC scan in for smc_fbclk_in_0 domain</td>
</tr>
<tr>
<td>smc_si_int_0</td>
<td>Input</td>
<td>Scan chains</td>
<td>SMC scan in for smc_int_0 domain</td>
</tr>
<tr>
<td>so_hclk</td>
<td>Output</td>
<td>Scan chains</td>
<td>Scan out for hclk domain</td>
</tr>
<tr>
<td>smc_so_aclk</td>
<td>Output</td>
<td>Scan chains</td>
<td>SMC scan out for smc_aclk domain</td>
</tr>
<tr>
<td>smc_so_mclk0</td>
<td>Output</td>
<td>Scan chains</td>
<td>SMC scan out for smc_mclk0 domain</td>
</tr>
<tr>
<td>smc_so_mclk0n</td>
<td>Output</td>
<td>Scan chains</td>
<td>SMC scan out for smc_mclk0n domain</td>
</tr>
<tr>
<td>smc_so_fbclk_in_0</td>
<td>Output</td>
<td>Scan chains</td>
<td>SMC scan out for smc_fbclk_in_0 domain</td>
</tr>
<tr>
<td>smc_so_int_0</td>
<td>Output</td>
<td>Scan chains</td>
<td>SMC scan out for smc_int_0 domain</td>
</tr>
</tbody>
</table>
Glossary

This glossary describes some of the terms used in technical documents from ARM Limited.

**Advanced High-performance Bus (AHB)**
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. The full AMBA AHB protocol specification includes a number of features that are not commonly required for master and slave IP developments and ARM Limited recommends only a subset of the protocol is usually used. This subset is defined as the AMBA AHB-Lite protocol.

*See also* Advanced Microcontroller Bus Architecture and AHB-Lite.

**Advanced Microcontroller Bus Architecture (AMBA)**
A family of protocol specifications that describe a strategy for the interconnect. AMBA is the ARM open standard for on-chip buses. It is an on-chip bus specification that describes a strategy for the interconnection and management of functional blocks that make up a *System-on-Chip* (SoC). It aids in the development of embedded processors with one or more CPUs or signal processors and multiple peripherals. AMBA complements a reusable design methodology by defining a common backbone for SoC modules.
Advanced Peripheral Bus (APB)

A simpler bus protocol than AHB. It is designed for use with ancillary or
general-purpose peripherals such as timers, interrupt controllers, UARTs, and I/O ports.
Connection to the main system bus is through a system-to-peripheral bus bridge that
helps to reduce system power consumption.

AHB

See Advanced High-performance Bus.

Aligned

A data item stored at an address that is divisible by the number of bytes that defines the
data size is said to be aligned. Aligned words and halfwords have addresses that are
divisible by four and two respectively. The terms word-aligned and halfword-aligned
therefore stipulate addresses that are divisible by four and two respectively.

AMBA

See Advanced Microcontroller Bus Architecture.

APB

See Advanced Peripheral Bus.

Beat

Alternative word for an individual transfer within a burst. For example, an INCR4 burst
comprises four beats.

See also Burst.

BE-8

Big-endian view of memory in a byte-invariant system.

See also BE-32, LE, Byte-invariant and Word-invariant.

BE-32

Big-endian view of memory in a word-invariant system.

See also BE-8, LE, Byte-invariant and Word-invariant.

Big-endian

Byte ordering scheme in which bytes of decreasing significance in a data word are
stored at increasing addresses in memory.

See also Little-endian and Endianness.

Big-endian memory

Memory in which:

- a byte or halfword at a word-aligned address is the most significant byte or
  halfword within the word at that address

- a byte at a halfword-aligned address is the most significant byte within the
  halfword at that address.

See also Little-endian memory.
**Boundary scan chain**

A boundary scan chain is made up of serially-connected devices that implement boundary scan technology using a standard JTAG TAP interface. Each device contains at least one TAP controller containing shift registers that form the chain connected between TDI and TDO, through which test data is shifted. Processors can contain several shift registers to enable you to access selected parts of the device.

**Burst**

A group of transfers to consecutive addresses. Because the addresses are consecutive, there is no requirement to supply an address for any of the transfers after the first one. This increases the speed at which the group of transfers can occur. Bursts over AMBA are controlled using signals to indicate the length of the burst and how the addresses are incremented.

*See also* Beat.

**Byte**

An 8-bit data item.

**Byte lane strobe**

A signal that is used for unaligned or mixed-endian data accesses to determine the byte lanes that are active in a transfer. One bit of this signal corresponds to eight bits of the data bus.

**Multi-master AHB**

Typically a shared, not multi-layer, AHB interconnect scheme. More than one master connects to a single AMBA AHB link. In this case, the bus is implemented with a set of full AMBA AHB master interfaces. Masters that use the AMBA AHB-Lite protocol must connect through a wrapper to supply full AMBA AHB master signals to support multi-master operation.

**Endianness**

Byte ordering. The scheme that determines the order that successive bytes of a data word are stored in memory. An aspect of the system’s memory mapping.

*See also* Little-endian and Big-endian

**Little-endian**

Byte ordering scheme in which bytes of increasing significance in a data word are stored at increasing addresses in memory.

*See also* Big-endian and Endianness.

**Little-endian memory**

Memory in which:

- a byte or halfword at a word-aligned address is the least significant byte or halfword within the word at that address
- a byte at a halfword-aligned address is the least significant byte within the halfword at that address.

*See also* Big-endian memory.
Glossary

SBO

See Should Be One.

SBZ

See Should Be Zero.

SBZP

See Should Be Zero or Preserved.

Scan chain

A scan chain is made up of serially-connected devices that implement boundary scan technology using a standard JTAG TAP interface. Each device contains at least one TAP controller containing shift registers that form the chain connected between TDI and TDO, through which test data is shifted. Processors can contain several shift registers to enable you to access selected parts of the device.

Should Be One (SBO)

Should be written as 1 (or all 1s for bit fields) by software. Writing a 0 produces Unpredictable results.

Should Be Zero (SBZ)

Should be written as 0 (or all 0s for bit fields) by software. Writing a 1 produces Unpredictable results.

Should Be Zero or Preserved (SBZP)

Should be written as 0 (or all 0s for bit fields) by software, or preserved by writing the same value back that has been previously read from the same field on the same processor.

Unaligned

A data item stored at an address that is not divisible by the number of bytes that defines the data size is said to be unaligned. For example, a word stored at an address that is not divisible by four.

Undefined

Indicates an instruction that generates an Undefined instruction trap. See the ARM Architecture Reference Manual for more information on ARM exceptions.

UNP

See Unpredictable.

Unpredictable

Means that the behavior of the ETM cannot be relied on. Such conditions have not been validated. When applied to the programming of an event resource, only the output of that event resource is Unpredictable.

Unpredictable behavior can affect the behavior of the entire system, because the ETM is capable of causing the core to enter debug state, and external outputs can be used for other purposes.

Unpredictable

For reads, the data returned when reading from this location is unpredictable. It can have any value.

For writes, writing to this location causes unpredictable behavior, or an unpredictable change in device configuration. Unpredictable instructions must not halt or hang the processor, or any part of the system.
| **Remapping** | Changing the address of physical memory or devices after the application has started executing. This is typically done to permit RAM to replace ROM when the initialization has been completed. |
| **Reserved**  | A field in a control register or instruction format is reserved if the field is to be defined by the implementation, or produces Unpredictable results if the contents of the field are not zero. These fields are reserved for use in future extensions of the architecture or are implementation-specific. All reserved bits not used by the implementation must be written as 0 and read as 0. |