# GICV\_RPR, Virtual Machine Running Priority Register

The GICV RPR characteristics are:

### **Purpose**

This register indicates the running priority of the virtual CPU interface.

This register corresponds to the physical CPU interface register GICC RPR.

## **Configuration**

This register is present only when FEAT\_GICv3\_LEGACY is implemented and EL2 is implemented. Otherwise, direct accesses to GICV\_RPR are res0.

This register is available when the GIC implementation supports interrupt virtualization.

#### **Attributes**

GICV RPR is a 32-bit register.

## 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                                                                  |     |     | Priority |   |     |

#### Bits [31:8]

Reserved, res0.

#### Priority, bits [7:0]

The current running priority on the virtual CPU interface. This is the group priority of the current active interrupt.

If there are no active interrupts on the CPU interface, or all active interrupts have undergone a priority drop, the value returned is the Idle priority.

The priority returned is the group priority as if the BPR was set to the minimum value.

### Accessing GICV\_RPR

This register is used only when System register access is not enabled. When System register access is enabled:

- For AArch32 implementations, <a href="ICC\_RPR">ICC\_RPR</a> provides equivalent functionality.
- For AArch64 implementations, <a href="ICC\_RPR\_EL1">ICC\_RPR\_EL1</a> provides equivalent functionality.

Depending on the implementation, if no bits are set to 1 in <u>GICH\_APR<n></u>, indicating no active virtual interrupts in the virtual CPU interface, the priority reads as 0xFF or 0xF8 to reflect the number of supported interrupt priority bits defined by <u>GICH\_VTR.PRIbits</u>.

#### GICV RPR can be accessed through the memory-mapped interfaces:

| Component                    | Offset | Instance |
|------------------------------|--------|----------|
| GIC Virtual CPU<br>interface | 0x0014 | GICV_RPR |

This interface is accessible as follows:

- When GICD CTLR.DS == 0, accesses to this register are **RO**.
- When an access is Secure, accesses to this register are **RO**.
- When an access is Non-secure, accesses to this register are **RO**.

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