# TRBMAR\_EL1, Trace Buffer Memory Attribute Register

The TRBMAR EL1 characteristics are:

# **Purpose**

Controls Trace Buffer Unit accesses to memory.

# **Configuration**

External register TRBMAR\_EL1 bits [63:0] are architecturally mapped to AArch64 System register TRBMAR\_EL1[63:0].

This register is present only when FEAT\_TRBE\_EXT is implemented. Otherwise, direct accesses to TRBMAR\_EL1 are res0.

TRBMAR EL1 is in the Core power domain.

### **Attributes**

TRBMAR\_EL1 is a 64-bit register.

# Field descriptions

63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32

| RES0                                                        |       |     |                 |  |  |
|-------------------------------------------------------------|-------|-----|-----------------|--|--|
| RES0                                                        | PAS   | SH  | Attr            |  |  |
| 31 30 20 28 27 26 25 24 23 22 21 20 10 18 17 16 15 14 13 12 | 11 10 | 0 8 | 7 6 5 / 3 2 1 0 |  |  |

Bits [63:12]

Reserved, res0.

# PAS, bits [11:10] When FEAT TRBE EXT is implemented:

Physical address specifier. Defines the PAS attribute for memory addressed by the buffer in External mode.

| PAS  | Meaning         | Applies when                     |
|------|-----------------|----------------------------------|
| 00d0 | Secure.         | When Secure state is implemented |
| 0b01 | Non-<br>secure. |                                  |

| 0b10 | Root.  | When FEAT_RME is |
|------|--------|------------------|
|      |        | implemented      |
| 0b11 | Realm. | When FEAT_RME is |
|      |        | implemented      |

All other values are reserved.

If the Trace Buffer Unit is using external mode and either TRBMAR\_EL1.PAS is set to a reserved value, or the implementation defined authentication interface prohibits invasive debug of the Security state corresponding to the physical address space selected by TRBMAR\_EL1.PAS, then when the Trace Buffer Unit receives trace data from the trace unit, it does not write the trace data to memory and generates a trace buffer management event. That is, if any of the following apply:

- ExternalInvasiveDebugEnabled() == FALSE.
- Secure state is implemented, ExternalSecureInvasiveDebugEnabled() == FALSE, and TRBMAR EL1.PAS is 0b00.
- FEAT\_RME is implemented, ExternalRootInvasiveDebugEnabled() == FALSE, and TRBMAR EL1.PAS is 0b10.
- FEAT\_RME is implemented, ExternalRealmInvasiveDebugEnabled() == FALSE, and TRBMAR EL1.PAS is 0b11.

This field is ignored by the PE when SelfHostedTraceEnabled() == TRUE.

The reset behavior of this field is:

• On a Cold reset, this field resets to an architecturally unknown value.

#### Otherwise:

Reserved, res0.

#### **SH, bits [9:8]**

Trace buffer shareability domain. Defines the shareability domain for Normal memory used by the trace buffer.

| SH   | Meaning          |
|------|------------------|
| 0b00 | Non-shareable.   |
| 0b10 | Outer Shareable. |
| 0b11 | Inner Shareable. |

All other values are reserved.

This field is ignored when TRBMAR\_EL1.Attr specifies any of the following memory types:

- Any Device memory type.
- Normal memory, Inner Non-cacheable, Outer Non-cacheable.

All Device and Normal Inner Non-cacheable Outer Non-cacheable memory regions are always treated as Outer Shareable.

The reset behavior of this field is:

• On a Cold reset, this field resets to an architecturally unknown value.

# Attr, bits [7:0] When TRBMAR\_EL1.Attr == 0bxxxx0000:

Trace buffer memory type and attributes. Defines the memory type and, for Normal memory, the cacheability attributes, for memory addressed by the trace buffer.

