## Arm<sup>®</sup> CoreLink<sup>™</sup> MMU-600 System Memory Management Unit

Revision: r0p1

**Technical Reference Manual** 



## Arm<sup>®</sup> CoreLink<sup>™</sup> MMU-600 System Memory Management Unit

#### **Technical Reference Manual**

Copyright © 2016, 2017 Arm Limited (or its affiliates). All rights reserved.

#### Release Information

#### **Document History**

| Issue   | Date             | Confidentiality  | Change                  |
|---------|------------------|------------------|-------------------------|
| 0000-00 | 16 December 2016 | Confidential     | First release for r0p0  |
| 0000-01 | 19 May 2017      | Confidential     | Second release for r0p0 |
| 0001-00 | 23 August 2017   | Confidential     | First release for r0p1  |
| 0001-01 | 10 November 2017 | Non-Confidential | Second release for r0p1 |

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

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

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

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

This document may include technical inaccuracies or typographical errors.

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

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

If any of the provisions contained in these terms conflict with any of the provisions of any click through or signed written agreement covering this document with Arm, then the click through or signed written agreement prevails over and supersedes the conflicting provisions of these terms. This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version of the Agreement shall prevail.

The Arm corporate logo and words marked with ® or TM are registered trademarks or trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners. Please follow Arm's trademark usage guidelines at http://www.arm.com/company/policies/trademarks.

Copyright © 2016, 2017 Arm Limited (or its affiliates). All rights reserved.

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

#### LES-PRE-20349

### **Additional Notices**

Some material in this document is based on IEEE 754-2008 IEEE Standard for Binary Floating-Point Arithmetic. The IEEE disclaims any responsibility or liability resulting from the placement and use in the described manner.

#### **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.

Unrestricted Access is an Arm internal classification.

#### **Product Status**

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

#### Web Address

http://www.arm.com

## Contents

# **Arm® CoreLink™ MMU-600 System Memory Management Unit Technical Reference Manual**

|           | Pref  | face                                  |      |
|-----------|-------|---------------------------------------|------|
|           |       | About this book                       |      |
|           |       | Feedback                              |      |
| Chapter 1 | Intro | oduction                              |      |
|           | 1.1   | About the MMU-600                     | 1-12 |
|           | 1.2   | Compliance                            | 1-13 |
|           | 1.3   | Features                              | 1-14 |
|           | 1.4   | Interfaces                            | 1-10 |
|           | 1.5   | Configurable options                  | 1-1  |
|           | 1.6   | Product documentation and design flow | 1-18 |
|           | 1.7   | Product revisions                     | 1-20 |
| Chapter 2 | Fun   | ctional description                   |      |
|           | 2.1   | About the functions                   | 2-22 |
|           | 2.2   | Interfaces                            | 2-28 |
|           | 2.3   | Operation                             | 2-36 |
|           | 2.4   | Constraints and limitations of use    | 2-48 |
| Chapter 3 | Prog  | grammers model                        |      |
|           | 3.1   | About the programmers model           | 3-58 |
|           | 3.2   | SMMU architectural registers          | 3-57 |
|           |       |                                       |      |

|            | 3.3   | MMU-600 memory map                            | 3-61       |
|------------|-------|-----------------------------------------------|------------|
|            | 3.4   | Register summary                              | 3-63       |
|            | 3.5   | TCU Component and Peripheral ID Registers     | 3-66       |
|            | 3.6   | TCU PMU Component and Peripheral ID Registers | 3-67       |
|            | 3.7   | TCU microarchitectural registers              | 3-68       |
|            | 3.8   | TCU RAS registers                             | 3-76       |
|            | 3.9   | TBU Component and Peripheral ID Registers     | 3-81       |
|            | 3.10  | TBU PMU Component and Peripheral ID Registers | 3-82       |
|            | 3.11  | TBU microarchitectural registers              | 3-83       |
|            | 3.12  | TBU RAS registers                             | 3-85       |
| Appendix A | Sign  | al descriptions                               |            |
|            | A.1   | Clock and reset signals                       | Appx-A-90  |
|            | A.2   | TCU QTW/DVM interface signals                 | Appx-A-91  |
|            | A.3   | TCU programming interface signals             | Appx-A-93  |
|            | A.4   | TCU SYSCO interface signals                   | Appx-A-94  |
|            | A.5   | TCU PMU snapshot interface signals            |            |
|            | A.6   | TCU LPI_PD interface signals                  | Appx-A-96  |
|            | A.7   | TCU LPI_CG interface signals                  | Appx-A-97  |
|            | A.8   | TCU DTI interface signals                     | Appx-A-98  |
|            | A.9   | TCU interrupt signals                         | Appx-A-99  |
|            | A.10  | TCU tie-off signals                           | Appx-A-100 |
|            | A.11  | TCU and TBU test and debug signals            | Appx-A-101 |
|            | A.12  | TBU TBS interface signals                     | Appx-A-102 |
|            | A.13  | TBU TBM interface signals                     | Appx-A-104 |
|            | A.14  | TBU PMU snapshot interface signals            | Appx-A-106 |
|            | A.15  | TBU LPI_PD interface signals                  | Appx-A-107 |
|            | A.16  | TBU LPI_CG interface signals                  | Appx-A-108 |
|            | A.17  | TBU DTI interface signals                     | Appx-A-109 |
|            | A.18  | TBU interrupt signals                         | Appx-A-110 |
|            | A.19  | TBU tie-off signals                           | Аррх-А-111 |
|            | A.20  | DTI interconnect switch signals               | Appx-A-113 |
|            | A.21  | DTI interconnect sizer signals                | Appx-A-115 |
|            | A.22  | DTI interconnect register slice signals       | Appx-A-117 |
| Appendix B | Softv | ware initialization examples                  |            |
|            | B.1   | Initializing the SMMU                         | Аррх-В-120 |
|            | B.2   | Enabling the SMMU                             |            |
| Appendix C | Revi  | sions                                         |            |
|            | C.1   | Revisions                                     | Appx-C-127 |

## **Preface**

This preface introduces the  $Arm^*$   $CoreLink^*$  MMU-600 System Memory Management Unit Technical Reference Manual.

It contains the following:

- About this book on page 7.
- Feedback on page 10.

#### About this book

This book is for the Arm® CoreLink™ MMU-600 System Memory Management Unit.

#### **Product revision status**

The rmpn identifier indicates the revision status of the product described in this book, for example, r1p2, where:

- rm Identifies the major revision of the product, for example, r1.
- pn Identifies the minor revision or modification status of the product, for example, p2.

#### Intended audience

This book is written for system designers, system integrators, and programmers who are designing or programming a System-on-Chip (SoC) that uses the MMU-600.

## Using this book

This book is organized into the following chapters:

#### **Chapter 1 Introduction**

This chapter provides an overview of the MMU-600.

#### **Chapter 2 Functional description**

This chapter describes the functionality of the MMU-600.

#### Chapter 3 Programmers model

This chapter describes the MMU-600 programmers model.

## Appendix A Signal descriptions

This appendix describes the MMU-600 external signals.

#### Appendix B Software initialization examples

This appendix provides examples of how software can initialize and enable the MMU-600.

#### Appendix C Revisions

This appendix describes the technical changes between released issues of this book.

#### Glossary

The Arm® Glossary is a list of terms used in Arm documentation, together with definitions for those terms. The Arm Glossary does not contain terms that are industry standard unless the Arm meaning differs from the generally accepted meaning.

See the *Arm*<sup>®</sup> *Glossary* for more information.

#### Typographic conventions

italic

Introduces special terminology, denotes 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.

#### <u>mono</u>space

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>

Encloses replaceable terms for assembler syntax where they appear in code or code fragments. For example:

```
MRC p15, 0, <Rd>, <CRn>, <CRm>, <Opcode_2>
```

SMALL CAPITALS

Used in body text for a few terms that have specific technical meanings, that are defined in the *Arm*<sup>®</sup> *Glossary*. For example, IMPLEMENTATION DEFINED, IMPLEMENTATION SPECIFIC, UNKNOWN, and UNPREDICTABLE.

## **Timing diagrams**

The following figure 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.



Figure 1 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.
- · LOW for active-LOW signals.

#### Lowercase n

At the start or end of a signal name denotes an active-LOW signal.

## **Additional reading**

This section lists publications by Arm and by third parties.

See Infocenter http://infocenter.arm.com, for access to Arm documentation.

#### Arm publications

This book contains information that is specific to this product. See the following documents for other relevant information:

- Arm® System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1 (IHI 0070).
- Arm® Architecture Reference Manual, ARMv8, for ARMv8-A architecture profile (DDI 0487).
- Arm® AMBA® Distributed Translation Interface (DTI) Protocol Specification (100225).
- Arm® AMBA® APB Protocol Specification (IHI 0024).
- Arm<sup>®</sup> CoreSight<sup>™</sup> Architecture Specification (IHI 0029).
- Arm® AMBA® AXI and ACE Protocol Specification (IHI 0022F).
- Arm® AMBA® 4 AXI4-Stream Protocol Specification (IHI 0051).
- AMBA® Low Power Interface Specification, Arm® Q-Channel and P-Channel Interfaces (IHI 0068).
- Arm® CoreLink™ LPD-500 Low Power Distributor Technical Reference Manual (100361).
- Arm® Server Base System Architecture (DEN-0029).

The following confidential books are only available to licensees:

- Arm<sup>®</sup> CoreLink<sup>™</sup> MMU-600 System Memory Management Unit Configuration and Integration Manual (100311).
- Arm<sup>®</sup> CoreLink<sup>™</sup> ADB-400 AMBA<sup>®</sup> Domain Bridge User Guide (DUI 0615).

### **Feedback**

## Feedback on this product

If you have any comments or suggestions about this product, contact your supplier and give:

- The product name.
- The product revision or version.
- An explanation with as much information as you can provide. Include symptoms and diagnostic procedures if appropriate.

### Feedback on content

If you have comments on content then send an e-mail to errata@arm.com. Give:

- The title Arm CoreLink MMU-600 System Memory Management Unit Technical Reference Manual.
- The number 100310 0001 01 en.
- If applicable, the page number(s) to which your comments refer.
- A concise explanation of your comments.

| Arm also welcomes general suggestions for additions and improvements.                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note                                                                                                                                                          |
| Arm tests the PDF only in Adobe Acrobat and Acrobat Reader, and cannot guarantee the quality of the represented document when used with any other PDF reader. |

## Chapter 1 **Introduction**

This chapter provides an overview of the MMU-600.

It contains the following sections:

- 1.1 About the MMU-600 on page 1-12.
- 1.2 Compliance on page 1-13.
- 1.3 Features on page 1-14.
- 1.4 Interfaces on page 1-16.
- 1.5 Configurable options on page 1-17.
- 1.6 Product documentation and design flow on page 1-18.
- 1.7 Product revisions on page 1-20.

### 1.1 About the MMU-600

The MMU-600 is a *System*-level *Memory Management Unit* (SMMU) that translates an input address to an output address. This translation is based on address mapping and memory attribute information that is available in the MMU-600 internal registers and translation tables.

The MMU-600 implements the Arm SMMU architecture version 3.1, SMMUv3.1, as defined by the *Arm® System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1*.

An address translation from an input address to an output address is described as a stage of address translation. The MMU-600 can perform:

- Stage 1 translations that translate an input *virtual address* (VA) to an output *physical address* (PA) or *intermediate physical address* (IPA).
- Stage 2 translations that translate an input IPA to an output PA.
- Combined stage 1 and stage 2 translations that translate an input VA to an IPA, and then translate that IPA to an output PA. The MMU-600 performs translation table walks for each stage of the translation.

In addition to translating an input address to an output address, a stage of address translation also defines the memory attributes of the output address. With a two-stage translation, the stage 2 translation can modify the attributes that the stage 1 translation defines. A stage of address translation can be disabled or bypassed, and the MMU-600 can define memory attributes for disabled and bypassed stages of translation.

The MMU-600 uses inputs from the requesting master to identify a context. Configuration tables in memory tell the MMU-600 how to translate each context, such as which translation tables to use.

The MMU-600 can cache the result of a translation table lookup in a *Translation Lookaside Buffer* (TLB). It can also cache configuration tables in a configuration cache.

The MMU-600 contains the following key components:

- Translation Buffer Units (TBUs) that use a TLB to cache translation tables.
- A Translation Control Unit (TCU) that controls and manages address translations.
- *Distributed Translation Interface* (DTI) interconnect components that connect multiple TBUs to the TCU.

#### Related concepts

2.1 About the functions on page 2-22.

## 1.2 Compliance

The MMU-600 complies with, or implements, the specifications that this section describes. This *Technical Reference Manual* (TRM) complements architecture reference manuals, architecture specifications, protocol specifications, and relevant external standards. It does not duplicate information from these sources.

#### 1.2.1 Arm® architecture

The MMU-600 implements parts of the ARMv8 *Virtual Memory System Architecture* (VMSA), as defined by the *Arm® Architecture Reference Manual, ARMv8, for ARMv8-A architecture profile*. The SMMUv3 architecture describes the parts of VMSA that apply to the MMU-600.

#### 1.2.2 SMMU architecture

The MMU-600 implements the SMMUv3.1 architecture, as defined by the *Arm*<sup>®</sup> *System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1.* 

#### Related concepts

2.4.1 SMMUv3 support on page 2-48.

## 1.2.3 AMBA® DTI protocol

The MMU-600 implements the *Distributed Translation Interface* (DTI) protocol, as defined by the *Arm*<sup>®</sup> *AMBA*<sup>®</sup> *Distributed Translation Interface* (DTI) *Protocol Specification*.

The DTI interfaces use an AXI4-Stream interface, as defined by the *Arm*\* *AMBA*\* *4 AXI4-Stream Protocol Specification*.

## **Related concepts**

2.3.2 DTI overview on page 2-42.

#### 1.2.4 AMBA® ACE-Lite and AMBA® AXI5 protocol

The MMU-600 complies with the AMBA ACE-Lite protocol. It also supports certain functionality from the AMBA 5 AXI protocol, AXI5.

See the Arm® AMBA® AXI and ACE Protocol Specification for more information.

#### Related references

2.4.2 AMBA support on page 2-51.

### 1.2.5 AMBA® APB protocol

The MMU-600 complies with the AMBA APB4 protocol, as defined by the *Arm® AMBA® APB Protocol Specification*.

### 1.3 Features

The MMU-600 provides the following features:

- Compliance with the SMMUv3.1 architecture:
  - Support for Stage 1 translation, Stage 2 translation, and Stage 1 followed by stage 2 translation.
  - Support for ARMv8 AArch32 and AArch64 translation table formats.
  - Support for 4KB, 16KB and 64KB granule sizes in AArch64 format.
  - Masters can be stalled while a processor handles translation faults, enabling software support for demand paging.
  - Configuration tables in memory can support millions of active translation contexts.
  - Queues in memory perform MMU-600 management, no requirement to stall a processor when it accesses the MMU-600.
  - Support for PCI Express (PCIe) integration, including Address Translation Services (ATS) and Process Address Space IDs (PASIDs).
  - Support for *Generic Interrupt Controller* (GIC) integration, with *Message Signaled Interrupts* (MSIs) supported for common interrupt types.
  - A *Performance Monitoring Unit* (PMU) in each TBU and TCU that enables MMU-600 performance to be investigated.
  - Reliability, Serviceability and Availability (RAS) features for cache corruption detection and correction.
- Support for AMBA interfaces, including:
  - ACE5-Lite TBU transaction interfaces that support cache stash transactions, deallocating transactions, and cache maintenance.
  - An architected AXI5 extension that communicates per-transaction translation stream information.
  - An ACE5-Lite + Distributed Virtual Memory (DVM) TCU table walk interface that enables ARMv8.2 processors to perform shared TLB invalidate operations without accessing the MMU-600 directly.
  - An ACE5 Low Power extension that enables the TCU to subscribe to DVM TLB invalidate requests on powerup and powerdown without reprogramming the DTI interconnect.
  - AMBA DTI communication between the TCU and TBUs, enabling masters to request translations and implement TBU functionality internally.
  - Support for the AMBA *Low-Power Interface* (LPI) Q-Channel so that standard controllers can control power and clock gating.
  - AXI5 WAKEUP signaling on all interfaces, including DTI and APB interfaces.
- Support for flexible integration:
  - A configurable number of TBUs can be placed close to the masters being translated.
  - Communication between TBU and TCU over AXI4-Stream, supported using the supplied DTI interconnect components, or any other AXI4-Stream interconnect.
  - DTI interconnect components support hierarchical topologies, and control of the tradeoff between number of wires and DTI bandwidth.
- Support for high-performance translation:
  - Scalable configurable micro TLB and Main TLB in the TBU can reduce the number of translation requests to the TCU.
  - Optimization to store all architecturally defined page and block sizes, including contiguous page and block entries, as a single entry in the TBU and TCU TLBs.
  - Per-TBU prioritization in the TCU enable high-priority transaction streams to be translated before low-priority streams.
  - *Hit-Under-Miss* (HUM) support in the TBU enables transactions with different AXI IDs to be propagated out of order, when a translation is available.
  - TBU detection of multiple transactions that require the same translation so that only one TBU request to the TCU is required.
  - TCU detection of multiple translations that require the same table in memory so that only one TCU memory request is required.

- Multi-level, multi-stage walk caches in the TCU reduce translation cost by performing only part
  of the table walk process on a miss.
- A configurable number of concurrent translations in the TBU and TCU promotes high translation throughput.

## 1.4 Interfaces

Both the TCU and TBU support the following common interfaces:

- DTI.
- Tie-offs.
- Interrupts.
- PMU snapshot.
- Test and debug.
- · LPI clock gating.
- LPI powerdown.

The TCU also supports the following interfaces:

- · Programming.
- System coherency.
- Queue and Table Walk (QTW)/DVM.

The TBU also supports the following interfaces:

- Transaction slave (TBS).
- Transaction master (TBM).

## **Related concepts**

2.2 Interfaces on page 2-28.

## 1.5 Configurable options

The MMU-600 is highly configurable and provides configuration options for each of the main blocks.

For the TCU, you can configure:

- The size of each of the caches.
- The data width of the QTW/DVM interface.
- The number of translations that can be performed at the same time.
- The number of translation requests that can be accepted from all DTI masters.

For the TBU, you can configure:

- Write data buffer depth.
- The size of each of the caches.
- The number of transactions that can be translated at the same time.
- The number of outstanding read and write transactions that the TBM interface supports.
- The width of data, ID, user, StreamID, and SubstreamID signals on the TBS and TBM interfaces.

| Note                                                  |  |
|-------------------------------------------------------|--|
| Depths are specified as a discrete number of entries. |  |
| <del></del>                                           |  |

You can also configure the DTI interconnect components to meet your system requirements.

## 1.6 Product documentation and design flow

This section describes the MMU-600 documentation in relation to the design flow.

#### 1.6.1 Documentation

The MMU-600 documentation is as follows:

#### **Technical Reference Manual**

The *Technical Reference Manual* (TRM) describes the functionality and the effects of functional options on the behavior of the MMU-600. It is required at all stages of the design flow. The choices that are made in the design flow can mean that some behaviors that are described in the TRM are not relevant. If you are programming the MMU-600, then contact:

- The implementer to determine:
  - The build configuration of the implementation.
  - What integration, if any, was performed before implementing the MMU-600.
- The integrator to determine the pin configuration of the device that you are using.

#### **Configuration and Integration Manual**

The Configuration and Integration Manual (CIM) describes:

- The available build configuration options and related issues in selecting them.
- How to integrate the MMU-600 into a SoC. This section includes describing the pins that the integrator must tie off to configure the macrocells for the required integration.
- The processes to sign off the configuration, integration, and implementation of the design.

The Arm product deliverables include reference scripts and information about using them to implement your design. Reference methodology flows that Arm supplies are example reference implementations. Contact your EDA vendor for EDA tool support.

The CIM is a confidential book that is only available to licensees.

### 1.6.2 Design flow

The MMU-600 is delivered as synthesizable RTL. Before it can be used in a product, it must go through the following processes:

#### **Implementation**

The implementer configures and synthesizes the RTL to produce a hard macrocell. This process might include integrating RAMs into the design.

## Integration

The integrator connects the implemented design into a SoC. Integration includes connecting the design to a memory system and peripherals.

#### **Programming**

The system programmer develops the software to configure and initialize the MMU-600, and tests the required application software.

Each process is separate, and can include implementation and integration choices that affect the behavior and features of the MMU-600.

The operation of the final device depends on:

#### **Build configuration**

The implementer chooses the options that affect how the RTL source files are pre-processed. These options usually include or exclude logic that affects one or more of the following:

- Area
- Maximum frequency.
- Features of the resulting macrocell.

### **Configuration inputs**

The integrator configures some features of the MMU-600 by tying inputs to specific values. These configurations affect the start-up behavior before any software configuration is made. They can also limit the options that are available to the software, for example, by enabling QoS features.

## **Software configuration**

The programmer configures the MMU-600 by programming particular values into registers. This configuration affects the behavior of the MMU-600.

## **Related concepts**

1.5 Configurable options on page 1-17.

### Related references

1.2 Compliance on page 1-13.

## 1.7 Product revisions

This section describes the differences in functionality between product revisions:

r0p0

First release.

## r0p0-r0p1

The following changes apply to this release:

- Modified bits in TCU\_CTRL.
- Modified bits in TBU\_CTRL.

# **Chapter 2 Functional description**

This chapter describes the functionality of the MMU-600.

It contains the following sections:

- 2.1 About the functions on page 2-22.
- 2.2 Interfaces on page 2-28.
- 2.3 Operation on page 2-36.
- 2.4 Constraints and limitations of use on page 2-48.

### 2.1 About the functions

The major functional blocks of the MMU-600 are the TCU, TBU, and DTI interconnect.

The following figure shows an example system that uses the MMU-600.



Figure 2-1 Example system with the MMU-600

The MMU-600 contains the following key components:

#### Translation Buffer Unit (TBU)

The TBU contains *Translation Lookaside Buffers* (TLBs) that cache translation tables. The MMU-600 implements at least one TBU for each connected master, and these TBUs are local to the corresponding master.

#### Translation Control Unit (TCU)

The TCU controls and manages the address translations. The MMU-600 implements a single TCU. In MMU-600-based systems, the AMBA DTI protocol defines the standard for communicating with the TCU.

#### **DTI** interconnect

The DTI interconnect connects multiple TBUs to the TCU.

When an MMU-600 TBU receives a transaction on the TBS interface, it looks for a matching translation in its TLBs. If it has a matching translation, it uses it to translate the transaction and outputs the transaction on the TBM interface. If it does not have a matching translation, it requests a new translation from the TCU using the DTI interface.

When the TCU receives a DTI translation request, it uses the QTW interface to perform:

- Configuration table walks, which return configuration information for the translation context.
- Translation table walks, which return translation information specific to the transaction address.

The TCU contains caches that reduce the number of configuration and translation table walks that are to be performed. Sometimes no walks are required.

When the TBU receives the translation from the TCU, it stores it in its TLBs. If the translation was successful, the TBU uses it to translate the transaction, otherwise it terminates it.

A processor controls the TCU by:

- Writing commands to a Command queue in memory.
- Receiving events from an Event queue in memory.
- Writing to its configuration registers using the programming interface.

See the Arm® System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1 for more information about translation and how software communicates with the TCU.

This section contains the following subsections:

- 2.1.1 Translation Control Unit (TCU) on page 2-23.
- 2.1.2 Translation Buffer Unit (TBU) on page 2-25.
- 2.1.3 DTI interconnect on page 2-26.

## 2.1.1 Translation Control Unit (TCU)

A typical SMMUv3-based system includes a single TCU. The TCU is usually the largest block in the system, and performs several roles.

#### The TCU:

- · Manages the memory queues.
- Performs translation table walks.
- Performs configuration table walks.
- Implements backup caching structures.
- Implements the SMMU programmers model.

The following figure shows the TCU.



Figure 2-2 MMU-600 TCU

The TCU consists of:

#### Walk caches

The TCU includes separate four-way set-associative walk caches to store results of translation table walks. During MMU-600 configuration, the cache line entries are split to create separate walk caches that are reserved for:

- Stage 1 level 0 table entries.
- Stage 1 level 1 table and block entries.
- Stage 1 level 2 table and block entries.
- Stage 1 level 3 table entries.
- Stage 2 level 0 table entries.
- Stage 2 level 1 table and block entries.
- Stage 2 level 2 table and block entries.
- Stage 2 level 3 table entries.

To enable and disable the walk cache for a particular stage and level of translation, use the TCU\_CTRL register. If an error occurs for a cache line entry, the TCU\_ERRSTATUS register identifies the affected entry.

The walk cache is useful in cases where a translation request results in a miss in other TCU caches. A subsequent hit in the walk cache requires only a single memory access to complete the translation table walk and fetch the required descriptor.

## Configuration cache

The configuration caches are 4-way set-associative cache structures that store configuration information. Each entry stores the *Context Descriptor* (CD) and *Stream Table Entry* (STE) contents for a translation context.

| Note |
|------|
|------|

The configuration cache does not cache the contents of intermediate configuration tables.

## Translation manager

The translation manager manages translation requests that are in progress. All translation table walks and configuration table walks are hazard-checked to reduce the possibility of multiple transactions requesting duplicate walks.

## Translation request buffer

The translation request buffer stores translation requests from TBUs when all translation manager slots are full. The translation request buffer supports more slots than the translation manager. When correctly configured, this buffer has enough space to store all translation requests that TBUs can issue simultaneously. This buffer therefore prevents the DTI interface from becoming blocked.

#### **PMU**

The PMU counts TCU performance-related events.

#### Clock and power control

The TCU has its own clock and power control, provided by the Q-Channel.

#### Queue manager

The queue manager manages all SMMUv3 Command queues and Event queues that are stored in memory.

#### QTW/DVM interface

The Queue and Table Walk (QTM)/Distributed Virtual Memory (DVM) interface is an ACE-Lite +DVM master interface.

## Register file

The register file implements the SMMUv3 programmers model, as defined by the *Arm® System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1*.

#### DTI interface

The slave DTI interface uses the DTI protocol, typically over AXI4-Stream, to enable the TCU to communicate with a master component. For the MMU-600, the master component is either a TBU or a PCIe master.

## **Related concepts**

2.2 Interfaces on page 2-28.

#### Related references

3.2 SMMU architectural registers on page 3-57.

## 2.1.2 Translation Buffer Unit (TBU)

A typical SMMUv3-based system includes multiple TBUs. Each TBU is located close to the component that it provides address translation for.

A TBU intercepts transactions and provides the required translation from a *Translation Lookaside Buffer* (TLB) if possible. If a TLB does not contain the required translation, the TBU requests translations from the TCU and then caches the translation in one of the TLBs.

The following figure shows the TBU.



Figure 2-3 MMU-600 TBU

The TBU consists of:

#### Master and slave interfaces

These interfaces manage the TBS and TBM interfaces.

#### Micro TLB

The TBU compares incoming transactions with translations that are cached in the micro TLB before looking in the *Main TLB* (MTLB). The micro TLB is a fully associative TLB that provides configuration cache and TLB functionality. You can use a tie-off signal to configure the cache replacement policy as either round-robin or *Pseudo Least Recently Used* (PLRU).

