AArch64
Instructions

Index by Encoding External Registers

# GICV\_EOIR, Virtual Machine End Of Interrupt Register

The GICV EOIR characteristics are:

## **Purpose**

A write to this register performs a priority drop for the specified Group 0 virtual interrupt and, if  $\underline{\text{GICV\_CTLR}}$ .EOImode == 0, also deactivates the interrupt.

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

# Configuration

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

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

#### **Attributes**

GICV EOIR 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.

The behavior of this register depends on the setting of GICV CTLR.EOImode:

| <b>GICV_CTLR.</b> EOI mode | Behavior          |
|----------------------------|-------------------|
| 0b0                        | Both the priority |
|                            | drop and the      |
|                            | deactivate        |
|                            | interrupt effects |
|                            | occur             |
| 0b1                        | Only the priority |
|                            | drop effect       |
|                            | occurs.           |

A successful EOI request means that:

- The highest priority bit in <u>GICH\_APR<n></u> is cleared, causing the running priority to drop.
- If the appropriate <a href="GICV\_CTLR">GICV\_CTLR</a>. EOImode bit == 0, the interrupt is deactivated in the corresponding List register <a href="GICH\_LR<n>">GICH\_LR<n></a>. HW == 1, indicating the INTID corresponds to a hardware interrupt, a deactivate request is also sent to the physical Distributor, identifying the physical INTID from the corresponding field in the List register. This effect is identical to a Non-secure write to <a href="GICC\_DIR">GICC\_DIR</a> from the PE having that physical INTID. This means that if the corresponding physical interrupt is marked as Group 0, and <a href="GICD\_CTLR">GICD\_CTLR</a>. DS == 0, the deactivation request is ignored. See <a href="GICC\_EOIR">GICC\_EOIR</a> for more information.

#### **Note**

Only Group 1 interrupts can target the hypervisor, and therefore only Group 1 interrupts are deactivated in the Distributor.

## **Accessing GICV\_EOIR**

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

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

This register is used for Group 0 interrupts only. <u>GICV\_AEOIR</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 EOIR can be accessed through the memory-mapped interfaces:

| Component                    | Offset | Instance  |
|------------------------------|--------|-----------|
| GIC Virtual CPU<br>interface | 0x0010 | GICV_EOIR |

This interface is accessible as follows:

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

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