| Attr  | Meaning               | Applies<br>when |
|-------|-----------------------|-----------------|
| 0x00  | Device-nGnRnE         |                 |
|       | memory.               |                 |
| 0x40  | Normal memory,        | When            |
|       | Inner Non-            | FEAT_XS is      |
|       | cacheable,            | implemented     |
|       | Outer Non-            |                 |
|       | cacheable with        |                 |
|       | the XS attribute      |                 |
| 0 - 0 | set to 0.             | TA71            |
| 0xA0  | Normal memory,        | When            |
|       | Inner Write-          | FEAT_XS is      |
|       | through<br>Cacheable, | implemented     |
|       | Outer Write-          |                 |
|       | through               |                 |
|       | Cacheable, Non-       |                 |
|       | transient, Read-      |                 |
|       | Allocate with         |                 |
|       | the XS attribute      |                 |
|       | set to 0.             |                 |
| 0xF0  | Tagged Normal         | When            |
|       | memory, Outer         | FEAT_MTE2       |
|       | Write-Back Non-       | is              |
|       | transient, Read-      | implemented     |
|       | allocate Write-       |                 |
|       | allocate.             |                 |

All other values are reserved.

The reset behavior of this field is:

• On a Cold reset, this field resets to an architecturally unknown value.

### When TRBMAR\_EL1.Attr == 0b0000xxxx and TRBMAR\_EL1.Attr != 0b00000000:

Trace buffer memory attributes. Defines the Device memory attributes for memory addressed by the trace buffer.

| Attr  | Meaning               | Applies when |
|-------|-----------------------|--------------|
| 0x04  | Device-nGnRE          |              |
|       | memory.               |              |
| 0x08  | Device-nGRE           |              |
|       | memory.               |              |
| 0x0C  | Device-GRE            |              |
|       | memory.               |              |
| 0x01  | Device-               | When         |
|       | nGnRnE                | FEAT_XS is   |
|       | memory with           | implemented  |
|       | the XS                |              |
|       | attribute set to      |              |
|       | 0.                    | <b>.</b>     |
| 0x05  | Device-nGnRE          | When         |
|       | memory with<br>the XS | FEAT_XS is   |
|       | attribute set to      | implemented  |
|       | 0.                    |              |
| 0x09  | Device-nGRE           | When         |
| 0x09  | memory with           | FEAT XS is   |
|       | the XS                | implemented  |
|       | attribute set to      | mpiomontoa   |
|       | 0.                    |              |
| 0x0D  | Device-GRE            | When         |
| 01102 | memory with           | FEAT XS is   |
|       | the XS                | implemented  |
|       | attribute set to      | •            |
|       | 0.                    |              |

All other values are reserved.

The reset behavior of this field is:

• On a Cold reset, this field resets to an architecturally unknown value.

## When TRBMAR\_EL1.Attr != 0bxxxx0000 and TRBMAR\_EL1.Attr != 0b0000xxxx:

Trace buffer memory type and attributes. Defines the memory type and, for Normal memory, the Outer and Inner cacheability attributes, for memory addressed by the trace buffer.

|            | -                                                                                           |
|------------|---------------------------------------------------------------------------------------------|
| Attr       | Meaning                                                                                     |
| 0b0001xxxx | Normal memory, Outer<br>Write-Through Transient,                                            |
| 0b0010xxxx | Write-allocate. Normal memory, Outer Write-Through Transient,                               |
| 0b0011xxxx | Read-allocate. Normal memory, Outer Write-Through Transient, Read-allocate Write- allocate. |
| 0b0100xxxx | Normal memory, Outer<br>Non-cacheable.                                                      |
| 0b0101xxxx | Normal memory, Outer<br>Write-Back Transient,<br>Write-allocate.                            |
| 0b0110xxxx | Normal memory, Outer<br>Write-Back Transient,<br>Read-allocate.                             |
| 0b0111xxxx | Normal memory, Outer<br>Write-Back Transient,<br>Read-allocate Write-<br>allocate.          |
| 0b1000xxxx | Normal memory, Outer<br>Write-Through Non-<br>transient, No allocate.                       |
| 0b1001xxxx | Normal memory, Outer<br>Write-Through Non-<br>transient, Write-allocate.                    |
| 0b1010xxxx | Normal memory, Outer<br>Write-Through Non-<br>transient, Read-allocate.                     |
| 0b1011xxxx | Normal memory, Outer<br>Write-Through Non-<br>transient, Read-allocate<br>Write-allocate.   |
| 0b1100xxxx | Normal memory, Outer<br>Write-Back Non-transient,<br>No allocate.                           |
| 0b1101xxxx | Normal memory, Outer<br>Write-Back Non-transient,<br>Write-allocate.                        |
|            |                                                                                             |

