AArch64 Registers AArch32 Instructions AArch64 Instructions Index by Encoding

External Registers

# **EDVIDSR, External Debug Virtual Context Sample Register**

The EDVIDSR characteristics are:

# **Purpose**

Contains sampled values captured on reading <a href="EDPCSR[31:0]">EDPCSR[31:0]</a>.

### **Configuration**

EDVIDSR 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 EDVIDSR are res0.

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.

When the PC Sample-based Profiling Extension is implemented in the external debug registers space, if EL2 is not implemented and EL3 is not implemented, it is implementation defined whether EDVIDSR is implemented.

#### **Note**

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

### **Attributes**

EDVIDSR is a 32-bit register.

# Field descriptions

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

|          | 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 |
|----------|----------------------------------|---------------------|---|------|---|---|---|---|---|---|---|
| NSE2E3HV | RES0                             | VMID[15:8]          |   | VMID |   |   |   |   |   |   |   |

This format applies in all Armv8.0 implementations.

#### **NS, bit [31]**

Non-secure state sample. Indicates the Security state associated with the most recent <u>EDPCSR</u> sample.

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.

# E2, bit [30]

#### When EL2 is implemented:

Exception level 2 status sample. Indicates whether the most recent EDPCSR sample was associated with EL2.

| <b>E2</b> | Meaning                 |
|-----------|-------------------------|
| 0b0       | Sample is not from EL2. |
| 0b1       | Sample is from EL2.     |

The reset behavior of this field is:

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

#### Otherwise:

Reserved, res0.

#### E3, bit [29]

#### When EL3 is implemented and AArch64 is supported:

Exception level 3 status sample. Indicates whether the most recent <u>EDPCSR</u> sample was associated with EL3 using AArch64.

| <b>E3</b> | Meaning                               |
|-----------|---------------------------------------|
| 0b0       | Sample is not from EL3 using AArch64. |
| 0b1       | Sample is from EL3 using AArch64.     |

The reset behavior of this field is:

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

#### Otherwise:

Reserved, res0.

#### HV, bit [28]

EDPCSRhi (<u>EDPCSR</u>[63:32]) valid. Indicates whether bits [63:32] of the most recent <u>EDPCSR</u> sample might be nonzero:

| HV  | Meaning                         |
|-----|---------------------------------|
| 0b0 | Bits[63:32] of the most recent  |
|     | EDPCSR sample are zero.         |
| 0b1 | Bits[63:32] of the most recent  |
|     | EDPCSR sample might be nonzero. |

An EDVIDSR.HV value of 1 does not mean that the value of EDPCSRhi is nonzero. An EDVIDSR.HV value of 0 is a hint that EDPCSRhi (<u>EDPCSR</u>[63:32]) does not need to be read.

The reset behavior of this field is:

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

#### Bits [27:16]

Reserved, res0.

#### VMID[15:8], bits [15:8]

#### When FEAT VMID16 is implemented and EL2 is implemented:

Extension to VMID[7:0]. For more information, see VMID[7:0].

The reset behavior of this field is:

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

#### Otherwise:

Reserved, res0.

# VMID, bits [7:0] When EL2 is implemented:

VMID sample. The VMID associated with the most recent EDPCSRlo (EDPCSR[31:0]) sample. When the most recent EDPCSR sample was generated:

- This field is res0 if any of the following apply:
  - The PE is executing in Secure state.
  - The PE is executing at EL2.
- Otherwise:
  - If EL2 is using AArch64 and either FEAT\_VMID16 is not implemented or <u>VTCR\_EL2</u>.VS is 1, this field is set to <u>VTTBR\_EL2</u>.VMID.
  - If EL2 is using AArch64, FEAT\_VMID16 is implemented, and <u>VTCR\_EL2</u>.VS is 0, PMVIDSR.VMID[7:0] is set to <u>VTTBR\_EL2</u>.VMID[7:0] and PMVIDSR.VMID[15:8] is res0.
  - If EL2 is using AArch32, this field is set to <u>VTTBR</u>.VMID.

The reset behavior of this field is:

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

#### Otherwise:

Reserved, res0.

# When (FEAT\_VHE is implemented or FEAT\_Debugv8p2 is implemented) and EDSCR.SC2 == 1:

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

CONTEXTIDR\_EL2

#### **CONTEXTIDR EL2, bits [31:0]**

Context ID. The value of <u>CONTEXTIDR\_EL2</u> that is associated with the most recent <u>EDPCSR</u> sample. When the most recent <u>EDPCSR</u> sample is generated:

- If the PE is not executing at EL3, EL2 is using AArch64, and EL2 is enabled in the current Security state, then this field is set to the Context ID sampled from CONTEXTIDR EL2.
- Otherwise, this field is set to an unknown value.

The reset behavior of this field is:

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

# **Accessing EDVIDSR**

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'.

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

| Component | Offset | Instance |
|-----------|--------|----------|
| Debug     | 0x0A8  | EDVIDSR  |

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.

| AArch32          | AArch64          | AArch32             | AArch64             | Index by | <u>External</u>  |
|------------------|------------------|---------------------|---------------------|----------|------------------|
| <u>Registers</u> | <u>Registers</u> | <u>Instructions</u> | <u>Instructions</u> | Encoding | <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.