# GICH\_MISR, Maintenance Interrupt Status Register

The GICH MISR characteristics are:

# **Purpose**

Indicates which maintenance interrupts are asserted.

# **Configuration**

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

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

## **Attributes**

GICH MISR is a 32-bit register.

# **Field descriptions**

| 3130292827262524232221201918171615141312111098 | 7      | 6      | 5      | 4      | 3  | 2    | 1 0               |
|------------------------------------------------|--------|--------|--------|--------|----|------|-------------------|
| RES0                                           | VGrp1D | VGrp1E | VGrp0D | VGrp0E | NP | LREN | <sup>2</sup> UEOI |

#### Bits [31:8]

Reserved, res0.

#### VGrp1D, bit [7]

vPE Group 1 Disabled.

| VGrp1D | Meaning                   |
|--------|---------------------------|
| 0b0    | vPE Group 1 Disabled      |
|        | maintenance interrupt not |
|        | asserted.                 |
| 0b1    | vPE Group 1 Disabled      |
|        | maintenance interrupt     |
|        | asserted.                 |

This maintenance interrupt is asserted when <u>GICH\_HCR</u>.VGrp1DIE == 1 and <u>GICH\_VMCR</u>.VENG1 == 0.

The reset behavior of this field is:

• On a Warm reset, this field resets to 0.

## VGrp1E, bit [6]

vPE Group 1 Enabled.

| VGrp1E | Meaning                   |
|--------|---------------------------|
| 0b0    | vPE Group 1 Enabled       |
|        | maintenance interrupt not |
|        | asserted.                 |
| 0b1    | vPE Group 1 Enabled       |
|        | maintenance interrupt     |
|        | asserted.                 |

This maintenance interrupt is asserted when <u>GICH\_HCR</u>.VGrp1EIE == 1 and <u>GICH\_VMCR</u>.VENG1 == 1.

The reset behavior of this field is:

• On a Warm reset, this field resets to 0.

## VGrp0D, bit [5]

vPE Group 0 Disabled.

| VGrp0D | Meaning                   |
|--------|---------------------------|
| 0b0    | vPE Group 0 Disabled      |
|        | maintenance interrupt not |
|        | asserted.                 |
| 0b1    | vPE Group 0 Disabled      |
|        | maintenance interrupt     |
|        | asserted.                 |

This maintenance interrupt is asserted when <u>GICH\_HCR</u>.VGrp0DIE == 1 and <u>GICH\_VMCR</u>.VENG0 == 0.

The reset behavior of this field is:

• On a Warm reset, this field resets to 0.

## VGrp0E, bit [4]

vPE Group 0 Enabled.

| VGrp0E | Meaning                             |
|--------|-------------------------------------|
| 0b0    | vPE Group 0 Enabled                 |
|        | maintenance interrupt not asserted. |

| 0b1 | vPE Group 0 Enabled   |  |
|-----|-----------------------|--|
|     | maintenance interrupt |  |
|     | asserted.             |  |

This maintenance interrupt is asserted when <u>GICH\_HCR</u>.VGrp0EIE == 1 and <u>GICH\_VMCR</u>.VENG0 == 1.

The reset behavior of this field is:

• On a Warm reset, this field resets to 0.

#### NP, bit [3]

No Pending.

| NP  | Meaning                          |
|-----|----------------------------------|
| 0b0 | No Pending maintenance interrupt |
|     | not asserted.                    |
| 0b1 | No Pending maintenance interrupt |
|     | asserted.                        |

This maintenance interrupt is asserted when <u>GICH\_HCR</u>.NPIE == 1 and no List register is in the pending state.

The reset behavior of this field is:

• On a Warm reset, this field resets to 0.

#### LRENP, bit [2]

List Register Entry Not Present.

| LRENP | Meaning                         |
|-------|---------------------------------|
| 0b0   | List Register Entry Not Present |
|       | maintenance interrupt not       |
|       | asserted.                       |
| 0b1   | List Register Entry Not Present |
|       | maintenance interrupt           |
|       | asserted.                       |

This maintenance interrupt is asserted when <u>GICH\_HCR</u>.LRENPIE == 1 and <u>GICH\_HCR</u>.EOICount is nonzero.

The reset behavior of this field is:

• On a Warm reset, this field resets to 0.

#### U, bit [1]

Underflow.

| U   | Meaning                         |
|-----|---------------------------------|
| 0b0 | Underflow maintenance interrupt |
|     | not asserted.                   |
| 0b1 | Underflow maintenance interrupt |
|     | asserted.                       |

This maintenance interrupt is asserted when <u>GICH\_HCR</u>.UIE == 1 and zero or one of the List register entries are marked as a valid interrupt.

The reset behavior of this field is:

• On a Warm reset, this field resets to 0.

### **EOI**, bit [0]

End Of Interrupt.

| EOI | Meaning                      |
|-----|------------------------------|
| 0b0 | End Of Interrupt maintenance |
|     | interrupt not asserted.      |
| 0b1 | End Of Interrupt maintenance |
|     | interrupt asserted.          |

This maintenance interrupt is asserted when at least one bit in  $GICH\ EISR == 1$ .

The reset behavior of this field is:

• On a Warm reset, this field resets to 0.

#### Note

A List register is in the pending state only if the corresponding <u>GICH\_LR<n></u> value is 0b01, that is, pending. The active and pending state is not included.

# Accessing GICH\_MISR

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

- For AArch32 implementations, <u>ICH\_MISR</u> provides equivalent functionality.
- For AArch64 implementations, <u>ICH\_MISR\_EL2</u> provides equivalent functionality.

A maintenance interrupt is asserted only if at least one bit is set to 1 in this register and if  $\underline{GICH\ HCR}$ . En == 1.

## GICH\_MISR can be accessed through the memory-mapped interfaces:

| Component                     | Offset | Instance  |
|-------------------------------|--------|-----------|
| GIC Virtual interface control | 0x0010 | GICH_MISR |

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