| 0b1110xxxx | Normal memory, Outer<br>Write-Back Non-transient,<br>Read-allocate.                       |
|------------|-------------------------------------------------------------------------------------------|
| 0b1111xxxx | Normal memory, Outer<br>Write-Back Non-transient,<br>Read-allocate Write-<br>allocate.    |
| 0bxxxx0001 | Normal memory, Inner<br>Write-Through Transient,<br>Write-allocate.                       |
| 0bxxxx0010 | Normal memory, Inner<br>Write-Through Transient,<br>Read-allocate.                        |
| 0bxxxx0011 | Normal memory, Inner<br>Write-Through Transient,<br>Read-allocate Write-<br>allocate.     |
| 0bxxxx0100 | Normal memory, Inner Non-cacheable.                                                       |
| 0bxxxx0101 | Normal memory, Inner<br>Write-Back Transient,<br>Write-allocate.                          |
| 0bxxxx0110 | Normal memory, Inner<br>Write-Back Transient,<br>Read-allocate.                           |
| 0bxxxx0111 | Normal memory, Inner<br>Write-Back Transient,<br>Read-allocate Write-<br>allocate.        |
| 0bxxxx1000 | Normal memory, Inner<br>Write-Through Non-<br>transient, No allocate.                     |
| 0bxxxx1001 | Normal memory, Inner<br>Write-Through Non-<br>transient, Write-allocate.                  |
| 0bxxxx1010 | Normal memory, Inner<br>Write-Through Non-<br>transient, Read-allocate.                   |
| 0bxxxx1011 | Normal memory, Inner<br>Write-Through Non-<br>transient, Read-allocate<br>Write-allocate. |
| 0bxxxx1100 | Normal memory, Inner<br>Write-Back Non-transient,<br>No allocate.                         |
| 0bxxxx1101 | Normal memory, Inner<br>Write-Back Non-transient,<br>Write-allocate.                      |

| 0bxxxx1110 | Normal memory, Inner      |
|------------|---------------------------|
|            | Write-Back Non-transient, |
|            | Read-allocate.            |
| 0bxxxx1111 | Normal memory, Inner      |
|            | Write-Back Non-transient, |
|            | Read-allocate Write-      |
|            | allocate.                 |
|            |                           |

The reset behavior of this field is:

• On a Cold reset, this field resets to an architecturally unknown value.

#### Otherwise:

Reserved, res0.

# Accessing TRBMAR\_EL1

The PE might ignore a write to TRBMAR\_EL1 if any of the following apply:

- <u>TRBLIMITR\_EL1</u>.E == 1 and the Trace Buffer Unit is using Selfhosted mode.
- <u>TRBLIMITR\_EL1</u>.XE == 1 and the Trace Buffer Unit is using External mode.

#### TRBMAR\_EL1 can be accessed through the external debug interface:

| Component | Component Offset |            |
|-----------|------------------|------------|
| TRBE      | 0x028            | TRBMAR_EL1 |

This interface is accessible as follows:

- When DoubleLockStatus(), or !IsCorePowered(), or OSLockStatus() or !AllowExternalTraceBufferAccess(), accesses to this register generate an error response.
- Otherwise, accesses to this register are **RW**.

| AArch32          | AArch64          | AArch32             | AArch64             | Index by        | <u>External</u>  |
|------------------|------------------|---------------------|---------------------|-----------------|------------------|
| <u>Registers</u> | <u>Registers</u> | <u>Instructions</u> | <u>Instructions</u> | <b>Encoding</b> | <u>Registers</u> |

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

Copyright © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.