# GICV\_IAR, Virtual Machine Interrupt Acknowledge Register

The GICV IAR characteristics are:

## **Purpose**

Provides the INTID of the signaled Group 0 virtual interrupt. A read of this register by the PE acts as an acknowledge for the interrupt.

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

## **Configuration**

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

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

## **Attributes**

GICV\_IAR 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                 | INTID                                                            |

#### Bits [31:25]

Reserved, res0.

## INTID, bits [24:0]

The INTID of the signaled interrupt.

#### Note

INTIDs 1020-1023 are reserved and convey additional information such as spurious interrupts.

When affinity routing is not enabled:

- Bits [23:13] are res0.
- For SGIs, bits [12:10] identify the CPU interface corresponding to the source PE. For all other interrupts these bits are res0.

When the virtual machine writes to this register, the virtual CPU interface acknowledges the highest priority pending virtual interrupt and sets the state in the corresponding List register to active. The appropriate bit in the active priorities register <u>GICH\_APR<n></u> is set to 1.

If <u>GICH\_LR<n></u>.HW == 0, indicating that the interrupt is software-triggered, then bits [12:10] of <u>GICH\_LR<n></u> are returned in bits [12:10] of GICV\_IAR. Otherwise bits [12:10] are res0.

A read of this register returns the spurious INTID 1023 if either of the following is true:

- There are no pending interrupts of sufficiently high priority value to be signaled to the PE with the virtual CPU interface enabled and GICH HCR.En == 1.
- Interrupt signaling by the virtual CPU interface is disabled.

A read of this register returns the spurious INTID 1022 if the highest priority pending interrupt is Group 1 and GICV CTLR.AckCtl == 0.

# Accessing GICV\_IAR

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

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

This register is used for Group 0 interrupts only. <u>GICV\_AIAR</u> provides equivalent functionality for Group 1 interrupts.

When affinity routing is enabled, it is a programming error to use memory-mapped registers to access the GIC.

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

| Component                    | Offset | Instance |
|------------------------------|--------|----------|
| GIC Virtual CPU<br>interface | 0x000C | GICV_IAR |

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

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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