

# **Arm® Address Translation Unit**

Version 1.0

# **Specification**

Non-Confidential

Copyright  $\ensuremath{\mathbb{Q}}$  2023 Arm Limited (or its affiliates). All rights reserved.

**Issue 01** 107714\_0000\_01\_en



# Arm® Address Translation Unit

# **Specification**

Copyright © 2023 Arm Limited (or its affiliates). All rights reserved.

#### Release information

#### **Document history**

| Issue   | Date        | Confidentiality  | Change          |
|---------|-------------|------------------|-----------------|
| 0000-01 | 31 May 2023 | Non-Confidential | Initial release |

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

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 ™ are registered trademarks or trademarks of Arm Limited (or its affiliates) 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 https://www.arm.com/company/policies/trademarks.

Copyright © 2023 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|version 21.0)

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

#### Feedback

Arm welcomes feedback on this product and its documentation. To provide feedback on the product, create a ticket on https://support.developer.arm.com

To provide feedback on the document, fill the following survey: https://developer.arm.com/documentation-feedback-survey.

# Inclusive language commitment

Arm values inclusive communities. Arm recognizes that we and our industry have used language that can be offensive. Arm strives to lead the industry and create change.

We believe that this document contains no offensive language. To report offensive language in this document, email terms@arm.com.

# **Contents**

| 1. Introduction                                                        |    |
|------------------------------------------------------------------------|----|
| 1.1 Conventions                                                        | 7  |
| 1.2 Useful resources                                                   | 8  |
| 1.3 Other information                                                  | 8  |
| 2. ATU overview                                                        | 9  |
| 2.1 Topology                                                           | 9  |
| 2.2 Terms used for the address-translation scheme                      | 10 |
| 2.3 Address translation scheme                                         | 11 |
| 2.3.1 Sample address-translation hardware flow                         | 13 |
| 2.3.2 Sample software address-translation setup examples               | 14 |
| 2.4 Uninitialized ATU                                                  | 14 |
| 3. Functional descriptions                                             | 15 |
| 3.1 ATU register block                                                 | 15 |
| 3.2 Address translator                                                 |    |
| 3.3 Hardware interfaces                                                | 15 |
| 3.3.1 APB4 subordinate programming port interface                      | 16 |
| 3.3.2 AXI subordinate interface                                        | 16 |
| 3.3.3 AXI manager interface                                            | 16 |
| 3.3.4 Interrupt and alarm interface                                    | 16 |
| 4. Configuration options                                               | 17 |
| 5. Programmers model                                                   | 19 |
| 5.1 ATU register summary                                               | 20 |
| 5.1.1 ATUBC, Build Configuration register                              | 21 |
| 5.1.2 ATUC, Configuration register                                     | 22 |
| 5.1.3 ATUIS, Interrupt Status register                                 | 23 |
| 5.1.4 ATUIE, Interrupt Enable register                                 | 24 |
| 5.1.5 ATUIC, Interrupt Clear register                                  | 24 |
| 5.1.6 ATUMA, Mismatched Address register                               | 25 |
| 5.1.7 ATURSSLA <n>, Right Shifted Start Logical Address n register</n> | 26 |

| 5.1.8 ATURSELA <n>, Right Shifted End Logical Address n register</n> | 27 |
|----------------------------------------------------------------------|----|
| 5.1.9 ATURAV_L <n>, Region AddValue Low n the register</n>           | 27 |
| 5.1.10 ATURAV_H <n>, Region AddValue High n register</n>             | 28 |
| 5.1.11 ATUROBA <n>, Region Output Bus Attributes n register</n>      | 30 |
| 5.1.12 ATURGPV <n>, Region General Purpose n register</n>            | 32 |
| 5.1.13 PIDR4, Peripheral ID 4 register                               | 33 |
| 5.1.14 PIDRO, Peripheral ID 0 register                               | 33 |
| 5.1.15 PIDR1, Peripheral ID 1 register                               | 34 |
| 5.1.16 PIDR2, Peripheral ID 2 register                               | 35 |
| 5.1.17 PIDR3, Peripheral ID 3 register                               | 36 |
| 5.1.18 CIDRO, Component ID 0 register                                | 36 |
| 5.1.19 CIDR1, Component ID 1 register                                | 37 |
| 5.1.20 CIDR2, Component ID 2 register                                | 38 |
| 5.1.21 CIDR3, Component ID 3 register                                | 38 |
| 6. Typical software flows                                            | 40 |
| 6.1 Enable a translation region                                      | 40 |
| 6.2 Disable a translation region                                     | 40 |
| 6.3 Dynamically remap an enabled translation region                  | 41 |
| 6.4 Block access to disabled address ranges                          | 41 |
| 6.4.1 Software analysis flow when SAM resets the subsystem           | 42 |
| 6.4.2 Software analysis flow when SAM interrupts the subsystem       | 43 |
| 6.4.3 Software analysis flow when ATU interrupts the subsystem       | 45 |
| 6.4.4 Software analysis flow when ATU responds with bus error        | 45 |
| Δ Revisions                                                          | 46 |

# 1. Introduction

# 1.1 Conventions

The following subsections describe conventions used in Arm documents.

### 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 Glossary for more information: developer.arm.com/glossary.

## Typographic conventions

Arm documentation uses typographical conventions to convey specific meaning.

| Convention                 | Use                                                                                                                                                                    |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| italic                     | Citations.                                                                                                                                                             |
| bold                       | Interface elements, such as menu names.                                                                                                                                |
|                            | Terms in descriptive lists, where appropriate.                                                                                                                         |
| monospace                  | Text that you can enter at the keyboard, such as commands, file and program names, and source code.                                                                    |
| monospace <u>underline</u> | A permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name.                                        |
| <and></and>                | Encloses replaceable terms for assembler syntax where they appear in code or code fragments.                                                                           |
|                            | For example:                                                                                                                                                           |
|                            | MRC p15, 0, <rd>, <crn>, <opcode_2></opcode_2></crn></rd>                                                                                                              |
| SMALL CAPITALS             | Terms that have specific technical meanings as defined in the Arm® Glossary. For example, IMPLEMENTATION DEFINED, IMPLEMENTATION SPECIFIC, UNKNOWN, and UNPREDICTABLE. |
| Caution                    | Recommendations. Not following these recommendations might lead to system failure or damage.                                                                           |
| Warning                    | Requirements for the system. Not following these requirements might result in system failure or damage.                                                                |
| Danger                     | Requirements for the system. Not following these requirements will result in system failure or damage.                                                                 |
| Note                       | An important piece of information that needs your attention.                                                                                                           |

| Convention | Use Control of the Co |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| - Tip      | A useful tip that might make it easier, better or faster to perform a task.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Remember   | A reminder of something important that relates to the information you are reading.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

# 1.2 Useful resources

This document contains information that is specific to this product. See the following resources for other useful information.

Access to Arm documents depends on their confidentiality:

- Non-Confidential documents are available at developer.arm.com/documentation. Each document link in the following tables goes to the online version of the document.
- Confidential documents are available to licensees only through the product package.

| Arm product resources                                                    | Document ID | Confidentiality  |
|--------------------------------------------------------------------------|-------------|------------------|
| Arm® CoreLink™ SIE-200 System IP for Embedded Technical Reference Manual | DDI 0571    | Non-Confidential |

| Arm architecture and specifications       | Document ID | Confidentiality  |  |
|-------------------------------------------|-------------|------------------|--|
| AMBA® AXI Protocol Specification          | IHI 0022    | Non-Confidential |  |
| Arm® Security Alarm Manager Specification | 107716      | Non-Confidential |  |



Arm tests its PDFs only in Adobe Acrobat and Acrobat Reader. Arm cannot guarantee the quality of its documents when used with any other PDF reader.

Adobe PDF reader products can be downloaded at http://www.adobe.com

# 1.3 Other information

See the Arm website for other relevant information.

- Arm® Developer.
- Arm® Documentation.
- Technical Support.
- Arm® Glossary.

# 2. ATU overview

The Arm® Address Translation Unit (ATU) allows you to convert the Logical Address (LA) of an outgoing transaction that is initiated in the subsystem memory space to a *Physical Address* (PA) residing in the system memory.

The ATU gives you the flexibility to allocate for or share the compute environment memory regions with the subsystem. These regions are in any address within the system memory space, and decoupled from the LA mapping in the subsystem.

