AArch64
Instructions

Index by Encoding External Registers

## **PMVIDSR, VMID Sample Register**

The PMVIDSR characteristics are:

## **Purpose**

Contains the sampled VMID value that is captured on reading PMU.PMPCSR[31:0].

## **Configuration**

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

PMVIDSR is in the Core power domain.

If FEAT\_PMUv3\_EXT64 is implemented, the same content is present in the same location, and can be accessed using PMVCIDSR[63:32].

#### 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 <u>EDDEVID</u>.PCSample.

## **Attributes**

PMVIDSR is a 32-bit register.

This register is part of the <u>PMU</u> 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 |  |
|-------------------------------------------------|-----------------------|-----------------|--|
| RES0                                            | VMID[15:8]            | VMID            |  |

#### Bits [31:16]

Reserved, res0.

# VMID[15:8], bits [15:8] When FEAT VMID16 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]

VMID sample. The VMID associated with the most recent PMU.PMPCSR sample. When the most recent PMU.PMPCSR sample was generated:

- This field is set to an unknown value if any of the following apply:
  - EL2 is disabled in the current Security state.
  - The PE is executing at EL2.
  - EL2 is enabled in the current Security state, the PE is executing at EL0, EL2 is using AArch64, HCR\_EL2.E2H == 1, and HCR EL2.TGE == 1.
- 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 VTTBR.VMID.

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

- An instruction that writes to the VMID value.
- 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 PMVIDSR**

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 0x20C from PMU

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

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

28/03/2023 16:01; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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