AArch64 Instructions Index by Encoding

External Registers

# EDPCSR, External Debug Program Counter Sample Register

The EDPCSR characteristics are:

# **Purpose**

Holds a sampled instruction address value.

# **Configuration**

EDPCSR is in the Core power domain.

This register is present only when FEAT\_PCSRv8 is implemented and FEAT\_PCSRv8p2 is not implemented. Otherwise, direct accesses to EDPCSR are res0.

EDPCSR[63:32] and EDPCSR[31:0] are accessed at 32-bit memory mapped addresses that are not contiguous.

If FEAT\_VHE is implemented, the format of this register differs depending on the value of <u>EDSCR</u>.SC2.

Implemented only if the optional PC Sample-based Profiling Extension is implemented in the external debug registers space.

#### **Note**

FEAT\_PCSRv8p2 implements the PC Sample-based Profiling Extension in the Performance Monitors registers space.

# **Attributes**

EDPCSR is a 64-bit register.

# Field descriptions

When FEAT\_VHE is not implemented or EDSCR.SC2 == 0:

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

PC Sample high word, EDPCSRhi

PC Sample low word

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

#### Bits [63:32]

PC Sample high word, EDPCSRhi. If <u>EDVIDSR</u>.HV == 0 then this field is RAZ, otherwise bits [63:32] of the sampled instruction address value. The translation regime that EDPCSR samples can be determined from <u>EDVIDSR</u>.{NS,E2,E3}.

The reset behavior of this field is:

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

#### Bits [31:0]

PC Sample low word. EDPCSRlo, bits[31:0] of the sampled instruction address value.

EDPCSRlo reads as 0xffffffff when any of the following are true:

- The PE is in Debug state.
- PC Sample-based profiling is prohibited.

If a branch instruction has retired since the PE left reset state, then the first read of EDPCSR[31:0] is permitted but not required to return <code>0xfffffffff</code>.

EDPCSRlo reads as an unknown value when any of the following are true:

- The PE is in reset state.
- No branch instruction has retired since the PE left reset state, Debug state, or a state where PC Sample-based Profiling is prohibited.
- No branch instruction has retired since the last read of EDPCSR[31:0].

Otherwise, a read of EDPCSR[31:0] returns bits [31:0] of the sampled instruction address value and has the side-effect of indirectly writing to EDPCSRhi, <u>EDCIDSR</u>, and <u>EDVIDSR</u>. The translation regime that EDPCSR samples can be determined from <u>EDVIDSR</u>.{NS,E2,E3}.

For a read of EDPCSR[31:0] from the memory-mapped interface, if EDLSR.SLK == 1, meaning the optional Software Lock is locked, then the side-effect of the access does not occur and EDPCSRhi, EDCIDSR, and EDVIDSR are unchanged.

The reset behavior of this field is:

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

# When FEAT\_VHE is implemented and EDSCR.SC2 == 1:

| 63                 | 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 |                |          |          |      |       |     |     |         |               |   |   |    |  |  |               |               |   |               |
|--------------------|-------------------------------------------------------------------------------------------------|----------------|----------|----------|------|-------|-----|-----|---------|---------------|---|---|----|--|--|---------------|---------------|---|---------------|
| NS                 | NS EL RESO PC Sample high word, EDPCSRhi                                                        |                |          |          |      |       |     |     |         |               |   |   |    |  |  |               |               |   |               |
| PC Sample low word |                                                                                                 |                |          |          |      |       |     |     |         |               |   |   |    |  |  |               |               |   |               |
| 21                 | 20 20                                                                                           | 20 27 26 25 24 | 22 22 21 | 20 10 10 | 1716 | 15 1/ | 112 | 101 | 1 1 1 1 | $\overline{}$ | _ | 7 | -6 |  |  | $\overline{}$ | $\overline{}$ | 1 | $\overline{}$ |

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

## **NS, bit [63]**

Non-secure state sample. Indicates the Security state that is associated with the most recent EDPCSR sample or, when it is read as a single atomic 64-bit read, the current EDPCSR sample. The translation regime that EDPCSR samples can be determined from EDPCSR.{NS,EL}.

If EL3 is not implemented, this bit indicates the Effective value of SCR.NS.

| NS  | Meaning                          |
|-----|----------------------------------|
| 0b0 | Sample is from Secure state.     |
| 0b1 | Sample is from Non-secure state. |

The reset behavior of this field is:

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

#### **EL, bits [62:61]**

Exception level status sample. Indicates the Exception level that is associated with the most recent EDPCSR sample or, when it is read as a single atomic 64-bit read, the current EDPCSR sample. The translation regime that EDPCSR samples can be determined from EDPCSR.{NS,EL}.

| EL   | Meaning             |
|------|---------------------|
| 0b00 | Sample is from EL0. |
| 0b01 | Sample is from EL1. |
| 0b10 | Sample is from EL2. |
| 0b11 | Sample is from EL3. |

The reset behavior of this field is:

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

#### Bits [60:56]

Reserved, res0.

### Bits [55:32]

PC Sample high word, EDPCSRhi. Bits [55:32] of the sampled instruction address value. The translation regime that EDPCSR samples can be determined from EDPCSR.{NS,EL}.

The reset behavior of this field is:

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

## Bits [31:0]

PC Sample low word. EDPCSRlo, bits[31:0] of the sampled instruction address value.

EDPCSRlo reads as <code>0xffffffff</code> when any of the following are true:

- The PE is in Debug state.
- PC Sample-based profiling is prohibited.

If a branch instruction has retired since the PE left reset state, then the first read of EDPCSR[31:0] is permitted but not required to return <code>0xfffffffff</code>.

EDPCSRlo reads as an unknown value when any of the following are true:

- The PE is in reset state.
- No branch instruction has retired since the PE left reset state, Debug state, or a state where PC Sample-based Profiling is prohibited.
- No branch instruction has retired since the last read of EDPCSR[31:0].

Otherwise, a read of EDPCSR[31:0] returns bits [31:0] of the sampled instruction address value and has the side-effect of indirectly writing to EDPCSRhi, <u>EDCIDSR</u>, and <u>EDVIDSR</u>. The translation regime that EDPCSR samples can be determined from EDPCSR.{NS,EL}.

For a read of EDPCSR[31:0] from the memory-mapped interface, if EDLSR.SLK == 1, meaning the optional Software Lock is locked, then the side-effect of the access does not occur and EDPCSRhi, EDCIDSR, and EDVIDSR are unchanged.

The reset behavior of this field is:

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

# **Accessing EDPCSR**

implementation defined extensions to external debug might make the value of this register unknown, see 'Permitted behavior that might make the PC Sample-based profiling registers UNKNOWN'

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

| Component | Offset | Instance | Range |  |  |  |
|-----------|--------|----------|-------|--|--|--|
| Debug     | 0x0A0  | EDPCSR   | 31:0  |  |  |  |

This interface is accessible as follows:

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

| Component | Offset | Instance | Range |  |  |  |
|-----------|--------|----------|-------|--|--|--|
| Debug     | 0x0AC  | EDPCSR   | 63:32 |  |  |  |

This interface is accessible as follows:

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

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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