The ATU is informed of the security attributes of the incoming transaction from the subsystem computer environment at its subordinate AXI interface. This environment supports secure, non-secure, user, and admin privileges. The SoC can support four physical address spaces: Secure, Non-secure, Root, and Realm. To address that gap, the ATU provides a way to translate LA to PA. It also targets system addresses with rich security attributes according to the translation region as defined in the output bus attributes, see ATUROBA<n>, Region Output Bus Attributes n register.

The ATU serves as a firewall. Any attempt to access a LA which has no matching configured address region in the ATU results in an alarm signal which can be routed to an alarm manager entity, such as the *Arm® Security Alarm Manager* (SAM). You can configure the entity to react to this alarm from the ATU. Such reaction can be to reset the subsystem. Alternatively the alarm can set an IRQ for the processor of the subsystem.

For more information on the SAM, see the Arm® Security Alarm Manager Specification.

# 2.1 Topology

This topics provides information about the ATU components and interfaces.

The components of the ATU are as follows:

## 3.1 ATU register block on page 15

Configures the ATU and checks its status

#### 3.2 Address translator on page 15

Scans the incoming logical address and attempts to find a match in all the enabled regions according to the defined algorithm

#### 3.3 Hardware interfaces on page 15

The ATU includes several hardware interfaces, such as the APB4 subordinate programming port interface, the AXI subordinate interface, the AXI manager interface, and the Interrupt and alarm interface

#### ATU inputs and outputs

Figure 2-1: ATU inputs and outputs on page 10 shows the inputs and outputs connected to the operation of the ATU.

Figure 2-1: ATU inputs and outputs



The ATU in bus attributes input is the incoming security and caching attributes at the AXI subordinate interface. The ATU out bus attributes are programmable by the subsystem software for each address region according to the expected bus attributes of the target SoC.

The in bus and out bus attributes are as follows:

#### In bus attributes

AxProt[2:0], and AxCache[3:0] attributes.

#### Out bus attributes

AxProt[2:0], AxCache[3:0], and AxNSE attributes. The current ATU implementation assumes that the subsystem does not support AxNSE. However, the ATU supports AxNSE towards the external system.

The in bus attributes are evaluated by the matching address region in the AXI subordinate interface, and are forwarded or overridden as the out bus attributes at the AXI manager interface.

# 2.2 Terms used for the address-translation scheme

An overview of the relevant terms used in address-translation hardware flow.

The following terms are used for both the hardware address-translation flow and the software address-translation setup computation:

#### PS

The page size that the ATU supports. For example, for 4KB, PS for the following computation is 0xC.

#### LA

The subsystem's Logical Address (LA) which is input to the ATU. LA is a 32-bit address.

#### **PAW**

The SoC's Physical Address Width (PAW) configuration option.

#### PA

The system's Physical Address (PA) which is the output of the ATU. Its width is per ATUBC.PAW. PA width in bits = 32 + 4\*PAW.

#### **CRSLA**

The Computed Right Shifted (according to the ATU page size) Logical Address (CRSLA). The address bits within the page are removed. The size of CRSLA is 32-PS bits.

#### **CRSPA**

The Computed Right Shifted (according to the ATU page size) Physical Address (CRSPA). The address bits within the page are removed. The size of CRSPA is (32 + 4\*PAW)-PS bits.

#### NR

The number of regions that the ATU supports.

The following terms are only used for the software address-translation setup computation:

#### **RSLA**

The Right Shifted Logical Address.

#### **RSPA**

The Right Shifted Physical Address.

#### ATURAV L

Region Add Value Low n register.

#### ATURAV\_H

Region Add Value High n register.

# 2.3 Address translation scheme

The ATU compares the incoming 32-bit LA and the transaction size to the programmed regions setting. It produces the outgoing ATUPAW-bits wide PA using the address configuration of the matching region.

If the transaction LA and the transaction size do not match any of the programmed and enabled regions, the ATU blocks the transaction, responds with a bus error, and sets the ATUIS.ME register bit.

The outgoing PA size, ATUPAW, is a build-time configuration option.

The granularity of the ATU regions is by pages. ATU page size, ATUPS, is a build-time configuration option.

### Requirements for address translation

 An AXI burst must not pass the 4KB address boundary. ATU page sizes of less than 4KB are not supported. Otherwise, a single AXI transaction can pass the ATU page boundary which would require a more complex ATU end-region check. • The ATU validates that there is a match between the incoming address and an enabled region, <n>, if ((ATURSSLA<n>.RSSLA bit <= CRSLA) and (CRSLA<= ATURSELA<n>.RSELA bit)).

For more information about the ATURSSLA<n> register, see 5.1.7 ATURSSLA<n>, Right Shifted Start Logical Address n register on page 26.

For more information about the ATURSELA<n> register, see 5.1.8 ATURSELA<n>, Right Shifted End Logical Address n register on page 26.

- Software must make sure that there is no LA overlap in the enabled regions.
- ATURSELA<n>.RSELA bit is the LA of the last page within the region.

Software can set two different LA regions to map into same PA region. For example, to allow access to system memory content as data from one LA region, then access this content as code from another logical address region.

#### **Process**

The ATU finds the accessed region using the LA and the transaction size. Then it constructs the PA as follows:

- 1. The LA is right shifted by the value of ATUBC.PS bits, and the least significant address bits within a page are dropped. The result is the Computed Right Shifted Logical Address (CRSLA).
- 2. The CRSLA is checked to ensure that:
  - It is higher than or equal to ATURSSLA<n>.RSSLA bits
  - It is lower than or equal to ATURSELA

If there is a match in only one enabled address region <n>:

- The CRSLA is added to the concatenation of ATURAV\_H<n>.AddValue\_M and ATURAV L<n>.AddValue L. This result is known as the adder result.
- The adder result is left shifted by the bit value of ATUBC.PS. Then it is ORed with the remaining page size related to the least significant address bits from the LA. The result is the output PA.



For more information about the ATURAV\_H<n>.AddValue\_M, see 5.1.10 ATURAV\_H<n>, Region AddValue High n register on page 28.

For more information about the ATURAV\_L<n>.AddValue\_L, see 5.1.9 ATURAV\_L<n>, Region AddValue Low n the register on page 27.

If there is a mismatch or there is more than one enabled address region <n>, the ATU:

- Blocks the access and responds to the originator with a bus error
- Sets the ATUIS.ME register bit
- Captures the mismatched LA in the ATUMA register

For more information about the ATUIS register, see 5.1.3 ATUIS, Interrupt Status register on page 23.

# 2.3.1 Sample address-translation hardware flow

We provide an example for the sample hardware flow.

The snippet shows a sample hardware address-translation.

```
CRSLA = LA >> PS
   MatchesFound = 0
3. On all regions (from n = 0 to NR-1)
    The following operation is implemented in all regions that are parallel to
    one another, to complete the operation in minimal time.
    If (ATUC.n & (ATURSSLA<n>.RSSLA <= CRSLA) & (CRSLA <= ATURSELA<n>.RSELA)),
    then:
    a. MatchesFound += 1
    b. AddValue = (ATURAV H<n>.AddValue M<<32) | ATURAV L<n>.AddValue L
        AddValue size is (\overline{3}2 + 4 \times PAW) - P\overline{S} bits.
        PA = ((AddValue + CRSLA) \< \&lt; PS) + (LA & (2 < sup > PS < / sup > -1))
    Notes:
        - AddValue is the right shifted (according to the ATU page size)
        value to add to the CRSLA. It is a (32 + 4 \times PAW)-PS bits value.
        - If the PA result is less than the LA then the AddValue is a
        negative number, that is its MS bits are FFs.
        - The adder of each region is of \[(32 + 4\)^*PAW) - PS\] bits wide.
        It adds AddValue of [(32 + 4)^PAW) - PS] bits to CRSLA of [32-PS] bits
    - Software must assure that there is no overlap in the ATU regions, such that only one match will be found by the hardware.
    - If an overlap of more than one region is found or considered as a software
    bug, then the ATU must block the transaction to the SoC and respond with
    a bus error.
    Then it raise an interrupt bit in the ATUIS register.
4. If (MatchesFound == 1)
      a. Forward the transaction using the translated address.
      b. Set the out bus attributes according to the setup in the ATUROBA<n>
      register.
5. Else (Either MatchesFound == 0 or MatchesFound > 1)
      It is either software bug or an attack. Then, do the following:
      a. Block the access to system memory
      b. Respond with a bus error
      c. Set the ATUIS.ME field
      d. Latch the mismatched LA in the ATUMA.MA bit value
```

