AArch64
Instructions

Index by Encoding

External Registers

# PMCID1SR, CONTEXTIDR\_EL1 Sample Register

The PMCID1SR characteristics are:

## **Purpose**

Contains the sampled value of <a href="CONTEXTIDR\_EL1">CONTEXTIDR\_EL1</a>, captured on reading PMU.PMPCSR[31:0].

## **Configuration**

This register is present only when FEAT\_PMUv3\_EXT32 is implemented and FEAT\_PCSRv8p2 is implemented. Otherwise, direct accesses to PMCID1SR are res0.

If FEAT\_PMUv3\_EXT64 is implemented, the same content is present in the same location, and can be accessed using PMCCIDSR[31:0] or PMCVIDSR[31:0].

PMCID1SR is in the Core power domain.

#### **Note**

Before Armv8.2, the PC Sample-based Profiling Extension can be implemented in the external debug register space, as indicated by the value of EDDEVID.PCSample.

### **Attributes**

PMCID1SR is a 32-bit register.

This register is part of the **PMU** block.

## 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 CONTEXTIDR EL1

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

Context ID. The value of CONTEXTIDR that is associated with the most recent PMU.PMPCSR sample. When the most recent PMU.PMPCSR sample is generated:

- If EL1 is using AArch64, then the Context ID is sampled from CONTEXTIDR EL1.
- If EL1 is using AArch32, then the Context ID is sampled from CONTEXTIDR.
- If EL3 is implemented and is using AArch32, then <a href="CONTEXTIDR">CONTEXTIDR</a> is a banked register and this register samples the current banked copy of <a href="CONTEXTIDR">CONTEXTIDR</a> for the Security state that is associated with the most recent PMU.PMPCSR sample.

Because the value written to this registser is an indirect read of CONTEXTIDR, it is constrained unpredictable whether this register is set to the original or new value if PMU.PMPCSR samples:

- An instruction that writes to CONTEXTIDR.
- The next Context synchronization event.
- Any instruction executed between these two instructions.

The reset behavior of this field is:

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

## **Accessing PMCID1SR**

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

Accesses to this register use the following encodings:

## Accessible at offset 0x208 from PMU

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

## Accessible at offset 0x228 from PMU

• When DoubleLockStatus(), or !IsCorePowered() or OSLockStatus(), accesses to this register generate an error response.

• Otherwise, accesses to this register are **RO**.

AArch32 Registers AArch64 Registers

AArch32 Instructions AArch64 Instructions Index by Encoding

External Registers

28/03/2023 16:01; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

Copyright  $\hat{A}$  © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.