AArch64
Instructions

Index by Encoding External Registers

# TRCITEEDCR, Instrumentation Trace Extension External Debug Control Register

The TRCITEEDCR characteristics are:

# **Purpose**

Controls instrumentation trace filtering.

# **Configuration**

This register is present only when FEAT\_ETE is implemented, FEAT\_TRC\_EXT is implemented and TRCIDR0.ITE == 1. Otherwise, direct accesses to TRCITEEDCR are res0.

## **Attributes**

TRCITEEDCR is a 32-bit register.

# Field descriptions

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

RESO

RL S NSE3E2E1E0

## Bits [31:7]

Reserved, res0.

# RL, bit [6] When FEAT RME is implemented:

Instrumentation Trace in Realm state.

| RL  | Meaning                                          |
|-----|--------------------------------------------------|
| 0d0 | Instrumentation trace prohibited in Realm state. |
| 0b1 | Instrumentation trace permitted in Realm state.  |

This field is ignored when SelfHostedTraceEnabled() returns TRUE.

This field is used in conjunction with <u>TRCCONFIGR</u>.ITO and TRCITEEDCR.E<m> to control whether Instrumentation trace is permitted or prohibited in Realm state.

The reset behavior of this field is:

 On a Trace unit reset, this field resets to an architecturally unknown value.

#### Otherwise:

Reserved, res0.

#### S, bit [5]

#### When Secure state is implemented:

Instrumentation Trace in Secure state.

| S   | Meaning                             |
|-----|-------------------------------------|
| 0b0 | Instrumentation trace prohibited in |
|     | Secure state.                       |
| 0b1 | Instrumentation trace permitted in  |
|     | Secure state.                       |

This field is ignored when SelfHostedTraceEnabled() returns TRUE.

When FEAT\_RME is not implemented, this field is used in conjunction with <a href="mailto:TRCCONFIGR">TRCCONFIGR</a>.ITO, TRCITEEDCR.E3, and TRCITEEDCR.E<m> to control whether Instrumentation trace is permitted or prohibited in Secure state.

When FEAT\_RME is implemented, this field is used in conjunction with <u>TRCCONFIGR</u>.ITO and TRCITEEDCR.E<m> to control whether Instrumentation trace is permitted or prohibited in Secure state.

The reset behavior of this field is:

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

#### Otherwise:

Reserved, res0.

#### **NS**, bit [4]

#### When Non-secure state is implemented:

Instrumentation Trace in Non-secure state.

| NS  | Meaning                             |
|-----|-------------------------------------|
| 0b0 | Instrumentation trace prohibited in |
|     | Non-secure state.                   |
| 0b1 | Instrumentation trace permitted in  |
|     | Non-secure state.                   |

This field is ignored when SelfHostedTraceEnabled() returns TRUE.

This field is used in conjunction with <u>TRCCONFIGR</u>.ITO and TRCITEEDCR.E<m> to control whether Instrumentation trace is permitted or prohibited in Non-secure state.

The reset behavior of this field is:

 On a Trace unit reset, this field resets to an architecturally unknown value.

#### Otherwise:

Reserved, res0.

## E3, bit [3] When EL3 is implemented:

Instrumentation Trace Enable at EL3.

| <b>E3</b> | Meaning                                  |
|-----------|------------------------------------------|
| 0b0       | Instrumentation trace prohibited at EL3. |
| 0b1       | Instrumentation trace permitted at EL3.  |

This field is ignored when SelfHostedTraceEnabled() returns TRUE.

When FEAT\_RME is not implemented, TRCITEEDCR.E3 is used in conjunction with <u>TRCCONFIGR</u>.ITO and TRCITEEDCR.S to control whether Instrumentation trace is permitted or prohibited at EL3.

When FEAT\_RME is implemented, TRCITEEDCR.E3 is used in conjunction with <u>TRCCONFIGR</u>.ITO to control whether Instrumentation trace is permitted or prohibited at EL3.

The reset behavior of this field is:

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

#### Otherwise:

Reserved, res0.

#### E < m >, bit [m], for m = 2 to 0

Instrumentation Trace Enable at EL<m>.

| E <m></m> | Meaning |  |
|-----------|---------|--|
|           |         |  |

| 000 | Instrumentation trace prohibited at EL <m>.</m> |
|-----|-------------------------------------------------|
| 0b1 | Instrumentation trace permitted at EL <m>.</m>  |

This field is ignored when SelfHostedTraceEnabled() returns TRUE.

This bit is used in conjunction with <u>TRCCONFIGR</u>.ITO, TRCITEEDCR.NS, TRCITEEDCR.S, and TRCITEEDCR.RL to control whether Instrumentation trace is permitted or prohibited at EL<m> in the specified Security states.

TRCITEEDCR.E<2> is res0 if EL2 is not implemented in any Security states.

The reset behavior of this field is:

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

# **Accessing TRCITEEDCR**

Writes are constrained unpredictable if the trace unit is not in the Idle state.

## TRCITEEDCR can be accessed through the external debug interface:

| Component | Offset | Instance   |
|-----------|--------|------------|
| ETE       | 0x048  | TRCITEEDCR |

This interface is accessible as follows:

- When OSLockStatus(), or !AllowExternalTraceAccess() or ! IsTraceCorePowered(), accesses to this register generate an error response.
- Otherwise, accesses to this register are RW.

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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