The coalesced interrupt output from the ATU can be connected to the SAM (or similar function). When the ATUIS.ME and the ATUIE.ME bits are set, the coalesce interrupt output is set, and the ATUERR alarm event can be registered by the function (for example SAM).

# 2.3.2 Sample software address-translation setup examples

We provide examples for for the sample software address-translation setup.

If the value of the PA is lower than the value of the LA, then the SW must compute an add value with FFs in its top bits. This value must be the sum of the add value and the RSLA result with a lower PA value. The overflow top bits of the add operation are ignored.

#### Example 1 - Step-down address translation

```
PS = 0xC (4KB)
LA = 0x30000000
PAW = 6 (56 bits)
PA = 0x00000000_00D000000
SW computation:
RSLA = 0x30000
RSPA = 0x000_00000D00
Add = RSPA - RSLA = 0x000_0000D00 - 0x30000 = 0xFFF_FFD0D00
ATURAV_L = 0xFFFD0D00
ATURAV_H = 0x000000FFF
```

# Example 2 - Step-up address translation (most significant supported bit of the PA (bit 55) is set)

```
PS = 0xC (4KB)
LA = 0x30000000
PAW = 6 (56 bits)
PA = 0x00800000_30D000000
SW computation:
RSLA = 0x30000
RSPA = 0x800_00030D00
Add = RSPA - RSLA = 0x800_00030D00 - 0x30000 = 0x00000800_0000D00
ATURAV_L = 0x00000D00
ATURAV_H = 0x00000800
```

# 2.4 Uninitialized ATU

When the ATU is uninitialized, its regions are not enabled, and any attempt to access any system memory address fails.

This failure results in the following:

- A bus error occurs
- The transaction to the SoC is blocked
- The ATUIS.MF bit is set.
- The mismatched LA is latched in the ATUMA
- A mismatch is considered as a security breach. Its interrupt is enabled by default, and is also conveyed to the SAM.

# 3. Functional descriptions

The ATU has several components that provide different functionality.

# 3.1 ATU register block

Software uses the ATU register block to configure the ATU and check its status.

For more information on the ATU registers and their properties, see the Programmers model.

# 3.2 Address translator

The ATU address translator operation starts when a read or write transaction is detected at its AMBA AXI subordinate interface.

The address translator scans the incoming logical address and attempts to find a match in all the enabled regions, according to the algorithm that the Address translation scheme defines. If there is no match, the interrupt, ATUIRQ and alarm signal, ATUERR, are set.

# 3.3 Hardware interfaces

The ATU has several hardware interfaces, each with its own role.

The list of hardware interfaces are as follows:

### APB4 subordinate programming port interface

The ATU includes an AMBA APB4 subordinate programming port interface that the subsystem software uses to control the ATU operation and read its status.

#### **AXI** subordinate interface

The ATU includes an AXI subordinate interface that the subsystem software or hardware uses to access the system address space for reads and writes.

#### **AXI** manager interface

The ATU includes an AXI manager interface used by the ATU to generate the outgoing AXI transaction to the system memory.

#### Interrupt and alarm interface

The ATU includes an interrupt and alarm interface.

# 3.3.1 APB4 subordinate programming port interface

The ATU includes an AMBA APB4 subordinate programming port interface that the subsystem software uses to control the ATU operation and read its status.

The APB4 subordinate programming port interface does not filter transactions according to their security attributes, Secure or Non-secure, or their privilege level attributes. To filter these transactions, we recommend controlling the ATU APB4 subordinate programming port interface using an Arm TrustZone® Peripheral Protection Controller (PPC). For more details about the APB4 TrustZone PPC, see the Arm® CoreLink™ SIE-200 System IP for Embedded Technical Reference Manual.

For more information about the memory map and registers exposed in the APB4 subordinate programming port interface, see the Programmers model.

#### 3.3.2 AXI subordinate interface

The ATU includes an AXI subordinate interface that the subsystem software or hardware uses to access the system address space for reads and writes.

The ATU uses the incoming address as its logical address input, and uses the incoming security and caching attributes as its in bus attributes input in the AXI subordinate interface.

# 3.3.3 AXI manager interface

The ATU includes an AXI manager interface used by the ATU to generate the outgoing AXI transaction to the system memory.

The ATU uses the address as its physical address output, and uses the security and caching attributes as its out bus attributes output in the AXI manager interface, which replace those coming from the AXI subordinate interface according to the the programmed ATU translation scheme in the ATUROBA<n> register.

# 3.3.4 Interrupt and alarm interface

The ATU includes an interrupt and alarm interface.

The following table lists the interrupt and alarms used by the interface.

Table 3-1: Interrupt and alarm interface signals

| Signal name | Туре      | Trigger                                   |
|-------------|-----------|-------------------------------------------|
| ATUIRQ      | Interrupt | A non-matching incoming address           |
| ATUERR      | Alarm     | A non-matching incoming address           |
| ATUPARERR   | Alarm     | A parity error in the ATU register values |

# 4. Configuration options

The ATU provides configuration options to configure its features and components.

The following table describes the configuration options of the ATU.

Table 4-1: ATU configuration options

| Configuration parameter name | Allowed values                                                                                     | Default<br>values | Description                                                                                                                                                                                                                                                                                                                                          |
|------------------------------|----------------------------------------------------------------------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ATUNTR                       | 1 = 2<br>regions<br>2 = 4<br>regions<br>3 = 8<br>regions<br>4 = 16<br>regions<br>5 = 32<br>regions | NA                | Selects the number of translation regions that the ATU supports. This value is reflected in the ATUBC.NTR bit.                                                                                                                                                                                                                                       |
| ATUPS                        | 0xC = 4096 bytes   0xD = 8192 bytes   0xE = 16384 bytes                                            | NA                | Selects the page size granularity that the ATU supports. This value is reflected in the ATUBC.PS bit.  Note:  An AXI burst must not pass the 4KB address boundary. The ATU page sizes of less than 4KB are not supported, otherwise a single AXI transaction can pass the ATU page boundary which would require a more complex ATU end-region check. |

| Configuration parameter name | Allowed values | Default<br>values | Description                                                                                                                                               |
|------------------------------|----------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| ATUPAW                       | 0 = 32<br>bits | NA                | Selects the SoC's physical address width. This value affects the adders of the ATU and ATURAV_H <n> registers, and is reflected in the ATUBC.PAW bit.</n> |
|                              | 1 = 36<br>bits |                   |                                                                                                                                                           |
|                              | 2 = 40<br>bits |                   |                                                                                                                                                           |
|                              | 3 = 44<br>bits |                   |                                                                                                                                                           |
|                              | 4 = 48<br>bits |                   |                                                                                                                                                           |
|                              | 5 = 52<br>bits |                   |                                                                                                                                                           |
|                              | 6 = 56<br>bits |                   |                                                                                                                                                           |
|                              | 7 = 64<br>bits |                   |                                                                                                                                                           |

# 5. Programmers model

This chapter provides general information about the ATU register properties.

The following information applies to ATU 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 results in unexpected 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 the reset value specified in the register summary table of each block

Access type is described as follows:

#### **RW**

Read/write

RO

Read-only

WO

Write-only

WI

Write ignore

#### RAZ/WI

Read as zero, write ignore

#### RAZW1C

Read as zero, write 1 to clear the respective bit in the register

# 5.1 ATU register summary

The ATU register summary table lists the registers in the ATU register block, where n is 0 to (ATUBC.NTR - 1).

Table 5-1: ATU register summary