## Main TLB

Each TBU includes an optional *Main TLB* (MTLB) that caches translation table walk entries from:

- Stage 1 translations.
- Stage 2 translations.
- Stage 1 combined with stage 2 translations.

The MTLB is a configurable four-way set associative cache structure that uses a random cache replacement policy.

If multiple translation sizes are in use, a single transaction might require multiple lookups. Lookups are pipelined to permit a sustained rate of one lookup per cycle.

#### Translation manager

The translation manager manages translation requests that are in progress. Each transaction occupies a translation slot until it is propagated downstream through the master interface. All transactions are hazard-checked to reduce the possibility of duplicate translation requests being sent to the TCU.

There is no restriction on the ordering of transactions with different AXI IDs. Transactions with different AXI IDs can be propagated downstream out-of-order.

All transactions with a given AXI ID value must remain ordered. The translation manager propagates such transactions when the translation is ready, provided no other transaction with the same AXI ID is already waiting.

See the *Arm*® *AMBA*® *AXI and ACE Protocol Specification* for more information about AXI transaction identifiers.

#### Write data buffer

The optional write data buffer enables write transactions with different AXI IDs to progress through the TBU out-of-order. It reorders the data to match the downstream transaction order.

#### **PMU**

The PMU counts TBU performance-related events.

#### Clock and power control

The TBU has its own clock and power control, provided by the Q-Channel.

#### **DTI** interface

The master DTI interface uses the DTI protocol, typically over AXI4-Stream, to enable the TBU to communicate with a slave component. For the MMU-600, the slave component is the TCU. Although you can implement DTI over different transport protocols, the MMU-600 interfaces use AXI4-Stream.

#### Transaction tracker

The transaction trackers manage outstanding read and write transactions, permitting invalidation and synchronization to take place without stalling the AXI interfaces.

#### Related references

3.2 SMMU architectural registers on page 3-57.

#### 2.1.3 DTI interconnect

The TBU and TCUs use a DTI interface to communicate. The DTI interconnect enables the DTI interface to use the AXI4-Stream protocol.

The DTI interconnect can connect any components that conform to the AXI4 Stream subset, as defined by the *Arm*<sup>®</sup> *AMBA*<sup>®</sup> *Distributed Translation Interface (DTI) Protocol Specification*.

The DTI interconnect contains internal components that are hierarchically composable, that is, they can be connected in different ways to suit your system requirements. For example, within an MMU-600 system, you can use the switch component to combine the DTI interfaces of multiple TBUs into a single DTI interface. You can then connect the combined DTI interface to another DTI interconnect that is closer to the TCU. The DTI interconnect includes switch, sizer, and register slice components.

#### Switch

The switch connects multiple DTI masters, such as TBUs, to a DTI slave such as a TCU. The switch implements the following parallel networks:

- For TBU to TCU traffic, a network that connects multiple AXI4-Stream slave interfaces to a single AXI4-Stream master interface.
- For TCU to TBU traffic, a network that connects a single AXI4-Stream slave interface to multiple AXI4-Stream master interfaces.

| N                        | Tote ———                                                                        |
|--------------------------|---------------------------------------------------------------------------------|
| The switch do interface. | oes not store any data, and therefore does not require a Q-Channel clock-gating |

#### Sizer

The sizer connects channels that have different data widths, enabling different tradeoffs of bandwidth to area. The sizer supports conversion between any of the supported AXI4-Stream data widths:

- 1 byte.
- 4 bytes.
- 10 bytes.
- 20 bytes.

The sizer includes a Q-Channel interface to provide clock-gating control.

### Register slice

Use the register slice to improve timing. The register slice includes a Q-Channel interface to provide clock-gating control.

The MMU-600 DTI interconnect components do not include a component to connect different clock and power domains. You can connect DTI interfaces in different clock and power domains by using the *Bidirectional AXI4-Stream* (BAS) configuration of the ADB-400 AMBA Domain Bridge.

## **Related concepts**

2.3 Operation on page 2-36.

### 2.2 Interfaces

The MMU-600 includes interfaces for each of the TCU, TBU, and DTI interconnect components.

The DTI interconnect consists of switch, sizer, and register slice components that can be connected separately, and therefore have their own interfaces.

The PMU snapshot interface is common to both TCU and TBU.

This section contains the following subsections:

- 2.2.1 TCU interfaces on page 2-28.
- 2.2.2 TBU interfaces on page 2-30.
- 2.2.3 DTI interconnect interfaces on page 2-33.

#### 2.2.1 TCU interfaces

The MMU-600 contains various TCU interfaces.

The following figure shows the TCU interfaces.



Figure 2-4 TCU interfaces

#### TCU Queue and Table Walk/Distributed Virtual Memory (QTW/DVM) interface

The QTW/DVM interface is an ACE-Lite+DVM master interface.

The QTW/DVM interface issues the following transaction types:

- ReadNoSnoop.
- WriteNoSnoop.
- ReadOnce.
- · WriteUnique.
- DVM Complete.

The QTW/DVM interface uses the write address transaction ID signal **awid\_qtw**, and the read address transaction ID signal, **arid\_qtw**. The value of **awid\_qtw** is always 0, and the value of **arid\_qtw** depends on the transaction type. The following table shows the possible values of **arid\_qtw**.

Table 2-1 Possible arid\_qtw values

| Transaction type       | arid_qtw[n:1]                                                    | arid_qtw[0] |
|------------------------|------------------------------------------------------------------|-------------|
| Translation table walk | Indicates the slot that is requesting the translation table walk | 1           |
| Command queue read     | All bits = $0$ .                                                 | 0           |
| DVM Complete           | All bits = $1$ .                                                 | 0           |

To support 16-bit Virtual Machine IDentifiers (VMIDs), the interface provides DVMv8.1 support.

The interface does not issue cache maintenance operations or exclusive accesses.

#### **Related concepts**

2.3.5 Distributed Virtual Memory (DVM) messages on page 2-43. 2.3.6 Error responses on page 2-44.

#### Related references

AXI5 support on page 2-53.

A.2 TCU QTW/DVM interface signals on page Appx-A-91.

#### **TCU PROG interface**

The PROG interface is an AMBA APB4 slave interface. It enables software to program the MMU-600 internal registers and read the *Performance Monitoring Unit* (PMU) registers and the debug registers.

This interface runs synchronously with the other TCU interfaces.

The applicable address width for this interface depends on the value of TCUCFG\_NUM\_TBU:

- When TCUCFG\_NUM\_TBU = 14, the address width is 21 bits.
- When TCUCFG\_NUM\_TBU = 62, the address width is 23 bits.

Transactions are Read-As-Zero, Writes Ignored (RAZ/WI) when any of the following apply:

- An unimplemented register is accessed.
- PSTRB[3:0] is not 0b1111 for write transfers.
- PPROT[1] is not set to 0 for Secure register accesses.

See the Arm® AMBA® APB Protocol Specification for more information.

#### Related references

A.3 TCU programming interface signals on page Appx-A-93.

#### **TCU LPI PD interface**

This Q-Channel slave interface manages LPI powerdown for the TCU.

See the AMBA® Low Power Interface Specification, Arm® Q-Channel and P-Channel Interfaces for more information.

#### Related references

A.6 TCU LPI PD interface signals on page Appx-A-96.

#### **TCU LPI CG interface**

This Q-Channel slave interface enables LPI clock-gating for the TCU.

See the AMBA® Low Power Interface Specification, Arm® Q-Channel and P-Channel Interfaces for more information.

## Related references

A.7 TCU LPI CG interface signals on page Appx-A-97.

#### **TCU DTI interface**

The DTI interface manages communication between the TBUs and the TCU, using the DTI protocol. The DTI protocol can be conveyed over different transport layer mediums, including AXI4-Stream.

The TCU includes a slave DTI interface and each TBU includes a master DTI interface. To permit bidirectional communication, each DTI interface includes one AXI4-Stream master interface and one AXI4-Stream slave interface.

See the Arm® AMBA® Distributed Translation Interface (DTI) Protocol Specification and the Arm® AMBA® 4 AXI4-Stream Protocol Specification for more information.

#### **Related concepts**

2.3.2 DTI overview on page 2-42.

#### Related references

A.8 TCU DTI interface signals on page Appx-A-98.

#### **TCU** interrupt interfaces

This interface provides global, per-context, and performance interrupts.

#### Related references

A.9 TCU interrupt signals on page Appx-A-99.

### **TCU SYSCO interface**

The MMU-600 provides a hardware system coherency interface. This interface permits the TCU to remove itself from a coherency domain in response to an LPI request.

The SYSCO interface uses the **syscoreq** and **syscoack** handshake signals to enter or exit a coherency domain.

If the **sup** btm signal is tied LOW:

- syscoreq is always driven LOW and syscoack is ignored.
- The TCU SYSCO interface is not used and can be left unconnected.

#### Related references

A.4 TCU SYSCO interface signals on page Appx-A-94.

## TCU tie-off signals

The TCU tie-off signals enable you to initialize various operating parameters on exit from reset state.

At reset, the value of each tie-off signal controls the respective bits in the SMMU IDR0 Register.

#### Related references

A.10 TCU tie-off signals on page Appx-A-100.

#### 2.2.2 TBU interfaces

The following figure shows the TBU interfaces.



Figure 2-5 TBU interfaces

#### **TBU TBS interface**

The *transaction slave* (TBS) interface is an ACE5-Lite interface on which the TBU receives incoming untranslated memory accesses.

This interface supports a 64-bit address width.

The interface implements optional signals to support the following AXI5 extensions:

- Untranslated Transactions.
- · Cache Stash Transactions.
- · DeAllocation Transactions.
- · Low Power Signals.

The TBS interface implements **AWAKEUP** to support the Low\_Power\_Signals extension. It does not support the other signals that AXI5 associates with this extension.



The TBS interface does not support WriteEvict transactions, and therefore does not support the **AWUNIQUE** signal.

The TBS interface supports ACE Exclusive accesses.

If a transaction is terminated in the TBU, the transaction tracker returns the transaction with the user-defined AXI RUSER and BUSER bits set to 0.

#### **Related concepts**

2.3.6 Error responses on page 2-44.

#### Related references

A.12 TBU TBS interface signals on page Appx-A-102.

#### **TBU TBM interface**

The TBM transaction master interface is an ACE5-Lite interface on which the TBU sends outgoing translated memory accesses.

The AXI ID of a transaction on this interface is the same as the AXI ID of the corresponding transaction on the TBS interface.

This interface supports a 64-bit address width, and TBUCFG\_DATA\_WIDTH defines the data width.

This interface can issue read and write transactions until the outstanding transaction limit is reached. The MMU-600 provides parameters that permit you to configure:

- · The outstanding read transactions limit.
- · The outstanding write transactions limit.
- The total outstanding read and write transactions limit.

The interface implements optional signals to support the following AXI5 extensions:

- Untranslated Transactions.
- Cache\_Stash\_Transactions.
- · DeAllocation Transactions.
- Low\_Power\_Signals.

| <br>Note — |
|------------|
| Note       |

The TBM interface implements **AWAKEUP** to support the Low\_Power\_Signals extension. It does not support the other signals that AXI5 associates with this extension.

| <br>Note - |
|------------|
| TAULE      |

The TBM interface does not support WriteEvict transactions, and therefore does not support the **AWUNIQUE** signal.

When receiving an SLVERR or DECERR response to a downstream transaction, the TBM interface propagates the same response to the TBS interface.

The TBM interface supports ACE Exclusive accesses.

#### Related concepts

2.3.6 Error responses on page 2-44.

#### Related references

2.4.2 AMBA support on page 2-51.
A.13 TBU TBM interface signals on page Appx-A-104.

#### TBU LPI\_PD interface

This Q-Channel slave interface manages LPI powerdown for the TBU.

See the AMBA® Low Power Interface Specification, Arm® Q-Channel and P-Channel Interfaces for more information.

#### Related references

A.15 TBU LPI PD interface signals on page Appx-A-107.

## TBU LPI\_CG interface

This Q-Channel slave interface enables LPI clock-gating for the TBU.

See the AMBA® Low Power Interface Specification, Arm® Q-Channel and P-Channel Interfaces for more information.

## Related references

A.16 TBU LPI\_CG interface signals on page Appx-A-108.

#### **TBU DTI interface**

The TBU DTI interface enables master devices with their own TLB and prefetch capability to request translations from the MMU-600. This interface uses the DTI-TBU protocol for communication between the TBU and the TCU.

The TCU includes a slave DTI interface and each TBU includes a master DTI interface. To permit bidirectional communication, each DTI interface includes one AXI4-Stream master interface and one AXI4-Stream slave interface.

See the Arm® AMBA® Distributed Translation Interface (DTI) Protocol Specification and the Arm® AMBA® 4 AXI4-Stream Protocol Specification for more information.

## **Related concepts**

2.3.2 DTI overview on page 2-42.

### Related references

A.17 TBU DTI interface signals on page Appx-A-109.

## **TBU** interrupt interfaces

This interface provides global, per-context, and performance interrupts.

#### Related references

A.18 TBU interrupt signals on page Appx-A-110.

#### TBU tie-off signals

The TBU tie-off signals enable you to initialize various operating parameters on exit from reset state.

At reset, the value of each tie-off signal controls the respective bits in the SMMU IDR0 Register.

#### Related references

A.19 TBU tie-off signals on page Appx-A-111.

#### 2.2.3 DTI interconnect interfaces

The DTI interconnect includes interfaces for each of the switch, sizer, and register slice components.

#### **DTI** interconnect switch interfaces

The DTI interconnect switch component includes dedicated interfaces.

The following figure shows the DTI interconnect switch interfaces.



Figure 2-6 DTI interconnect switch interfaces

The following table provides more information about the switch interfaces.

Table 2-2 DTI interconnect switch interfaces

| Interface | Interface type | Protocol    | Description                                                                          |
|-----------|----------------|-------------|--------------------------------------------------------------------------------------|
| DN_Sn     | Slave          | AXI4-Stream | Slave downstream interface. One DN_Sn interface is present for each slave interface. |
| UP_Sn     | Master         |             | Slave upstream interface. One UP_Sn interface is present for each slave interface.   |
| DN_M      | Master         |             | Master downstream interface.                                                         |
| UP_M      | Slave          |             | Master upstream interface.                                                           |

\_\_\_\_\_ Note \_\_\_\_\_

The interconnect switch does not store any data, and therefore does not require a Q-Channel clock-gating interface.

### **DTI** interconnect sizer interfaces

The DTI interconnect sizer component includes dedicated interfaces.

The following figure shows the DTI interconnect sizer interfaces.



Figure 2-7 DTI interconnect sizer interfaces

The following table provides more information about the sizer interfaces.

Table 2-3 DTI interconnect sizer interfaces

| Interface | Interface type | Protocol    | Description                  |
|-----------|----------------|-------------|------------------------------|
| LPI_CG    | Slave          | Q-Channel   | Clock-gating interface.      |
| DN_S      | Slave          | AXI4-Stream | Slave downstream interface.  |
| UP_S      | Master         |             | Slave upstream interface.    |
| DN_M      | Master         |             | Master downstream interface. |
| UP_M      | Slave          |             | Master upstream interface.   |

## DTI interconnect register slice interfaces

The DTI interconnect register slice component includes dedicated interfaces.

The following figure shows the DTI interconnect register slice interfaces.



Figure 2-8 DTI interconnect register slice interfaces

The following table provides more information about the register slice interfaces.

Table 2-4 DTI interconnect register slice interfaces

| Interface | Interface type | Protocol    | Description                  |
|-----------|----------------|-------------|------------------------------|
| LPI_CG    | Slave          | Q-Channel   | Clock-gating interface.      |
| DN_S      |                | AXI4-Stream | Slave downstream interface.  |
| UP_S      | Master         |             | Slave upstream interface.    |
| DN_M      |                |             | Master downstream interface. |
| UP_M      | Slave          |             | Master upstream interface.   |

## 2.3 Operation

This section provides information about the operation of the MMU-600 features.

This section contains the following subsections:

- 2.3.1 Performance Monitoring Unit on page 2-36.
- 2.3.2 DTI overview on page 2-42.
- 2.3.3 Reliability, Availability, and Serviceability on page 2-43.
- 2.3.4 Quality of Service on page 2-43.
- 2.3.5 Distributed Virtual Memory (DVM) messages on page 2-43.
- 2.3.6 Error responses on page 2-44.
- 2.3.7 Conversion between ACE-Lite and ARMv8 attributes on page 2-44.

## 2.3.1 Performance Monitoring Unit

The MMU-600 includes a PMU for the TCU and a PMU for each TBU. The PMU events and counters indicate the runtime performance of the MMU-600.

The MMU-600 includes logic to gather various statistics on the operation of the MMU during runtime, using events and counters. These events, which the SMMUv3 architecture defines, provide useful information about the behavior of the MMU. You can use this information when debugging or profiling traffic.

The **sec override** signal permits certain registers to be accessible to Non-secure software.



A single DTI translation request might correspond to multiple translation request events in either of the following circumstances:

- A translation results in a stall fault event and is restarted.
- If a translation results in a stall fault event because of the Event queue being full, the translation is retried when an Event queue slot becomes available.

## SMMUv3 architectural performance events

Both the TCU and the TBU implement performance events that the SMMUv3 Performance Monitor extension defines.

The SMMU\_PMCG\_SMR0 register can filter some events so that only events with a particular StreamID are counted.

The following table shows the architecturally defined MMU-600 TCU performance events.

Table 2-5 SMMUv3 performance events for the TCU

| Event                                                           | Event ID | SMMU_PMCG_SMR0 filterable | Description                                                                                              |
|-----------------------------------------------------------------|----------|---------------------------|----------------------------------------------------------------------------------------------------------|
| Clock cycle.                                                    | 0x0      | No                        | Counts clock cycles.  Cycles where the clock is gated after a clock Q-Channel handshake are not counted. |
| Transaction.                                                    | 0x1      | Yes                       | Counts translation requests that originate from a DTI-TBU or DTI-ATS master.                             |
| TLB miss caused by incoming transaction or translation request. | 0x2      | Yes                       | Counts translation requests where the translation walks new translation table entries.                   |

Table 2-5 SMMUv3 performance events for the TCU (continued)

| Event                                                                  | Event ID | SMMU_PMCG_SMR0 filterable | Description                                                                              |
|------------------------------------------------------------------------|----------|---------------------------|------------------------------------------------------------------------------------------|
| Configuration cache miss caused by transaction or translation request. | 0x3      | Yes                       | Counts translation requests where the translation walks new configuration table entries. |
| Translation table walk access.                                         | 0x4      | Yes                       | Counts translation table walk accesses.                                                  |
| Configuration structure access.                                        | 0x5      | Yes                       | Counts configuration table walk accesses.                                                |
| PCIe ATS Translation Request received.                                 | 0x6      | Yes                       | Counts translation requests that originate from a DTI-ATS master.                        |

The following table shows the architecturally defined MMU-600 TBU performance events.

Table 2-6 SMMUv3 performance events for the TBU

| Event                                                           | Event ID | SMMU_PMCG_SMR0 filterable | Description                                                                                              |
|-----------------------------------------------------------------|----------|---------------------------|----------------------------------------------------------------------------------------------------------|
| Clock cycle.                                                    | 0x0      | No                        | Counts clock cycles.  Cycles where the clock is gated after a clock Q-Channel handshake are not counted. |
| Transaction.                                                    | 0x1      | Yes                       | Counts transactions that are issued on the TBM interface.                                                |
| TLB miss caused by incoming transaction or translation request. | 0x2      | Yes                       | Counts non-speculative translation requests that are issued to the TCU.                                  |
| PCIe ATS Translation<br>Request received.                       | 0x7      | Yes                       | Counts ATS-translated transactions that are issued on the TBM interface.                                 |

See the *Arm*<sup>®</sup> *System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1* for more information.

## MMU-600 TCU events

The MMU-600 PMU can be configured to monitor a range of IMPLEMENTATION DEFINED TCU performance events.

The SMMU\_PMCG\_SMR0 register can filter some TCU performance events so that only events with a particular StreamID are counted.

The following table shows the TCU performance events.

Table 2-7 MMU-600 TCU performance events

| Event   Event ID   SMMU_PMCG_SMR0   Description   filterable |      | Description |                                                                                           |
|--------------------------------------------------------------|------|-------------|-------------------------------------------------------------------------------------------|
| S1L0WC lookup                                                | 0x80 | Yes         | Counts translation requests that access the S1L0WC walk cache.                            |
| S1L0WC miss                                                  | 0x81 | Yes         | Counts translation requests that access the S1L0WC walk cache and do not result in a hit. |
| S1L1WC lookup                                                | 0x82 | Yes         | Counts translation requests that access the S1L1WC walk cache.                            |

# Table 2-7 MMU-600 TCU performance events (continued)

| Event                   | Event ID | SMMU_PMCG_SMR0 filterable | Description                                                                                                                                                                                                                        |
|-------------------------|----------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S1L1WC miss             | 0x83     | Yes                       | Counts translation requests that access the S1L1WC walk cache and do not result in a hit.                                                                                                                                          |
| S1L2WC lookup           | 0×84     | Yes                       | Counts translation requests that access the S1L2WC walk cache.                                                                                                                                                                     |
| S1L2WC miss             | 0x85     | Yes                       | Counts translation requests that access the S1L2WC walk cache and do not result in a hit.                                                                                                                                          |
| S1L3WC lookup           | 0x86     | Yes                       | Counts translation requests that access the S1L3WC walk cache.                                                                                                                                                                     |
| S1L3WC miss             | 0x87     | Yes                       | Counts translation requests that access the S1L3WC walk cache and do not result in a hit.                                                                                                                                          |
| S2L0WC lookup           | 0×88     | Yes                       | Counts translation requests that access the S2L0WC walk cache.                                                                                                                                                                     |
| S2L0WC miss             | 0x89     | Yes                       | Counts translation requests that access the S2L0WC walk cache and do not result in a hit.                                                                                                                                          |
| S2L1WC lookup           | 0×8A     | Yes                       | Counts translation requests that access the S2L1WC walk cache.                                                                                                                                                                     |
| S2L1WC miss             | 0x8B     | Yes                       | Counts translation requests that access the S2L1WC walk cache and do not result in a hit.                                                                                                                                          |
| S2L2WC lookup           | 0×8C     | Yes                       | Counts translation requests that access the S2L2WC walk cache.                                                                                                                                                                     |
| S2L2WC miss             | 0x8D     | Yes                       | Counts translation requests that access the S2L2WC walk cache and do not result in a hit.                                                                                                                                          |
| S2L3WC lookup           | 0x8E     | Yes                       | Counts translation requests that access the S2L3WC walk cache.                                                                                                                                                                     |
| S2L3WC miss             | 0x8F     | Yes                       | Counts translation requests that access the S2L3WC walk cache and do not result in a hit.                                                                                                                                          |
| WC read                 | 0×90     | Yes                       | Counts reads from the walk cache RAMs, excluding reads that are caused by invalidation requests.  Note  A single walk cache lookup might result in multiple RAM reads. This behavior permits contiguous entries to be located.     |
| Buffered translation    | 0x91     | Yes                       | Counts translations written to the translation request buffer because all translation slots are full.                                                                                                                              |
| CC lookup               | 0x92     | Yes                       | Counts lookups into the configuration cache.                                                                                                                                                                                       |
| CC read                 | 0x93     | Yes                       | Counts reads from the configuration cache RAMs, excluding reads that are caused by invalidation requests.  Note  A single cache lookup might result in multiple RAM reads. This behavior permits contiguous entries to be located. |
| Speculative translation | 0xA0     | Yes                       | Counts translation requests that are marked as speculative.                                                                                                                                                                        |

Table 2-7 MMU-600 TCU performance events (continued)

| Event         | Event ID | SMMU_PMCG_SMR0 filterable | Description                                                                  |
|---------------|----------|---------------------------|------------------------------------------------------------------------------|
| S1L0WC error  | 0xC0     | No                        | RAS corrected error in S1L0 walk cache.                                      |
|               |          |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1. |
| S1L1WC error  | 0xC1     | No                        | RAS corrected error in S1L1 walk cache.                                      |
|               |          |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1. |
| S1L2WC error  | 0xC2     | No                        | RAS corrected error in S1L2 walk cache.                                      |
|               |          |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1. |
| S1L3WC error  | 0xC3     | No                        | RAS corrected error in S1L3 walk cache.                                      |
|               |          |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1. |
| S2L0WC error  | 0xC4     | No                        | RAS corrected error in S2L0 walk cache.                                      |
|               |          |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1. |
| S2L1WC error  | 0xC5     | No                        | RAS corrected error in S2L1 walk cache.                                      |
|               |          |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1. |
| S2L2WC error  | 0xC6     | No                        | RAS corrected error in S2L2 walk cache.                                      |
|               |          |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1. |
| S2L3WC error  | 0xC7     | No                        | RAS corrected error in S2L3 walk cache.                                      |
|               |          |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1. |
| Configuration | 0xC8     | No                        | RAS corrected error in configuration cache.                                  |
| cache error   |          |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1. |

## MMU-600 TBU events

The MMU-600 PMU can be configured to monitor a range of IMPLEMENTATION DEFINED TBU performance events.

The SMMU\_PMCG\_SMR0 register can filter the TBU performance events so that only events with a particular StreamID are counted.

The following table shows the TBU performance events.

# Table 2-8 MMU-600 TBU performance events

| Event                                       | Event<br>ID | SMMU_PMCG_SMR0 filterable | Description                                                                                                                                                                                                                             |
|---------------------------------------------|-------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Main TLB lookup                             | 0x80        | Yes                       | Counts Main TLB lookups.                                                                                                                                                                                                                |
| Main TLB miss                               | 0x81        | Yes                       | Counts translation requests that miss in the Main TLB.                                                                                                                                                                                  |
| Main TLB read                               | 0x82        | Yes                       | Counts once per access to the Main TLB RAMs, excluding reads that are caused by invalidation requests.  Note  A transaction might access the Main TLB multiple times to look for different page sizes.                                  |
| Micro TLB lookup                            | 0x83        | Yes                       | Counts micro TLB lookups.                                                                                                                                                                                                               |
| Micro TLB miss                              | 0x84        | Yes                       | Counts translation requests that miss in the micro TLB.                                                                                                                                                                                 |
| Slots full                                  | 0x85        | No                        | Counts once per cycle when all slots are occupied and not ready to issue transactions downstream.                                                                                                                                       |
|                                             |             |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1.                                                                                                                                                            |
| Out of translation tokens                   | 0x86        | No                        | Counts once per cycle when a translation request cannot be issued because all translation tokens are in use.                                                                                                                            |
|                                             |             |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1.                                                                                                                                                            |
| Write data buffer full                      | 0x87        | No                        | Counts once per cycle when a transaction is blocked because the write data buffer is full.                                                                                                                                              |
|                                             |             |                           | This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1.                                                                                                                                                            |
| Translation request                         | 0x88        | Yes                       | Counts translation requests, including both speculative and non-speculative requests.                                                                                                                                                   |
| Write data uses<br>write data buffer        | 0x89        | Yes                       | Counts transactions with write data that is stored in the write data buffer.                                                                                                                                                            |
| Write data<br>bypasses write data<br>buffer | 0x8A        | Yes                       | Counts transactions with write data that bypasses the write data buffer.                                                                                                                                                                |
| MakeInvalid<br>downgrade                    | 0x8B        | Yes                       | Counts when either:  • A MakeInvalid transaction on the TBS interface is output as CleanInvalid on the TBM interface.  • A ReadOnceMakeInvalid transaction on the TBS interface is output as ReadOnceCleanInvalid on the TBM interface. |

