## **EDDFR1, External Debug Feature Register 1**

The EDDFR1 characteristics are:

### **Purpose**

Provides top level information about the debug system in AArch64.

### **Configuration**

The power domain of EDDFR1 is implementation defined.

### **Attributes**

EDDFR1 is a 64-bit register.

### Field descriptions

| 63 62 61 60 59 58 57 56 | <u>55 54 53 52</u> | <u>51 50 49 48</u> | <u>47 46 45 44</u> | <u>43 42 41 40</u> | <u>39 38 37 36</u> | <u>35 34 33 32</u> |
|-------------------------|--------------------|--------------------|--------------------|--------------------|--------------------|--------------------|
| ABL_CMPs                | RES0               | EBEP               | ITE                | ABLE               | <b>PMICNTR</b>     | SPMU               |
| CTX_CMPs                | WF                 | RPs                | BR                 | Ps                 | SYSP               | MUID               |

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

# ABL\_CMPs, bits [63:56] When FEAT ABLE is implemented:

Number of breakpoints that support address linking, minus 1.

The values 0x40 to 0xFF are reserved.

The value of this field is never greater than either EDDFR1.WRPs or EDDFR1.BRPs.

#### Otherwise:

Reserved, res0.

### Bits [55:52]

Reserved, res0.

### EBEP, bits [51:48]

This field either has the same value as <u>ID\_AA64DFR1\_EL1</u>.EBEP or reads as zero.

### ITE, bits [47:44]

This field either has the same value as <u>ID\_AA64DFR1\_EL1</u>.ITE or reads as zero.

### **ABLE, bits [43:40]**

Address Breakpoint Linking Extension. Defined values are:

| ABLE   | Meaning                    |
|--------|----------------------------|
| 0b0000 | Address Breakpoint Linking |
|        | Extension not implemented. |
| 0b0001 | Address Breakpoint Linking |
|        | Extension implemented.     |

All other values are reserved.

FEAT\_ABLE implements the functionality identified by the value 0b0001.

In an implementation that supports AArch64, this field has the same value as ID AA64DFR1 EL1.ABLE.

### **PMICNTR**, bits [39:36]

This field either has the same value as <u>ID\_AA64DFR1\_EL1</u>.PMICNTR or reads as zero.

### **SPMU, bits [35:32]**

This field either has the same value as <u>ID\_AA64DFR1\_EL1</u>.SPMU or reads as zero.

### CTX\_CMPs, bits [31:24]

When FEAT Debugv8p9 is implemented and EDDFR.CTX CMPs == 0b1111:

Number of breakpoints that are context-aware, minus 1.

The value 0x00 means 16 breakpoints that are context-aware are implemented. Otherwise, this field is the number of breakpoints that are context-aware, minus 1.

The values 0x01 to 0x0F and 0x40 to 0xFF are reserved.

The value of this field is never greater than EDDFR1.BRPs.

In an implementation that supports AArch64, this field has the same value as ID AA64DFR1 EL1.CTX CMPs.

#### Otherwise:

Reserved, res0.

### WRPs, bits [23:16]

### When FEAT\_Debugv8p9 is implemented and EDDFR.WRPs == 0b1111:

Number of watchpoints, minus 1.

The value  $0 \times 00$  means 16 watchpoints are implemented. Otherwise, this field is the number of watchpoints, minus 1.

The values  $0 \times 01$  to  $0 \times 0F$  and  $0 \times 40$  to  $0 \times FF$  are reserved.

In an implementation that supports AArch64, this field has the same value as ID AA64DFR1 EL1.WRPs.

#### Otherwise:

Reserved, res0.

### **BRPs, bits** [15:8]

### When FEAT Debugv8p9 is implemented and EDDFR.BRPs == 0b1111:

Number of breakpoints, minus 1.

The value  $0 \times 00$  means 16 breakpoints are implemented. Otherwise, this field is the number of breakpoints, minus 1.

The values 0x01 to 0x0F and 0x40 to 0xFF are reserved.

In an implementation that supports AArch64, this field has the same value as ID AA64DFR1 EL1.BRPs.

#### Otherwise:

Reserved, res0.

### SYSPMUID, bits [7:0]

This field either has the same value as <a href="https://linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.com/linear.co

### **Accessing EDDFR1**

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

| Component | Offset | Instance | Range |
|-----------|--------|----------|-------|
|-----------|--------|----------|-------|

| Debug | 0xD48 | EDDFR1 | 31:0 |
|-------|-------|--------|------|
|-------|-------|--------|------|

This interface is accessible as follows:

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

| Component | Offset | Instance | Range |
|-----------|--------|----------|-------|
| Debug     | 0xD4C  | EDDFR1   | 63:32 |

This interface is accessible as follows:

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

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

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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