| Offset | Name             | Access | Reset value | Width  | Description                                                                                                                                                                                                                                                                             |
|--------|------------------|--------|-------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x000  | ATUBC            | RO     | CFG_DEF     | 32-bit | ATU Build Configuration register. This register reflects the build configuration for software usage.                                                                                                                                                                                    |
|        |                  |        |             |        | Its reset value depends on the selected configuration parameter in Configuration options.                                                                                                                                                                                               |
|        |                  |        |             |        | ATUNTR is reflected in the ATUBC.NTR                                                                                                                                                                                                                                                    |
|        |                  |        |             |        | ATUPS is reflected in the ATUBC.PS                                                                                                                                                                                                                                                      |
|        |                  |        |             |        | ATUPAW is reflected in the ATUBC.PAW                                                                                                                                                                                                                                                    |
| 0x004  | ATUC             | RW     | 0x0000_0000 | 32-bit | ATU Configuration register. This register controls each ATU configuration.                                                                                                                                                                                                              |
| 0x008  | ATUIS            | RO     | 0x0000_0000 | 32-bit | ATU Interrupt Status register. This register indicates the current interrupt events.                                                                                                                                                                                                    |
| 0x00C  | ATUIE            | RW     | 0x0000_0001 | 32-bit | ATU Interrupt Enable register. This register is used to enable the corresponding interrupt events.                                                                                                                                                                                      |
| 0x010  | ATUIC            | RW     | 0x0000_0000 | 32-bit | ATU Interrupt Clear register. This register is used to clear the corresponding interrupt events.                                                                                                                                                                                        |
| 0x014  | ATUMA            | RO     | 0x0000_0000 | 32-bit | ATU Mismatched Address register. This register holds the last mismatched Logical Address which caused bus error and interrupt event.                                                                                                                                                    |
| 0x018  | Reserved         | RAZ/WI | 0x0000_0000 | 32-bit | Reserved                                                                                                                                                                                                                                                                                |
| 0x01C  | Reserved         | RAZ/WI | 0x0000_0000 | 32-bit | Reserved                                                                                                                                                                                                                                                                                |
| 0x020  | ATURSSLA <n></n> | RW     | 0x0000_0000 | 32-bit | ATU Right Shifted Start Logical Address n register. This register defines the starting Logical Address for region n. The number of regions n depends on the ATUNTR configuration parameter.                                                                                             |
| 0x0A0  | ATURSELA <n></n> | RW     | 0x0000_0000 | 32-bit | ATU Right Shift End Logical Address n register. This register defines the End Logical Address for region n. The number of regions n depends on the ATUNTR configuration parameter.                                                                                                      |
| 0x120  | ATURAV_L <n></n> | RW     | 0x0000_0000 | 32-bit | ATU Region Add Value Low n register. This register, along with the ATURAV_H register, defines the offset to be added to the incoming Logical Address, to compute the result, the Physical Address for region n. The number of regions n depends on the ATUNTR configuration parameter.  |
| 0x1A0  | ATURAV_H <n></n> | RW     | 0x0000_0000 | 32-bit | ATU Region Add Value High n register. This register, along with the ATURAV_L register, defines the offset to be added to the incoming Logical Address, to compute the result, the Physical Address for region n. The number of regions n depends on the ATUNTR configuration parameter. |
| 0x220  | ATUROBA <n></n>  | RW     | 0x0000_8000 | 32-bit | ATU Region Output Bus Attributes n register. This register defines how the input bus attributes are transferred to the output bus attributes.                                                                                                                                           |
| 0x2A0  | ATURGPV <n></n>  | RW     | 0x0000_0000 | 32-bit | ATU Region General Purpose n register. This register serves the software and is not used by the ATU hardware.                                                                                                                                                                           |
| -      | Reserved         | RAZ/WI | 0x0000_0000 | 32-bit | Reserved                                                                                                                                                                                                                                                                                |
| 0xFCC  | 2000             | 5.0    |             | 00.11  |                                                                                                                                                                                                                                                                                         |
| 0xFD0  | PIDR4            | RO     | 0x0000_0004 | 32-bit | The Peripheral ID4 register returns byte[4] of the peripheral ID.                                                                                                                                                                                                                       |

| Offset     | Name     | Access | Reset value | Width  | Description                                                        |
|------------|----------|--------|-------------|--------|--------------------------------------------------------------------|
| 0xFD4      | Reserved | RAZ/WI | 0x0000_0000 | 32-bit | Reserved                                                           |
| -<br>0xFDC |          |        |             |        |                                                                    |
| 0xFE0      | PIDRO    | RO     | 0x0000_00C0 | 32-bit | The Peripheral ID0 register. Returns byte[0] of the peripheral ID. |
| 0xFE4      | PIDR1    | RO     | 0x0000_00B3 | 32-bit | The Peripheral ID1 register. Returns byte[1] of the peripheral ID. |
| 0xFE8      | PIDR2    | RO     | 0x0000_000B | 32-bit | The Peripheral ID2 register. Returns byte[2] of the peripheral ID. |
| 0xFEC      | PIDR3    | RO     | 0x0000_0000 | 32-bit | The Peripheral ID3 register. Returns byte[3] of the peripheral ID. |
| 0xFF0      | CIDRO    | RO     | 0x0000_000D | 32-bit | The Component IDO register. Returns byte[0] of the component ID.   |
| 0xFF4      | CIDR1    | RO     | 0x0000_00F0 | 32-bit | The Component ID1 register. Returns byte[1] of the component ID.   |
| 0xFF8      | CIDR2    | RO     | 0x0000_0005 | 32-bit | The Component ID2 register. Returns byte[2] of the component ID.   |
| 0xFFC      | CIDR3    | RO     | 0x0000_00B1 | 32-bit | The Component ID3 register. Returns byte[3] of the component ID.   |

# 5.1.1 ATUBC, Build Configuration register

The ATUBC register reflects the ATU build configuration to the software.

# Configurations

This register is available in all configurations.

**Attributes** 

Width

32

**Functional group** 

ATU register summary

Address offset

0x000

Type

RO

Reset value

CFG DEF

## Bit descriptions

The following table shows the register bit assignments.

#### Table 5-2: ATUBC register bit description

| Bits    | Name | Description | Туре | Reset |
|---------|------|-------------|------|-------|
| [31:12] | -    | Reserved    | RAZ/ | 0x0   |
|         |      |             | WI   |       |

| Bits   | Name | Description                                                                                                                                                     | Туре       | Reset  |
|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------|
| [11:8] | PAW  | The physical address width of the SoC. This value affects the address of the ATU and the ATURAV_H <n> registers.</n>                                            | RO         | ATUPAW |
|        |      | The ATUPAW configuration option defines the supported values in Configuration options                                                                           |            |        |
|        |      | Physical address width in bits = 32 + 4*PAW.                                                                                                                    |            |        |
| [7:4]  | PS   | Page size. It is the region granularity and alignment in bytes.                                                                                                 | RO         | ATUPS  |
|        |      | The ATUPS configuration option defines the supported values in Configuration options                                                                            |            |        |
| [3]    | -    | Reserved                                                                                                                                                        | RAZ/<br>WI | 0x0    |
| [2:0]  | NTR  | Number of translation regions. Specifies the number of available regions. The ATUNTR configuration option defines the supported values in Configuration options | RO         | ATUNTR |

# 5.1.2 ATUC, Configuration register

The ATUC register is used by software to control each ATU configuration.

### Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

#### **Functional group**

ATU register summary

#### Address offset

0x004

Type

RW

## Reset value

0x0000\_0000

# Bit descriptions

The following table shows the register bit assignments.

### **Table 5-3: ATUC bit descriptions**

| Bits   | Name | Description | Туре | Reset  |
|--------|------|-------------|------|--------|
| [31:n] | -    | Reserved    | RAZ/ | 0x0000 |
|        |      |             | WI   |        |

| Bits      | Name | Description                                                                                         | Type | Reset       |
|-----------|------|-----------------------------------------------------------------------------------------------------|------|-------------|
| [(n-1):0] | RE   | ATU regions enablement. The bit that is set enables its corresponding region, where n=the ATUBC.NTR | RW   | 0x0000_0000 |
|           |      | n = ATUBC.NTR                                                                                       |      |             |
|           |      | Then the number of implemented bits [(n-1):0] is according to the ATUBC.NTR bit value:              |      |             |
|           |      | Bit 0                                                                                               |      |             |
|           |      | Enable Region 0                                                                                     |      |             |
|           |      | Bit 1                                                                                               |      |             |
|           |      | Enable Region 1                                                                                     |      |             |
|           |      | Bit n-1                                                                                             |      |             |
|           |      | Enable Region n-1                                                                                   |      |             |