Table 2-8 MMU-600 TBU performance events (continued)

| Event          | Event<br>ID | SMMU_PMCG_SMR0 filterable | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|-------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stash fail     | 0x8C        | Yes                       | Counts when either.  • A WriteUniquePtlStash or WriteUniqueFullStash transaction on TBS is output as a WriteNoSnoop or WriteUnique transaction on the TBM interface.  • A StashOnceShared or StashOnceUnique transaction on the TBS interface has a valid translation, but is terminated in the TBU.  Note  Note  A StashOnceShared or StashOnceUnique transaction that is terminated because of a StreamDisable or GlobalDisable translation response does not cause this event to count. |
| Main TLB error | 0xC0        | No                        | RAS corrected error in Main TLB.  This Secure event is visible only when the SMMU_PMCG_SCR.SO bit is set to 1.                                                                                                                                                                                                                                                                                                                                                                             |

## SMMUv3 PMU register architectural options

The SMMUv3 architecture defines the *Performance Monitor Counter Group* (PMCG) configuration register, SMMU\_PMCG\_CFGR. An MMU-600 implementation assumes fixed values for SMMU\_PMCG\_CFGR, and these values define behavioral aspects of the implementation.

The following table shows the SMMU\_PMCG\_CFGR register options that the MMU-600 TCU and TBU use.

Table 2-9 MMU-600 SMMU\_PMCG\_CFGR register architectural options

| Field           | Default value | Description for default value                                      |
|-----------------|---------------|--------------------------------------------------------------------|
| SID_FILTER_TYPE | 1             | A single StreamID filter applies to all PMCG counters.             |
| CAPTURE         | 1             | Capture of counter values into SVRn registers is supported.        |
| MSI             | 0             | The counter group does not support MSIs.                           |
| RELOC_CTRS      | 1             | The PMCG registers are relocated to page 1 of the PMU address map. |
| SIZE            | 0x31          | The counter group implements 32-bit counters.                      |
| NCTR            | 0x3           | The counter group includes 4 counters.                             |

#### Related references

3.3 MMU-600 memory map on page 3-61.

## PMU snapshot interface

The *Performance Monitoring Unit* (PMU) snapshot interface is included on the TCU and on each TBU. You can use this asynchronous interface to initiate a PMU snapshot. A simultaneous snapshot of each counter register is created and copied to the respective SMMU PMCG SVRn register.

The PMU snapshot sequence is a 4-phase handshake. Both **pmusnapshot\_req** and **pmusnapshot\_ack** are LOW after reset. A snapshot occurs on the rising edge of **pmusnapshot\_req**, and is equivalent to writing the value 1 to SMMU PMCG CAPR.CAPTURE.

The **pmusnapshot\_req** signal is sampled using synchronizing registers. A register drives **pmusnapshot ack** so that the connected component can sample the signal asynchronously.

## Related references

A.5 TCU PMU snapshot interface signals on page Appx-A-95. A.14 TBU PMU snapshot interface signals on page Appx-A-106.

## Related concepts

2.3.3 Reliability, Availability, and Serviceability on page 2-43.

## 2.3.2 DTI overview

In an MMU-600-based system, the AMBA DTI protocol defines the standard for communicating with a TCU.

The AMBA DTI protocol includes both:

- DTI-TBU protocol, for communication between a TBU and a TCU.
- DTI-ATS protocol, for communication between a PCIe Root Complex and a TCU.

The DTI protocol is a point-to-point protocol. Each channel consists of a link, a DTI master, and a DTI slave. The DTI masters in the respective protocols are:

- The TBU, in the DTI-TBU protocol.
- The PCIe Root Complex, in the DTI-ATS protocol.

The DTI slave in both DTI-TBU and DTI-ATS is the TCU.

DTI masters and slaves communicate using defined DTI messages. The DTI protocol defines the following message groups:

- · Connection and disconnection.
- Translation request.
- Invalidation and synchronization.
- Page request.
- Register access.

The DTI\_TBU\_CONDIS\_REQ message initiates a TBU connection or disconnection handshake. The TBU uses this message to connect to the TCU. During connection, the TBU can specify the number of requested translation tokens.

The TBU uses the TOK\_TRANS\_REQ field to request translation tokens. The **max\_tok\_trans** signal defines the number of translation tokens that the TBU requests.

The TBU uses the TOK\_INV\_GNT field to grant invalidation tokens. The TBU grants only one invalidation token, and the TCU is only capable of issuing one invalidate message at a time.

A DTI master uses a DTI\_TBU\_CONDIS\_REQ or a DTI\_ATS\_CONDIS\_REQ message to initiate a connection handshake. If the master provides a **TID** value that is greater than the maximum supported **TID** that TCUCFG\_NUM\_TBU defines, the slave sends a Connect Deny message.

A translation request to the TCU where StreamID  $\geq 2^{24}$  results in a fault and an SMMUv3 C\_BAD\_STREAMID event. If the TBU receives an invalidation request where StreamID  $\geq 2^{24}$ , any comparisons with a StreamID value fail. No TLB entries are invalidated, but other effects that do not consider the supplied StreamID occur as normal.

| Noto |
|------|
| Note |

- The TBU never generates translation requests with StreamID  $\geq 2^{24}$ .
- The TCU never generates invalidation requests with StreamID  $\geq 2^{24}$ .

See the Arm® AMBA® Distributed Translation Interface (DTI) Protocol Specification for more information.

## 2.3.3 Reliability, Availability, and Serviceability

Reliability, Serviceability, and Availability (RAS) features enable cache corruption to be detected and corrected, optionally generating interrupts into the system. All MMU-600 RAM-based caches support RAS error detection and correction.

The RAS Extension registers permit software to monitor the following caches for errors:

- TBU Main TLB (MTLB).
- TCU configuration cache.
- TCU translation table walk cache.

Within a coherent system, these caches are always clean, and there is no requirement to correct data on these caches. Any incorrect data is discarded and refetched. From an RAS standpoint, discarding and refetching counts as a corrected error.

See the Arm® System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1 for more information.

## Related references

```
3.12.1 TBU_ERRFR on page 3-85.
3.12.2 TBU_ERRCTLR on page 3-85.
3.12.3 TBU_ERRSTATUS on page 3-86.
3.8.1 TCU_ERRFR on page 3-76.
3.8.2 TCU_ERRCTLR on page 3-76.
3.8.3 TCU_ERRSTATUS on page 3-77.
```

# 2.3.4 Quality of Service

You can program the TCU with a priority level for each TBU. The priority level is applied to every translation from that TBU.

The TCU uses this priority level to:

- Arbitrate between translations that are waiting in the translation request buffer when translation manager slots become available.
- Arbitrate between translation manager slots when they access the caches and perform configuration table walks and translation table walks.
- Determine the AXI **AxQOS** value for translation table walks and configuration table walks that the TCU issues on the QTW/DVM interface.

The arbiters contain starvation avoidance mechanisms to prevent transactions from being stalled indefinitely.

The TBU does not implement any prioritization between transactions. Arm recommends that bus masters with different QoS requirements use separate TBUs for translation.

## Related references

```
3.7.2 TCU_QOS on page 3-69.
3.7.6 TCU_NODE_CTRLn on page 3-73.
```

## 2.3.5 Distributed Virtual Memory (DVM) messages

The QTW/DVM interface supports DVM messages. The MMU-600 supports DVMv8.1.

The interface supports DVM transactions of message types TLB Invalidate and Synchronization. The interface accepts all other DVM transaction message types, and sends a snoop response, but otherwise ignores such transactions.

Tie the **sup btm** input signal HIGH when Broadcast TLB Maintenance is supported.

You can use SMMU\_CR2 and SMMU\_S\_CR2 to control how the QTW/DVM interface responds to TLB Invalidate operations:

- If SMMU\_CR2.PTM = 1, the interface ignores Non-secure TLB Invalidate operations.
- If SMMU S CR2.PTM = 1, the interface ignores Secure TLB Invalidate operations.

| <br>Note ——— |
|--------------|
| NOLE -       |

Although TLB Invalidate operations have no effect on the QTW/DVM interface when PTM = 1, the interface still returns the appropriate response.

The QTW/DVM interface might receive DVM Sync transactions without receiving a DVM TLB Invalidate transaction, or when the PTM bits have masked a TLB Invalidate. If no DVM TLB Invalidate operations have occurred since the most recent DVM Sync transaction, subsequent DVM Sync transactions result in an immediate DVM Complete transaction. This behavior ensures that the TCU does not affect system DVM performance unless TLB Invalidate operations are performed.

The DTI interface allocates the access permissions and shareability of DVM Complete transactions as follows:

- **ARPROT** = 06000, indicating Unprivileged, Secure, Data access.
- **ARDOMAIN** = 0b01, indicating Inner Shareable.

For a DVM Operation or DVM Sync request on the **AC** channel, the snoop response signal **CRRESP[4:0]** is always set to 0b00000.

## 2.3.6 Error responses

AMBA defines external AXI slave error, SLVERR, and external AXI decode error, DECERR. The MMU-600 error response behavior depends on the interface.

The TCU QTW/DVM interface treats SLVERR and DECERR identically, as an abort.

When terminating a transaction, the TBS interface generates a SLVERR response.

If the TBU TBM interface receives a SLVERR or DECERR response to a downstream transaction, it propagates the same abort type to the TBS interface.

## 2.3.7 Conversion between ACE-Lite and ARMv8 attributes

The SMMUv3 architecture defines attributes in terms of the ARMv8 architecture. The MMU-600 components are therefore required to perform conversion between ACE-Lite and ARMv8 attributes.

The TBU must convert:

- ACE-Lite attributes to ARMv8 attributes when it receives transactions on the *Transaction Slave* (TBS) interface.
- ARMv8 attributes to ACE-Lite attributes when it outputs transactions on the *Transaction Master* (TBM) interface.

The TCU must convert ARMv8 attributes to ACE-Lite attributes when it outputs transactions on the QTW/DVM interface.

## Slave interface memory type attribute handling

The memory attributes that apply to the TBS interface are contained in the **AxCACHE** and **AxDOMAIN** signals.

The following table shows the ACE-Lite to ARMv8 attribute conversions that the TBU TBS interface performs.

Table 2-10 MMU-600 ACE-Lite to ARMv8 memory attribute conversions

| AxCACHE attribute     | AxDOMAIN attribute | ARMv8 memory attribute | ARMv8 shareability |
|-----------------------|--------------------|------------------------|--------------------|
| Device Non-bufferable | System             | Device-nGnRnE          | Outer Shareable    |
| Device Bufferable     | System             | Device-nGnRE           | Outer Shareable    |

Table 2-10 MMU-600 ACE-Lite to ARMv8 memory attribute conversions (continued)

| AxCACHE attribute                       | AxDOMAIN attribute | ARMv8 memory attribute           | ARMv8 shareability |
|-----------------------------------------|--------------------|----------------------------------|--------------------|
| Normal Non-cacheable Bufferable         | Any                | Normal Inner Non-cacheable Outer | Outer Shareable    |
| Normal Non-cacheable Non-bufferable     |                    | Non-cacheable                    |                    |
| Write-Through No Allocate               |                    |                                  |                    |
| Write-Through Read-allocate             |                    |                                  |                    |
| Write-Through Write-Allocate            |                    |                                  |                    |
| Write-Through Read and Write-Allocate   |                    |                                  |                    |
| Write-Back No Allocate                  | Non-shareable      | Normal Inner Write-Back Outer    | Non-shareable      |
| Write-Back Read-Allocate                | Inner Shareable    | Write-Back                       | Non-shareable      |
| Write-Back Write-Allocate               | Outer Shareable    |                                  | Outer Shareable    |
| Write-Back Read Allocate Write-Allocate |                    |                                  |                    |

| Note |
|------|
| 7016 |

- Write-Back transactions are always treated as non-transient.
- The ARMv8-A Read-Allocate and Write-Allocate hints are the same as the hints that the **AxCACHE** Write-Back type provides.
- The TBU TBS interface converts instruction writes into data writes. That is, it treats **AWPROT[2]** as 0.

# Master interface memory type attribute handling

The memory attributes that apply to the TBM and the QTW/DVM interfaces are contained in the **AxCACHE** and **AxDOMAIN** signals.

In addition, the TBU TBM interface can use the **AxLOCK** signal to indicate an Exclusive access. The QTW/DVM interface does not use the **AxLOCK** signal.

On the TBU TBM interface, a bit on **AxUSER** indicates whether the memory type before the conversion is Outer Cacheable.

The following table shows the ARMv8 to ACE-Lite attribute conversions that the master interfaces perform.

Table 2-11 MMU-600 ARMv8 to ACE-Lite memory attribute conversions

| ARMv8 memory attribute | AxCACHE attribute      | AxDOMAIN attribute | AxLOCK attribute                        | AxUSER Outer<br>Cacheable |
|------------------------|------------------------|--------------------|-----------------------------------------|---------------------------|
| Device-nGnRnE          | Device Non-bufferable. | System.            | As Transaction Slave (TBS) AxLOCK value | 0                         |
| Device-GRE             | Device Bufferable.     | System.            | As TBS AxLOCK value                     | 0                         |
| Device-nGRE            |                        |                    |                                         |                           |
| Device-nGnRE           |                        |                    |                                         |                           |

Table 2-11 MMU-600 ARMv8 to ACE-Lite memory attribute conversions (continued)

| ARMv8 memory attribute                                 | AxCACHE attribute                                                                               | AxDOMAIN attribute                                                                                                                                        | AxLOCK attribute    | AxUSER Outer<br>Cacheable |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------------------|
| Normal Inner Non-<br>cacheable Outer Non-<br>cacheable | Normal Non-cacheable<br>Bufferable.                                                             | System.                                                                                                                                                   | As TBS AxLOCK value | 0                         |
| Normal Inner Write-<br>Through Outer Non-<br>cacheable |                                                                                                 |                                                                                                                                                           |                     |                           |
| Normal Inner Write-<br>Back Outer Non-<br>cacheable    |                                                                                                 |                                                                                                                                                           |                     |                           |
| Normal Inner Non-<br>cacheable Outer Write-<br>Through | Normal Non-cacheable<br>Bufferable.                                                             | System.                                                                                                                                                   | As TBS AxLOCK value | 1                         |
| Normal Inner Write-<br>Through Outer Write-<br>Through |                                                                                                 |                                                                                                                                                           |                     |                           |
| Normal Inner Write-<br>Back Outer Write-<br>Through    |                                                                                                 |                                                                                                                                                           |                     |                           |
| Normal Inner Non-<br>cacheable Outer Write-<br>Back    |                                                                                                 |                                                                                                                                                           |                     |                           |
| Normal Inner Write-<br>Through Outer Write-<br>Back    |                                                                                                 |                                                                                                                                                           |                     |                           |
| Normal Inner Write-<br>Back Outer Write-Back           | Write-Back No Allocate Write-Back Read-Allocate. Write-Back Write-Allocate. Write-Back Read and | If AxBURST == FIXED, Non-shareable. If AxBURST != FIXED, the attribute reflects the ARMv8 shareability:  Non-shareable. Inner Shareable. Outer Shareable. | 0                   | 1                         |

# AXI USER bits defined by the MMU-600 TBU

The TBU TBM interface **AxUSER** signals, **aruser\_m** and **awuser\_m**, have 13 bits more than the corresponding signals on the TBS interface. These extra bits are output in higher-order bits of **aruser\_m** and **awuser m**.

The following table shows the aruser\_s and awuser\_s bits that are defined by the MMU-600 TBU.

Table 2-12 MMU-600 defined aruser\_m and awuser\_m bits

| Bit position | Value                                                |  |
|--------------|------------------------------------------------------|--|
| [n+12]       | Outer Cacheable.                                     |  |
| [n+11:n+8]   | The Stream Table Entry (STE) defines the attributes. |  |

Table 2-12 MMU-600 defined aruser\_m and awuser\_m bits (continued)

| Bit position | Value                                   |  |
|--------------|-----------------------------------------|--|
| [n+7:n+4]    | Stage 2 Page Based Hardware Attributes. |  |
| [n+3:n]      | Stage 2 Page Based Hardware Attributes. |  |

Bits [119:116] of the STE are IMPLEMENTATION DEFINED in SMMUv3. The MMU-600 TCU outputs these bits in the DTI\_TBU\_TRANS\_RESP.CTXTATTR field. The MMU-600 TBU outputs these bits as STE-defined attributes.

## Related references

Master interface memory type attribute handling on page 2-45.

## 2.4 Constraints and limitations of use

Certain usage constraints and limitations apply to the MMU-600.

Unless otherwise specified:

- An IMPLEMENTATION DEFINED field in a structure that the MMU-600 generates is 0.
- An IMPLEMENTATION DEFINED field in a structure that the MMU-600 reads is ignored.

This section contains the following subsections:

- 2.4.1 SMMUv3 support on page 2-48.
- 2.4.2 AMBA support on page 2-51.

## 2.4.1 SMMUv3 support

The MMU-600 does not implement, or require, certain SMMUv3 functionality.

The SMMUv3 architectural registers include a set of ID registers that indicate the SMMUv3 features that the MMU-600 implements. The following table shows the SMMUv3 ID register values that the MMU-600 uses.

| Note                                                                                              |  |
|---------------------------------------------------------------------------------------------------|--|
| The values in this table are not configurable except for values that are specified in <b>bold</b> |  |

# Table 2-13 MMU-600 SMMUv3 ID register architectural options

| Register  | Field          | Value                    | Description for value                                                                                     |
|-----------|----------------|--------------------------|-----------------------------------------------------------------------------------------------------------|
| SMMU_IDR0 | S2P            | 1                        | Stage 2 translations are supported.                                                                       |
|           | S1P            | 1                        | Stage 1 translations are supported.                                                                       |
|           | TTF            | 0b11                     | Both AArch32 Long-descriptor and AArch64 translation tables are supported.                                |
|           | СОНАСС         | sup_cohacc               | Coherent access to translations, structure, and queues is supported.                                      |
|           | BTM            | sup_btm                  | Broadcast TLB maintenance is supported.                                                                   |
|           | HTTU[1:0]      | 0b00                     | Updates of the Dirty state and Access flag are not supported.                                             |
|           | DORMHINT       | 0                        | Dormant hint is not supported.                                                                            |
|           | НҮР            | 1                        | Hypervisor stage 1 context is supported.                                                                  |
|           | ATS            | 1                        | PCIe Root Complex ATS is supported.                                                                       |
|           | NS1ATS         | 1                        | Stage 1-only ATS is not supported.                                                                        |
|           | ASID16         | 1                        | 16-bit ASID is supported.                                                                                 |
|           | MSI            | 1                        | Message-signaled interrupts are supported.                                                                |
|           | SEV            | sup_sev                  | SMMU and system support for the generation of events.                                                     |
|           | ATOS           | 0                        | Address translation operations are not supported.                                                         |
|           | PRI            | 0                        | PCIe Page Request Interface (PRI) is not supported.                                                       |
|           | VMW            | 1                        | VMID wildcard-matching is supported for TLB invalidation.                                                 |
|           | VMID16         | 1                        | 16-bit VMIDs are supported.                                                                               |
|           | CD2L           | 1                        | 2-level <i>Context Descriptor</i> (CD) tables are supported.                                              |
|           | VATOS          | 0                        | Virtual ATOS page interface is not supported.                                                             |
|           | TTENDIAN       | 0b00                     | Mixed-endian translation walks are supported.                                                             |
|           | STALL_MODEL    | {0, SMMU_S_CR0.NSSTALLD} | Stall model and Terminate model are both supported, unless the Secure world disables Non-secure stalling. |
|           | TERM_MODEL     | 0                        | Terminated transactions can terminate with either RAZ/WI behavior or abort.                               |
|           | ST_LEVEL       | 0b01                     | 2-level Stream tables are supported.                                                                      |
| SMMU_IDR1 | SIDSIZE        | 0b11000                  | 24-bit stream IDs are supported.                                                                          |
|           | SSIDSIZE       | 0b10100                  | 20-bit substream IDs are supported.                                                                       |
|           | PRIQS          | 0b00000                  | PCIe PRI is not supported.                                                                                |
|           | EVENTQS        | 0b10011                  | 2 <sup>19</sup> Event queue entries are supported.                                                        |
|           | CMDQS          | 0b10011                  | 2 <sup>19</sup> Command queue entries are supported.                                                      |
|           | ATTR_PERMS_OVR | 1                        | Incoming permission attributes can be overridden.                                                         |
|           | ATTR_TYPES_OVR | 1                        | Incoming memory attributes can be overridden.                                                             |
|           | REL            | 0                        | Base addresses are not fixed.                                                                             |
|           | QUEUES_PRESET  | 0                        | The queue base addresses are not fixed.                                                                   |
|           | TABLES_PRESET  | 0                        | The table base addresses are not fixed.                                                                   |

Table 2-13 MMU-600 SMMUv3 ID register architectural options (continued)

| Register    | Field        | Value               | Description for value                                                                                                |
|-------------|--------------|---------------------|----------------------------------------------------------------------------------------------------------------------|
| SMMU_IDR2   | BA_VATOS     | 0                   | No VATOS page is present.                                                                                            |
| SMMU_IDR3   | HAD          | 1                   | Hierarchical Attribute Disable is supported.                                                                         |
|             | РВНА         | 1                   | Page-Based Hardware Attributes are supported.                                                                        |
|             | XNX          | 1                   | EL0/EL1 execute control distinction at stage 2 is supported for both AArch64 and AArch32 stage 2 translation tables. |
| SMMU_IDR4   | IMPDEF       | 0                   | No implementation defined features apply.                                                                            |
| SMMU_IDR5   | OAS          | sup_oas             | The size of the physical address that is output from the SMMU.                                                       |
|             | GRAN4K       | 1                   | 4KB translation granule is supported.                                                                                |
|             | GRAN16K      | 1                   | 16KB translation granule is supported.                                                                               |
|             | GRAN64K      | 1                   | 64KB translation granule is supported.                                                                               |
|             | VAX          | 0b00                | Virtual addresses of 48 bits per CD.TTBx are supported.                                                              |
|             | STALL_MAX    | TCUCFG_XLATE_SLOTS  | Maximum number of outstanding stalled transactions that the SMMU supports.                                           |
| SMMU_IIDR   | Implementer  | 0x43B               | Arm implementation.                                                                                                  |
|             | Revision     | MAX(0x1, ecorevnum) | Minor revision is p1.  Note  ecorevnum is not configurable.                                                          |
|             | Variant      | 0                   | Product variant, or major revision is r0.                                                                            |
|             | ProductID    | 0x483               | Arm ID.                                                                                                              |
| SMMU_AIDR   | ArchMinorRev | 0b0001              | Architecture minor revision is SMMUv3.1.                                                                             |
|             | ArchMajorRev | 0b0000              | Architecture major revision is SMMUv3.                                                                               |
| SMMU_S_IDR0 | MSI          | 1                   | Secure MSIs are supported.                                                                                           |
|             | STALL_MODEL  | 0b00                | Stall model and Terminate model are both supported.                                                                  |
| SMMU_S_IDR1 | S_SIDSIZE    | 0b11000             | 24-bit Secure stream IDs are supported.                                                                              |
|             | SECURE_IMPL  | 1                   | Security implemented.                                                                                                |
| SMMU_S_IDR3 | SAMS         | 1                   | Secure Address Translation Services (ATS) maintenance is not implemented.                                            |

In an MMU-600-based system:

- The PRIQ ABT ERR global error cannot occur, because PRI is not implemented.
- The SFM ERR global error cannot occur, because Service Failure Mode (SFM) is not required.

The MMU-600 accepts but does not act on the following SMMUv3 Prefetch commands:

# CMD PREFETCH CONFIG

Prefetch configuration. This command prefetches the required configuration for a StreamID.

# CMD PREFETCH ADDR

Prefetch address. This command prefetches configuration and TLB entries for an address range.

The MMU-600 does not generate any of the following SMMUv3 events, because they are not required:

## F UUT

Unsupported Upstream Transaction.

## F TLB CONFLICT

TLB conflict.

## F CFG CONFLICT

Configuration cache conflict.

## E PAGE REQUEST

Speculative page request hint.

## IMPDEF EVENTn

IMPLEMENTATION DEFINED event allocation.

F\_TLB\_CONFLICT and F\_CFG\_CONFLICT are not required because the MMU-600 caches include logic to ensure that only one entry can match at a time. If multiple cache entries match a transaction or translation request, only one entry is used and the others are ignored.

The MMU-600 never merges events. The STE.MEV field is ignored.

The TBU ignores the STE.ALLOCCFG field that is communicated to the TBU in the ALLOCCFG field of the DTI\_TBU\_TRANS\_RESP message.

The TCU sup\_oas[2:0] signal must not be set to 0b110. If this value is used, the TCU treats it as 0b101, that is, 48 bits. The TBU supports a 48-bit PA size. The MMU-600 TBU and TCU cannot be used with other components that implement DTI and are configured for a 52-bit PA size.

## Related references

3.2 SMMU architectural registers on page 3-57.

#### 2.4.2 AMBA support

Certain behavior applies to how the MMU-600 implements its ACE-Lite interfaces.

## **TBU** support for ACE-Lite transactions

The MMU-600 TBU supports many ACE-Lite transaction types, and handles these transactions in certain ways. Typically, when propagating downstream transactions on the TBU TBM interface, the MMU-600 uses the same transaction type that the upstream master presents to the TBU TBS interface.

If the shareability domain of a downstream WriteLineUnique transaction is not Inner Shareable or Outer Shareable, the MMU-600 outputs the transaction as WriteNoSnoop. That is, **AWSNOOP** = 0b0000. The **AWDOMAIN** signal indicates the shareability domain of write transactions.

## Transactions that can result in a translation fault

In an MMU-600 system, some transactions can result in a translation fault, and certain behavior is associated with such transactions.

The MMU-600 treats the following transactions as ordinary reads when calculating translation faults:

- · CleanShared.
- CleanInvalid.
- MakeInvalid.
- CleanSharedPersist.
- ReadOnceMakeInvalid.
- ReadOnceCleanInvalid.

Therefore, these transactions might require either read permission or execute permission at the appropriate privilege level.

The MMU-600 treats the following transactions as ordinary writes when calculating translation faults:

- WriteUniquePtlStash.
- WriteUniqueFullStash.

Therefore, these transactions require write permission at the appropriate privilege level.

CleanShared, CleanInvalid, MakeInvalid, and CleanSharedPersist transactions do not have a memory type. The input transaction and output transaction memory type and allocation hints are ignored and replaced by Normal, Inner Write-Back, Outer Write-Back, Read Allocate, Write Allocate. This behavior means that the **ARDOMAIN** output on the TBM interface is never System Shareable for these transactions, because they are never Non-cacheable or Device.

