Index by Encoding External Registers

# EDACR, External Debug Auxiliary Control Register

The EDACR characteristics are:

### **Purpose**

Allows implementations to support implementation defined controls.

#### **Configuration**

The power domain of EDACR is implementation defined.

Implementation of this register is optional.

This register is only implemented if <u>DBGDEVID</u>.AuxRegs == 0b0001.

If FEAT\_DoPD is implemented, this register is implemented in the Core power domain.

If FEAT\_DoPD is not implemented, the power domain that this register is implemented in is implementation defined.

Changing this register from its reset value causes implementation defined behavior, including possible deviation from the architecturally-defined behavior.

If the EDACR contains any control bits that must be preserved over power down, then these bits must be accessible by the external debug interface when the OS Lock is locked,  $\underline{OSLSR\_EL1}$ .OSLK == 1, and when the Core is powered off.

#### **Attributes**

EDACR 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 IMPLEMENTATION DEFINED

#### **IMPLEMENTATION DEFINED, bits [31:0]**

implementation defined.

The following resets apply:

- If the register is implemented in the Core power domain:
  - On a Cold reset, this field resets to an architecturally unknown value.
  - On an External debug reset, the value of this field is unchanged.
  - on a Warm reset, the value of this field is unchanged.
- If the register is implemented in the External debug power domain:
  - On a Cold reset, the value of this field is unchanged.
  - On an External debug reset, this field resets to an architecturally unknown value.
  - On a Warm reset, the value of this field is unchanged.

## **Accessing EDACR**

#### **EDACR** can be accessed through the external debug interface:

| Component | Offset | Instance |
|-----------|--------|----------|
| Debug     | 0x094  | EDACR    |

This interface is accessible as follows:

- When IsCorePowered(), !DoubleLockStatus(), !OSLockStatus() and SoftwareLockStatus(), accesses to this register are **RO**.
- When IsCorePowered(), !DoubleLockStatus(), !OSLockStatus() and ! SoftwareLockStatus(), accesses to this register are **RW**.
- Otherwise, accesses to this register are **IMPDEF**.

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:01; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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