# 5.1.3 ATUIS, Interrupt Status register

The ATUIS register indicates the status of the current interrupt events.

# Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

#### **Functional group**

ATU register summary

#### Address offset

0x008

Type

RO

#### Reset value

0x0000 0000

## Bit descriptions

The following table shows the register bit assignments.

#### Table 5-4: ATUIS bit descriptions

| Bits   | Name | Description                                                                                                            | Туре       | Reset |
|--------|------|------------------------------------------------------------------------------------------------------------------------|------------|-------|
| [31:1] | -    | Reserved                                                                                                               | RAZ/<br>WI | 0x0   |
| [O]    | ME   | Mismatch Error. Indicates an address mismatch error. When set, the ATUMA register holds the offending Logical Address. | RO         | 0x0   |

# 5.1.4 ATUIE, Interrupt Enable register

The ATUIE register is used to enable corresponding interrupt events. When the interrupt enable field is set and the corresponding interrupt event in the status register is set, the coalesced interrupt output is asserted.

# Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

## **Functional group**

ATU register summary

#### Address offset

0x00C

Type

RW

#### Reset value

0x0000 0001

## Bit descriptions

The following table shows the register bit assignments.

#### Table 5-5: ATUIE register bit description

| Bits   | Name | Description                     | Туре   | Reset |
|--------|------|---------------------------------|--------|-------|
| [31:1] | -    | Reserved                        | RAZ/WI | 0x0   |
| [O]    | ME   | Enable Mismatch Error interrupt | RW     | 0x1   |

# 5.1.5 ATUIC, Interrupt Clear register

The ATUIC register clears the corresponding interrupt events.

### Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

#### **Functional group**

ATU register summary

#### Address offset

0x010

Type

RW

Reset value

0x0000 0000

#### Bit descriptions

The following table shows the register bit assignments.

#### Table 5-6: ATUIC register bit description

| Bits   | Name | Description                                                             | Туре   | Reset |
|--------|------|-------------------------------------------------------------------------|--------|-------|
| [31:1] | -    | Reserved                                                                | RAZ/WI | 0x0   |
| [O]    | ME   | When written as 1, clears the ME interrupt status in the ATUIS register | razW1C | 0x0   |

# 5.1.6 ATUMA, Mismatched Address register

The ATUMA register indicates the offending mismatched logical address that caused the ATU to reject the access to the system memory and caused the bus error or the interrupt.

### Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

#### **Functional group**

ATU register summary

#### Address offset

0x014

Type

RO

#### Reset value

0x0000 0000

#### Bit descriptions

The following table shows the register bit assignments.

#### Table 5-7: ATUMA register bit description

| Bits   | Name | Description                                                                                          | Туре | Reset |
|--------|------|------------------------------------------------------------------------------------------------------|------|-------|
| [31:0] | MA   | Mismatch Address. Indicates the offending mismatched logical address that caused the mismatch error. | RO   | 0x0   |

# 5.1.7 ATURSSLA<n>, Right Shifted Start Logical Address n register

The ATURSSLA<n> register indicates the right shifted start logical address of region <n>. The access to addresses between the ATURSSLA<n> and the ATURSELA<n> registers is allowed by the ATU.

If all the enabled regions do not allow access, then the transaction is blocked.

### Configurations

The number of actual supported translation regions (ATUNTR) is a configuration option.

#### **Attributes**

#### Width

32

#### **Functional group**

ATU register summary

#### Address offset

0x020

### Type

- RW
- Unimplemented region registers are implemented as RAZ/WI

#### Reset value

0x0000 0000

#### Bit descriptions

The following table shows the register bit assignments.

#### Table 5-8: ATURSSLA<n> regiser bit description

| Bits            | Name  | Description                                                                                            | Туре       | Reset       |
|-----------------|-------|--------------------------------------------------------------------------------------------------------|------------|-------------|
| [31:(PS<br>+1)] | -     | Reserved                                                                                               | RAZ/<br>WI | 0×0         |
| [PS:0]          | RSSLA | Right Shifted Start LA used for the corresponding region. Page Size (PS) refers to the ATUBC.PS bit.   | RW         | 0x0000_0000 |
|                 |       | The value stored in this field is the start LA, on the last page right shifted by the value of the PS. |            |             |

# 5.1.8 ATURSELA<n>, Right Shifted End Logical Address n register

The ATURSELA<n> register indicates the right shifted end logical address of region <n>. ATU allows access to the address between the ATURSSLA<n> and the ATURSELA<n> registers. If all of the enabled regions do not allow access, then the transaction is blocked.

#### Configurations

The number of actual supported translation regions (ATUNTR) is a configuration option.

#### **Attributes**

Width

32

#### **Functional group**

ATU register summary

#### Address offset

0x0A0

#### Type

- RW
- Unimplemented region registers are implemented as RAZ/WI

#### Reset value

0x0000 0000

#### Bit descriptions

The following table shows the register bit assignments.

#### Table 5-9: ATURSELA<n> register bit description

| Bits            | Name  | Description                                                                                                           | Туре       | Reset       |
|-----------------|-------|-----------------------------------------------------------------------------------------------------------------------|------------|-------------|
| [31:(PS<br>+1)] | -     | Reserved                                                                                                              | RAZ/<br>WI | 0x0         |
| [PS:0]          | RSELA | Right Shifted End logical address used for the corresponding region. Page Size (PS) refers to the ATUBC.PS bit.       | RW         | 0x0000_0000 |
|                 |       | The value stored in this field is the end logical address within the last page, right shifted by the value of the PS. |            |             |

# 5.1.9 ATURAV\_L<n>, Region AddValue Low n the register

The ATURAV\_L<n> register indicates the least significant bits of AddValue of region <n>.

AddValue is the concatenation of ATURAV\_H<n> and ATURAV\_L<n> registers to a (32 + 4\*PAW)-PS bits value.

AddValue = (ATURAV H<n>.AddValue M<<32) | ATURAV L<n>.AddValue L

# Configurations

The number of actual supported translation regions (ATUNTR) is a configuration option.

#### **Attributes**

#### Width

32

#### **Functional group**

ATU register summary

#### Address offset

0x120

#### Type

- RW
- Unimplemented region registers are implemented as RAZ/WI

#### Reset value

0x0000\_0000

## Bit descriptions

The following table shows the register bit assignments.

Table 5-10: ATURAV\_L<n> register bit description

| Bits                                                               | Name       | Description                                                                                                                                                                    | Туре       | Reset       |
|--------------------------------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------|
| If (4*PAW - PS) < 0 Reserved field consumes (PS-4*PAW) bits.       | -          | Reserved                                                                                                                                                                       | RAZ/<br>WI | 0x0         |
| If (4*PAW - PS) >= 0                                               |            |                                                                                                                                                                                |            |             |
| Reserved field is of 0 bits (does not exist).                      |            |                                                                                                                                                                                |            |             |
| If (4*PAW - PS) < 0 AddValue_L field consumes 32- (PS-4*PAW) bits. | AddValue_L | LS bits of the AddValue used for the corresponding region. Page Size (PS) refers to the ATUBC.PS bit.  The value stored in this field is the LS bits of AddValue right shifted | RW         | 0x0000_0000 |
| If (4*PAW - PS) >= 0  AddValue_L field  consumes 32 bits.          |            | by the value of the PS. The MS bits are stored in the ATURAV_H <n> register.</n>                                                                                               |            |             |

# 5.1.10 ATURAV\_H<n>, Region AddValue High n register

The ATURAV\_H<n> register indicates the most significant bits of AddValue of region <n>.

AddValue is the concatenation of ATURAV\_H<n> and ATURAV\_L<n> registers to a (32 + 4\*PAW)-PS bits value.

AddValue = (ATURAV\_H<n>.AddValue\_M<<32) | ATURAV\_L<n>.AddValue\_L

## Configurations

The number of actual supported translation regions (ATUNTR) is a configuration option.

#### **Attributes**

#### Width

32

## **Functional group**

ATU register summary

#### Address offset

0x1A0

### Type

- RW
- Unimplemented region registers are implemented as RAZ/WI

#### Reset value

0x0000 0000

### Bit descriptions

The following table shows the register bit assignments.

#### Table 5-11: ATURAV\_H<n> register bit description