The MMU-600 treats transactions that pass the translation fault check as follows:

#### MakeInvalid transactions

The MMU-600 converts MakeInvalid transactions to CleanInvalid transactions, unless the translation also grants write permission and *Destructive Read Enable* (DRE) permission.

# ReadOnceMakeInvalid and ReadOnceCleanInvalid transactions

The MMU-600 outputs ReadOnceMakeInvalid transactions as ReadOnceCleanInvalid transactions, unless the translation also granted write permission and DRE permission. If the final transaction attributes on the TBU TBM interface are not Inner Shareable Write-Back or Outer Shareable Write-Back, the MMU-600 converts ReadOnceMakeInvalid and ReadOnceCleanInvalid transactions into ordinary reads.

# WriteUniquePtlStash and WriteUniqueFullStash transactions

If they pass the translation fault check, the MMU-600 converts WriteUniquePtlStash and WriteUniqueFullStash transactions to ordinary write transactions if either:

- The translation did not grant *Directed Cache Prefetch* (DCP) permission.
- The final transaction attributes on the TBU TBM interface are not Inner Shareable or Outer Shareable Write-Back.

If such a conversion occurs, AWSTASH\* is driven as 0.

## Transactions that cannot result in a translation fault

In an MMU-600 system, certain transactions cannot result in a translation fault, and certain behavior is associated with such transactions.

The following transactions never result in a translation fault:

- StashOnceShared.
- StashOnceUnique.
- · StashTranslation.

If any of these transactions require a translation request to the TCU, the MMU-600 issues a speculative translation request on the DTI interconnect. StashOnceShared and StashOnceUnique transactions are terminated in the TBU, with a **BRESP** value of OKAY, when any of the following cases apply:

- The translation did not grant *Directed Cache Prefetch* (DCP) permission.
- The final transaction attributes on the TBM interface are not Inner Shareable or Outer Shareable Write-Back.

| • | The translation did not grant any of read, write, or execute permission at the appropriate privilege level. |
|---|-------------------------------------------------------------------------------------------------------------|
|   | Note                                                                                                        |
|   | Only one of these permissions is required for the stash transaction to be permitted.                        |
|   |                                                                                                             |
|   |                                                                                                             |

\_\_\_\_\_ Note \_\_\_\_\_

A **BRESP** value of OKAY indicates transaction success. The MMU-600 always generates this value when a StashOnceShared or a StashOnceUnique transaction is terminated in the TBU. This behavior

applies even when a StreamDisable or GlobalDisable translation response causes the transaction to be terminated.

The MMU-600 never propagates StashTranslation transactions downstream, and uses StashTranslation only to prefetch TLB contents. The MMU-600 always terminates StashTranslation transactions with a

**BRESP** value of OKAY, even if no translation could be stored in the TLB.

The TBU ignores AWPROT[0] and AWPROT[2] for StashTranslation transactions, because they do not affect speculative translation requests.

# **AXI5** support

The AXI5 protocol includes extensions that are not included in previous AXI versions. The *Arm*® *AMBA*® *AXI and ACE Protocol Specification* defines these extensions.

The following table shows whether individual TCU and TBU interfaces support the AXI5 extensions.

Table 2-14 TCU and TBU interface support for AXI5 extensions

| AXI5 extension            | QTW/DVM | тви твѕ | тви твм |
|---------------------------|---------|---------|---------|
| DVM_v8.1                  | Yes     | No      | No      |
| Low_Power_Signals         | Yes     | Yes     | Yes     |
| Atomic_Transactions       | No      | No      | No      |
| Cache_Stash_Transactions  | No      | Yes     | Yes     |
| DeAllocation_Transactions | No      | Yes     | Yes     |
| Untranslated_Transactions | No      | Yes     | Yes     |
| Poison                    | No      | No      | No      |
| Data_Check                | No      | No      | No      |
| QoS_Accept                | No      | No      | No      |
| Trace_Signals             | No      | No      | No      |
| Loopback_Signals          | No      | No      | No      |
| NSAccess_Identifiers      | No      | No      | No      |
| Barrier_Transactions      | No      | No      | No      |
| Persist_CMO               | No      | Yes     | Yes     |

# Chapter 3 **Programmers model**

This chapter describes the MMU-600 programmers model.

## It contains the following sections:

- *3.1 About the programmers model* on page 3-55.
- 3.2 SMMU architectural registers on page 3-57.
- *3.3 MMU-600 memory map* on page 3-61.
- 3.4 Register summary on page 3-63.
- 3.5 TCU Component and Peripheral ID Registers on page 3-66.
- 3.6 TCU PMU Component and Peripheral ID Registers on page 3-67.
- 3.7 TCU microarchitectural registers on page 3-68.
- 3.8 TCU RAS registers on page 3-76.
- 3.9 TBU Component and Peripheral ID Registers on page 3-81.
- 3.10 TBU PMU Component and Peripheral ID Registers on page 3-82.
- 3.11 TBU microarchitectural registers on page 3-83.
- 3.12 TBU RAS registers on page 3-85.

# 3.1 About the programmers model

This section provides general information about the MMU-600 register properties.

The following information applies to the MMU-600 registers:

- The base address is not fixed, and can be different for any particular system implementation. The offset of each register from the base address is fixed.
- Do not attempt to access reserved or unused address locations. Attempting to access these locations can result in UNPREDICTABLE behavior.
- Unless otherwise stated in the accompanying text:
  - Do not modify undefined register bits.
  - Ignore undefined register bits on reads.
  - All register bits are reset to 0 by a system or powerup reset.
- Access type is described as follows:

RW Read and write.
RO Read only.
WO Write only.
RAZ Read as zero.
WI Writes ignored.

- Bit positions that are described as reserved are:
  - In an RW register, RAZ/WI.
  - In an RO register, RAZ.
  - In a WO register, WI.

The MMU-600 registers are accessed using the PROG APB4 slave interface on the TCU, and cannot be accessed directly through any other slave interfaces.

Some registers are 64 bits, but the PROG APB4 interface is 32 bits. Because software accesses 64-bit registers 32 bits at a time, such accesses are not guaranteed to be 64-bit atomic. This behavior does not cause problems for software, because the SMMUv3 architecture does not require 64-bit atomic access to any registers.

The programmers model contains separate TBU and TCU regions for internal control, RAS, and identification registers. Accesses to unmapped or reserved registers are RAZ/WI. Non-secure accesses to Secure registers are RAZ/WI. The MMU-600 implements the identification register scheme that the SMMUv3 architecture defines.

The MMU-600 implements all the *Performance Monitor Counter Group* (PMCG) registers that the SMMUv3 architecture defines, except for:

- SMMU\_PMCG\_IRQ\_CFG0.
- SMMU PMCG IRQ CFG1.
- SMMU\_PMCG\_IRQ\_CFG2.
- SMMU\_PMCG\_IRQ\_STATUS.

The MMU-600 does not implement the following SMMUv3 architectural registers, and accesses to these locations are RAZ/WI:

- · SMMU IDR4.
- SMMU STATUSR.
- SMMU AGBPA.
- SMMU PRIQ \*.
- SMMU GATOS \*.
- SMMU S IDR4.
- SMMU S AGBPA.
- SMMU S GATOS \*.
- SMMU VATOS \*.

See the *Arm® System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1* for more information about the SMMU architectural registers.

# 3.2 SMMU architectural registers

The MMU-600 implements many of the SMMU architectural registers, as defined by the Arm® System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1.

The following table lists the SMMUv3 architectural registers that the MMU-600 implements.

——Note——

All writable register fields reset to 0 unless the SMMU architecture specifies otherwise.

Table 3-1 SMMUv3 architectural registers

| Register                                           | Name                                                   | Description                                                                                                        |
|----------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| SMMU_S_IDR0 - SMMU_S_IDR3                          | SMMU Secure feature<br>Identification Registers        | Provides information about the Secure features that the SMMU implementation supports.                              |
| SMMU_S_CR0                                         | Secure global Control Register 0                       | Provides global configuration of the Secure SMMU.                                                                  |
| SMMU_S_CR0ACK                                      | Secure global Control Register 0<br>update Acknowledge | Provides acknowledgement of completion of updates to SMMU_S_CR0.                                                   |
| SMMU_S_CR1<br>SMMU_S_CR2                           | Secure global Control Registers                        | Provides the controls for Secure table and queue access attributes.                                                |
| SMMU_S_INIT                                        | Secure Initialization control register                 | Provides a control to invalidate all Secure SMMU caching on system initialization.                                 |
| SMMU_S_GBPA                                        | Secure Global Bypass Attribute register                | Controls the global bypass attributes that are used for transactions from Secure streams when the MMU is disabled. |
| SMMU_S_IRQ_CTRL                                    | Secure Interrupt Control register                      | Contains enables for SMMU interrupts.                                                                              |
| SMMU_S_IRQ_CTRLACK                                 | Secure Interrupt Control register update Acknowledge   | Provides acknowledgement of the completion of updates to SMMU_S_IRQ_CTRL.                                          |
| SMMU_S_GERROR                                      | Secure Global Error status register                    | Provides information on Secure global programming interface errors.                                                |
| SMMU_S_GERRORN                                     | Secure Global Error<br>Acknowledgement register        | Contains the acknowledgement fields for SMMU_S_GERROR errors.                                                      |
| SMMU_S_GERROR_IRQ_CFG0 -<br>SMMU_S_GERROR_IRQ_CFG2 | Secure Global Error IRQ<br>Configuration register      | Contains the Secure MSI address configuration for the GERROR IRQ.                                                  |
| SMMU_S_STRTAB_BASE                                 | Secure Stream Table Base address register              | Contains the base address and attributes for the Secure Stream table.                                              |
| SMMU_S_STRTAB_BASE_CFG                             | Secure Stream Table Base<br>Configuration register     | Contains configuration fields for the Secure Stream table.                                                         |
| SMMU_S_CMDQ_BASE                                   | Secure Command queue Base address register             | Contains the base address and attributes for the Secure Command queue.                                             |
| SMMU_S_CMDQ_PROD                                   | Secure Command queue Producer index register           | Contains the Secure Command queue index for writes by the producer.                                                |
| SMMU_S_CMDQ_CONS                                   | Secure Command queue Consumer index register           | Contains the Secure Command queue index for reads by the consumer.                                                 |

# Table 3-1 SMMUv3 architectural registers (continued)

| Register                                           | Name                                                                | Description                                                                                                            |  |
|----------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--|
| SMMU_S_EVENTQ_BASE                                 | Secure Event queue Base address register                            | Contains the base address and attributes for the Secure Event queue.                                                   |  |
| SMMU_S_EVENTQ_PROD                                 | Secure Event queue Producer index register                          | Contains the Secure Event queue index for writes by the producer.                                                      |  |
| SMMU_S_EVENTQ_CONS                                 | Secure Event queue Consumer index register                          | Contains the Secure Event queue index for reads by the consumer.                                                       |  |
| SMMU_S_EVENTQ_IRQ_CFG0 -<br>SMMU_S_EVENTQ_IRQ_CFG2 | Secure Event queue IRQ<br>Configuration registers                   | Contains the MSI address configuration for the Secure Event queue IRQ.                                                 |  |
| SMMU_IDR0 - SMMU_IDR3<br>SMMU_IDR5                 | SMMU feature Identification<br>Registers                            | Provides information about the features that the SMMU implementation supports.                                         |  |
| SMMU_IIDR                                          | Implementation Identification<br>Register                           | Provides implementer, part, and revision information for the SMMU implementation.                                      |  |
| SMMU_AIDR                                          | Architecture Identification Register                                | Identifies the SMMU architecture version to which the implementation conforms.                                         |  |
| SMMU_CR0                                           | Non-secure global Control Register 0                                | Provides the controls for the global configuration of the Non-secure SMMU.                                             |  |
| SMMU_CR0ACK                                        | Non-secure global Control Register<br>0 update Acknowledge register | Provides acknowledgement of completion of updates to SMMU_CR0.                                                         |  |
| SMMU_CR1                                           | Non-secure global Control Register 1                                | Provides the controls for Non-secure table and queue access attributes.                                                |  |
| SMMU_CR2                                           | Non-secure global Control Register 2                                | Provides the controls for the configuration of the global Non-secure features.                                         |  |
| SMMU_GBPA                                          | Non-secure Global Bypass Attribute register                         | Controls the global bypass attributes that are used for transactions from Non-secure streams when the MMU is disabled. |  |
| SMMU_IRQ_CTRL                                      | Non-secure Interrupt Control register                               | Provides IRQ enable flags for edge-triggered wired outputs, if implemented, and MSI writes, if implemented.            |  |
| SMMU_IRQ_CTRLACK                                   | Non-secure Interrupt Control register update Acknowledge register   | Provides acknowledgement of the completion of updates to SMMU_IRQ_CTRL.                                                |  |
| SMMU_GERROR                                        | Non-secure Global Error status register                             | Provides information about Non-secure global programming interface errors.                                             |  |
| SMMU_GERRORN                                       | Non-secure Global Error acknowledgement register                    | Contains the acknowledgement fields for SMMU_GERROR errors.                                                            |  |
| SMMU_GERROR_IRQ_CFG0                               | Non-secure Global Error IRQ<br>Configuration register 0             | Contains the MSI address configuration for the GERROR IRQ.                                                             |  |
| SMMU_GERROR_IRQ_CFG1                               | Non-secure Global Error IRQ<br>Configuration register 1             | Contains the MSI payload configuration for the GERROR IRQ.                                                             |  |
| SMMU_GERROR_IRQ_CFG2                               | Non-secure Global Error IRQ<br>Configuration register 2             | Contains the MSI attribute configuration for the GERROR IRQ.                                                           |  |

Table 3-1 SMMUv3 architectural registers (continued)

| Register             | Name                                                   | Description                                                                |  |
|----------------------|--------------------------------------------------------|----------------------------------------------------------------------------|--|
| SMMU_STRTAB_BASE     | Non-secure Stream Table Base address register          | Contains the base address and attributes for the Non-secure Stream table.  |  |
| SMMU_STRTAB_BASE_CFG | Non-secure Stream Table<br>Configuration register      | Contains configuration fields for the Non-secure Stream table.             |  |
| SMMU_CMDQ_BASE       | Non-secure Command queue Base address register         | Contains the base address and attributes for the Non-secure Command queue. |  |
| SMMU_CMDQ_PROD       | Non-secure Command queue<br>Producer index register    | Contains the Non-secure Command queue index for writes by the producer.    |  |
| SMMU_CMDQ_CONS       | Non-secure Command queue<br>Consumer index register    | Contains the Non-secure Command queue index for reads by the consumer.     |  |
| SMMU_EVENTQ_BASE     | Non-secure Event queue Base address register           | Contains the base address and attributes for the Non-secure Event queue.   |  |
| SMMU_EVENTQ_PROD     | Non-secure Event queue Producer index register         | Contains the Non-secure Event queue index for writes by the producer.      |  |
| SMMU_EVENTQ_CONS     | Non-secure Event queue Consumer index register         | Contains the Non-secure Event queue index for reads by the consumer.       |  |
| SMMU_EVENTQ_IRQ_CFG0 | Non-secure Event queue IRQ<br>Configuration register 0 | Contains the MSI address configuration for the Event queue IRQ.            |  |
| SMMU_EVENTQ_IRQ_CFG1 | Non-secure Event queue IRQ<br>Configuration register 1 | Contains the MSI payload configuration for the Event queue IRQ.            |  |
| SMMU_EVENTQ_IRQ_CFG2 | Non-secure Event queue IRQ<br>Configuration register 2 | Contains the MSI attribute configuration for the Event queue IRQ.          |  |

The MMU-600 implements an SMMUv3 *Performance Monitor Counter Group* (PMCG) in the TCU and in each TBU. The following table lists the registers that the MMU-600 implements in each PMCG.

Table 3-2 SMMUv3 PMCG registers

| Register                                   | Name                                                 | Description                                                                |
|--------------------------------------------|------------------------------------------------------|----------------------------------------------------------------------------|
| SMMU_PMCG_EVCNTR0 -<br>SMMU_PMCG_EVCNTR3   | SMMU PMCG Event Counter registers                    | Contains the values of the event counters.                                 |
| SMMU_PMCG_EVTYPER0 -<br>SMMU_PMCG_EVTYPER3 | SMMU PMCG Event Type configuration registers         | Configures the events that the corresponding counter counts.               |
| SMMU_PMCG_SVR0 -<br>SMMU_PMCG_SVR3         | SMMU PMCG Shadow Value<br>Registers                  | Contains the shadow value of the corresponding event counter.              |
| SMMU_PMCG_SMR0                             | SMMU PMCG Stream Match filter Register               | Configures the stream match filter for the corresponding event counter.    |
| SMMU_PMCG_CNTENSET0                        | SMMU PMCG Counter Enable<br>Set register             | Provides the set mechanism for the counter enables.                        |
| SMMU_PMCG_CNTENCLR0                        | SMMU PMCG Counter Enable<br>Clear register           | Provides the clear mechanism for the counter enables.                      |
| SMMU_PMCG_INTENSET0                        | SMMU PMCG Interrupt contribution Enable Set register | Provides the set mechanism for the counter interrupt contribution enables. |

# Table 3-2 SMMUv3 PMCG registers (continued)

| Register                             | Name                                                         | Description                                                                                                           |  |
|--------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|--|
| SMMU_PMCG_INTENCLR0                  | SMMU PMCG Interrupt<br>contribution Enable Clear<br>register | Provides the clear mechanism for the counter interrupt enables.                                                       |  |
| SMMU_PMCG_OVSCLR0                    | SMMU PMCG Overflow Status<br>Clear register                  | Provides the clear mechanism for the overflow status bits and provides read access to the overflow status bit values. |  |
| SMMU_PMCG_OVSSET0                    | SMMU PMCG Overflow Status<br>Set register                    | Provides the set mechanism for the overflow status bits and provides read access to the overflow status bit values.   |  |
| SMMU_PMCG_CAPR                       | SMMU PMCG Counter shadow value Capture Register              | Controls the counter shadow value capture mechanism.                                                                  |  |
| SMMU_PMCG_SCR                        | SMMU PMCG Secure Control<br>Register                         | Secure Control Register.                                                                                              |  |
| SMMU_PMCG_CFGR                       | SMMU PMCG Configuration information Register                 | Provides information about the PMCG implementation.                                                                   |  |
| SMMU_PMCG_CR                         | SMMU PMCG Control Register                                   | Contains the Performance Monitor control flags.                                                                       |  |
| SMMU_PMCG_CEID0 -<br>SMMU_PMCG_CEID1 | SMMU PMCG Common Event ID registers                          | Contains the lower and upper 64 bits of the Common Event identification bitmap.                                       |  |
| SMMU_PMCG_IRQ_CTRL                   | SMMU PMCG IRQ enable register                                | Contains the Performance Monitors IRQ enable.                                                                         |  |
| SMMU_PMCG_IRQ_CTRLACK                | SMMU PMCG IRQ enable<br>Acknowledge register                 | Provides acknowledgement of the completion of updates to SMMU_PMCG_IRQ_CTRL.                                          |  |
| SMMU_PMCG_AIDR                       | SMMU PMCG Architecture<br>Identification Register            | Provides the Performance Monitor Architecture Identification.                                                         |  |
| SMMU_PMCG_ID_REGS                    | ID registers                                                 | IMPLEMENTATION DEFINED.                                                                                               |  |

# 3.3 MMU-600 memory map

The MMU-600 memory map contains all registers.

The following table shows the MMU-600 memory map with the maximum number of implemented TBUs.

Table 3-3 MMU-600 memory map

| Address range       | Description      |
|---------------------|------------------|
| 0x000000 - 0x03FFFC | TCU registers.   |
| 0x040000 - 0x05FFFC | TBU0 registers.  |
| 0x060000 - 0x07FFFC | TBU1 registers   |
| 0x080000 - 0x09FFFC | TBU2 registers.  |
|                     |                  |
|                     |                  |
|                     |                  |
| 0x7C0000 - 0x7DFFFC | TBU60 registers. |
| 0x7E0000 - 0x7FFFFC | TBU61 registers. |

\_\_\_\_\_ Note \_\_\_\_\_

All TBU and TCU register addresses in this manual are described relative to the beginning of the respective address range for the component.

The following table shows the MMU-600 TCU memory map.

Table 3-4 MMU-600 TCU memory map

| Address           | Description                                                                                                                                                                                                                                  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00000 - 0x0FFFC | <ul> <li>TCU registers, page 0, including:</li> <li>SMMUv3 registers, page 0.</li> <li>TCU Performance Monitor Counter Group (PMCG) registers, page 0, starting at offset 0x02000.</li> <li>TCU IMPLEMENTATION DEFINED registers.</li> </ul> |
| 0x10000 - 0x1FFFC | TCU registers, page 1.  This address range contains the SMMUv3 registers, page 1.                                                                                                                                                            |
| 0x20000 - 0x2FFFC | TCU registers, page 2.  This address range contains the TCU PMCG registers, page 1, starting at offset 0x22000.                                                                                                                              |
| 0x30000 - 0x3FFFC | Reserved.                                                                                                                                                                                                                                    |

The following table shows the MMU-600 TBU memory map.

# Table 3-5 MMU-600 TBU memory map

| Address           | Description                                                                                                                       |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 0x00000 - 0x0FFFC | TBU registers, page 0, including:  TBU PMCG registers, page 0, starting at offset 0x02000.  TBU IMPLEMENTATION DEFINED registers. |
| 0x10000 - 0x1FFFC | TBU registers, page 1.  This address range contains the TBU PMCG registers, page 1, starting at offset 0x12000.                   |

# 3.4 Register summary

The register summary lists all MMU-600 registers and some key characteristics.

# TBU identification register summary

The following table shows the TBU identification registers in offset order from the base memory address.

Table 3-6 TBU identification register summary

| Offset  | Name       | Туре | Description                                                 |
|---------|------------|------|-------------------------------------------------------------|
| 0x00FD0 | SMMU_PIDR4 | RO   | 3.9 TBU Component and Peripheral ID Registers on page 3-81. |
| 0x00FD4 | SMMU_PIDR5 | RO   |                                                             |
| 0x00FD8 | SMMU_PIDR6 | RO   |                                                             |
| 0x00FDC | SMMU_PIDR7 | RO   |                                                             |
| 0x00FE0 | SMMU_PIDR0 | RO   |                                                             |
| 0x00FE4 | SMMU_PIDR1 | RO   |                                                             |
| 0x00FE8 | SMMU_PIDR2 | RO   |                                                             |
| 0x00FEC | SMMU_PIDR3 | RO   |                                                             |
| 0x00FF0 | SMMU_CIDR0 | RO   |                                                             |
| 0x00FF4 | SMMU_CIDR1 | RO   |                                                             |
| 0x00FF8 | SMMU_CIDR2 | RO   |                                                             |
| 0x00FFC | SMMU_CIDR3 | RO   |                                                             |

## **TBU RAS register summary**

The following table shows the TBU *Reliability, Availability, and Serviceability* (RAS) registers in offset order from the base memory address.

Table 3-7 TBU RAS register summary

| Offset  | Name          | Туре | Description                             |
|---------|---------------|------|-----------------------------------------|
| 0x08E80 | TBU_ERRFR     | RO   | 3.12.1 TBU_ERRFR on page 3-85.          |
| 0x08E88 | TBU_ERRCTLR   | RW   | <i>3.12.2 TBU_ERRCTLR</i> on page 3-85. |
| 0x08E90 | TBU_ERRSTATUS | RW   | 3.12.3 TBU_ERRSTATUS on page 3-86.      |
| 0x08EC0 | TBU_ERRGEN    | RW   | <i>3.12.4 TBU_ERRGEN</i> on page 3-87.  |

# TBU microarchitectural register summary

The following table shows the TBU microarchitectural registers in offset order from the base memory address.

Table 3-8 TBU microarchitectural register summary

| Offset  | Name     | Туре | Description                   |
|---------|----------|------|-------------------------------|
| 0x08E00 | TBU_CTRL | RW   | 3.11.1 TBU_CTRL on page 3-83. |
| 0x08E18 | TBU_SCR  | RW   | 3.11.2 TBU_SCR on page 3-83.  |

# TCU identification register summary

The following table shows the TCU identification registers in offset order from the base memory address.

Table 3-9 TCU identification register summary

| Offset  | Name       | Туре | Description                                                 |
|---------|------------|------|-------------------------------------------------------------|
| 0x00FD0 | SMMU_PIDR4 | RO   | 3.5 TCU Component and Peripheral ID Registers on page 3-66. |
| 0x00FD4 | SMMU_PIDR5 | RO   |                                                             |
| 0x00FD8 | SMMU_PIDR6 | RO   |                                                             |
| 0x00FDC | SMMU_PIDR7 | RO   |                                                             |
| 0x00FE0 | SMMU_PIDR0 | RO   |                                                             |
| 0x00FE4 | SMMU_PIDR1 | RO   |                                                             |
| 0x00FE8 | SMMU_PIDR2 | RO   |                                                             |
| 0x00FEC | SMMU_PIDR3 | RO   |                                                             |
| 0x00FF0 | SMMU_CIDR0 | RO   |                                                             |
| 0x00FF4 | SMMU_CIDR1 | RO   |                                                             |
| 0x00FF8 | SMMU_CIDR2 | RO   |                                                             |
| 0x00FFC | SMMU_CIDR3 | RO   |                                                             |

# TCU and TBU PMU identification register summary

The TCU and the TBU use the same PMU identification registers. The following table shows the TCU and TBU PMU identification registers in offset order from the base memory address.

Table 3-10 TCU and TBU PMU identification register summary

| Offset  | Name                   | Туре | Description                                                      |
|---------|------------------------|------|------------------------------------------------------------------|
| 0x02FB8 | SMMU_PMCG_PMAUTHSTATUS | RO   | 3.6 TCU PMU Component and Peripheral ID Registers on page 3-67.  |
| 0x02FD0 | SMMU_PMCG_PIDR4        | RO   | 3.10 TBU PMU Component and Peripheral ID Registers on page 3-82. |
| 0x02FD4 | SMMU_PMCG_PIDR5        | RO   |                                                                  |
| 0x02FD8 | SMMU_PMCG_PIDR6        | RO   |                                                                  |
| 0x02FDC | SMMU_PMCG_PIDR7        | RO   |                                                                  |
| 0x02FE0 | SMMU_PMCG_PIDR0        | RO   |                                                                  |
| 0x02FE4 | SMMU_PMCG_PIDR1        | RO   |                                                                  |
| 0x02FE8 | SMMU_PMCG_PIDR2        | RO   |                                                                  |
| 0x02FEC | SMMU_PMCG_PIDR3        | RO   |                                                                  |
| 0x02FF0 | SMMU_PMCG_CIDR0        | RO   |                                                                  |
| 0x02FF4 | SMMU_PMCG_CIDR1        | RO   |                                                                  |
| 0x02FF8 | SMMU_PMCG_CIDR2        | RO   |                                                                  |
| 0x02FFC | SMMU_PMCG_CIDR3        | RO   |                                                                  |

# **TCU RAS register summary**

