The GICH_VMCR characteristics are:
Enables the hypervisor to save and restore the virtual machine view of the GIC state. This register is updated when a virtual machine updates the virtual CPU interface registers.
This register is present only when FEAT_GICv3_LEGACY is implemented and EL2 is implemented. Otherwise, direct accesses to GICH_VMCR are RES0.
This register is available when the GIC implementation supports interrupt virtualization.
GICH_VMCR is a 32-bit register.
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 |
VPMR | VBPR0 | VBPR1 | RES0 | VEOIM | RES0 | VCBPR | VFIQEn | VAckCtl | VENG1 | VENG0 |
Virtual priority mask. The priority mask level for the CPU interface. If the priority of an interrupt is higher than the value indicated by this field, the interface signals the interrupt to the PE.
This alias field is updated when a VM updates GICV_PMR.Priority.
The reset behavior of this field is:
Virtual Binary Point Register, Group 0. Defines the point at which the priority value fields split into two parts, the Group priority field and the subpriority field. The Group priority field determines Group 0 interrupt preemption, and also determines Group 1 interrupt preemption if GICH_VMCR.VCBPR == 1.
This alias field is updated when a VM updates GICV_BPR.Binary_Point.
The reset behavior of this field is:
Virtual Binary Point Register, Group 1. Defines the point at which the priority value fields split into two parts, the Group priority field and the subpriority field. The Group priority field determines Group 1 interrupt preemption if GICH_VMCR.VCBPR == 0.
This alias field is updated when a VM updates GICV_ABPR.Binary_Point.
The reset behavior of this field is:
Reserved, RES0.
Virtual EOImode. Possible values of this bit are:
VEOIM | Meaning |
---|---|
0b0 |
A write of an INTID to GICV_EOIR or GICV_AEOIR drops the priority of the interrupt with that INTID, and also deactivates that interrupt. |
0b1 |
A write of an INTID to GICV_EOIR or GICV_AEOIR only drops the priority of the interrupt with that INTID. Software must write to GICV_DIR to deactivate the interrupt. |
This alias field is updated when a VM updates GICV_CTLR.EOImode.
The reset behavior of this field is:
Reserved, RES0.
Virtual Common Binary Point Register. Possible values of this bit are:
VCBPR | Meaning |
---|---|
0b0 |
GICV_ABPR determines the preemption group for Group 1 interrupts. |
0b1 |
GICV_BPR determines the preemption group for Group 1 interrupts. |
This alias field is updated when a VM updates GICV_CTLR.CBPR.
The reset behavior of this field is:
Virtual FIQ enable. Possible values of this bit are:
VFIQEn | Meaning |
---|---|
0b0 |
Group 0 virtual interrupts are presented as virtual IRQs. |
0b1 |
Group 0 virtual interrupts are presented as virtual FIQs. |
This alias field is updated when a VM updates GICV_CTLR.FIQEn.
The reset behavior of this field is:
Virtual AckCtl. Possible values of this bit are:
VAckCtl | Meaning |
---|---|
0b0 |
If the highest priority pending interrupt is Group 1, a read of GICV_IAR or GICV_HPPIR returns an INTID of 1022. |
0b1 |
If the highest priority pending interrupt is Group 1, a read of GICV_IAR or GICV_HPPIR returns the INTID of the corresponding interrupt. |
This alias field is updated when a VM updates GICV_CTLR.AckCtl.
This field is supported for backwards compatibility with GICv2. Arm deprecates the use of this field.
The reset behavior of this field is:
Virtual interrupt enable, Group 1. Possible values of this bit are:
VENG1 | Meaning |
---|---|
0b0 |
Group 1 virtual interrupts are disabled. |
0b1 |
Group 1 virtual interrupts are enabled. |
This alias field is updated when a VM updates GICV_CTLR.EnableGrp1.
The reset behavior of this field is:
Virtual interrupt enable, Group 0. Possible values of this bit are:
VENG0 | Meaning |
---|---|
0b0 |
Group 0 virtual interrupts are disabled. |
0b1 |
Group 0 virtual interrupts are enabled. |
This alias field is updated when a VM updates GICV_CTLR.EnableGrp0.
The reset behavior of this field is:
A List register is in the pending state only if the corresponding GICH_LR<n> value is 0b01, that is, pending. The active and pending state is not included.
This register is used only when System register access is not enabled. When System register access is enabled:
Component | Offset | Instance |
---|---|---|
GIC Virtual interface control | 0x0008 | GICH_VMCR |
This interface is accessible as follows:
26/03/2024 09:49; 67c0ae5282a7629ba0ea0ba7267b43cd4f7939f6
Copyright © 2010-2024 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.