| Bits                                                     | Name       | Description                                                                                        | Туре       | Reset       |
|----------------------------------------------------------|------------|----------------------------------------------------------------------------------------------------|------------|-------------|
| If (4*PAW-PS) < 0 Reserved field consumes 32 bits.       | -          | Reserved                                                                                           | RAZ/<br>WI | 0x0         |
| If (4*PAW-PS) >= 0  Reserved field                       |            |                                                                                                    |            |             |
| consumes 32-<br>(4*PAW-PS) bits.                         |            |                                                                                                    |            |             |
| If (4*PAW-PS) < 0                                        | AddValue_M |                                                                                                    | RW         | 0x0000_0000 |
| AddValue_M field<br>consumes 0 bits<br>(does not exist). |            | (PS) refers to ATUBC.PS bit. Physical Address Width (PAW) refers to the ATUBC.PAW bit.             |            |             |
| If (4*PAW-PS) >= 0                                       |            | The value stored in this field is the MS 32 bits of AddValue right shifted by the value of the PS. |            |             |
| AddValue_M<br>field consumes<br>(4*PAW-PS) bits.         |            | by the value of the F3.                                                                            |            |             |

# 5.1.11 ATUROBA<n>, Region Output Bus Attributes n register

The ATUROBA<n> register indicates the output bus attributes of region <n>.

The AxCACHE3.. AxCACHE0 must be programmed so that the resulting AxCACHE[3:0] values comply with the values available in the AMBA® AXI Protocol Specification. AxCACHE[3:0] must not be one of 0b0100, 0b0101, 0b1100, or 0b1101.

## Configurations

The number of actual supported translation regions (ATUNTR) is a configuration option.

#### **Attributes**

#### Width

32

#### **Functional group**

ATU register summary

#### Address offset

0x220

#### Type

- RW
- Unimplemented region registers are implemented as RAZ/WI

#### Reset value

0x0000\_8000

#### Bit descriptions

The following table shows the register bit assignments.

#### Table 5-12: ATUROBA<n> register bit description

| Bits    | Name  | Description                                                                                                                                                     | Туре       | Reset |
|---------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------|
| [31:16] | -     | Reserved                                                                                                                                                        | RAZ/<br>WI | 0x0   |
| [15:14] | AxNSE | Affects the AxNSE signal at the main AXI Interconnect which goes to the SoC. Supported values are as follows:                                                   | RW         | 0b10  |
|         |       | 0b00 - Reserved                                                                                                                                                 |            |       |
|         |       | 0b01 - Reserved                                                                                                                                                 |            |       |
|         |       | 0b10 - Set 0. AxNSE of the output bus is set to 0                                                                                                               |            |       |
|         |       | 0b11 - Set 1. AxNSE of the output bus is set to 1                                                                                                               |            |       |
|         |       | When the RME is supported in the SoC, the AxNSE signal is used with the AxPROT[1] signal to allow access to the Realm physical address space of the target SoC. |            |       |
|         |       | For information about the AxNSE signal, see AMBA® AXI Protocol Specification.                                                                                   |            |       |

| Bits    | Name     | Description                                                                                                                 | Туре | Reset |
|---------|----------|-----------------------------------------------------------------------------------------------------------------------------|------|-------|
| [13:12] | AxCACHE3 | Affects the AxCACHE[3] signal (Other Allocate) at the output bus which goes to the SoC. Supported values are as follows:    | RW   | 0000  |
|         |          | • 0b00 – Passthrough. AxCACHE[3] of the input bus is transferred as is to the output bus                                    |      |       |
|         |          | 0b01 - Reserved                                                                                                             |      |       |
|         |          | 0b10 - Set 0. AxCACHE[3] of the output bus is set to 0                                                                      |      |       |
|         |          | 0b11 - Set 1. AxCACHE[3] of the output bus is set to 1                                                                      |      |       |
| [11:10] | AxCACHE2 | Affects the AxCACHE[2] signal (Allocate) at the output bus which goes to the SoC. Supported values are as follows:          | RW   | 0b00  |
|         |          | 0b00 – Passthrough. AxCACHE[2] of the input bus is transferred as is to the output bus                                      |      |       |
|         |          | 0b01 - Reserved                                                                                                             |      |       |
|         |          | 0b10 - Set 0. AxCACHE[2] of the output bus is set to 0                                                                      |      |       |
|         |          | 0b11 - Set 1. AxCACHE[2] of the output bus is set to 1                                                                      |      |       |
| [9:8]   | AxCACHE1 | Affects the AxCACHE[1] signal (modifiable) at the output bus which goes to the SoC. Supported values are as follows:        | RW   | 0000  |
|         |          | 0b00 - Passthrough. AxCACHE[1] of the input bus is transferred as is to the output bus                                      |      |       |
|         |          | 0b01 - Reserved                                                                                                             |      |       |
|         |          | 0b10 - Set 0. AxCACHE[1] of the output bus is set to 0                                                                      |      |       |
|         |          | 0b11 - Set 1. AxCACHE[1] of the output bus is set to 1                                                                      |      |       |
| [7:6]   | AxCACHE0 | Affects the AxCACHE[0] signal (Bufferable) at the output bus which goes to the SoC. Supported values are as follows:        | RW   | 0000  |
|         |          | 0b00 - Passthrough. AxCACHE[0] of the input bus is transferred as is to the output bus                                      |      |       |
|         |          | 0b01 - Reserved                                                                                                             |      |       |
|         |          | 0b10 - Set 0. AxCACHE[0] of the output bus is set to 0                                                                      |      |       |
|         |          | 0b11 - Set 1. AxCACHE[0] of the output bus is set to 1                                                                      |      |       |
| [5:4]   | AxPROT2  | Affects the AxPROT[2] signal (Instruction access) at the output bus which goes to the SoC. Supported values are as follows: | RW   | 0000  |
|         |          | 0b00 - Passthrough. AxPROT[2] of the input bus is transferred as is to the output bus                                       |      |       |
|         |          | 0b01 - Reserved                                                                                                             |      |       |
|         |          | 0b10 - Set 0. AxPROT[2] of the output bus is set to 0                                                                       |      |       |
|         |          | 0b11 - Set 1. AxPROT[2] of the output bus is set to 1                                                                       |      |       |
| [3:2]   | AxPROT1  | Affects the AxPROT[1] signal (Non-secure access) at the output bus which goes to the SoC. Supported values are as follows:  | RW   | 0000  |
|         |          | • 0b00 – Passthrough. AxPROT[1] of the input bus is transferred as is to the output bus                                     |      |       |
|         |          | 0b01 - Reserved                                                                                                             |      |       |
|         |          | 0b10 - Set 0. AxPROT[1] of the output bus is set to 0                                                                       |      |       |
|         |          | 0b11 - Set 1. AxPROT[1] of the output bus is set to 1                                                                       |      |       |
| [1:0]   | AxPROT0  | Affects the AxPROT[0] signal (Privileged access) at the output bus which goes to the SoC. Supported values are as follows:  | RW   | 0000  |
|         |          | • 0b00 – Passthrough. AxPROT[0] of the input bus is transferred as is to the output bus                                     |      |       |
|         |          | 0b01 - Reserved                                                                                                             |      |       |
|         |          | 0b10 - Set 0. AxPROT[0] of the output bus is set to 0                                                                       |      |       |
|         |          | 0b11 - Set 1. AxPROT[0] of the output bus is set to 1                                                                       |      |       |

# 5.1.12 ATURGPV<n>, Region General Purpose n register

The ATURGPV<n> register is intended for general-purpose use of the software by storing software related values for region <n>. The hardware does not use the values stored in this register.

The idea is to put one software flag per region or attribute in this register, which describes the region to the software. An example use case is to mark which entity owns the destined physical address of this region, for example, a system-provided region versus a subsystem owned and managed region. Software can use the flags as a security measure when the address translation API is called.

# Configurations

The number of actual supported translation regions (ATUNTR) is a configuration option. For more information, see Configuration options.

#### **Attributes**

#### Width

32

### **Functional group**

ATU register summary

#### Address offset

0x2A0

#### Type

- RW
- Unimplemented region registers are implemented as RAZ/WI

#### Reset value

0x0000 0000

#### Bit descriptions

The following table shows the register bit assignments.

#### Table 5-13: ATUGPV<n> register bit description