The following table shows the TCU RAS registers in offset order from the base memory address.

Table 3-11 TCU RAS register summary

| Offset  | Name          | Туре | Description                       |
|---------|---------------|------|-----------------------------------|
| 0x08E80 | TCU_ERRFR     | RO   | 3.8.1 TCU_ERRFR on page 3-76.     |
| 0x08E88 | TCU_ERRCTLR   | RW   | 3.8.2 TCU_ERRCTLR on page 3-76.   |
| 0x08E90 | TCU_ERRSTATUS | RW   | 3.8.3 TCU_ERRSTATUS on page 3-77. |
| 0x08EC0 | TCU_ERRGEN    | RW   | 3.8.4 TCU_ERRGEN on page 3-79.    |

# TCU microarchitectural register summary

The following table shows the TCU microarchitectural registers in offset order from the base memory address.

Table 3-12 TCU microarchitectural register summary

| Offset            | Name             | Туре | Description                           |
|-------------------|------------------|------|---------------------------------------|
| 0x08E00           | TCU_CTRL         | RW   | 3.7.1 TCU_CTRL on page 3-68.          |
| 0x08E04           | TCU_QOS          | RW   | 3.7.2 TCU_QOS on page 3-69.           |
| 0x08E08           | TCU_CFG          | RO   | <i>3.7.3 TCU_CFG</i> on page 3-70.    |
| 0x08E10           | TCU_STATUS       | RO   | <i>3.7.4 TCU_STATUS</i> on page 3-71. |
| 0x08E18           | TCU_SCR          | RW   | <i>3.7.5 TCU_SCR</i> on page 3-72.    |
| 0x09000 - 0x093FC | TCU_NODE_CTRLn   | RW   | 3.7.6 TCU_NODE_CTRLn on page 3-73.    |
| 0x09400 - 0x097FC | TCU_NODE_STATUSn | RO   | 3.7.7 TCU_NODE_STATUSn on page 3-74.  |

# 3.5 TCU Component and Peripheral ID Registers

The component and peripheral identity registers comply with the format that the Arm CoreLink and CoreSight components use, and recommended in the SMMUv3 architecture. They provide key information about the MMU-600 hardware, including the product and associated revision number. They also identify Arm as the designer of the SMMU.

These registers are all read-only. Each field defines a single byte in the least significant 8 bits, and the most significant 24 bits are reserved. The least significant 8 bits of the four Component ID registers form a single 32-bit conceptual ID register. In a similar way, the defined fields of the eight Peripheral ID registers form a conceptual 64-bit ID register.

Table 3-13 TCU Component and Peripheral ID registers bit assignments

| Register   | Offset  | Bits  | Value              | Function                                                                                                     |
|------------|---------|-------|--------------------|--------------------------------------------------------------------------------------------------------------|
| SMMU_PIDR4 | 0x00FD0 | [7:4] | 0×0                | 4KB region count.                                                                                            |
|            |         | [3:0] | 0x4                | JEP106 continuation code for Arm.                                                                            |
| SMMU_PIDR5 | 0x00FD4 | [7:0] | 0x00               | Reserved.                                                                                                    |
| SMMU_PIDR6 | 0x00FD8 | [7:0] | 0x00               | Reserved.                                                                                                    |
| SMMU_PIDR7 | 0x00FDC | [7:0] | 0x00               | Reserved.                                                                                                    |
| SMMU_PIDR0 | 0x00FE0 | [7:0] | 0x83               | Part number[7:0].                                                                                            |
| SMMU_PIDR1 | 0x00FE4 | [7:4] | ØxВ                | JEP106 ID code[3:0] for Arm.                                                                                 |
|            |         | [3:0] | 0x4                | Part number[11:8].                                                                                           |
| SMMU_PIDR2 | 0x00FE8 | [7:4] | 0x0                | MMU-600 major revision.                                                                                      |
|            |         |       |                    | The value 0x0 indicates major product revision r0.                                                           |
|            |         | [3]   | 0x1                | The component uses a manufacturer identity code that JEDEC allocates, according to the JEP106 specification. |
|            |         | [2:0] | 0x3                | JEP106 ID code[6:4] for Arm.                                                                                 |
| SMMU_PIDR3 | 0x00FEC | [7:4] | MAX[0x1,ecorevnum] | MMU-600 minor revision.                                                                                      |
|            |         |       |                    | The value 0x1 indicates minor product revision p1.                                                           |
|            |         | [3:0] | 0×0                | CMOD. This field is not used.                                                                                |
| SMMU_CIDR0 | 0x00FF0 | [7:0] | 0×0D               | Preamble.                                                                                                    |
| SMMU_CIDR1 | 0x00FF4 | [7:0] | 0×F0               |                                                                                                              |
| SMMU_CIDR2 | 0x00FF8 | [7:0] | 0x05               |                                                                                                              |
| SMMU_CIDR3 | 0x00FFC | [7:0] | 0xB1               |                                                                                                              |

# 3.6 TCU PMU Component and Peripheral ID Registers

The component and peripheral identity registers comply with the format that Arm CoreLink and CoreSight components use, and recommended in the SMMUv3 architecture. They provide key information about the MMU-600 hardware, including the product and associated revision number. They also identify Arm as the designer of the SMMU.

These registers are all read-only. Each field defines a single byte in the least significant 8 bits, and the most significant 24 bits are reserved. The least significant 8 bits of the four Component ID registers form a single 32-bit conceptual ID register. In a similar way, the defined fields of the eight Peripheral ID registers form a conceptual 64-bit ID register.

Table 3-14 TCU PMU Component and Peripheral ID registers bit assignments

| Register               | Offset  | Bits  | Value              | Function                                                                                                     |
|------------------------|---------|-------|--------------------|--------------------------------------------------------------------------------------------------------------|
| SMMU_PMCG_PMAUTHSTATUS | 0x02FB8 | [7:0] | 0×00               | No authentication interface is implemented.                                                                  |
| SMMU_PMCG_PIDR4        | 0x02FD0 | [7:4] | 0x0                | 4KB region count.                                                                                            |
|                        |         | [3:0] | 0x4                | JEP106 continuation code for Arm.                                                                            |
| SMMU_PMCG_PIDR5        | 0x02FD4 | [7:0] | 0x00               | Reserved.                                                                                                    |
| SMMU_PMCG_PIDR6        | 0x02FD8 | [7:0] | 0x00               | Reserved.                                                                                                    |
| SMMU_PMCG_PIDR7        | 0x02FDC | [7:0] | 0x00               | Reserved.                                                                                                    |
| SMMU_PMCG_PIDR0        | 0x02FE0 | [7:0] | 0x83               | Part number[7:0].                                                                                            |
| SMMU_PMCG_PIDR1        | 0x02FE4 | [7:4] | 0xB                | JEP106 ID code[3:0] for Arm.                                                                                 |
|                        |         | [3:0] | 0x4                | Part number[11:8].                                                                                           |
| SMMU_PMCG_PIDR2        | 0x02FE8 | [7:4] | 0×0                | MMU-600 revision.                                                                                            |
|                        |         |       |                    | The value 0x0 indicates major product revision r0.                                                           |
|                        |         | [3]   | 0x1                | The component uses a manufacturer identity code that JEDEC allocates, according to the JEP106 specification. |
|                        |         | [2:0] | 0x3                | JEP106 ID code[6:4] for Arm.                                                                                 |
| SMMU_PMCG_PIDR3        | 0x02FEC | [7:4] | MAX[0x1,ecorevnum] | MMU-600 minor revision.                                                                                      |
|                        |         |       |                    | The value 0x1 indicates minor product revision p1.                                                           |
|                        |         | [3:0] | 0×0                | CMOD. This field is not used.                                                                                |
| SMMU_PMCG_CIDR0        | 0x02FF0 | [7:0] | 0×0D               | Preamble.                                                                                                    |
| SMMU_PMCG_CIDR1        | 0x02FF4 | [7:0] | 0×90               |                                                                                                              |
| SMMU_PMCG_CIDR2        | 0x02FF8 | [7:0] | 0x05               |                                                                                                              |
| SMMU_PMCG_CIDR3        | 0x02FFC | [7:0] | 0xB1               |                                                                                                              |

# 3.7 TCU microarchitectural registers

You can set the TCU microarchitectural registers at boot time to optimize TCU behavior for your system. Arm recommends the default settings for most systems.

This section contains the following subsections:

- 3.7.1 TCU CTRL on page 3-68.
- 3.7.2 TCU QOS on page 3-69.
- 3.7.3 TCU CFG on page 3-70.
- *3.7.4 TCU\_STATUS* on page 3-71.
- 3.7.5 TCU\_SCR on page 3-72.
- 3.7.6 TCU NODE CTRLn on page 3-73.
- 3.7.7 TCU NODE STATUSn on page 3-74.

# 3.7.1 TCU\_CTRL

The TCU Control register disables TCU features. You can disable individual walk caches to improve performance in some systems if the hit rate of the individual walk cache is very low. Do not modify the AUX bits unless directed to do so by Arm.

The TCU CTRL characteristics are:

## **Usage constraints**

When TCU\_SCR.NS\_UARCH = 0, Non-secure accesses to this register are RAZ/WI.

Writes to this register are possible only when both SMMU\_CR0.SMMUEN = 0 and SMMU\_S\_CR0.SMMUEN = 0. Writes at other times are ignored.

After modifying this register, software must issue an INV\_ALL operation using the SMMU\_S\_INIT register, before it sets SMMUEN to 1. Failure to issue an INV\_ALL operation results in UNPREDICTABLE behavior.

## **Configurations**

This register exists in all TCU configurations.

## **Attributes**

 Offset
 0x08E00

 Type
 RW

 Reset
 0x00000000

 Width
 32

The following figure shows the bit assignments.



Figure 3-1 TCU\_CTRL register bit assignments

The following table shows the bit assignments.

# Table 3-15 TCU\_CTRL register bit assignments

| Bits    | Name       | Function                                                                                                       |
|---------|------------|----------------------------------------------------------------------------------------------------------------|
| [31:16] | AUX[31:16] | Leave each of these bits as 0.                                                                                 |
| [15]    | WCS2L3_DIS | Walk cache disable.  0    Stage 2 level 3 walk cache is enabled.  1    Stage 2 level 3 walk cache is disabled. |
| [14]    | WCS2L2_DIS | Walk cache disable.  0 Stage 2 level 2 walk cache is enabled.  1 Stage 2 level 2 walk cache is disabled.       |
| [13]    | WCS2L1_DIS | Walk cache disable.  0 Stage 2 level 1 walk cache is enabled.  1 Stage 2 level 1 walk cache is disabled.       |
| [12]    | WCS2L0_DIS | Walk cache disable.  0 Stage 2 level 0 walk cache is enabled.  1 Stage 2 level 0 walk cache is disabled.       |
| [11]    | WCS1L3_DIS | Walk cache disable.  O Stage 1 level 3 walk cache is enabled.  Stage 1 level 3 walk cache is disabled.         |
| [10]    | WCS1L2_DIS | Walk cache disable.  0    Stage 1 level 2 walk cache is enabled.  1    Stage 1 level 2 walk cache is disabled. |
| [9]     | WCS1L1_DIS | Walk cache disable.  0 Stage 1 level 1 walk cache is enabled.  1 Stage 1 level 1 walk cache is disabled.       |
| [8]     | WCS1L0_DIS | Walk cache disable.  0 Stage 1 level 0 walk cache is enabled.  1 Stage 1 level 0 walk cache is disabled.       |
| [7:0]   | AUX[7:0]   | Leave each of these bits as 0.                                                                                 |

# 3.7.2 TCU\_QOS

This is the TCU *Quality of Service* (QoS) register. Use this register to specify **AxQOS** values for each transaction type that is issued on the QTW/DVM interface. The MMU-600 does not use this value internally, but a downstream interconnect can use the value to control how it prioritizes transactions.

The **AxQOS** value that is associated with each transaction does not take account of other transactions that are blocked behind it. For example, although higher priority translations are normally progressed before lower priority translations, a low priority translation table walk might prevent the TCU from issuing a translation table walk with a higher priority.

The TCU\_QOS characteristics are:

## **Usage constraints**

When TCU\_SCR.NS\_UARCH = 0, Non-secure accesses to this register are RAZ/WI.

Writes to this register are possible only when both SMMU\_CR0.SMMUEN = 0 and SMMU\_S CR0.SMMUEN = 0. Writes at other times are ignored.

After modifying this register, software must issue an INV\_ALL operation using the SMMU\_S\_INIT register, before it sets SMMUEN to 1. Failure to issue an INV\_ALL operation results in UNPREDICTABLE behavior.

## **Configurations**

Width

This register exists in all TCU configurations.

## **Attributes**

 Offset
 0x08E04

 Type
 RW

 Reset
 0x000000000

32

The following figure shows the bit assignments.



Figure 3-2 TCU\_QOS register bit assignments

The following table shows the bit assignments.

Table 3-16 TCU\_QOS register bit assignments

| Bits    | Name        | Function                                                                                                                                    |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | -           | Reserved.                                                                                                                                   |
| [27:24] | QOS_DVMSYNC | The <b>AxQOS</b> value that is used for DVM Sync Completion messages.                                                                       |
| [23:20] | QOS_MSI     | The <b>AxQOS</b> value that is used for MSIs.                                                                                               |
| [19:16] | QOS_QUEUE   | The <b>AxQOS</b> value that is used for queue accesses.                                                                                     |
| [15:12] | QOS_PTW3    | The <b>AxQOS</b> value that is used for translation table walks for translations where TCU_NODE_CTRLn.PRIORITY = 3 for the requesting node. |
| [11:8]  | QOS_PTW2    | The <b>AxQOS</b> value that is used for translation table walks for translations where TCU_NODE_CTRLn.PRIORITY = 2 for the requesting node. |
| [7:4]   | QOS_PTW1    | The <b>AxQOS</b> value that is used for translation table walks for translations where TCU_NODE_CTRLn.PRIORITY = 1 for the requesting node. |
| [3:0]   | QOS_PTW0    | The <b>AxQOS</b> value that is used for translation table walks for translations where TCU_NODE_CTRLn.PRIORITY = 0 for the requesting node. |

# 3.7.3 TCU\_CFG

This is the TCU Configuration Information register.

Its characteristics are:

## Usage constraints

When TCU SCR.NS UARCH = 0, Non-secure accesses to this register are RAZ.

## Configurations

This register exists in all TCU configurations.

## **Attributes**

Offset 0x08E08
Type RO

**Reset** See register bit assignments.

Width 32

The following figure shows the bit assignments.



Figure 3-3 TCU CFG register bit assignments

The following table shows the bit assignments.

Table 3-17 TCU\_CFG register bit assignments

| Bits    | Name        | Function                                                                                                                                |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | -           | Reserved.                                                                                                                               |
| [15:4]  | XLATE_SLOTS | The number of translation slots that are available for sharing between all nodes.  The reset value of this field is TCUCFG_XLATE_SLOTS. |
| [3:0]   | -           | Reserved.                                                                                                                               |

# 3.7.4 TCU\_STATUS

This is the TCU Status Information register.

Its characteristics are:

## **Usage constraints**

When TCU\_SCR.NS\_UARCH = 0, Non-secure accesses to this register are RAZ.

# Configurations

This register exists in all TCU configurations.

## Attributes

 Offset
 0x08E10

 Type
 RO

 Reset
 0x00000000

 Width
 32

The following figure shows the bit assignments.



Figure 3-4 TCU\_STATUS register bit assignments

The following table shows the bit assignments.

Table 3-18 TCU\_STATUS register bit assignments

| Bits    | Name | Function                                                                                                                                |
|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | -    | Reserved.                                                                                                                               |
| [15:4]  |      | This is the number of translation slots that are currently allocated to connected nodes. You can use this value for debugging purposes. |
| [3:0]   | -    | Reserved.                                                                                                                               |

# 3.7.5 TCU\_SCR

This is the TCU Secure Control register. Use this register to control whether Non-secure software is permitted to access each TCU register group.

The TCU\_SCR characteristics are:

## **Usage constraints**

Non-secure accesses to this register are RAZ/WI.

This register does not control Secure access to the MMU-600 PMU registers. To control Secure PMU register access, use the SMMU\_PMCG\_SCR register.

## **Configurations**

This register exists in all TCU configurations.

## **Attributes**

Offset 0x08E18
Type RW

**Reset** See register bit assignments.

Width 32

The following figure shows the bit assignments.



Figure 3-5 TCU\_SCR register bit assignments

The following table shows the bit assignments.

Table 3-19 TCU\_UARCH\_TCU\_SCR register bit assignments

| Bits   | Name    | Function                                                                                                                          |
|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | -       | Reserved                                                                                                                          |
| [3]    | NS_INIT | Non-secure register access to SMMU_S_INIT. When this bit is set to 0, Non-secure accesses to the SMMU_S_INIT register are RAZ/WI. |
| [2]    | -       | Reserved                                                                                                                          |

#### Table 3-19 TCU\_UARCH\_TCU\_SCR register bit assignments (continued)

| Bits | Name     | Function                                                                                                                                                                                                                                                                                                                                                   |
|------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1]  | NS_RAS   | Non-secure register access is permitted for RAS registers. When this bit is set to 0, Non-secure accesses to register addresses 0x08E80–0x08EC0 are RAZ/WI.  The sec_override input signal defines the reset value of this bit.                                                                                                                            |
| [0]  | NS_UARCH | Non-secure register access is permitted for MMU-600 registers. When this bit is set to 0, Non-secure accesses to register addresses 0x08E00-0x08E7C and 0x09000-0x093FC are RAZ/WI.  The <b>sec_override</b> input signal defines the reset value of this bit.  If your implementation might use Secure translation, Arm recommends setting this bit to 0. |

#### 3.7.6 TCU\_NODE\_CTRLn

Each TCU Node Control register controls how the TCU communicates with a single node. A node is a DTI master that is typically either a TBU or a PCIe Root Complex that implements ATS.

The TCU NODE CTRLn characteristics are:

#### **Usage constraints**

The DIS DMV bit can be used for TBU nodes, but is ignored for ATS nodes.

When TCU SCR.NS UARCH = 0, Non-secure accesses to this register are RAZ/WI.

Writes to this register are possible only when both SMMU\_CR0.SMMUEN = 0 and SMMU\_S CR0.SMMUEN = 0. Writes at other times are ignored.

After modifying this register, software must issue an INV\_ALL operation using the SMMU\_S\_INIT register, before it sets SMMUEN to 1. Failure to issue an INV\_ALL operation results in UNPREDICTABLE behavior.

#### **Configurations**

The value of the TCUCFG\_NUM\_TBUs configuration parameter defines n, that is, the number of TCU\_NODE\_CTRL registers that are implemented. Each register has an address width of 4 bytes, therefore the offset of a register n is:

 $0 \times 09000 + (4 \times n)$ 

#### **Attributes**

Offset 0x09000-0x093FC

Type RW

Reset 0x00000000

Width 32

The following figure shows the bit assignments.



Figure 3-6 TCU\_NODE\_CTRL register bit assignments

The following table shows the bit assignments.

#### Table 3-20 TCU\_NODE\_CTRL register bit assignments

| Bits   | Name      | Function                                                                                                                                                                                                                                                                                                                              |  |  |  |
|--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:5] | -         | Reserved.                                                                                                                                                                                                                                                                                                                             |  |  |  |
| [4]    | DIS_DVM   | Disable DVM. When this bit is set to 1, the corresponding node does not participate in DVM invalidation. Set this bit to 1 to improve performance if the node is slow to respond to invalidations issued over DTI.  Note ————  This bit is ignored for connected DTI-ATS masters, because they never participate in DVM invalidation. |  |  |  |
| [3:2]  | -         | Reserved.                                                                                                                                                                                                                                                                                                                             |  |  |  |
| [1:0]  | PRI_LEVEL | Priority level. This field indicates the priority level of the corresponding node. Translation requests from a node with a higher priority level are normally progressed before requests from a node with a lower priority level.                                                                                                     |  |  |  |

#### 3.7.7 TCU\_NODE\_STATUSn

Each TCU Node Status register provides the status of a DTI master. A node is a DTI master that is typically either a TBU or a PCIe Root Complex that implements ATS.

The TCU NODE STATUS*n* characteristics are:

#### **Usage constraints**

This register indicates the status of the corresponding node only when the node is connected.

When TCU\_SCR.NS\_UARCH = 0, Non-secure accesses to this register are RAZ.

#### Configurations

The value of the TCUCFG\_NUM\_TBUs configuration parameter defines the number of TCU\_NODE\_CTRL registers that are implemented. Each register has an address width of 4 bytes, therefore the offset of a register *n* is:

$$0 \times 09400 + (4 \times n)$$

#### **Attributes**

**Offset** 0x09400-0x097FC

Type RO

Reset 0x00000000

Width 32

The following figure shows the bit assignments.



Figure 3-7 TCU\_NODE\_STATUS register bit assignments

The following table shows the bit assignments.

## Table 3-21 TCU\_NODE\_STATUS register bit assignments

| Bits   | Name      | Function                                                                                                                                                                                                                                                                                                                                                              |
|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | -         | Reserved.                                                                                                                                                                                                                                                                                                                                                             |
| [1]    | ATS       | <ul> <li>ATS implemented.</li> <li>When this bit is set to 0, the corresponding node is a TBU that is connected to the TCU using the DTI-TBU protocol.</li> <li>When this bit is set to 1, the corresponding node is a PCIe Root Complex that supports ATS, and is connected to the TCU using the DTI-ATS protocol.</li> </ul>                                        |
| [0]    | CONNECTED | DTI link is connected.  When this bit is set to 0, the DTI link for the corresponding node is not connected.  When this bit is set to 1, the DTI link for the corresponding node is connected.  If a DTI link is not connected, accesses to TBU registers are RAZ/WI. However, the state might change between reading this register and attempting to access the TBU. |

#### 3.8 TCU RAS registers

The MMU-600 includes TCU registers that are related to *Reliability, Availability, and Serviceability* (RAS).

This section contains the following subsections:

- 3.8.1 TCU ERRFR on page 3-76.
- 3.8.2 TCU ERRCTLR on page 3-76.
- 3.8.3 TCU ERRSTATUS on page 3-77.
- 3.8.4 TCU ERRGEN on page 3-79.

#### 3.8.1 TCU\_ERRFR

This is the TCU Error Feature register. Use this register to discover how the TCU handles errors.

The TCU ERRFR characteristics are:

#### **Usage constraints**

This register is read-only. When TCU\_SCR.NS\_RAS = 0, Non-secure accesses to this register are RAZ.

#### Configurations

This register exists in all TCU configurations.

#### **Attributes**

 Offset
 0x08E80

 Type
 RO

 Reset
 0x00000082

 Width
 32

The following figure shows the bit assignments.



Figure 3-8 TCU ERRFR register bit assignments

The following table shows the bit assignments.

Table 3-22 TCU\_ERRFR register bit assignments

| Bits   | Name | Function                                                                    |
|--------|------|-----------------------------------------------------------------------------|
| [31:8] | -    | Reserved                                                                    |
| [7:6]  | FI   | The value 0b10 indicates that the fault handling interrupt is controllable. |
| [5:2]  | -    | Reserved                                                                    |
| [1:0]  | ED   | The value 0b01 indicates that TCU error detection is always enabled.        |

#### 3.8.2 TCU\_ERRCTLR

This is the TCU Error Control register. Use this register to enable fault handling interrupts.

The TCU ERRCTLR characteristics are:

#### **Usage constraints**

When TCU SCR.NS RAS = 0, Non-secure accesses to this register are RAZ/WI.

#### Configurations

This register exists in all MMU-600 configurations.

#### Attributes

Offset 0x08E88 RW **Type** Reset 0x00000000

Width 32

The following figure shows the bit assignments.



Figure 3-9 TCU\_ERRCTLR register bit assignments

The following table shows the bit assignments.

Table 3-23 TCU\_ERRCTLR register bit assignments

| Bits   | Name | Function                                                     |  |  |  |  |
|--------|------|--------------------------------------------------------------|--|--|--|--|
| [31:4] | -    | Reserved                                                     |  |  |  |  |
| [3]    | FI   | Enable fault handling interrupts:                            |  |  |  |  |
|        |      | 0 An interrupt is generated on ras_irpt when a fault occurs. |  |  |  |  |
|        |      | 1 No interrupt is generated when a fault occurs.             |  |  |  |  |
| [2:0]  | -    | Reserved                                                     |  |  |  |  |

#### 3.8.3 TCU\_ERRSTATUS

This is the TCU Error Record Primary Syndrome register. Use this register to find out whether different types of error have occurred on the TCU.

The TCU ERRSTATUS characteristics are:

#### **Usage constraints**

When TCU SCR.NS RAS = 0, Non-secure accesses to this register are RAZ/WI.

To prevent race conditions, under certain circumstances, writes to some bits in this register are ignored. Typically, these writes are ignored when software has not yet observed a new error.

#### **Configurations**

This register exists in all TCU configurations.

#### **Attributes**

Offset 0x08E90 RW **Type** Reset 0x00000000 Width 32

The following figure shows the bit assignments.



Figure 3-10 TCU\_ERRSTATUS register bit assignments

The following table shows the bit assignments.

Table 3-24 TCU\_ERRSTATUS register bit assignments

| Bits    | Name | Function                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31]    | -    | Reserved                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [30]    | V    | Register valid. This bit is set to 1 to indicate that at least one RAS error was recorded.                                                                                                                                                           |  |  |  |  |  |  |
|         |      | Clear this bit by writing a 1 to it. If CE is not 0b00 and is not being cleared, the write is ignored. A write of 0 is ignored.                                                                                                                      |  |  |  |  |  |  |
| [29:28] | -    | Reserved                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [27]    | OF   | Overflow. This bit is set to 1 to indicate that multiple correctable errors were recorded. That is, at least one correctable error was recorded when CE != 0b00.  Clear this bit by writing a 1 to it. A write of 0 is ignored.                      |  |  |  |  |  |  |
| [26]    | _    | Reserved                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [25:24] | СЕ   | Correctable Error. This field is set to 0b10 to indicate that a corrected error occurred. Clear this field by writing 0b11 to it. If OF is set to 1 and is not being cleared, the write is ignored. A write of any value other than 0b11 is ignored. |  |  |  |  |  |  |
| [23:16] | -    | Reserved                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [15:8]  | IERR | IMPLEMENTATION DEFINED error code. When SERR is not set to 0, this field indicates the source of the error, as follows:                                                                                                                              |  |  |  |  |  |  |
|         |      | 0x00 Stage 1, level 0 walk cache.                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |      | 0x01 Stage 1, level 1 walk cache.                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |      | 0x02 Stage 1, level 2 walk cache.                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |      | 0x03 Stage 1, level 3 walk cache.                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |      | 0x04 Stage 2, level 0 walk cache.                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |      | 0x05 Stage 2, level 1 walk cache.                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |      | 0x06 Stage 2, level 2 walk cache.                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |      | 0x07 Stage 2, level 3 walk cache.                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |      | 0x08 Configuration cache.                                                                                                                                                                                                                            |  |  |  |  |  |  |
|         |      | Writes to this field are ignored.                                                                                                                                                                                                                    |  |  |  |  |  |  |
| [7:0]   | SERR | Error code. This read-only field provides information about the earliest unacknowledged correctable error, as follows:                                                                                                                               |  |  |  |  |  |  |
|         |      | 0x00 No error. This code occurs when CE = $0b00$ .                                                                                                                                                                                                   |  |  |  |  |  |  |
|         |      | 0x07 Tag corrupted. This code can occur when CE != 0b00.                                                                                                                                                                                             |  |  |  |  |  |  |
|         |      | 0x08 Data corrupted. This code can occur when CE != 0b00.                                                                                                                                                                                            |  |  |  |  |  |  |

