AArch64
Instructions

Index by Encoding

External Registers

# GICV\_DIR, Virtual Machine Deactivate Interrupt Register

The GICV DIR characteristics are:

# **Purpose**

Deactivates a specified virtual interrupt in the <u>GICH\_LR<n></u> List registers.

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

# **Configuration**

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

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

### **Attributes**

GICV DIR 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 specified interrupt in the List registers is changed from active to inactive, or from active and pending to pending. If the specified interrupt is present in the List registers but is not in either the active or active and pending states, the effect is unpredictable. If the specified interrupt is not present in the List registers, <u>GICH\_HCR</u>.EOICount is incremented, potentially generating a maintenance interrupt.

#### Note

If the specified interrupt is not present in the List registers, the virtual machine cannot recover the INTID. Therefore, the hypervisor must ensure that, when <u>GICV\_CTLR</u>.EOImode == 1, no more than one active interrupt is transferred from the List registers into a software list. If more than one active interrupt that is not stored in the List registers exists, the hypervisor must handle accesses to GICV\_DIR in software, typically by trapping these accesses.

If the corresponding  $\underline{\text{GICH\_LR} < n}$ .HW == 1, indicating a hardware interrupt, then a deactivate request is 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  $\underline{\text{GICC\_DIR}}$  from the PE having that physical INTID. This means that if the corresponding physical interrupt is marked as Group 0, the request is ignored.

### Note

Interrupt deactivation using this register is based on the provided INTID, with no requirement to deactivate interrupts in any particular order. A single register is therefore used to deactivate both Group 0 and Group 1 interrupts.

# **Accessing GICV\_DIR**

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

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

Writes to this register are valid only when <u>GICV\_CTLR</u>.EOImode == 1. Writes to this register are otherwise unpredictable.

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

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

| Component                    | Offset | Instance |  |
|------------------------------|--------|----------|--|
| GIC Virtual CPU<br>interface | 0x1000 | GICV_DIR |  |

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