| Bits   | Name  | Description             | Туре   | Reset |
|--------|-------|-------------------------|--------|-------|
| [31:8] | -     | Reserved                | RAZ/WI | 0x0   |
| [7:0]  | Value | Value. Used by software | RW     | 0x00  |

# 5.1.13 PIDR4, Peripheral ID 4 register

The Peripheral ID4 register returns byte[4] of the peripheral ID.

## Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

#### **Functional group**

ATU register summary

#### Address offset

0xFD0

Type

RO

#### Reset value

0x0000 0004

# Bit descriptions

The following table shows the register bit assignments.

Table 5-14: Peripheral ID 4 register bit description

| Bits   | Name  | Description                             | Туре | Reset    |
|--------|-------|-----------------------------------------|------|----------|
| [31:8] | -     | Reserved                                | -    | 0x000000 |
| [7:4]  | SIZE  | 4KB Count, the number of 4K pages used. | RO   | 0x0      |
|        |       | • 0x00:4K                               |      |          |
|        |       | • 0x01:8K                               |      |          |
|        |       | • 0x02: 16K                             |      |          |
|        |       | • 0x03:32K                              |      |          |
| [3:0]  | DES_2 | JEP106 Continuation Code                | RO   | 0x4      |

# 5.1.14 PIDRO, Peripheral ID 0 register

The Peripheral IDO register returns byte[0] of the peripheral ID.

### Configurations

This register is available in all configurations.

**Attributes** 

Width

32

### **Functional group**

ATU register summary

#### Address offset

0xFE0

Type

RO

#### Reset value

0x0000\_00C0

## Bit descriptions

The following table shows the register bit assignments.

Table 5-15: Peripheral ID 0 register bit description

| Bits   | Name            | Description                                            | Туре | Reset |
|--------|-----------------|--------------------------------------------------------|------|-------|
| [31:8] | -               | Reserved                                               | -    | 0x00  |
| [7:0]  | Peripheral ID 0 | PART_0, Identification register part number, bits[7:0] | RO   | 0xC0  |

# 5.1.15 PIDR1, Peripheral ID 1 register

The Peripheral ID1 register returns byte[1] of the peripheral ID.

## Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

# **Functional group**

ATU register summary

# Address offset

0xxFE4

Type

RO

#### Reset value

0x0000\_00B3

## Bit descriptions

The following table shows the register bit assignments.

Table 5-16: Peripheral ID 1 register bit description

| Bits   | Name   | Description                                     | Туре | Reset    |
|--------|--------|-------------------------------------------------|------|----------|
| [31:8] | -      | Reserved                                        | -    | 0x000000 |
| [7:4]  | DES_0  | JEP106 identification code, bits[3:0]           | RO   | 0xB      |
| [3:0]  | PART_1 | Identification register part number, bits[11:8] | RO   | 0x3      |

# 5.1.16 PIDR2, Peripheral ID 2 register

The Peripheral ID2 register returns byte[2] of the peripheral ID.

# Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

#### **Functional group**

ATU register summary

#### Address offset

0xFE8

Type

RO

#### Reset value

0x0000 000B

#### Bit descriptions

The following table shows the register bit assignments.

Table 5-17: Peripheral ID 2 register bit description

| Bits   | Name     | Description                          | Туре | Reset    |
|--------|----------|--------------------------------------|------|----------|
| [31:8] | _        | Reserved                             | _    | 0x000000 |
| [7:4]  | REVISION | Revision Code                        | RO   | 0x0      |
| [3]    | JEDEC    | JEDEC                                | RO   | 0x1      |
| [2:0]  | DES_1    | JEP106 identification code,bits[6:4] | RO   | 0x3      |

# 5.1.17 PIDR3, Peripheral ID 3 register

The Peripheral ID3 register returns byte[3] of the peripheral ID.

## Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

### **Functional group**

ATU register summary

#### Address offset

0xFEC

Type

RO

#### Reset value

0x0000 0000

# Bit descriptions

The following table shows the register bit assignments.

Table 5-18: Peripheral ID 3 register bit description

| Bits   | Name   | Description                  | Туре | Reset    |
|--------|--------|------------------------------|------|----------|
| [31:8] | -      | Reserved                     | -    | 0x000000 |
| [7:4]  | REVAND | Manufacturer revision number | RO   | 0x0      |
| [3:0]  | CMOD   | Customer Modified            | RO   | 0x0      |

# 5.1.18 CIDRO, Component ID 0 register

The Component IDO register returns byte[0] of the component ID.

### Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

### **Functional group**

ATU register summary

#### Address offset

0xFF0

Type

RO

#### Reset value

0x0000\_000D

### Bit descriptions

The following table shows the register bit assignments.

### Table 5-19: Component ID 0 register bit description

| Bits   | Name    | Description | Туре | Reset    |
|--------|---------|-------------|------|----------|
| [31:8] | -       | Reserved    | -    | 0x000000 |
| [7:0]  | PRMBL_0 | Preamble    | RO   | 0×0D     |

# 5.1.19 CIDR1, Component ID 1 register

The Component ID1 register returns byte[1] of the component ID.

## Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

#### **Functional** group

ATU register summary

#### Address offset

0xFF4

Type

RO

#### Reset value

0x0000\_00F0

#### Bit descriptions

The following table shows the register bit assignments.

#### Table 5-20: Component ID 1 register bit description

| Bits   | Name  | Description     | Туре | Reset    |
|--------|-------|-----------------|------|----------|
| [31:8] | -     | Reserved        | -    | 0x000000 |
| [7:4]  | Class | Component class | RO   | 0xF      |

| Bits  | Name    | Description | Туре | Reset |
|-------|---------|-------------|------|-------|
| [3:0] | PRMBL_1 | Preamble    | RO   | 0x0   |

# 5.1.20 CIDR2, Component ID 2 register

The Component ID2 register returns byte[2] of the component ID.

### Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

### **Functional group**

ATU register summary

#### Address offset

0xFF8

Type

RO

#### Reset value

0x0000 0005

#### Bit descriptions

The following table shows the register bit assignments.

Table 5-21: Component ID 2 register bit description

| Bits   | Name    | Description | Туре | Reset    |
|--------|---------|-------------|------|----------|
| [31:8] | -       | Reserved    | -    | 0x000000 |
| [7:0]  | PRMBL_2 | Preamble    | RO   | 0x05     |

# 5.1.21 CIDR3, Component ID 3 register

The Component ID3 register returns byte[3] of the component ID.

# Configurations

This register is available in all configurations.

#### **Attributes**

Width

32

# **Functional group**

ATU register summary

# Address offset

0xFFC

Type

RO

Reset value

0x0000\_00B1

# Bit descriptions

The following table shows the register bit assignments.

# Table 5-22: Component ID 3 register bit description

| Bits   | Name    | Description | Туре | Reset    |
|--------|---------|-------------|------|----------|
| [31:8] | -       | Reserved    | -    | 0x000000 |
| [7:0]  | PRMBL_3 | Preamble    | RO   | 0xB1     |

# 6. Typical software flows

There are several typical software flows that occur under specific circumstances.

# 6.1 Enable a translation region

External system memories or devices can be accessed if a translation region is enabled.

Before the processor or a DMA device in the subsystem in which the ATU is installed attempts to access the external system memories or devices, its software must enable a translation region for these accesses. If the target address is already part of the enabled region, then such enablement is not required.

The flow for enablement of a translation region is as follows:

- 1. Select an unused and disabled region. For example, region <n>
- 2. Configure the selected region registers:
  - RSLA<n>
  - RSPA<n>
  - ATURAV L<n>
  - ATURAV\_H<n>
  - ATUROBA<n>
  - ATURGPV<n>
- 3. Set bit <n> in ATUC register to enable the region

# 6.2 Disable a translation region

When an ATU region is no longer used by the processor or a DMA device, the translation region should be disabled.

When the processor or a DMA device in the subsystem, in which the ATU is installed, stops using an ATU region, its software must disable the translation region for further accesses to:

- Free the region for other purposes
- Trap further mistaken accesses to the unused region as a security countermeasure

The flow for disabling translation regions:

- 1. Select the region to be disabled. For example, region <n>
- 2. Ensure that there are no outstanding transactions using region <n>
- 3. Clear bit <n> in ATUC register to disable the region

# 6.3 Dynamically remap an enabled translation region