#### 3.8.4 TCU\_ERRGEN

This is the TCU Error Generation Register. Use this register to generate tag parity errors, for example when testing error-handling software.

The TCU\_ERRGEN characteristics are:

#### **Usage constraints**

When TCU SCR.NS RAS = 0, Non-secure accesses to this register are RAZ/WI.

#### **Configurations**

This register exists in all TCU configurations.

#### **Attributes**

 Offset
 0x08EC0

 Type
 RW

 Reset
 0x000000000

Width 64

The following figure shows the bit assignments.



Figure 3-11 TCU\_ERRGEN register bit assignments

The following table shows the bit assignments.

Table 3-25 TCU\_ERRGEN register bit assignments

| Bits   | Name | Function                                                                                                                                                              |  |  |  |  |  |  |
|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [63:4] | -    | Reserved.                                                                                                                                                             |  |  |  |  |  |  |
| [3]    | TCC  | Configuration cache tag parity error.  O No tag parity error is written to the configuration cache.                                                                   |  |  |  |  |  |  |
|        |      | 1 Entries that are written to the configuration cache include a tag parity error. A fault occurs when the entry is used.                                              |  |  |  |  |  |  |
| [2]    | DCC  | Configuration cache data parity error.                                                                                                                                |  |  |  |  |  |  |
|        |      | <b>0</b> No data parity error is written to the configuration cache.                                                                                                  |  |  |  |  |  |  |
|        |      | 1 Entries that are written to the configuration cache include a data parity error. A fault occurs when the entry is used.                                             |  |  |  |  |  |  |
|        |      | Note                                                                                                                                                                  |  |  |  |  |  |  |
|        |      | Tag parity errors mask data parity errors. When testing data parity error functionality, ensure that software does not set this bit and the TCC bit at the same time. |  |  |  |  |  |  |
|        |      |                                                                                                                                                                       |  |  |  |  |  |  |

## Table 3-25 TCU\_ERRGEN register bit assignments (continued)

| Bits | Name | Function                                                                                                                   |  |  |  |
|------|------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [1]  | TWC  | Walk cache tag parity error.                                                                                               |  |  |  |
|      |      | <b>0</b> No tag parity error is written to the walk cache.                                                                 |  |  |  |
|      |      | 1 Entries that are written to the walk cache include a tag parity error. A fault occurs when the entry is used.            |  |  |  |
| [0]  | DWC  | Walk cache data parity error.                                                                                              |  |  |  |
|      |      | <b>0</b> No data parity error is written to the walk cache.                                                                |  |  |  |
|      |      | 1 Entries that are written to the walk cache include a data parity error. A fault occurs when the entry is used.           |  |  |  |
|      |      | Note                                                                                                                       |  |  |  |
|      |      | Tag parity errors mask data parity errors. When testing data parity error functionality, ensure that software does not set |  |  |  |
|      |      | this bit and the TWC bit at the same time.                                                                                 |  |  |  |
|      |      |                                                                                                                            |  |  |  |

### 3.9 TBU Component and Peripheral ID Registers

The component and peripheral identity registers comply with the format used by Arm CoreLink and CoreSight components and recommended in the SMMUv3 architecture. They provide key information about the MMU-600 hardware, including the product and associated revision number. They also identify Arm as the designer of the SMMU.

These registers are all read-only. Each field defines a single byte in the least significant 8 bits, and the most significant 24 bits are reserved. The least significant 8 bits of the four Component ID registers form a single 32-bit conceptual ID register. In a similar way, the defined fields of the eight Peripheral ID registers form a conceptual 64-bit ID register.

Table 3-26 TBU Component and Peripheral ID registers bit assignments

| Register                                     | Offset  | Bits  | Value              | Function                                                                                                           |  |
|----------------------------------------------|---------|-------|--------------------|--------------------------------------------------------------------------------------------------------------------|--|
| SMMU_PIDR4   0x00FD0   [7:4]   0x0   4KB reg |         | 0×0   | 4KB region count.  |                                                                                                                    |  |
|                                              |         | [3:0] | 0x4                | JEP106 continuation code for Arm.                                                                                  |  |
| SMMU_PIDR5                                   | 0x00FD4 | [7:0] | 0x00               | Reserved.                                                                                                          |  |
| SMMU_PIDR6                                   | 0x00FD8 | [7:0] | 0x00               | Reserved.                                                                                                          |  |
| SMMU_PIDR7                                   | 0x00FDC | [7:0] | 0x00               | Reserved.                                                                                                          |  |
| SMMU_PIDR0                                   | 0x00FE0 | [7:0] | 0x84               | Part number[7:0].                                                                                                  |  |
| SMMU_PIDR1                                   | 0x00FE4 | [7:4] | 0xB                | JEP106 ID code[3:0] for Arm.                                                                                       |  |
|                                              |         | [3:0] | 0x4                | Part number[11:8].                                                                                                 |  |
| SMMU_PIDR2                                   | 0x00FE8 | [7:4] | 0x0                | MMU-600 major revision.                                                                                            |  |
|                                              |         |       |                    | The value 0x0 indicates major product revision r0.                                                                 |  |
|                                              |         | [3]   | 0x1                | The component uses a manufacturer identity code that is allocated by JEDEC, according to the JEP106 specification. |  |
|                                              |         | [2:0] | 0x3                | JEP106 ID code[6:4] for Arm.                                                                                       |  |
| SMMU_PIDR3                                   | 0x00FEC | [7:4] | MAX[0x1,ecorevnum] | MMU-600 minor revision.                                                                                            |  |
|                                              |         |       |                    | The value 0x1 indicates minor product revision p1.                                                                 |  |
|                                              |         | [3:0] | 0×0                | CMOD. This field is not used.                                                                                      |  |
| SMMU_CIDR0                                   | 0x00FF0 | [7:0] | 0×0D               | Preamble.                                                                                                          |  |
| SMMU_CIDR1                                   | 0x00FF4 | [7:0] | 0×F0               |                                                                                                                    |  |
| SMMU_CIDR2                                   | 0x00FF8 | [7:0] | 0x05               |                                                                                                                    |  |
| SMMU_CIDR3                                   | 0x00FFC | [7:0] | 0xB1               |                                                                                                                    |  |

### 3.10 TBU PMU Component and Peripheral ID Registers

The component and peripheral identity registers comply with the format used by Arm CoreLink and CoreSight components and recommended in the SMMUv3 architecture. They provide key information about the MMU-600 hardware, including the product and associated revision number. They also identify Arm as the designer of the SMMU.

These registers are all read-only. Each field defines a single byte in the least significant 8 bits, and the most significant 24 bits are reserved. The least significant 8 bits of the four Component ID registers form a single 32-bit conceptual ID register. In a similar way, the defined fields of the eight Peripheral ID registers form a conceptual 64-bit ID register.

Table 3-27 TBU PMU Component and Peripheral ID registers bit assignments

| Register               | Offset  | Bits  | Value              | Function                                                                                                           |
|------------------------|---------|-------|--------------------|--------------------------------------------------------------------------------------------------------------------|
| SMMU_PMCG_PMAUTHSTATUS | 0x02FB8 | [7:0] | 0×00               | No authentication interface is implemented.                                                                        |
| SMMU_PIDR4             | 0x02FD0 | [7:4] | 0×0                | 4KB region count.                                                                                                  |
|                        |         | [3:0] | 0×4                | JEP106 continuation code for Arm.                                                                                  |
| SMMU_PIDR5             | 0x02FD4 | [7:0] | 0×00               | Reserved.                                                                                                          |
| SMMU_PIDR6             | 0x02FD8 | [7:0] | 0x00               | Reserved.                                                                                                          |
| SMMU_PIDR7             | 0x02FDC | [7:0] | 0×00               | Reserved.                                                                                                          |
| SMMU_PIDR0             | 0x02FE0 | [7:0] | 0x83               | Part number[7:0].                                                                                                  |
| SMMU_PIDR1             | 0x02FE4 | [7:4] | 0xB                | JEP106 ID code[3:0] for Arm.                                                                                       |
|                        |         | [3:0] | 0x4                | Part number[11:8].                                                                                                 |
| SMMU_PIDR2             | 0x02FE8 | [7:4] | 0×0                | MMU-600 major revision.                                                                                            |
|                        |         |       |                    | The value 0x0 indicates major product revision r0.                                                                 |
|                        |         | [3]   | 0x1                | The component uses a manufacturer identity code that is allocated by JEDEC, according to the JEP106 specification. |
|                        |         | [2:0] | 0x3                | JEP106 ID code[6:4] for Arm.                                                                                       |
| SMMU_PIDR3             | 0x02FEC | [7:4] | MAX[0x1,ecorevnum] | MMU-600 minor revision.                                                                                            |
|                        |         |       |                    | The value 0x1 indicates minor product revision p1.                                                                 |
|                        |         | [3:0] | 0x0                | CMOD. This field is not used.                                                                                      |
| SMMU_CIDR0             | 0x02FF0 | [7:0] | 0×0D               | Preamble.                                                                                                          |
| SMMU_CIDR1             | 0x02FF4 | [7:0] | 0×F0               |                                                                                                                    |
| SMMU_CIDR2             | 0x02FF8 | [7:0] | 0×05               |                                                                                                                    |
| SMMU_CIDR3             | 0x02FFC | [7:0] | 0xB1               |                                                                                                                    |

#### 3.11 TBU microarchitectural registers

You can set the TBU microarchitectural registers at boot time to optimize TBU behavior for your system. Arm recommends the default settings for most systems.

This section contains the following subsections:

- 3.11.1 TBU CTRL on page 3-83.
- 3.11.2 TBU SCR on page 3-83.

#### 3.11.1 TBU\_CTRL

This register disables TBU features. Do not modify the bits in this register unless directed to do so by Arm

Its characteristics are:

#### **Usage constraints**

There are no usage constraints.

#### **Configurations**

This register exists in all TBU configurations.

#### **Attributes**

 Offset
 0x08E00

 Type
 RW

 Reset
 0x00000000

 Width
 32

The following figure shows the bit assignments.



Figure 3-12 TBU\_CTRL register bit assignments

The following table shows the bit assignments.

Table 3-28 TBU\_CTRL register bit assignments

| Bits    | Name      | Function                       |
|---------|-----------|--------------------------------|
| [31:16] | -         | Reserved.                      |
| [15:0]  | AUX[15:0] | Leave each of these bits as 0. |

#### 3.11.2 TBU\_SCR

The TBU Secure Control register controls whether Non-secure software is permitted to access the TBU registers.

Its characteristics are:

#### **Usage constraints**

This register is accessible only by Secure software. Non-secure accesses to this register are RAZ/WI.

#### Configurations

This register exists in all TBU configurations.

#### Attributes

Offset 0x08E18

Type RW

Reset 0x00000000

Width 32

The following figure shows the bit assignments.



Figure 3-13 TBU\_SCR register bit assignments

The following table shows the bit assignments.

Table 3-29 TBU\_SCR register bit assignments

| Bits   | Name     | Function                                                                                                                                                                                                                    |  |  |  |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:2] | -        | Reserved.                                                                                                                                                                                                                   |  |  |  |
| [1]    | NS_RAS   | Non-secure register access to RAS registers.  When this bit is set to 0, Non-secure accesses to register addresses 0x08E80-0x08EC0 are RAZ/WI.  When this bit is set to 1, Non-secure access to RAS registers is permitted. |  |  |  |
| [0]    | NS_UARCH | Non-secure register access to TBU_CTRL.  When this bit is set to 0, Non-secure accesses to TBU_CTRL are RAZ/WI.  When this bit is set to 1, Non-secure accesses to TBU_CTRL are permitted.                                  |  |  |  |

#### 3.12 TBU RAS registers

The MMU-600 includes TBU registers that are related to *Reliability, Availability, and Serviceability* (RAS).

This section contains the following subsections:

- 3.12.1 TBU ERRFR on page 3-85.
- 3.12.2 TBU ERRCTLR on page 3-85.
- 3.12.3 TBU ERRSTATUS on page 3-86.
- *3.12.4 TBU ERRGEN* on page 3-87.

#### 3.12.1 TBU\_ERRFR

This is the TBU Error Feature register. Use this register to discover how the TBU handles errors.

The TBU ERRFR characteristics are:

#### **Usage constraints**

This register is read-only. When TBU\_SCR.NS\_RAS = 0, Non-secure accesses to this register are RAZ.

#### Configurations

This register exists in all TBU configurations.

#### **Attributes**

 Offset
 0x08E80

 Type
 RO

 Reset
 0x00000081

 Width
 32

The following figure shows the bit assignments.



Figure 3-14 TBU\_ERRFR register bit assignments

The following table shows the bit assignments.

Table 3-30 TBU\_ERRFR register bit assignments

| Bits   | Name | Function                                                                    |
|--------|------|-----------------------------------------------------------------------------|
| [31:8] | -    | Reserved                                                                    |
| [7:6]  | FI   | The value 0b10 indicates that the fault handling interrupt is controllable. |
| [5:2]  | -    | Reserved                                                                    |
| [1:0]  | ED   | The value 0b01 indicates that TBU error detection is always enabled.        |

#### 3.12.2 TBU\_ERRCTLR

This is the TBU Error Control register. Use this register to enable fault handling interrupts.

The TBU ERRCTLR characteristics are:

#### **Usage constraints**

When TBU SCR.NS RAS = 0, Non-secure accesses to this register are RAZ/WI.

#### **Configurations**

This register exists in all MMU-600 configurations. An instance of this register exists for each implemented TBU.

#### **Attributes**

 Offset
 0x08E88

 Type
 RW

 Reset
 0x000000000

 Width
 32

The following figure shows the bit assignments.



Figure 3-15 TBU ERRCTLR register bit assignments

The following table shows the bit assignments.

Table 3-31 TBU\_ERRCTLR register bit assignments

| Bits   | Name | Function                                                           |
|--------|------|--------------------------------------------------------------------|
| [31:4] | -    | Reserved                                                           |
| [3]    | FI   | Set this bit to 1 to enable fault handling interrupts for the TBU. |
| [2:0]  | -    | Reserved                                                           |

#### 3.12.3 TBU\_ERRSTATUS

This is the TBU Error Record Primary Syndrome register. Use this register to find out whether different types of error have occurred on the TBU.

The TBU ERRSTATUS characteristics are:

#### **Usage constraints**

When TBU\_SCR.NS\_RAS = 0, Non-secure accesses to this register are RAZ/WI. To prevent race conditions, under certain circumstances, writes to some bits in this register are ignored. Typically, these writes are ignored when a new error has not yet been observed by software.

#### Configurations

This register exists in all MMU-600 configurations. An instance of this register exists for each implemented TBU.

#### **Attributes**

 Offset
 0x08E90

 Type
 RW

 Reset
 0x00000000

 Width
 32

The following figure shows the bit assignments.



Figure 3-16 TBU\_ERRSTATUS register bit assignments

The following table shows the bit assignments.

Table 3-32 TBU\_ERRSTATUS register bit assignments

| Bits    | Name | Function                                                                                                                                                                                                                                             |  |  |  |
|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31]    | -    | Reserved                                                                                                                                                                                                                                             |  |  |  |
| [30]    | V    | Register valid. This bit is set to 1 to indicate that at least one RAS error was recorded.                                                                                                                                                           |  |  |  |
|         |      | Clear this bit by writing a 1 to it. If CE is not <b>0b00</b> and is not being cleared, the write is ignored. A write of 0 is ignored.                                                                                                               |  |  |  |
| [29:28] | -    | Reserved                                                                                                                                                                                                                                             |  |  |  |
| [27]    | OF   | Overflow. This bit is set to 1 to indicate that multiple correctable errors were recorded. That is, at least one correctable error was recorded when CE != 0b00.                                                                                     |  |  |  |
|         |      | Clear this bit by writing a 1 to it. A write of 0 is ignored.                                                                                                                                                                                        |  |  |  |
| [26]    | -    | Reserved                                                                                                                                                                                                                                             |  |  |  |
| [25:24] | CE   | Correctable Error. This field is set to 0b10 to indicate that a corrected error occurred. Clear this field by writing 0b11 to it. If OF is set to 1 and is not being cleared, the write is ignored. A write of any value other than 0b11 is ignored. |  |  |  |
| [23:8]  | -    | Reserved                                                                                                                                                                                                                                             |  |  |  |
| [7:0]   | SERR | Error code. This field provides information about the earliest unacknowledged correctable error, as follows:                                                                                                                                         |  |  |  |
|         |      | 0x00 No error. This code occurs when CE = 0b00.                                                                                                                                                                                                      |  |  |  |
|         |      | Main TLB tag is corrupted. This code can occur when CE != 0b00.                                                                                                                                                                                      |  |  |  |
|         |      | Main TLB data is corrupted. This code can occur when CE != 0b00.                                                                                                                                                                                     |  |  |  |
|         |      | Writes to this field are ignored.                                                                                                                                                                                                                    |  |  |  |

#### 3.12.4 TBU\_ERRGEN

This is the TBU Error Generation register. Use this register to generate tag parity errors. You might want to generate errors in certain cases, such as when testing error-handling software.

The TBU\_ERRGEN characteristics are:

#### **Usage constraints**

When TBU\_SCR.NS\_RAS = 0, Non-secure accesses to this register are RAZ/WI.

#### **Configurations**

This register exists in all TBU configurations.

#### Attributes

Offset 0x08EC0
Type RW

Reset 0x00000000

Width 64

The following figure shows the bit assignments.



Figure 3-17 TBU\_ERRGEN register bit assignments

The following table shows the bit assignments.

Table 3-33 TBU\_ERRGEN register bit assignments

| Bits   | Name  | Function                                                                                                                                                                |  |
|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [63:2] | -     | Reserved.                                                                                                                                                               |  |
| [1]    | TMTLB | Main TLB tag parity error.                                                                                                                                              |  |
|        |       | 0 No tag parity error is written to the Main TLB.                                                                                                                       |  |
|        |       | 1 Entries that are written to the Main TLB include a tag parity error. A fault occurs when the entry is used.                                                           |  |
| [0]    | DMTLB | Main TLB data parity error.                                                                                                                                             |  |
|        |       | No data parity error is written to the Main TLB.                                                                                                                        |  |
|        |       | 1 Entries that are written to the Main TLB include a data parity error. A fault occurs when the entry is used.                                                          |  |
|        |       | Note                                                                                                                                                                    |  |
|        |       | Tag parity errors mask data parity errors. When testing data parity error functionality, ensure that software does not set this bit and the TMTLB bit at the same time. |  |
|        |       |                                                                                                                                                                         |  |

# Appendix A **Signal descriptions**

This appendix describes the MMU-600 external signals.

#### It contains the following sections:

- A.1 Clock and reset signals on page Appx-A-90.
- A.2 TCU QTW/DVM interface signals on page Appx-A-91.
- A.3 TCU programming interface signals on page Appx-A-93.
- A.4 TCU SYSCO interface signals on page Appx-A-94.
- A.5 TCU PMU snapshot interface signals on page Appx-A-95.
- A.6 TCU LPI\_PD interface signals on page Appx-A-96.
- A.7 TCU LPI\_CG interface signals on page Appx-A-97.
- A.8 TCU DTI interface signals on page Appx-A-98.
- A.9 TCU interrupt signals on page Appx-A-99.
- A.10 TCU tie-off signals on page Appx-A-100.
- A.11 TCU and TBU test and debug signals on page Appx-A-101.
- A.12 TBU TBS interface signals on page Appx-A-102.
- A.13 TBU TBM interface signals on page Appx-A-104.
- A.14 TBU PMU snapshot interface signals on page Appx-A-106.
- A.15 TBU LPI PD interface signals on page Appx-A-107.
- A.16 TBU LPI\_CG interface signals on page Appx-A-108.
- A.17 TBU DTI interface signals on page Appx-A-109.
- A.18 TBU interrupt signals on page Appx-A-110.
- A.19 TBU tie-off signals on page Appx-A-111.
- A.20 DTI interconnect switch signals on page Appx-A-113.
- A.21 DTI interconnect sizer signals on page Appx-A-115.
- A.22 DTI interconnect register slice signals on page Appx-A-117.

## A.1 Clock and reset signals

The MMU-600 uses a single set of standard clock and reset signals.

The following table shows the clock and reset signals.

Table A-1 Clock and reset signals

| Signal  | Direction | Description   |
|---------|-----------|---------------|
| aclk    | Input     | Global clock. |
| aresetn | Input     | Global reset. |

## A.2 TCU QTW/DVM interface signals

The TCU QTW/DVM interface signals are based on the AMBA ACE5-Lite signals. See the *Arm*® *AMBA*® *AXI and ACE Protocol Specification* for more information about these signals.

The following table shows the TCU QTW/DVM interface signals.

Table A-2 TCU QTW/DVM interface signals

| Signal       | Direction | Description             |
|--------------|-----------|-------------------------|
| acaddr_qtw   | Input     | Snoop address.          |
| acprot_qtw   | Input     | Snoop protection type.  |
| acready_qtw  | Output    | Snoop address ready.    |
| acsnoop_qtw  | Input     | Snoop transaction type. |
| acvalid_qtw  | Input     | Snoop address valid.    |
| arid_qtw     | Output    | Read address ID.        |
| araddr_qtw   | Output    | Read address.           |
| arburst_qtw  | Output    | Burst type.             |
| arcache_qtw  | Output    | Memory type.            |
| ardomain_qtw | Output    | Shareability domain.    |
| arlen_qtw    | Output    | Burst length.           |
| arlock_qtw   | Output    | Lock type.              |
| arprot_qtw   | Output    | Protection type.        |
| arqos_qtw    | Output    | QoS identifier.         |
| arready_qtw  | Input     | Read address ready.     |
| arregion_qtw | Output    | Region identifier.      |
| arsize_qtw   | Output    | Burst size.             |
| arsnoop_qtw  | Output    | Transaction type.       |
| arvalid_qtw  | Output    | Read address valid.     |
| awid_qtw     | Output    | Write address ID.       |
| awaddr_qtw   | Output    | Write address.          |
| awburst_qtw  | Output    | Burst type.             |
| awcache_qtw  | Output    | Memory type.            |
| awdomain_qtw | Output    | Shareability domain.    |
| awlen_qtw    | Output    | Burst length.           |
| awlock_qtw   | Output    | Lock type.              |
| awprot_qtw   | Output    | Protection type.        |
| awqos_qtw    | Output    | QoS identifier.         |
| awready_qtw  | Input     | Write address ready.    |
| awregion_qtw | Output    | Region identifier.      |

#### Table A-2 TCU QTW/DVM interface signals (continued)

| Signal        | Direction | Description                                       |
|---------------|-----------|---------------------------------------------------|
| awsize_qtw    | Output    | Burst size.                                       |
| awsnoop_qtw   | Output    | Transaction type.                                 |
| awvalid_qtw   | Output    | Write address valid.                              |
| crready_qtw   | Input     | Snoop response ready.                             |
| crresp_qtw    | Output    | Snoop response.                                   |
| crvalid_qtw   | Output    | Snoop response valid.                             |
| rid_qtw       | Input     | Read data ID.                                     |
| rdata_qtw     | Input     | Read data.                                        |
| rlast_qtw     | Input     | Read last.                                        |
| rready_qtw    | Output    | Read ready.                                       |
| rresp_qtw     | Input     | Read response.                                    |
| rvalid_qtw    | Input     | Read valid.                                       |
| wdata_qtw     | Output    | Write data.                                       |
| wlast_qtw     | Output    | Write last.                                       |
| wready_qtw    | Input     | Write ready.                                      |
| wstrb_qtw     | Output    | Write strobe.                                     |
| wvalid_qtw    | Output    | Write valid.                                      |
| bid_qtw       | Input     | Response ID.                                      |
| bready_qtw    | Output    | Response ready.                                   |
| bresp_qtw     | Input     | Write response.                                   |
| bvalid_qtw    | Input     | Write response valid.                             |
| awakeup_qtw   | Output    | Wakeup.                                           |
| acwakeup_qtw  | Input     | Snoop wakeup.                                     |
| acvmidext_qtw | Input     | Snoop Extended Virtual Machine IDentifier (VMID). |

## A.3 TCU programming interface signals

The TCU programming interface signals are based on the AMBA APB4 signals. See the *Arm*® *AMBA*® *APB Protocol Specification* for more information about these signals.

The following table shows the TCU programming interface signals.

Table A-3 TCU programming interface signals

| Signal       | Direction | Description                  |
|--------------|-----------|------------------------------|
| paddr_prog   | Input     | Peripheral address.          |
| psel_prog    | Input     | Peripheral select.           |
| penable_prog | Input     | Enable for transfer.         |
| pwrite_prog  | Input     | Write transaction indicator. |
| pprot_prog   | Input     | Protection type.             |
| pwdata_prog  | Input     | Write data.                  |
| pstrb_prog   | Input     | Write data strobe.           |
| pslverr_prog | Output    | Error response.              |
| prdata_prog  | Output    | Read data.                   |
| pready_prog  | Output    | Transfer ready.              |
| pwakeup_prog | Input     | Interface wakeup.            |

## A.4 TCU SYSCO interface signals

The following table shows the TCU SYSCO interface signals.

Table A-4 TCU SYSCO interface signals

| Signal   | Direction | Description                                                                                                                     |  |
|----------|-----------|---------------------------------------------------------------------------------------------------------------------------------|--|
| syscoreq | Output    | System coherency request.                                                                                                       |  |
|          |           | This output transitions:                                                                                                        |  |
|          |           | To indicate that the master is requesting to enter the coherency domain.                                                        |  |
|          |           | LOW To indicate that the master is requesting to exit the coherency domain.                                                     |  |
| syscoack | Input     | System coherency acknowledge.                                                                                                   |  |
|          |           | This input transitions to the same level as <b>syscoreq</b> when the request to enter or exit the coherency domain is complete. |  |

See the Arm® AMBA® AXI and ACE Protocol Specification for more information about these signals.

## A.5 TCU PMU snapshot interface signals

The following table shows the TCU PMU snapshot interface signals.

#### Table A-5 TCU PMU snapshot interface signals

| Signal          | Direction | Description                                                                                                                            |
|-----------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------|
| pmusnapshot_req | Input     | PMU snapshot request. The PMU snapshot occurs on the rising edge of <b>pmusnapshot_req</b> .                                           |
| pmusnapshot_ack | Output    | PMU snapshot acknowledge. The TCU uses this signal to acknowledge that the PMU snapshot has occurred.  This signal is LOW after reset. |

## A.6 TCU LPI\_PD interface signals

The following table shows the TCU LPI PD interface signals.

Table A-6 TCU LPI\_PD interface signals

| Signal      | Direction | Description         |
|-------------|-----------|---------------------|
| qactive_pd  | Output    | Component active.   |
| qreqn_pd    | Input     | Quiescence request. |
| qacceptn_pd | Output    | Quiescence accept.  |
| qdeny_pd    | Output    | Quiescence deny.    |

See the AMBA<sup>®</sup>  $Low\ Power\ Interface\ Specification,\ Arm$ <sup>®</sup> Q- $Channel\ and\ P$ - $Channel\ Interfaces\ for\ more\ information\ about\ these\ signals.$ 

## A.7 TCU LPI\_CG interface signals

The following table shows the TCU LPI CG interface signals.

Table A-7 TCU LPI\_CG interface signals

| Signal      | Direction | Description         |
|-------------|-----------|---------------------|
| qactive_cg  | Output    | Component active.   |
| qreqn_cg    | Input     | Quiescence request. |
| qacceptn_cg | Output    | Quiescence accept.  |
| qdeny_cg    | Output    | Quiescence deny.    |

See the *AMBA*® *Low Power Interface Specification*, *Arm*® *Q-Channel and P-Channel Interfaces* for more information about these signals.

## A.8 TCU DTI interface signals

The following table shows the TCU DTI interface signals.

Table A-8 TCU DTI interface signals

| Signal         | Direction        | Description                                          |  |
|----------------|------------------|------------------------------------------------------|--|
| tvalid_dti_dn  | Master to slave. | Flow control signal.                                 |  |
| tready_dti_dn  | Slave to master. | Flow control signal.                                 |  |
| tdata_dti_dn   | Master to slave. | Message data signal.                                 |  |
| tid_dti_dn     | Master to slave. | Identifies the master that initiated the message.    |  |
| tlast_dti_dn   | Master to slave. | Indicates the last cycle of a message.               |  |
| tkeep_dti_dn   | Master to slave. | This signal indicates valid bytes.                   |  |
| tvalid_dti_up  | Slave to master. | Flow control signal.                                 |  |
| tready_dti_up  | Master to slave. | Flow control signal.                                 |  |
| tdata_dti_up   | Slave to master. | Message data signal.                                 |  |
| tdest_dti_up   | Slave to master. | Identifies the master that is receiving the message. |  |
| tlast_dti_up   | Slave to master. | Indicates the last cycle of a message.               |  |
| tkeep_dti_up   | Slave to master. | Indicates valid bytes.                               |  |
| twakeup_dti_up | Slave to master. | . Wakeup signal.                                     |  |
| twakeup_dti_dn | Master to slave. | Wakeup signal.                                       |  |

See the Arm® AMBA® 4 AXI4-Stream Protocol Specification for more information about the DTI signals.

See the  $Arm^{*}$   $AMBA^{*}$  Distributed Translation Interface (DTI) Protocol Specification for more information about DTI protocol messages.

## A.9 TCU interrupt signals

The TCU interrupt signals are edge-triggered. The interrupt controller must detect the rising edge of these signals.

The TCU can also output the Secure and Non-secure Event queue, SYNC complete commands, and global interrupts as *Message Signaled Interrupts* (MSIs) on the QTW/DVM interface. If the system supports capturing MSIs from the TCU, there is no requirement to connect the corresponding interrupt signals in this interface.

The following table shows the TCU interrupt signals.

Table A-9 TCU interrupt interface signals

| Signal           | Direction | Description                                                                                                                                                                                 |  |
|------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| event_q_irpt_s   | Output    | Event queue, Secure interrupt. Asserts a Secure interrupt to indicate that the Event queue is not empty or has overflowed.                                                                  |  |
| event_q_irpt_ns  | Output    | Event queue, Non-secure interrupt. Asserts a Non-secure interrupt to indicate that the Event queue is not empty or has overflowed.                                                          |  |
| cmd_sync_irpt_ns | Output    | SYNC complete, Non-secure interrupt. Asserts a Non-secure interrupt to indicate that the CMD_SYNC command is complete.                                                                      |  |
| cmd_sync_irpt_s  | Output    | SYNC complete, Secure interrupt. Asserts a Secure interrupt to indicate that the CMD_SYNC command is complete.                                                                              |  |
| global_irpt_ns   | Output    | Asserts a global Non-secure interrupt.                                                                                                                                                      |  |
| global_irpt_s    | Output    | Asserts a global Secure interrupt.                                                                                                                                                          |  |
| ras_irpt         | Output    | Asserts a Reliability, Availability, and Serviceability (RAS) interrupt.  Note  The MMU-600 cannot output RAS interrupts as MSIs. This output must be connected to an interrupt controller. |  |
| pmu_irpt         | Output    | Asserts a PMU interrupt.  Note  Note  The MMU-600 cannot output PMU interrupts as MSIs. This output must be connected to an interrupt controller.                                           |  |
| evento           | Output    | Event output for connection to processors. This signal is asserted for one cycle to indicate an event that enables processors to wake up from WFE low-power state.                          |  |

## A.10 TCU tie-off signals

The TCU tie-off signals are sampled at reset. Ensure that the value of these signals does not change when the LPI PD interface is not in Q STOPPED state.

The following table shows the TCU tie-off signals.

Table A-10 TCU tie-off signals

| Signal         | Direction | Description                                                                                                                                        |                                     |
|----------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| sup_cohacc     | Input     | This signal indicates whether the QTW interface is I/O-coherent. Tie HIGH when the TCU is connected to a coherent interconnect.                    |                                     |
| sup_btm        | Input     | This signal indicates whether the Broadcast TLB Maintenance is supported. Tie HIGH when the TCU is connected to an interconnect that supports DVM. |                                     |
| sup_sev        | Input     | This signal indicates whether the Send Event mechanism is supported. Tie HIGH when <b>evento</b> is connected.                                     |                                     |
| sup_oas[2:0]   | Input     | Output address size supported.  The encodings for this input are:  0b000 32 bits.                                                                  |                                     |
|                |           | 0b01<br>0b010<br>0b011<br>0b100                                                                                                                    | 36 bits. 40 bits. 42 bits. 44 bits. |
|                |           | Øb101 48 bits.  You must not use other encodings, including Øb110 that SMMUv3.1 defines to indicate 52-bit addresses. They are treated as Øb101.   |                                     |
| sec_override   | Input     | When HIGH, certain registers are accessible to Non-secure accesses from reset, as the TCU_SCR register settings describe.                          |                                     |
| ecorevnum[3:0] | Input     | Tie this signal to 0 unless directed otherwise by Arm.                                                                                             |                                     |

See the *Arm® System Memory Management Unit Architecture Specification, SMMU architecture version 3.0* for more information about the SMMUv3 ID signals.

## A.11 TCU and TBU test and debug signals

The test and debug signals are common to the TCU and TBU.

The following table shows the test and debug signals.

Table A-11 Test and debug signals

| Signal        | Direction | Description                                                                                              |
|---------------|-----------|----------------------------------------------------------------------------------------------------------|
| dftcgen       | Input     | Clock gate enable.                                                                                       |
|               |           | To enable architectural clock gates for the <b>aclk</b> clock, set this signal HIGH during scan shift.   |
| dftrstdisable | Input     | Reset disable.                                                                                           |
|               |           | To disable reset, set this signal HIGH during scan shift.                                                |
| dftramhold    | Input     | Preserve RAM state.                                                                                      |
|               |           | To preserve the state of the RAMs and their connected registers, set this signal HIGH during scan shift. |
| mbistresetn   | Input     | MBIST mode reset. This active-LOW signal is encoded as follows:                                          |
|               |           | Reset MBIST functional logic.                                                                            |
|               |           | 1 Normal operation.                                                                                      |
| mbistreq      | Input     | MBIST test request. This signal is encoded as follows:                                                   |
|               |           | 0 Normal operation.                                                                                      |
|               |           | 1 Enable MBIST testing.                                                                                  |

## A.12 TBU TBS interface signals

The TBU TBS interface signals are based on the AMBA ACE5-Lite signals.

The following table shows the TBU TBS interface signals.

Table A-12 TBU TBS interface signals

| Signal        | Direction | Description                                                                                    |  |
|---------------|-----------|------------------------------------------------------------------------------------------------|--|
| aclk          | Input     | Clock input.                                                                                   |  |
| araddr_s      | Input     | Read address.                                                                                  |  |
| arburst_s     | Input     | Burst type.                                                                                    |  |
| arcache_s     | Input     | Memory type.                                                                                   |  |
| ardomain_s    | Input     | Shareability domain.                                                                           |  |
| aresetn       | Input     | Active-LOW reset signal.                                                                       |  |
| arid_s        | Input     | Read address ID.                                                                               |  |
| arlen_s       | Input     | Burst length.                                                                                  |  |
| arlock_s      | Input     | Lock type.                                                                                     |  |
| arprot_s      | Input     | Protection type.                                                                               |  |
| arqos_s       | Input     | Quality of Service (QoS).                                                                      |  |
| arready_s     | Output    | Read address ready.                                                                            |  |
| arregion_s    | Input     | Region identifier.                                                                             |  |
| arsize_s      | Input     | Burst size.                                                                                    |  |
| armmussid_s   | Input     | These signals indicate the StreamID, SubstreamID, and ATS translated status of the originating |  |
| armmusid_s    | Input     | transaction.                                                                                   |  |
| armmussidv_s  | Input     | These signals are defined by the AXI5 Untranslated_Transactions extension.                     |  |
| armmusecsid_s | Input     |                                                                                                |  |
| armmuatst_s   | Input     |                                                                                                |  |
| arvalid_s     | Input     | Read address valid.                                                                            |  |
| awaddr_s      | Input     | Write address.                                                                                 |  |
| awburst_s     | Input     | Burst type.                                                                                    |  |
| awcache_s     | Input     | Memory type.                                                                                   |  |
| awdomain_s    | Input     | Shareability domain.                                                                           |  |
| awid_s        | Input     | Write address ID.                                                                              |  |
| awlen_s       | Input     | Burst length.                                                                                  |  |
| awlock_s      | Input     | Lock type.                                                                                     |  |
| awprot_s      | Input     | Protection type.                                                                               |  |
| awqos_s       | Input     | QoS.                                                                                           |  |
| awready_s     | Output    | Write address ready.                                                                           |  |
| awregion_s    | Input     | Region identifier.                                                                             |  |

#### Table A-12 TBU TBS interface signals (continued)

| Signal          | Direction | Description                                                                                    |
|-----------------|-----------|------------------------------------------------------------------------------------------------|
| awsize_s        | Input     | Burst size.                                                                                    |
| awmmussid_s     | Input     | These signals indicate the StreamID, SubstreamID, and ATS translated status of the originating |
| awmmusid_s      |           | transaction.                                                                                   |
| awmmussidv_s    |           | These signals are defined by the AXI5 Untranslated_Transactions extension.                     |
| awmmusecsid_s   |           |                                                                                                |
| awmmuatst_s     |           |                                                                                                |
| awvalid_s       | Input     | Write address valid.                                                                           |
| bid_s           | Output    | Response ID.                                                                                   |
| bready_s        | Input     | Response ready.                                                                                |
| bresp_s         | Output    | Write response.                                                                                |
| bvalid_s        | Output    | Write response valid.                                                                          |
| rdata_s         | Output    | Read data.                                                                                     |
| rid_s           | Output    | Read ID.                                                                                       |
| rlast_s         | Output    | Read last.                                                                                     |
| rready_s        | Input     | Read ready.                                                                                    |
| rresp_s         | Output    | Read response.                                                                                 |
| rvalid_s        | Output    | Read valid.                                                                                    |
| wdata_s         | Input     | Write data.                                                                                    |
| wlast_s         | Input     | Write last.                                                                                    |
| wready_s        | Output    | Write ready.                                                                                   |
| wstrb_s         | Input     | Write strobes.                                                                                 |
| wvalid_s        | Input     | Write valid.                                                                                   |
| aruser_s        | Input     | Read address (AR) channel user signal.                                                         |
| awuser_s        | Input     | Write address (AW) channel user signal.                                                        |
| wuser_s         | Input     | Write data (W) channel user signal.                                                            |
| ruser_s         | Output    | Read data (R) channel user signal.                                                             |
| buser_s         | Output    | Write response (B) channel user signal.                                                        |
| awakeup_s       | Input     | Wakeup signal.                                                                                 |
| arsnoop_s       | Input     | Transaction type of read transaction.                                                          |
| awsnoop_s       | Input     | Transaction type of write transaction.                                                         |
| awstashnid_s    | Input     | These signals are defined by the AXI5 Cache_Stash_Transactions extension.                      |
| awstashniden_s  | Input     | If TBUCFG_STASH = 0, these signals are ignored.                                                |
| awstashlpid_s   | Input     |                                                                                                |
| awstashlpiden_s | Input     |                                                                                                |

## A.13 TBU TBM interface signals

The TBU TBM interface signals are based on the AMBA ACE5-Lite signals.

The following table shows the TBU TBM interface signals.

Table A-13 TBU TBM interface signals

| Signal        | Direction | Description                                                         |
|---------------|-----------|---------------------------------------------------------------------|
| aclk          | Input     | Clock input.                                                        |
| araddr_m      | Output    | Read address.                                                       |
| arburst_m     | Output    | Burst type.                                                         |
| arcache_m     | Output    | Memory type.                                                        |
| ardomain_m    | Output    | Shareability domain.                                                |
| aresetn       | Input     | Active LOW reset signal.                                            |
| arid_m        | Output    | Read address ID.                                                    |
| arlen_m       | Output    | Burst length.                                                       |
| arlock_m      | Output    | Lock type.                                                          |
| arprot_m      | Output    | Protection type.                                                    |
| arqos_m       | Output    | Quality of Service (QoS).                                           |
| arready_m     | Input     | Read address ready.                                                 |
| arregion_m    | Output    | Region identifier.                                                  |
| arsize_m      | Output    | Burst size.                                                         |
| armmusid_m    | Output    | These signals indicate the StreamID of the originating transaction. |
| armmusecsid_m | Output    |                                                                     |
| arvalid_m     | Output    | Read address valid.                                                 |
| awaddr_m      | Output    | Write address.                                                      |
| awburst_m     | Output    | Burst type.                                                         |
| awcache_m     | Output    | Memory type.                                                        |
| awdomain_m    | Output    | Shareability domain.                                                |
| awid_m        | Output    | Write address ID.                                                   |
| awlen_m       | Output    | Burst length.                                                       |
| awlock_m      | Output    | Lock type.                                                          |
| awprot_m      | Output    | Protection type.                                                    |
| awqos_m       | Output    | QoS.                                                                |
| awready_m     | Input     | Write address ready.                                                |
| awregion_m    | Output    | Region identifier.                                                  |
| awsize_m      | Output    | Burst size.                                                         |

#### Table A-13 TBU TBM interface signals (continued)

| Signal          | Direction | Description                                                                                                                              |
|-----------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------|
| awmmusid_m      | Output    | These signals indicate the StreamID of the originating transaction.                                                                      |
| awmmusecsid_m   | Output    | The <i>Generic Interrupt Controller</i> (GIC) uses these signals to determine the DeviceID of MSIs that originate from upstream masters. |
| awvalid_m       | Output    | Write address valid.                                                                                                                     |
| bid_m           | Input     | Response ID.                                                                                                                             |
| bready_m        | Output    | Response ready.                                                                                                                          |
| bresp_m         | Input     | Write response.                                                                                                                          |
| bvalid_m        | Input     | Write response valid.                                                                                                                    |
| rdata_m         | Input     | Read data.                                                                                                                               |
| rid_m           | Input     | Read ID.                                                                                                                                 |
| rlast_m         | Input     | Read last.                                                                                                                               |
| rready_m        | Output    | Read ready.                                                                                                                              |
| rresp_m         | Input     | Read response.                                                                                                                           |
| rvalid_m        | Input     | Read valid.                                                                                                                              |
| wdata_m         | Output    | Write data.                                                                                                                              |
| wlast_m         | Output    | Write last.                                                                                                                              |
| wready_m        | Input     | Write ready.                                                                                                                             |
| wstrb_m         | Output    | Write strobes.                                                                                                                           |
| wvalid_m        | Output    | Write valid.                                                                                                                             |
| aruser_m        | Output    | Read address (AR) channel user signal.                                                                                                   |
| awuser_m        | Output    | Write address (AW) channel user signal.                                                                                                  |
| wuser_m         | Output    | Write data (W) channel user signal.                                                                                                      |
| ruser_m         | Input     | Read data (R) channel user signal.                                                                                                       |
| buser_m         | Input     | Write response (B) channel user signal.                                                                                                  |
| awakeup_m       | Output    | Wakeup signal.                                                                                                                           |
| arsnoop_m       | Output    | Transaction type of read transaction.                                                                                                    |
| awsnoop_m       | Output    | Transaction type of write transaction.                                                                                                   |
| awstashnid_m    | Output    | These signals are defined by the AXI5 Cache_Stash_Transactions extension.                                                                |
| awstashniden_m  | Output    | If TBUCFG_STASH = $0$ , these signals are $0$ .                                                                                          |
| awstashlpid_m   | Output    |                                                                                                                                          |
| awstashlpiden_m | Output    |                                                                                                                                          |

## A.14 TBU PMU snapshot interface signals

The following table shows the TBU PMU snapshot interface signals.

#### Table A-14 TBU PMU snapshot interface signals

| Signal          | Direction | Description                                                                                                                            |
|-----------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------|
| pmusnapshot_req | Input     | PMU snapshot request. The PMU snapshot occurs on the rising edge of <b>pmusnapshot_req</b> .                                           |
| pmusnapshot_ack | Output    | PMU snapshot acknowledge. The TBU uses this signal to acknowledge that the PMU snapshot has occurred.  This signal is LOW after reset. |

## A.15 TBU LPI\_PD interface signals

The following table shows the TBU LPI PD interface signals.

Table A-15 TBU LPI\_PD interface signals

| Signal     | Direction | Description         |
|------------|-----------|---------------------|
| qactive_pd | Output    | Component active.   |
| qreqn_pd   | Input     | Quiescence request. |
| qaccept_pd | Output    | Quiescence accept.  |
| qdeny_pd   | Output    | Quiescence deny.    |

See the *AMBA*® *Low Power Interface Specification*, *Arm*® *Q-Channel and P-Channel Interfaces* for more information about these signals.

## A.16 TBU LPI\_CG interface signals

The following table shows the TBU LPI CG interface signals.

Table A-16 TBU LPI\_CG interface signals

| Signal     | Direction | Description         |
|------------|-----------|---------------------|
| qactive_cg | Output    | Component active.   |
| qreqn_cg   | Input     | Quiescence request. |
| qaccept_cg | Output    | Quiescence accept.  |
| qdeny_cg   | Output    | Quiescence deny.    |

See the AMBA<sup>®</sup>  $Low\ Power\ Interface\ Specification,\ Arm$ <sup>®</sup> Q- $Channel\ and\ P$ - $Channel\ Interfaces\ for\ more\ information\ about\ these\ signals.$ 

# A.17 TBU DTI interface signals

The following table shows the TBU DTI interface signals.

Table A-17 TBU DTI interface signals

| Signal         | Direction        | Description                            |
|----------------|------------------|----------------------------------------|
| tvalid_dti_dn  | Master to slave. | Flow control signal.                   |
| tready_dti_dn  | Slave to master. | Flow control signal.                   |
| tdata_dti_dn   | Master to slave. | Message data signal.                   |
| tlast_dti_dn   | Master to slave. | Indicates the last cycle of a message. |
| tkeep_dti_dn   | Master to slave. | Indicates valid bytes.                 |
| tvalid_dti_up  | Slave to master. | Flow control signal.                   |
| tready_dti_up  | Master to slave. | Flow control signal.                   |
| tdata_dti_up   | Slave to master. | Message data signal.                   |
| tlast_dti_up   | Slave to master. | Indicates the last cycle of a message. |
| tkeep_dti_up   | Slave to master. | Indicates valid bytes.                 |
| twakeup_dti_up | Slave to master. | Wakeup signal.                         |
| twakeup_dti_dn | Master to slave. | Wakeup signal.                         |

See the Arm® AMBA® 4 AXI4-Stream Protocol Specification for more information about the DTI signals.

See the *Arm*® *AMBA*® *Distributed Translation Interface (DTI) Protocol Specification* for more information about DTI protocol messages.

# A.18 TBU interrupt signals

The TBU interrupt signals are edge-triggered. The interrupt controller must detect the rising edge of these signals.

The MMU-600 TBU cannot output these interrupts as *Message Signaled Interrupts* (MSIs). These signals must be connected to an interrupt controller.

The following table shows the TBU interrupt signals.

Table A-18 TBU interrupt signals

| Signal   | Direction | Description    |
|----------|-----------|----------------|
| ras_irpt | Output    | RAS interrupt. |
| pmu_irpt | Output    | PMU interrupt. |

# A.19 TBU tie-off signals

The TBU tie-off signals are sampled at reset. Ensure that the value of these signals does not change when the LPI  $\,$ PD interface is not in the  $\,$ Q  $\,$ STOPPED state.

The following table shows the TBU tie-off signals.

Table A-19 TBU tie-off signals

| Signal                                      | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ns_sid_high[23:TBUCFG_SID_WIDTH]            | Input     | Provides the high-order stream ID bits for all transactions with a Non-secure StreamID that pass through the TBU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| s_sid_high[23:TBUCFG_SID_WIDTH]             | Input     | Provides the high-order stream ID bits for all transactions with a Secure StreamID that pass through the TBU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| max_tok_trans[log2(TBUCFG_XLATE_SLOTS)-1:0] | Input     | Indicates the number of DTI translation tokens to request when connecting to the TCU, minus 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| pcie_mode                                   | Input     | You must tie this signal HIGH when the TBU is connected to a PCIe interface.  When this signal is HIGH, the TBU behaves as if the PCIe No Snoop property is applied to transactions downstream of the SMMU, provided that the PCIe interface outputs transactions with the following AXI memory types:  • Normal Non-Cacheable Bufferable, when No Snoop is set for the transaction.  • Write-Back, when No Snoop is not set for the transaction.  This TBU behavior is a requirement of the <i>Arm Server Base System Architecture</i> .  If this signal is HIGH, the attributes of TBS interface transactions are always combined with the translation attributes, even if stage 1 translation is enabled. That is, the transaction attributes are always calculated as if the DTI_TBU_TRANS_RESP.STRW field is EL1-S2, regardless of the actual STRW value.  If this signal is HIGH, the input attribute and shareability override information in the ATTR_OVR field of the DTI_TBU_TRANS_RESP message is ignored. For SMMUv3, PCIe masters do not support this feature. |
| sec_override                                | Input     | When HIGH, certain registers are accessible to Non-secure accesses from reset, as the TCU_SCR register settings describe.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## Table A-19 TBU tie-off signals (continued)

| Signal          | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ecorevnum[3:0]  | Input     | Tie this signal to 0 unless directed otherwise by Arm.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| utlb_roundrobin | Input     | Defines the Micro TLB entry replacement policy.  When LOW, the Micro TLB uses a <i>Pseudo Least Recently Used</i> (PLRU) replacement policy. This policy typically provides the best average performance. However, when multiple translations are prefetched using a StashTranslation transaction, they might evict each other.  When HIGH, the Micro TLB uses a round-robin replacement policy. With this policy, you can prefetch multiple translations using a StashTranslation transaction without evictions occurring, as long as the Micro TLB size is not exceeded.  Tie this signal HIGH if a real-time upstream master prefetches translations and you want to avoid transactions evicting each other. Otherwise, tie this signal LOW. |

## **Related references**

3.7.5 TCU\_SCR on page 3-72.

# A.20 DTI interconnect switch signals

The DTI interconnect switch provides signals for each of its interfaces.

The switch provides one  $DN_Sn$  slave downstream interface per slave interface. The following table shows the  $DN_Sn$  signals.

Table A-20 DTI interconnect switch DN\_Sn interface signals

| Signal            | Direction        | Description                                      |
|-------------------|------------------|--------------------------------------------------|
| tvalid_dti_dn_sn  | Slave to master. | Flow control signal.                             |
| tready_dti_dn_sn  | Master to slave. | Flow control signal.                             |
| tdata_dti_dn_sn   | Slave to master. | Message data signal.                             |
| tid_dti_dn_sn     | Slave to master. | Indicates the master that initiated the message. |
| tlast_dti_dn_sn   | Slave to master. | Indicates the last cycle of a message.           |
| tkeep_dti_dn_sn   | Slave to master. | Indicates valid bytes.                           |
| twakeup_dti_up_sn | Slave to master. | Wakeup signal.                                   |

The switch provides one  $UP\_Sn$  slave upstream interface per slave interface. The following table shows the  $UP\_Sn$  signals.

Table A-21 DTI interconnect switch UP\_Sn interface signals

| Signal            | Direction        | Description                                      |
|-------------------|------------------|--------------------------------------------------|
| tvalid_dti_up_sn  | Master to slave. | Flow control signal.                             |
| tready_dti_up_sn  | Slave to master. | Flow control signal.                             |
| tdata_dti_up_sn   | Master to slave. | Message data signal.                             |
| tdest_dti_up_sn   | Master to slave. | Indicates the master that initiated the message. |
| tlast_dti_up_sn   | Master to slave. | Indicates the last cycle of a message.           |
| tkeep_dti_up_sn   | Master to slave. | Indicates valid bytes.                           |
| twakeup_dti_up_sn | Master to slave. | Wakeup signal.                                   |

The switch provides a DN\_M master downstream interface. The following table shows the DN\_M signals.

Table A-22 DTI interconnect switch DN\_M interface signals

| Signal           | Direction        | Description                                      |
|------------------|------------------|--------------------------------------------------|
| tvalid_dti_dn_m  | Slave to master. | Flow control signal.                             |
| tready_dti_dn_m  | Master to slave. | Flow control signal.                             |
| tdata_dti_dn_m   | Slave to master. | Message data signal.                             |
| tid_dti_dn_m     | Slave to master. | Indicates the master that initiated the message. |
| tlast_dti_dn_m   | Slave to master. | Indicates the last cycle of a message.           |
| tkeep_dti_dn_m   | Slave to master. | Indicates valid bytes.                           |
| twakeup_dti_dn_m | Slave to master. | Wakeup signal.                                   |

The switch provides an UP\_M master upstream interface. The following table shows the UP\_M signals.

Table A-23 DTI interconnect switch UP\_M interface signals

| Signal           | Direction        | Description                                      |
|------------------|------------------|--------------------------------------------------|
| tvalid_dti_up_m  | Master to slave. | Flow control signal.                             |
| tready_dti_up_m  | Slave to master. | Flow control signal.                             |
| tdata_dti_up_m   | Master to slave. | Message data signal.                             |
| tdest_dti_up_m   | Master to slave. | Indicates the master that initiated the message. |
| tlast_dti_up_m   | Master to slave. | Indicates the last cycle of a message.           |
| tkeep_dti_up_m   | Master to slave. | Indicates valid bytes.                           |
| twakeup_dti_up_m | Slave to master. | Wakeup signal.                                   |

# A.21 DTI interconnect sizer signals

The DTI interconnect sizer provides signals for each of its interfaces.

The sizer provides an LPI\_CG clock gating interface. The following table shows the LPI\_CG signals.