It is necessary to either enable a translation region or to extend the already enabled region when accessing unmapped system memories or devices.

When the processor or a DMA device in the subsystem in which the ATU is installed must access partially-unmapped system memories or devices, its software must extend the enabled region to include the new system address range.

If the translation region is not yet enabled, see Enable a translation region.

The flow for remapping an enabled translation region:

- 1. Select the active region to be changed. For example, region <n>
- 2. Ensure that there are no outstanding transactions using region <n>
- 3. Clear bit <n> in ATUC register to disable the region
- 4. Reconfigure the selected region registers:
  - RSLA<n>
  - RSPA<n>
  - ATURAV L<n>
  - ATURAV H<n>
  - ATUROBA<n>
  - ATURGPV<n>
- 5. Set bit <n> in ATUC register to enable the region

# 6.4 Block access to disabled address ranges

The ATU should block an address that is not enabled.

When the processor or a DMA device attempts to access a disabled address range, the ATU performs the following steps:

- 1. Blocks the access and returns a bus error. The response generated by the ATU is a SLVERR (2'b10) error on a write response (BRESP) or read response (RRESP) signal.
- 2. Sets the ME bit in the ATUIS register, which if set generates an ATUIRQ interrupt to the processor or a DMA device.
- 3. Sets the ATUERR signal, which is typically connected to the SAM.
- 4. The ATUMA register captures the offending address to allow software to analyze the cause of the error.

If the SAM subsystem is installed and programmed to generate a reset response for the ATU reported error, then the subsystem is reset including the ATU. Following the reset, the software can detect the cause of the reset by reading the RESET\_SYNDROME register of the subsystem, if available. The RESET\_SYNDROME register indicates the cause for the reset. The SAMWRSTREQ or SAMCRSTREQ bit is set in the RESET\_SYNDROME register of the subsystem, but because the ATU was reset, the ATUMA loses its value. Therefore, software cannot analyze the exact cause of the error.

If the error is sporadic, you can assume that it is because of an attack, and the reset response is an effective countermeasure.

However, if the error repeats, it is possible that a software error has occurred. In this case, it is important to know the exact offending address to fix the software bug.

If the ATU alarm event is connected to the SAM input event 5 and a software error is being analyzed:

- One option is that the software can replace the SAM reset response to one of the following interrupts:
  - Non-Maskable Interrupt (NMI), response 2
  - Critical Severity Fault Interrupt, response 3
  - Severity Fault Interrupt, response 4
- Another option is to disable the ATU input in the SAM and use the ATU interrupt. If the ATU input, the NMI, the Critical Severity Fault Interrupt, the Severity Fault Interrupt, and ATU interrupt are all disabled, the ATU still responds with a bus error to accesses to mismatch address. After one of these interrupts is serviced, software can read the ATUMA register to know the offending address.

For more information on the SAM, see the Arm® Security Alarm Manager Specification.

# 6.4.1 Software analysis flow when SAM resets the subsystem

After SAM resets the subsystem a specific analysis flow is used.

The following analysis flow is used after reset:

```
Read RESET_SYNDROME register
if (SAMWRSTREQ or SAMCRSTREQ bit is set)
{
   Read the SAMESO register
   //Check and handle the ATUERR event:
   if (ATUERR bit (bit 5) in SAMESO register is set)
        {
            //It is an ATU address mismatch event
            If of interest, log the ATU address mismatch event
            Clear the ATUERR bit (bit 5) in the SAMESO register by writing 1
            to the ATUERR bit (bit 5) in the SAMECLO register
        }
    else
        {
            Check and handle other SAM reported events.
        }
}
```

```
Clear the AMWRSTREQ or SAMCRSTREQ bit in RESET_SYNDROME register
}
else - the subsystem was reset for other reasons (most likely reason is power on).
Check the other RESET_SYNDROME register bits.
Proceed with subsystem boot
```

# 6.4.2 Software analysis flow when SAM interrupts the subsystem

The SAM response to any input event, including ATUERR, can be programmed to generate an interrupt.

The generated interrupts are as follows:

- NMI
- Critical Severity Fault Interrupt
- Severity Fault Interrupt

Severeal issues can cause an NMI interrupt. The NMI exception handler must check for each possible cause. The ATU has its ATUIS register that indicates an address mismatch error.

# 6.4.2.1 NMI exception handler

The following analysis flow is used within the NMI exception handler:

```
Read the SAMESO register
//Check and handle the ATUERR event:
if (ATUERR bit (bit 5) in SAMESO register is set)
    //It is an ATU address mismatch event
    Read the ATUIS register
   if (ME bit is set)
        Read the ATUMA register
        Log the offending mismatch address for analysis or debug
       Set the ME bit in the ATUIC register to clear the ME bit in the ATUIS
 register
    Clear the ATUERR bit (bit 5) in the SAMESO register by writing 1 to the ATUERR
bit (bit 5) in the SAMECLO register
else
    Check and handle other SAM reported events that could cause NMI, either in
SAMESO register or in SAMES1 register
Check for other reasons for NMI
    // Consider resetting the subsystem
    Exit from the NMI exception
```

# 6.4.2.2 Critical Severity Fault Interrupt exception handler

The following analysis flow is used within the Critical Severity Fault Interrupt exception handler:

```
Read the SAMESO register
//Check and handle the ATUERR event:
if (ATUERR bit (bit 5) in SAMESO register is set)
    //It is an ATU address mismatch event
    Read ATUIS register
    if (ME bit is set)
        Read the ATUMA register
        Log the offending mismatch address for analysis or debug
        Set the ME bit in the ATUIC register to clear the ME bit in the ATUIS
register
    Clear the ATUERR bit (bit 5) in the SAMESO register by writing 1 to the ATUERR
bit (bit 5) in the SAMECLO register
else
    Check and handle other SAM reported events that could cause a Critical Severity
Fault Interrupt, either in the SAMESO register
   or in the SAMES1 register
// Consider resetting the subsystem
Exit from the Critical Severity Fault exception
```

# 6.4.2.3 Severity Fault Interrupt exception handler

The following analysis flow is used within the Severity Fault Interrupt exception handler:

```
Read the SAMESO register
//Check and handle the ATUERR event:
if (ATUERR bit (bit 5) in SAMESO register is set)
    //It is ATU address mismatch event
    Read the ATUIS register
    if (ME bit is set)
        Read the ATUMA register
       Log the offending mismatch address for analysis or debug
       Set the ME bit in the ATUIC register to clear the ME bit in the ATUIS
 register
    Clear the ATUERR bit (bit 5) in the SAMESO register by writing 1 to the ATUERR
bit (bit 5) in the SAMECLO register
else
    Check and handle other SAM reported events that could cause a Severity Fault
 Interrupt, either in the SAMESO register or in
    the SAMES1 register
// Consider resetting the subsystem
Exit from the Severity Fault exception
```

# 6.4.3 Software analysis flow when ATU interrupts the subsystem

There is a specific software analysis flow for situations when ATU interrupts the subsystem by generating an ATUIRQ interrupt. This occurs when software programs SAM to mask out the ATUERR event, and enables the ATU mismatch error interrupt by setting the ME bit in the ATUIE register interrupt.

This analysis flow is used within the ATUIRQ exception handler.

The analysis flow is as follows:

```
Read the ATUIS register

if (ME bit is set)
{
   Read the ATUMA register
   Log the offending mismatch address for analysis or debug
   Set the ME bit in the ATUIC register to clear the ME bit in the ATUIS register
   }

// Consider resetting the subsystem
Exit from the ATUIRQ exception
```

# 6.4.4 Software analysis flow when ATU responds with bus error

There is a specific software analysis flow for situations when ATU responds with a bus error. This analysis flow is used within the bus error exception handler.

The software analysis flow is as follows:

```
Read ATUIS register
if (ME bit is set)
{
    Read the ATUMA register
    Log the offending mismatch address for analysis or debug
    Set the ME bit in the ATUIC register to clear the ME bit in the ATUIS register
    }
else
    {
        Check and handle other sources that could cause bus error exception
    }
// Consider resetting the subsystem
Exit from the bus error exception
```

# Appendix A Revisions

The following table describes the technical changes between released issues of this document.

#### Table A-1: Issue 0000-01

| Change                        | Location |
|-------------------------------|----------|
| Initial issue of the document | -        |