Table A-24 DTI interconnect sizer LPI\_CG interface signals

| Signal Direction |         | Description         |
|------------------|---------|---------------------|
| qaccept_cg       | Output. | Quiescence accept.  |
| qactive_cg       | Output. | Component active.   |
| qdeny_cg         | Output. | Quiescence deny.    |
| qreqn_cg         | Input.  | Quiescence request. |

The sizer provides a DN S slave downstream interface. The following table shows the DN S signals.

Table A-25 DTI interconnect sizer DN\_S interface signals

| Signal           | Direction        | Description                                      |
|------------------|------------------|--------------------------------------------------|
| tvalid_dti_dn_s  | Slave to master. | Flow control signal.                             |
| tready_dti_dn_s  | Master to slave. | Flow control signal.                             |
| tdata_dti_dn_s   | Slave to master. | Message data signal.                             |
| tid_dti_dn_s     | Slave to master. | Indicates the master that initiated the message. |
| tlast_dti_dn_s   | Slave to master. | Indicates the last cycle of a message.           |
| tkeep_dti_dn_s   | Slave to master. | Indicates valid bytes.                           |
| twakeup_dti_dn_s | Slave to master. | Wakeup signal.                                   |

The sizer provides an UP\_S slave upstream interface. The following table shows the UP\_S signals.

Table A-26 DTI interconnect sizer UP\_S interface signals

| Signal           | Direction        | Description                                      |
|------------------|------------------|--------------------------------------------------|
| tvalid_dti_up_s  | Master to slave. | Flow control signal.                             |
| tready_dti_up_s  | Slave to master. | Flow control signal.                             |
| tdata_dti_up_s   | Master to slave. | Message data signal.                             |
| tdest_dti_up_s   | Master to slave. | Indicates the master that initiated the message. |
| tlast_dti_up_s   | Master to slave. | Indicates the last cycle of a message.           |
| tkeep_dti_up_s   | Master to slave. | Indicates valid bytes.                           |
| twakeup_dti_up_s | Master to slave. | Wakeup signal.                                   |

The sizer provides a DN\_M master downstream interface. The following table shows the DN\_M signals.

Table A-27 DTI interconnect sizer DN\_M interface signals

| Signal           | Direction        | Description                                      |
|------------------|------------------|--------------------------------------------------|
| tvalid_dti_dn_m  | Slave to master. | Flow control signal.                             |
| tready_dti_dn_m  | Master to slave. | Flow control signal.                             |
| tdata_dti_dn_m   | Slave to master. | Message data signal.                             |
| tid_dti_dn_m     | Slave to master. | Indicates the master that initiated the message. |
| tlast_dti_dn_m   | Slave to master. | Indicates the last cycle of a message.           |
| tkeep_dti_dn_m   | Slave to master. | Indicates valid bytes.                           |
| twakeup_dti_dn_m | Slave to master. | Wakeup signal.                                   |

The sizer provides an UP\_M master upstream interface. The following table shows the UP\_M signals.

Table A-28 DTI interconnect sizer UP\_M interface signals

| Signal           | Direction        | Description                                      |
|------------------|------------------|--------------------------------------------------|
| tvalid_dti_up_m  | Master to slave. | Flow control signal.                             |
| tready_dti_up_m  | Slave to master. | Flow control signal.                             |
| tdata_dti_up_m   | Master to slave. | Message data signal.                             |
| tdest_dti_up_m   | Master to slave. | Indicates the master that initiated the message. |
| tlast_dti_up_m   | Master to slave. | Indicates the last cycle of a message.           |
| tkeep_dti_up_m   | Master to slave. | Indicates valid bytes.                           |
| twakeup_dti_up_m | Slave to master. | Wakeup signal.                                   |

## A.22 DTI interconnect register slice signals

The DTI interconnect register slice provides signals for each of its interfaces.

The register slice provides an LPI\_CG clock gating interface. The following table shows the LPI\_CG signals.

Table A-29 DTI interconnect register slice LPI\_CG interface signals

| Signal     | Direction | Description         |  |  |
|------------|-----------|---------------------|--|--|
| qaccept_cg | Output.   | Quiescence accept.  |  |  |
| qactive_cg | Output.   | Component active.   |  |  |
| qdeny_cg   | Output.   | Quiescence deny.    |  |  |
| qreqn_cg   | Input.    | Quiescence request. |  |  |

The register slice provides a DN\_S slave downstream interface. The following table shows the DN\_S signals.

Table A-30 DTI interconnect register slice DN\_S interface signals

| Signal Direction                 |                  | Description                                     |  |  |
|----------------------------------|------------------|-------------------------------------------------|--|--|
| tvalid_dti_dn_s Slave to master. |                  | Flow control signal.                            |  |  |
| tready_dti_dn_s                  | Master to slave. | Flow control signal.                            |  |  |
| tdata_dti_dn_s Slave to master.  |                  | Message data signal.                            |  |  |
| tid_dti_dn_s Slave to master.    |                  | Indicates the master that initiated the message |  |  |
| tlast_dti_dn_s                   | Slave to master. | Indicates the last cycle of a message.          |  |  |
| tkeep_dti_dn_s Slave to master.  |                  | Indicates valid bytes.                          |  |  |

The register slice provides an UP\_S slave upstream interface. The following table shows the UP\_S signals.

Table A-31 DTI interconnect register slice UP\_S interface signals

| Signal Direction |                                       | Description                                      |  |  |
|------------------|---------------------------------------|--------------------------------------------------|--|--|
| tvalid_dti_up_s  | Master to slave.                      | Flow control signal.                             |  |  |
| tready_dti_up_s  | Slave to master.                      | Flow control signal.                             |  |  |
| tdata_dti_up_s   | Master to slave. Message data signal. |                                                  |  |  |
| tdest_dti_up_s   |                                       | Indicates the master that initiated the message. |  |  |
| tlast_dti_up_s   | Master to slave.                      | Indicates the last cycle of a message.           |  |  |
| tkeep_dti_up_s   | Master to slave.                      | Indicates valid bytes.                           |  |  |

The register slice provides a DN\_M master downstream interface. The following table shows the DN\_M signals.

Table A-32 DTI interconnect register slice DN\_M interface signals

| Signal Direction              |                  | Description                                     |  |  |
|-------------------------------|------------------|-------------------------------------------------|--|--|
| tvalid_dti_dn_m               | Slave to master. | Flow control signal.                            |  |  |
| tready_dti_dn_m               | Master to slave. | Flow control signal.                            |  |  |
| tdata_dti_dn_m                | Slave to master. | Message data signal.                            |  |  |
| tid_dti_dn_m Slave to master. |                  | Indicates the master that initiated the message |  |  |
| tlast_dti_dn_m                | Slave to master. | Indicates the last cycle of a message.          |  |  |
| tkeep_dti_dn_m                | Slave to master. | Indicates valid bytes.                          |  |  |

The register slice provides an UP\_M master upstream interface. The following table shows the UP\_M signals.

Table A-33 DTI interconnect register slice UP\_M interface signals

| Signal Direction                |                  | Description                                     |  |  |
|---------------------------------|------------------|-------------------------------------------------|--|--|
| tvalid_dti_up_m                 | Master to slave. | Flow control signal.                            |  |  |
| tready_dti_up_m                 | Slave to master. | Flow control signal.                            |  |  |
| tdata_dti_up_m Master to slave. |                  | Message data signal.                            |  |  |
| tdest_dti_up_m Master to slave. |                  | Indicates the master that initiated the message |  |  |
| tlast_dti_up_m                  | Master to slave. | Indicates the last cycle of a message.          |  |  |
| tkeep_dti_up_m                  | Master to slave. | Indicates valid bytes.                          |  |  |

# Appendix B **Software initialization examples**

This appendix provides examples of how software can initialize and enable the MMU-600.

It contains the following sections:

- B.1 Initializing the SMMU on page Appx-B-120.
- B.2 Enabling the SMMU on page Appx-B-125.

## B.1 Initializing the SMMU

Software must initialize the MMU-600 before you can use it.

The MMU-600 supports Secure and Non-secure translation worlds. This section defines how to initialize Non-secure translation. The procedures for initializing Secure translation are similar, and require you to access the corresponding MMU-600 Secure registers.

| <u></u> | Note |
|---------|------|
|         |      |

This section does not describe how to create translation tables. See the *Arm® Architecture Reference Manual, ARMv8, for ARMv8-A architecture profile* for more information.

See the *Arm® System Memory Management Unit Architecture Specification, SMMU architecture version 3.0 and version 3.1* for more information about MMU-600 initialization.

This section contains the following subsections:

1. Allocate memory for the Command queue.

- B.1.1 Allocating the Command queue on page Appx-B-120.
- *B.1.2 Allocating the Event queue* on page Appx-B-120.
- B.1.3 Configuring the Stream table on page Appx-B-121.
- B.1.4 Initializing the Command queue on page Appx-B-121.
- B.1.5 Initializing the Event queue on page Appx-B-121.
- B.1.6 Invalidating TLBs and configuration caches on page Appx-B-122.
- B.1.7 Creating a basic Context Descriptor on page Appx-B-122.
- B.1.8 Creating a Stream Table Entry on page Appx-B-123.

#### **B.1.1** Allocating the Command queue

The MMU-600 uses the Command queue to receive commands. Software must allocate memory for the Command queue and configure the appropriate registers in the SMMU.

To allocate the Command queue, ensure that your software performs the following steps:

#### **Procedure**

| 2. | Configure the Command queue size and base address by writing to the SMMU_CMDQ_BASE register. |
|----|----------------------------------------------------------------------------------------------|
|    | Note                                                                                         |

The queue size can affect how many bits of the SMMU\_CMDQ\_CONS and SMMU\_CMDQ\_PROD indices are writeable. It is therefore important that you perform this step before writing to SMMU\_CMDQ\_CONS and SMMU\_CMDQ\_PROD.

| 3. | Set the queue read index in SMMU_CMDQ_CONS and the queue write index in SMMU_CMDQ_PROD to 0. |
|----|----------------------------------------------------------------------------------------------|
|    | Note                                                                                         |

Setting the queue read index and the queue write index to the same value indicates that the queue is empty.

#### B.1.2 Allocating the Event queue

The MMU-600 uses the Event queue to signal events. Software must allocate memory for the Event queue and configure the appropriate registers in the MMU.

To allocate the Event queue, ensure that your software performs the following steps:

#### **Procedure**

| 1. | Allocate memory | for the | Event c | jueue. |
|----|-----------------|---------|---------|--------|
|----|-----------------|---------|---------|--------|

| Configure the Event queue size and base address by writing to the SMMU_EVENTQ_BASE register.                                                                                                                              |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note                                                                                                                                                                                                                      |
| The queue size can affect how many bits of the SMMU_EVENTQ_CONS and SMMU_EVENTQ_PROD indices are writeable. It is therefore important that you perform this step before writing to SMMU_EVENTQ_CONS and SMMU_EVENTQ_PROD. |
| Set the queue read index in SMMU_EVENTQ_CONS and the queue write index in SMMU_EVENTQ_PROD to 0.                                                                                                                          |
| Note                                                                                                                                                                                                                      |
| Setting the queue read index and the queue write index to the same value indicates that the queue is empty.                                                                                                               |
|                                                                                                                                                                                                                           |

#### B.1.3 Configuring the Stream table

The Stream table is a configuration structure in memory that uses a *Context Descriptor* (CD) to locate translation data for a transaction. Software must allocate memory for the Stream table, configure the table format, and populate the table with *Stream Table Entries* (STEs).

To configure the Stream table, ensure that your software performs the following steps:

#### **Procedure**

- 1. Allocate memory for the Stream table.
- 2. Configure the format and size of the Stream table by writing to SMMU STRTAB BASE CFG.
- 3. Configure the base address for the Stream table by writing to SMMU STRTAB BASE.
- 4. Prevent uninitialized memory being interpreted as a valid configuration by setting STE.V = 0 for each STE to mark it as invalid.
- 5. Ensure that written data is observable to the SMMU by performing a *Data Synchronization Barrier* (DSB) operation.

If SMMU\_IDR0.COHACC = 0, the system does not support coherent access to memory for the TCU. In such cases, additional steps might be required to ensure that the written data is observable to the SMMU.

## B.1.4 Initializing the Command queue

Software must initialize the Command queue by enabling it and checking that the enable operation is complete.

To initialize the Command queue, ensure that your software performs the following steps:

#### **Procedure**

- 1. Enable the Command queue by setting the SMMU S CR0.CMDQEN bit to 1.
- 2. Check that the enable operation is complete by polling SMMU\_S\_CR0ACK until CMDQEN reads as 1.

## B.1.5 Initializing the Event queue

Software must initialize the Event queue by enabling it and checking that the enable operation is complete.

To initialize the Event queue, ensure that your software performs the following steps:

## **Procedure**

- 1. Enable the Event queue by setting the SMMU S CR0.EVENTQEN bit to 1.
- Check that the enable operation is complete by polling SMMU\_S\_CR0ACK until EVENTQEN reads as 1.

#### B.1.6 Invalidating TLBs and configuration caches

Before use, the MMU-600 TLBs and configuration cache structures must be invalidated by issuing commands to the Command queue. Alternatively, Secure software can invalidate all TLBs and caches with a single write.

To invalidate TLB entries, ensure that your software issues the appropriate command for the translation context. To invalidate:

- TLB entries for Non-secure EL1 contexts, issue CMD\_TLBI\_NSNH\_ALL.
- TLB entries for EL2 contexts, issue CMD TLBI EL2 ALL.
- TLB entries for EL3 contexts, issue CMD\_TLBI\_EL3\_ALL.
- TLB entries for Secure EL1 contexts, issue CMD\_TLBI\_NH\_ALL.

| <br>No |       |  |      |  |
|--------|-------|--|------|--|
| 1 .    | . 1.1 |  | TT D |  |

Commands to invalidate Secure TLB entries can only be issued through the Secure Command queue. For a system that implements two security states, Secure software must issue the appropriate command to the Secure Command queue for the first TLB invalidation. If your system does not use Secure software, you can permit Non-secure software to access SMMU\_S\_INIT by using either **sec\_override** or the TCU\_SCR register.

To invalidate both the TCU configuration cache and the TBU combined configuration cache and TLB, issue the CMD\_CFGI\_ALL command.

To force all previous commands to complete, issue CMD\_SYNC.

To invalidate all configuration caches and TLB entries for all translation regimes and security states, ensure that Secure software:

- 1. Sets SMMU\_S\_INIT.INV\_ALL to 1. The SMMU sets SMMU\_S\_INIT.INV\_ALL to 0 after the invalidation completes.
- 2. Polls SMMU S INIT.INV ALL to check it is set to 0 before continuing the SMMU configuration.

See the *Arm*<sup>®</sup> *System Memory Management Unit Architecture Specification, SMMU architecture version 3.0* for more information about issuing commands to the Command queue.

## **B.1.7** Creating a basic Context Descriptor

A *Context Descriptor* (CD) is a data structure in system memory. A CD defines how Stage 1 translation is performed. The SubstreamID is used to select the CD.

To create a CD, ensure that your software performs the following steps:

- 1. Allocate 64 bytes of memory for the CD.
- 2. Configure the CD fields according to the information in the following table.

Table B-1 Configuring the CD

| Field | Description                                        |  |  |
|-------|----------------------------------------------------|--|--|
| AA64  | Translation table format:                          |  |  |
|       | 0 AArch32.                                         |  |  |
|       | 1 AArch64.                                         |  |  |
| EPD0  | Enable translations for TTB0 by setting EPD0 to 0. |  |  |
| TTB0  | Base address of translation table 0.               |  |  |

#### Table B-1 Configuring the CD (continued)

| Field | Description                                                                                         |  |  |
|-------|-----------------------------------------------------------------------------------------------------|--|--|
| TG0   | Translation granule size for TTB0 when CD.AA64 = 1.                                                 |  |  |
| IR0   | Cacheability attribute to use for translation table walks to TTB0:                                  |  |  |
| OR0   | Non-cacheable.                                                                                      |  |  |
|       | Write-Back Cacheable, Read-Allocate Write-Allocate.                                                 |  |  |
|       | Write-through Cacheable, Read-Allocate.                                                             |  |  |
| SH0   | 0 Shareability of translation table walks to TTB0:                                                  |  |  |
|       | Non-shareable.                                                                                      |  |  |
|       | Outer Shareable.                                                                                    |  |  |
|       | 10 Inner Shareable.                                                                                 |  |  |
| EPD1  | If the StreamWorld supports split address spaces, enable table walks for TTB1.                      |  |  |
| ENDI  | The endianness for the translation tables.                                                          |  |  |
| IPS   | The IPA size when CD.AA64 = 1.                                                                      |  |  |
| ASET  | Defines whether the ASID values are shared with the ASID values of an Arm processor.                |  |  |
|       | Note                                                                                                |  |  |
|       | If you expect this context to receive broadcast TLB invalidation commands from a PE, set ASET to 0. |  |  |
| V     | Valid CD. This field must be set to 1.                                                              |  |  |

## B.1.8 Creating a Stream Table Entry

Each *Stream Table Entry* (STE) configures how Stage 2 translation is performed, and how the *Context Descriptor* (CD) table can be found. The StreamID is used to select an STE.

To create an STE, ensure that your software performs the following steps:

- 1. Allocate 64 bytes of memory for the STE.
- 2. Set the STE.Config field as required for Stage 1 translation, Stage 2 translation, or translation bypass:

No traffic can pass through the MMU. An abort is returned.

оьтоо Stage 1 and Stage 2 bypass.

**9b101** Stage 1 translation Stage 2 bypass.

Ob110 Stage 1 bypass Stage 2 translation.

**9b111** Stage 1 and Stage 2 translation.

3. If Stage 1 translation is enabled, you can set the following fields:

STE.S1CDMax Controls whether STE.S1ContextPtr points to a single CD or a CD table.

**STE.S1Fmt** If STE.S1CDMax > 0, configures the format of the CD table.

STE. S1ContextPtr Contains a pointer to either a CD or a CD table. If Stage 2 translation is

enabled, this pointer is an intermediate physical address (IPA), otherwise it is

an untranslated physical address PA.

4. If Stage 2 translation is enabled, you can set the following fields:

**STE.S2TTB** Points to the Stage 2 translation table base address.

**STE.S2PS** Contains the PA size of the stage 2 PA range.

STE.S2AA64 Indicates whether the Stage 2 tables are AArch32 or AArch64 format.

STE.S3ENDI Set this field to the required endianness for the stage 2 translation tables.

STE.S2AFFD Disable Access Flag faults for Stage 2 translation.

**STE.S2TG** 0b00: 4KB.

0b01: 64KB. 0b10: 16KB.

STE.S2IR0 and 0b00: Non-cacheable.

STE.S2OR0 øbø1: Write-Back Cacheable, Read-Allocate Write-Allocate.

øь10: Write-through Cacheable, Read-Allocate.

STE.S2SH0 øbøø: Non-shareable.

øьо1: Outer Shareable.

øь10: Inner Shareable.

**STE.S2VMID** Contains the VMID associated with these translations.

# B.2 Enabling the SMMU

Software can enable the SMMU by writing to SMMU CR0 after the Stream table is populated.

To enable the SMMU:

#### **Procedure**

- 1. Ensure that all Stream table entries are populated in memory.
- 2. Set the SMMU\_CR0.SMMUEN bit to 1.
- 3. Check that the enable operation is complete by polling SMMU\_CR0ACK until SMMUEN reads as 1.

# Appendix C **Revisions**

This appendix describes the technical changes between released issues of this book.

It contains the following section:

• *C.1 Revisions* on page Appx-C-127.

# C.1 Revisions

This appendix describes the technical changes between released issues of this book.

Table C-1 Issue 0000-00

| Change        | Location | Affects |
|---------------|----------|---------|
| First release | -        | -       |

Table C-2 Differences between Issue 0000-00 and Issue 0000-01

| Change                                                          | Location                                                             | Affects        |
|-----------------------------------------------------------------|----------------------------------------------------------------------|----------------|
| Clarified feature list.                                         | 1.3 Features on page 1-14.                                           | All revisions. |
| Added revised information about TCU, TBU, and DTI interconnect. | 2.1 About the functions on page 2-22.                                | All revisions. |
| Added various clarifications.                                   | 2.2 Interfaces on page 2-28.                                         | All revisions. |
| Added various clarifications.                                   | 2.3.1 Performance Monitoring Unit on page 2-36.                      | All revisions. |
| Added new section.                                              | SMMUv3 PMU register architectural options on page 2-41.              | All revisions. |
| Added information about DTI.                                    | 2.3.2 DTI overview on page 2-42.                                     | All revisions. |
| Added various clarifications.                                   | 2.3.4 Quality of Service on page 2-43.                               | All revisions. |
| Added new section.                                              | 2.3.7 Conversion between ACE-Lite and ARMv8 attributes on page 2-44. | All revisions. |
| Added various clarifications.                                   | 2.4 Constraints and limitations of use on page 2-48.                 | All revisions. |
| Amended address ranges.                                         | 3.3 MMU-600 memory map on page 3-61.                                 | All revisions. |
| New subsection TCU and TBU PMU identification register summary. | 3.4 Register summary on page 3-63.                                   | All revisions. |
| Added new section.                                              | 3.6 TCU PMU Component and Peripheral ID Registers on page 3-67.      | All revisions. |
| Modified bits[2:0].                                             | 3.7.1 TCU_CTRL on page 3-68.                                         | All revisions. |
| Amended section.                                                | 3.7.7 TCU_NODE_STATUSn on page 3-74.                                 | All revisions. |
| Added new sections.                                             | 3.8.4 TCU_ERRGEN on page 3-79.                                       | All revisions. |
|                                                                 | 3.10 TBU PMU Component and Peripheral ID Registers on page 3-82.     |                |
|                                                                 | <i>3.12.4 TBU_ERRGEN</i> on page 3-87.                               |                |
| Amended sections.                                               | A.9 TCU interrupt signals on page Appx-A-99.                         | All revisions. |
|                                                                 | A.12 TBU TBS interface signals on page Appx-A-102.                   |                |
|                                                                 | A.13 TBU TBM interface signals on page Appx-A-104.                   |                |
|                                                                 | A.18 TBU interrupt signals on page Appx-A-110.                       |                |
|                                                                 | A.19 TBU tie-off signals on page Appx-A-111.                         |                |
| Added new sections.                                             | A.20 DTI interconnect switch signals on page Appx-A-113.             | All revisions. |
|                                                                 | A.21 DTI interconnect sizer signals on page Appx-A-115.              |                |
|                                                                 | A.22 DTI interconnect register slice signals on page Appx-A-117.     |                |
|                                                                 | B.1.7 Creating a basic Context Descriptor on page Appx-B-122.        |                |
|                                                                 | B.1.8 Creating a Stream Table Entry on page Appx-B-123.              |                |

## Table C-3 Differences between Issue 0000-01 and Issue 0001-00

| Change                                                                                                              | Location                                                          | Affects        |
|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------|
| Added new section.                                                                                                  | 1.2.5 AMBA* APB protocol on page 1-13.                            | All revisions. |
| Modified description of Main TLB.                                                                                   | 2.1.2 Translation Buffer Unit (TBU) on page 2-25.                 | All revisions. |
| Added information about <b>sup_btm</b> signal.                                                                      | 2.3.5 Distributed Virtual Memory (DVM) messages on page 2-43.     | All revisions. |
| Added a note about the configurability of the ID register values.                                                   | 2.4.1 SMMUv3 support on page 2-48.                                | All revisions. |
| Modified description of SMMU_IIDR.Revision.                                                                         | 2.4.1 SMMUv3 support on page 2-48.                                | r0p1.          |
| Clarified description of CleanShared, CleanInvalid,<br>MakeInvalid, and CleanSharedPersist transaction<br>handling. | Transactions that can result in a translation fault on page 2-51. | All revisions. |
| Added SMMU_PMCG_IRQ_STATUS to list of unimplemented PMCG registers.                                                 | 3.1 About the programmers model on page 3-55.                     | All revisions. |
| Modified the value and description of SMMU_PIDR2[7:4] and SMMU_PIDR3[7:4].                                          | 3.5 TCU Component and Peripheral ID Registers on page 3-66.       | r0p1.          |
|                                                                                                                     | 3.6 TCU PMU Component and Peripheral ID Registers on page 3-67.   |                |
| Modified register description.                                                                                      | 3.7.1 TCU_CTRL on page 3-68.                                      | r0p1.          |
| Modified register bits [31:16] and [7:0].                                                                           |                                                                   |                |
| Added information about calculating the offset of a                                                                 | 3.7.6 TCU_NODE_CTRLn on page 3-73.                                | All revisions. |
| specific register.                                                                                                  | 3.7.7 TCU_NODE_STATUSn on page 3-74.                              |                |
| Added a note to DCC and DWC bit descriptions about conditions that apply when setting the bits.                     | 3.8.4 TCU_ERRGEN on page 3-79.                                    | All revisions. |
| Modified the value and description of SMMU_PIDR2[7:4] and SMMU_PIDR3[7:4].                                          | 3.9 TBU Component and Peripheral ID Registers on page 3-81.       | r0p1.          |
|                                                                                                                     | 3.10 TBU PMU Component and Peripheral ID Registers on page 3-82.  |                |
| Modified register description.                                                                                      | 3.11.1 TBU_CTRL on page 3-83.                                     | r0p1.          |
| Modified register bits.                                                                                             |                                                                   |                |
| Added a note to DMTLB bit description about conditions that apply when setting the bit.                             | 3.12.4 TBU_ERRGEN on page 3-87.                                   | All revisions. |

## Table C-4 Differences between Issue 0001-00 and Issue 0001-01

| Change                                         | Location                                          | Affects        |
|------------------------------------------------|---------------------------------------------------|----------------|
| Clarified description of translation manager.  | 2.1.2 Translation Buffer Unit (TBU) on page 2-25. | All revisions. |
| Clarified note about DTI translation requests. | 2.3.1 Performance Monitoring Unit on page 2-36.   | All revisions. |
| Clarified note about configurable values.      | 2.4.1 SMMUv3 support on page 2-48.                | All revisions. |
| Added note to SMMU_IIDR table entry.           |                                                   |                |

# Table C-4 Differences between Issue 0001-00 and Issue 0001-01 (continued)

| Change                                                                                         | Location                                                         | Affects        |
|------------------------------------------------------------------------------------------------|------------------------------------------------------------------|----------------|
| Added note to clarify reset values of architectural registers.                                 | 3.2 SMMU architectural registers on page 3-57.                   | All revisions. |
| Modified incorrect entries for SMMU_S_GBPA in SMMUv3 architectural registers table.            |                                                                  |                |
| Modified introductory description of TCU_CTRL.                                                 | 3.7.1 TCU_CTRL on page 3-68.                                     | r0p1.          |
| Modified register name.                                                                        | 3.8.2 TCU_ERRCTLR on page 3-76. 3.12.2 TBU_ERRCTLR on page 3-85. | r0p1.          |
| Modified section title.  Removed dftclkenable signal.  Added mbistresetn and mbistreq signals. | A.11 TCU and TBU test and debug signals on page Appx-A-101.      | All revisions. |