arm

# Arm<sup>®</sup> Generic Interrupt **Controller Architecture** Specification GIC architecture version 5

| Document number            | ARM-AES-0070            |
|----------------------------|-------------------------|
| Document quality           | BET                     |
| Document version           | 00bet0                  |
| Document confidentiality   | Non-confidential        |
| Document build information | 0b7a9f48 doctool 0.55.1 |

Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved.

# Arm® Generic Interrupt Controller Architecture Specification, GIC architecture version 5

### **Release information**

| Date        | Version | Changes              |  |
|-------------|---------|----------------------|--|
| 2025/Mar/28 | 00bet0  | • First BET release. |  |

## **Non-Confidential Proprietary Notice**

This document is protected by copyright and other related rights and the use or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of Arm Limited ("Arm"). **No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.** 

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether the subject matter of this document infringes any third party patents.

The content of this document is informational only. Any solutions presented herein are subject to changing conditions, information, scope, and data. This document was produced using reasonable efforts based on information available as of the date of issue of this document. The scope of information in this document may exceed that which Arm is required to provide, and such additional information is merely intended to further assist the recipient and does not represent Arm's view of the scope of its obligations. You acknowledge and agree that you possess the necessary expertise in system security and functional safety and that you shall be solely responsible for compliance with all legal, regulatory, safety and security related requirements concerning your products, notwithstanding any information or support that may be provided by Arm herein. In addition, you are responsible for any applications which are used in conjunction with any Arm technology described in this document, and to minimize risks, adequate design and operating safeguards should be provided for by you.

This document may include technical inaccuracies or typographical errors. THIS DOCUMENT IS PROVIDED "AS IS". ARM PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, Arm makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of, any patents, copyrights, trade secrets, trademarks, or other rights.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

Reference by Arm to any third party's products or services within this document is not an express or implied approval or endorsement of the use thereof.

This document consists solely of commercial items. You shall be responsible for ensuring that any permitted use, duplication, or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to Arm's customers is not intended to create or refer to any partnership relationship with any other company. Arm may make changes to this document at any time and without notice.

This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version of this document shall prevail.

The validity, construction and performance of this notice shall be governed by English Law.

The Arm corporate logo and words marked with ® or <sup>TM</sup> are registered trademarks or trademarks of Arm Limited (or its affiliates) in the US and/or elsewhere. Please follow Arm's trademark usage guidelines at https://www.arm.com/company/policies/trademarks. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners.

Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved.

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

PRE-20349

8 March 2024

#### **Confidentiality Status**

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by Arm and the party that Arm delivered this document to.

#### **Product Status**

The information in this document is at Beta quality. Beta quality means that all major features of the specification are described, but some details might be missing.

#### Web Address

https://www.arm.com

# Arm<sup>®</sup> Generic Interrupt Controller Architecture Specification, GIC architecture version 5

|           | Arm® Generic Interrupt Controller Architecture Specification, GIC architecture version 5       ii         Release information       iii         Non-Confidential Proprietary Notice       iii                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Preface   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|           | Conventions       xvi         Typographical conventions       xvi         Numbers       xvi         Pseudocode descriptions       xvi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           | Assembler syntax descriptions       xvi         Rules-based writing       xvii         Content item identifiers       xvii         Content item rendering       xvii         Content item classes       xvii                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|           | Additional reading       xviii         Feedback       xviii         Feedback on this book       xx         Inclusive terminology commitment       xx                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Chapter 1 | Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Chapter 2 | PE architecture         2.1       Architecture features and extensions       23         2.2       The GICv5 CPU interface       25         2.3       Interrupt Domains       27         2.4       Interrupt types and identifiers       29         2.4.1       PE-Private Peripheral Interrupts (PPIs)       30         2.4.2       Logical Peripheral Interrupts (LPIs)       31         2.5       Inter-Processor Interrupts       33         2.6       GIC System instructions       35         2.6.1       LPI and SPI configuration       37         2.7       Interrupt Prioritization       40         2.8       Interrupt handling       42 |
|           | 2.8Interrupt life cycle432.9The physical CPU interface462.9.1Physical PPIs462.9.2Physical priority masking482.9.3Preemptive interrupts492.9.4Physical interrupt signaling502.9.5Physical non-maskable interrupts522.9.6Doorbell PPIs532.10The virtual CPU interface562.10.1Virtual priority masking592.10.3Virtual interrupt signaling602.10.4Virtual non-maskable interrupts62                                                                                                                                                                                                                                                                     |

|           | 2.10.5 Selecting the resident VPE                              | 62  |
|-----------|----------------------------------------------------------------|-----|
|           | 2.10.6 Requesting VPE doorbells                                | 64  |
|           | 2.10.7 Legacy virtual CPU interface                            | 64  |
|           | 2.11 GIC synchronous exception priorities                      | 67  |
|           | 2.12 Interrupt ordering model and synchronization requirements | 68  |
|           | 2.12.1 GIC and GICR ordering semantics                         | 69  |
|           | 2.12.2 GSB instruction semantics                               | 71  |
|           | 2.12.3 GIC Ordering Model                                      | 71  |
|           | 2.13 Effects on the Transactional Memory Extension             | 76  |
| Chapter 3 | GICv5 system architecture                                      |     |
|           | 3.1 Interrupt Domains                                          | 81  |
|           | 3.2 Communication between GIC system components                | 83  |
|           | 3.3 Coherency considerations for GIC data structures           | 84  |
| Chapter 4 | Interrupt routing service (IRS)                                |     |
|           | 4.1 Communication between the IRS and the CPU interface        | 87  |
|           | 4.2 Signaling interrupts                                       | 88  |
|           | 4.3 IRS Domains                                                | 90  |
|           | 4.4 IRS Configuration                                          | 92  |
|           | 4.4.1 Enabling and disabling the IRS                           | 94  |
|           | 4.5 IRS synchronization requests                               | 95  |
|           | 4.6 Interrupt configuration and state                          | 97  |
|           | 4.7 The interrupt state table (IST)                            | 99  |
|           |                                                                | 101 |
|           | 4.7.2 Initialization of level 2 IST entries                    | 103 |
|           | 4.7.3 INTID state and configuration                            | 103 |
|           |                                                                | 104 |
|           | 4.7.5 Example IST structures                                   | 105 |
|           | ·                                                              | 107 |
|           | 4.8.1 Physical LPIs                                            | 107 |
|           | 4.8.2 Physical SPIs                                            | 108 |
|           | 4.8.3 Physical interrupt routing                               | 112 |
|           | 4.8.4 Physical interrupt signaling                             | 114 |
|           | 4.9 Virtualization data structures                             | 116 |
|           | 4.9.1 The VM table                                             | 117 |
|           | 4.9.2 The VPE table                                            | 122 |
|           | 4.10 Virtual interrupts                                        | 126 |
|           | 4.10.1 Virtual LPIs                                            | 126 |
|           | 4.10.2 Virtual SPIs                                            | 129 |
|           | 4.10.3 Virtual interrupt routing                               | 132 |
|           | 4.10.4 Virtual interrupt signaling                             | 133 |
|           | 4.10.5 VPE selection and configuration                         | 135 |
|           | 4.10.6 VPE residency                                           |     |
|           | 4.10.7 VPE doorbells                                           |     |
|           | 4.10.8 1ofN doorbells                                          | 138 |
|           | 4.10.9 Save and restore of virtual interrupts                  | 138 |
|           | 4.11 IRS power management                                      |     |
|           | 4.12 IRS memory access rules                                   |     |
|           | 4.13 IRS support for MPAM                                      | 146 |
|           | 4.14 IRS support for Memory Encryption Contexts                |     |
|           | 4.15 IRS support for software error reporting                  | 149 |
| Chapter 5 | Interrupt translation service (ITS)                            |     |
|           | 5.1 ITS Domains                                                | 155 |
|           |                                                                |     |

|           | 5.1.1       Supporting Realm interrupts from Non-secure writes       15         5.2       Operation       15         5.2.1       Enabling and disabling the ITS       15         5.2.2       Interrupt event types       15         5.2.3       Software generated ITS events       15         5.2.4       ITS synchronization requests       16         5.3       Translation structures       16         5.3.1       The Device Table (DT)       16         5.3.2       The Interrupt Translation Table (ITT)       16         5.4.1       ITS cache management       16         5.4.2       ITS cache management for EventIDs       16         5.4.1       ITS cache management for DeviceIDs       16         5.4.2       ITS cache management for DeviceIDs       16         5.5       ITS memory access rules       17         5.6       ITS support for MPAM       17         5.7       ITS support for Memory Encryption Contexts       17                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 5.8 ITS support for software error reporting                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Chapter 6 | Interrupt Wire Bridge (IWB)         6.1       IWB wire control registers       18         6.2       IWB support for multiple Interrupt Domains       18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Chapter 7 | GIC Performance Monitoring Unit (PMU)7.1CoreSight PMU extensions187.2GIC PMU Overflow interrupt187.3GIC PMU event types197.4Event filtering197.5IRS PMU events197.6.1ITS PMU events filtering197.6.1ITS PMU events filtering19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Chapter 8 | System instructions         8.1       System instructions for the Current Interrupt Domain       19         8.1.1       GIC CDAFF, Interrupt Set Target in the Current Interrupt Domain       20         8.1.2       GIC CDDI, Interrupt Deactivate in the Current Interrupt Domain       20         8.1.3       GIC CDDIS, Interrupt Deactivate in the Current Interrupt Domain       20         8.1.4       GIC CDEN, Interrupt Disable in the Current Interrupt Domain       20         8.1.5       GIC CDEOI, Priority Drop in the Current Interrupt Domain       20         8.1.6       GIC CDHM, Interrupt Handling mode state in the Current Interrupt Domain       20         8.1.6       GIC CDPEND, Interrupt Set/Clear Pending state in the Current Interrupt Domain       21         8.1.7       GIC CDPRI, Interrupt Set priority in the Current Interrupt Domain       21         8.1.8       GIC CDPRI, Interrupt Set priority in the Current Interrupt Domain       21         8.1.9       GIC CDRCFG, Request Interrupt Configuration in the Current Interrupt Domain       21         8.1.10       GICR CDIA, Interrupt Acknowledge in the Current Interrupt Domain       21         8.1.11       GICR CDNMIA, Non-maskable Interrupt Acknowledge in the Current Interrupt Domain       22         8.2       System instructions for the Virtual Interrupt Domain       22 |
|           | 8.2.1       GIC VDAFF, Interrupt Set Target in the Virtual Interrupt Domain       22         8.2.2       GIC VDDI, Interrupt Deactivate in the Virtual Interrupt Domain       22         8.2.3       GIC VDDIS, Interrupt Disable in the Virtual Interrupt Domain       22         8.2.4       GIC VDEN, Interrupt Enable in the Virtual Interrupt Domain       22         8.2.5       GIC VDHM, Interrupt Handling mode in the Virtual Interrupt Domain       23         8.2.6       GIC VDPEND, Interrupt Set/Clear Pending state in the Virtual Interrupt Domain       23         2.6       GIC VDPEND, Interrupt Set/Clear Pending state in the Virtual Interrupt Domain       23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|           |     | 8.2.7<br>8.2.8 | GIC VDPRI, Interrupt Set priority in the Virtual Interrupt Domain GIC VDRCFG, Request Interrupt Configuration in the Virtual Interrupt Domain |              |
|-----------|-----|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------|
|           | 8.3 | Syster         | m instructions for the Logical Interrupt Domain                                                                                               |              |
|           | 0.0 | 8.3.1          | GIC LDAFF, Interrupt Set Target in the Logical Interrupt Domain                                                                               |              |
|           |     | 8.3.2          | GIC LDDI, Interrupt Deactivate in the Logical Interrupt Domain                                                                                |              |
|           |     | 8.3.3          | GIC LDDIS, Interrupt Disable in the Logical Interrupt Domain                                                                                  |              |
|           |     | 8.3.4          | GIC LDEN, Interrupt Enable in the Logical Interrupt Domain                                                                                    |              |
|           |     | 8.3.4<br>8.3.5 | GIC LDHM, Interrupt Handling mode in the Logical Interrupt Domain                                                                             |              |
|           |     |                |                                                                                                                                               | 240          |
|           |     | 8.3.6          | GIC LDPEND, Interrupt Set/Clear Pending state in the Logical Interrupt Domain                                                                 | 250          |
|           |     | 8.3.7          | GIC LDPRI, Interrupt Set priority in the Logical Interrupt Domain                                                                             |              |
|           |     | 8.3.8          | GIC LDRCFG, Request Interrupt Configuration in the Logical Interrupt                                                                          |              |
|           |     |                | Domain                                                                                                                                        |              |
|           | 8.4 |                | ynchronization barrier instructions                                                                                                           |              |
|           |     | 8.4.1          | GSB SYS, GIC Synchronization Barrier System                                                                                                   |              |
|           |     | 8.4.2          | GSB ACK, GIC Synchronization Barrier Interrupt Acknowledge                                                                                    | 258          |
| Chapter 9 |     | tem regis      |                                                                                                                                               |              |
|           | 9.1 |                | rronization requirements for GICv5 System registers                                                                                           |              |
|           | 9.2 |                | nterface registers                                                                                                                            |              |
|           |     | 9.2.1          | ICC_APR_EL1, Interrupt Controller Physical Active Priorities Register .                                                                       | 262          |
|           |     | 9.2.2          | ICC_APR_EL3, Interrupt Controller Physical Active Priorities Register                                                                         |              |
|           |     |                | for EL3                                                                                                                                       |              |
|           |     | 9.2.3          | ICC_CR0_EL1, Interrupt Controller EL1 Physical Control Register                                                                               |              |
|           |     | 9.2.4          | ICC_CR0_EL3, Interrupt Controller EL3 Physical Control Register                                                                               | 271          |
|           |     | 9.2.5          | ICC_DOMHPPIR_EL3, Interrupt Controller Domain Highest Priority                                                                                |              |
|           |     |                | Pending Interrupt Register                                                                                                                    | 273          |
|           |     | 9.2.6          | ICC_HAPR_EL1, Interrupt Controller Physical Highest Active Priority                                                                           |              |
|           |     |                | Register                                                                                                                                      | 275          |
|           |     | 9.2.7          | ICC HPPIR EL1, Interrupt Controller Physical Highest Priority Pending                                                                         |              |
|           |     |                | Interrupt Register                                                                                                                            | 277          |
|           |     | 9.2.8          | ICC HPPIR EL3, Interrupt Controller Physical Highest Priority Pending                                                                         |              |
|           |     |                | Interrupt Register                                                                                                                            | 279          |
|           |     | 9.2.9          | ICC IAFFIDR EL1, Interrupt Controller PE Interrupt Affinity ID Register                                                                       |              |
|           |     | 9.2.10         | ICC ICSR EL1, Interrupt Controller Interrupt Configuration and State                                                                          | 201          |
|           |     | 0.2.10         | Register                                                                                                                                      | 282          |
|           |     | 9.2.11         | ICC IDR0 EL1, Interrupt Controller ID Register 0                                                                                              | 286          |
|           |     | 9.2.12         | ICC PCR EL1, Interrupt Controller Physical Interrupt Priority Control                                                                         | 200          |
|           |     | 9.2.12         |                                                                                                                                               | 000          |
|           |     | 0.0.10         | Register                                                                                                                                      | 200          |
|           |     | 9.2.13         |                                                                                                                                               | 001          |
|           |     | 0.0.14         | for EL3                                                                                                                                       |              |
|           |     | 9.2.14         | ID_AA64PFR2_EL1, AArch64 Processor Feature Register 2                                                                                         |              |
|           | 9.3 |                | I CPU interface registers                                                                                                                     |              |
|           |     | 9.3.1          | ICV_APR_EL1, Interrupt Controller Virtual Active Priorities Register                                                                          |              |
|           |     | 9.3.2          | ICV_CR0_EL1, Interrupt Controller EL1 Virtual Control Register                                                                                | 299          |
|           |     | 9.3.3          | ICV_HAPR_EL1, Interrupt Controller Virtual Highest Active Priority Reg-<br>ister                                                              | 302          |
|           |     | 9.3.4          | ICV HPPIR EL1, Interrupt Controller Virtual Highest Priority Pending                                                                          | 002          |
|           |     | 5.5.4          | Interrupt Register                                                                                                                            | 304          |
|           |     | 025            | ICV PCR EL1, Interrupt Controller Virtual Interrupt Priority Control                                                                          | 504          |
|           |     | 9.3.5          |                                                                                                                                               | 200          |
|           | 0.4 | יי וסס         |                                                                                                                                               |              |
|           | 9.4 |                |                                                                                                                                               | 309          |
|           |     | 9.4.1          | ICC_PPI_CACTIVER <n>_EL1, Interrupt Controller Physical PPI Clear</n>                                                                         | <b>a</b> · - |
|           |     |                | Active Registers, n = 0 - 1                                                                                                                   | 310          |

|     | 9.4.2   | ICC_PPI_CPENDR <n>_EL1, Interrupt Controller Physical PPI Clear<br/>Pending State Registers, n = 0 - 1</n> | 313        |
|-----|---------|------------------------------------------------------------------------------------------------------------|------------|
|     | 9.4.3   | ICC_PPI_DOMAINR <n>_EL3, Interrupt Controller PPI Domain Registers, n = 0 - 3</n>                          | 316        |
|     | 9.4.4   | ICC_PPI_ENABLER <n>_EL1, Interrupt Controller Physical PPI Enable<br/>Registers, n = 0 - 1</n>             | 318        |
|     | 9.4.5   | ICC_PPI_HMR <n>_EL1, Interrupt Controller Physical PPI Handling mode Registers, n = 0 - 1</n>              | 321        |
|     | 9.4.6   | ICC_PPI_PRIORITYR <n>_EL1, Interrupt Controller Physical PPI Priority<br/>Registers, n = 0 - 15</n>        | 323        |
|     | 9.4.7   | ICC_PPI_SACTIVER <n>_EL1, Interrupt Controller Physical PPI Set</n>                                        |            |
|     | 9.4.8   | Active Registers, n = 0 - 1                                                                                | 325<br>328 |
| 9.5 | Virtual | PPI registers                                                                                              | 331        |
| 5.5 | 9.5.1   | ICV PPI CACTIVER <n> EL1, Interrupt Controller Virtual PPI Clear</n>                                       | 001        |
|     | 9.5.1   | Active Registers, $n = 0 - 1$                                                                              | 332        |
|     | 0 5 0   |                                                                                                            | 332        |
|     | 9.5.2   | ICV_PPI_CPENDR <n>_EL1, Interrupt Controller Virtual PPI Clear Pend-</n>                                   | 005        |
|     | 9.5.3   | ing State Registers, n = 0 - 1                                                                             | 335        |
|     |         | able Registers, n = 0 - 1                                                                                  | 338        |
|     | 9.5.4   | ICV PPI HMR <n> EL1, Interrupt Controller Virtual PPI Handling mode</n>                                    |            |
|     |         | Registers, $n = 0 - 1$                                                                                     | 341        |
|     | 9.5.5   | ICV PPI PRIORITYR <n> EL1, Interrupt Controller Virtual PPI Priority</n>                                   | 011        |
|     | 5.5.5   | Registers, $n = 0 - 15$                                                                                    | 343        |
|     | 9.5.6   | ICV_PPI_SACTIVER <n>_EL1, Interrupt Controller Virtual PPI Set Active</n>                                  | 343        |
|     | 9.5.6   | Registers, n = 0 - 1                                                                                       | 345        |
|     | 9.5.7   | ICV_PPI_SPENDR <n>_EL1, Interrupt Controller Virtual PPI Set Pend-</n>                                     |            |
|     |         | ing State Registers, n = 0 - 1                                                                             | 348        |
| 9.6 | Hyper   | visor control registers                                                                                    | 351        |
|     | 9.6.1   | ICH APR EL2, Interrupt Controller Active Virtual Priorities Register                                       |            |
|     | 9.6.2   | ICH CONTEXTR EL2, Interrupt Controller Virtual Context Register                                            | 354        |
|     | 9.6.3   | ICH HFGITR EL2, Hypervisor GIC Fine-Grained Instruction Trap Registe                                       |            |
|     | 9.6.4   | ICH HFGRTR EL2, Hypervisor GIC Fine-Grained Read Trap Register                                             | 363        |
|     |         |                                                                                                            |            |
|     | 9.6.5   | ICH_HFGWTR_EL2, Hypervisor GIC Fine-Grained Write Trap Register                                            | 369        |
|     | 9.6.6   | ICH_HPPIR_EL2, Interrupt Controller Hypervisor Highest Priority Pend-                                      |            |
|     |         | ing Interrupt Register                                                                                     | 374        |
|     | 9.6.7   | ICH_PPI_ACTIVER <n>_EL2, Interrupt Controller Virtual Interrupt Active</n>                                 |            |
|     |         | Registers, $n = 0 - 1$                                                                                     | 376        |
|     | 9.6.8   | ICH_PPI_DVIR <n>_EL2, Interrupt Controller PPI Direct-inject Virtual</n>                                   |            |
|     |         | Interrupt Registers, $n = 0 - 1$                                                                           | 379        |
|     | 9.6.9   | ICH_PPI_ENABLER <n>_EL2, Interrupt Controller Virtual Interrupt En-</n>                                    |            |
|     | / -     | able Registers, n = 0 - 1                                                                                  | 382        |
|     | 9.6.10  | ICH_PPI_PENDR <n>_EL2, Interrupt Controller Virtual Interrupt Pending<br/>State Registers, n = 0 - 1</n>   | 384        |
|     | 9.6.11  | ICH PPI PRIORITYR <n> EL2, Interrupt Controller Virtual Interrupt</n>                                      |            |
|     | 0.0     | Priority Registers, $n = 0 - 15$                                                                           | 386        |
|     | 9.6.12  | ICH_VCTLR_EL2, Interrupt Controller Virtual CPU interface Control                                          | 000        |
|     |         | Register                                                                                                   | 388        |
|     | 9.6.13  | ICH_VMCR_EL2, Interrupt Controller Virtual Machine Control Register                                        | 391        |
|     | 9.6.14  | Nested virtualization                                                                                      | 393        |
| 9.7 | Legac   |                                                                                                            |            |
|     | 9.7.1   | ICH AP0R <n> EL2, Interrupt Controller Active Virtual Priorities Regis-</n>                                |            |
|     | ·       | ters 0, n = 0 - 3                                                                                          | 396        |
|     |         |                                                                                                            |            |

|                |              | 9.7.2     | ICH_AP1R <n>_EL2, Interrupt Controller Active Virtual Priorities Regis-</n> |
|----------------|--------------|-----------|-----------------------------------------------------------------------------|
|                |              |           | ters 1, n = 0 - 3                                                           |
|                |              | 9.7.3     | ICH_EISR_EL2, Interrupt Controller End of Interrupt Status Register 401     |
|                |              | 9.7.4     | ICH_ELRSR_EL2, Interrupt Controller Empty List Register Status Register403  |
|                |              | 9.7.5     | ICH_HCR_EL2, Interrupt Controller Hyp Control Register                      |
|                |              | 9.7.6     | ICH_LR <n>_EL2, Interrupt Controller List Registers, n = 0 - 15 409</n>     |
|                |              | 9.7.7     | ICH MISR EL2, Interrupt Controller Maintenance Interrupt State Register412  |
|                |              | 9.7.8     | ICH_VTR_EL2, Interrupt Controller VGIC Type Register                        |
|                |              | 9.7.9     | Nested virtualization                                                       |
|                | 9.8          |           | cy virtual CPU interface registers                                          |
|                | 0.0          | 9.8.1     | AArch64 Legacy virtual CPU interface registers                              |
|                |              | 0.0.1     |                                                                             |
| Chapter 10     | Reg          | isters a  | nd memory maps                                                              |
|                | 10.1         | Mem       | ory-mapped programmer's model                                               |
|                | 10.2         | IRS I     | register frames                                                             |
|                |              | 10.2.1    | IRS_CONFIG_FRAME, IRS configuration register frame                          |
|                |              | 10.2.2    | IRS SETLPI FRAME, IRS SETLPI register frame                                 |
|                | 10.3         |           | egister frames                                                              |
|                |              | 10.3.1    | ITS_CONFIG_FRAME, ITS configuration register frame                          |
|                |              | 10.3.2    | ITS TRANSLATE FRAME, ITS translate register frame                           |
|                | 10.4         |           | register frames                                                             |
|                | 10.4         | 10.4.1    | IWB_CONFIG_FRAME, IWB configuration registers frame                         |
|                | 10.5         |           | PMU register frame                                                          |
|                | 10.5         |           |                                                                             |
|                | 10.6         | 10.5.1    | GIC_PMU_FRAME, GIC PMU register frame                                       |
|                | 10.6         | laem      |                                                                             |
| Chapter 11     | Data         | a structu | Ires                                                                        |
| •              | 11.1         |           | Data Structures                                                             |
|                |              | 11.1.1    | L1_DTE, Level 1 device table entry                                          |
|                |              | 11.1.2    | L2_DTE, Level 2 device table entry                                          |
|                |              | 11.1.3    | L1_ITTE, Level 1 interrupt translation table entry                          |
|                |              | 11.1.4    | L2_ITTE, Level 2 interrupt translation table entry                          |
|                | 11.2         |           |                                                                             |
|                | 11.2         | 11.2.1    |                                                                             |
|                |              |           | L1_VMTE, Level 1 VM table entry                                             |
|                |              | 11.2.2    | L2_VMTE, Level 2 VM table entry                                             |
|                |              | 11.2.3    | L1_ISTE, Level 1 interrupt state table entry                                |
|                |              | 11.2.4    | L2_ISTE, Level 2 interrupt state table entry                                |
|                |              | 11.2.5    | VPETE, VPE table entry                                                      |
|                |              | 11.2.6    | VM_DESC, VM descriptor                                                      |
|                |              | 11.2.7    | VPE_DESC, VPE descriptor                                                    |
|                |              |           |                                                                             |
| Part A GICv5 S | trear        | n Prote   | ocol interface                                                              |
|                |              |           |                                                                             |
| Chapter A1     | GIC          | v5 Strea  | m Protocol overview                                                         |
| Chapter A2     | AME          | BA AXI5   | -Stream Transport Layer                                                     |
|                | A2.1         |           | als                                                                         |
|                | A2.2         |           | nel identification                                                          |
|                | A2.3         |           | status                                                                      |
|                | 712.0        | Link      | 510105                                                                      |
| Chapter A3     | Com          | nmon be   | ehaviors                                                                    |
| Chapter A4     | Inter        | rrupt Ha  | Indling channel                                                             |
|                | A4.1         |           | mand summary                                                                |
|                | A4.1<br>A4.2 |           | tanding commands                                                            |
|                | A4.2         | Outs      | Lanung commanus                                                             |
|                |              |           |                                                                             |

|            | A4.3<br>A4.4<br>A4.5<br>A4.6<br>A4.7 | Mana<br>A4.4.1<br>A4.4.2<br>Forwa<br>INTID | ection management                                                                                                              | 657<br>657<br>658<br>659<br>661 |
|------------|--------------------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Chapter A5 | Inter                                | rupt Sig                                   | Inaling channel                                                                                                                |                                 |
| •          | A5.1                                 |                                            | nand summary                                                                                                                   | 664                             |
|            | A5.2                                 |                                            | anding commands                                                                                                                |                                 |
|            | A5.3                                 | Signa                                      | ling interrupts to the IRS                                                                                                     | 666                             |
|            | A5.4                                 | Conn                                       | ection management                                                                                                              | 667                             |
| Chapter A6 | Alph                                 | abetica                                    | l list of commands                                                                                                             |                                 |
|            | A6.1                                 | Interr                                     | upt Handling channel                                                                                                           |                                 |
|            |                                      | A6.1.1                                     | Activate, Activate command (CPUIF -> IRS)                                                                                      |                                 |
|            |                                      | A6.1.2                                     | ActivateAck, Activate Acknowledge command (IRS -> CPUIF)                                                                       |                                 |
|            |                                      | A6.1.3                                     | Deactivate, Deactivate interrupt command (CPUIF -> IRS)                                                                        | 672                             |
|            |                                      | A6.1.4                                     | DeactivateAck, Deactivate interrupt Acknowledge command (IRS ->                                                                | 674                             |
|            |                                      | A6.1.5                                     | CPUIF)                                                                                                                         |                                 |
|            |                                      | A6.1.6                                     | DownstreamControlAck, Downstream Control Acknowledge command                                                                   | 075                             |
|            |                                      | / 10/ 110                                  | (CPUIF -> IRS)                                                                                                                 | 676                             |
|            |                                      | A6.1.7                                     | Forward, Forward command (IRS -> CPUIF)                                                                                        |                                 |
|            |                                      | A6.1.8                                     | Recall, Recall command (IRS -> CPUIF)                                                                                          |                                 |
|            |                                      | A6.1.9                                     | Release, Release command (CPUIF -> IRS)                                                                                        |                                 |
|            |                                      | A6.1.10                                    | RequestConfig, Request Interrupt Configuration command (CPUIF -> IRS                                                           | 682(                            |
|            |                                      | A6.1.11                                    | RequestConfigAck, Request Interrupt Configuration Acknowledge com-<br>mand (IRS -> CPUIF)                                      | 684                             |
|            |                                      | A6.1.12                                    | SetAck, Set interrupt configuration acknowledge command (IRS -> CPUIF                                                          |                                 |
|            |                                      | A6.1.13                                    | SetEnabled, Set interrupt Enabled command (CPUIF -> IRS)                                                                       |                                 |
|            |                                      | A6.1.14                                    | SetHandling, Set Interrupt Handling Mode command (CPUIF -> IRS) .                                                              |                                 |
|            |                                      | A6.1.15                                    | SetPending, Set interrupt Pending command (CPUIF -> IRS)                                                                       |                                 |
|            |                                      | A6.1.16                                    | SetPriority, Set Interrupt Priority command (CPUIF -> IRS)                                                                     |                                 |
|            |                                      | A6.1.17                                    | SetResident, Set Resident command (CPUIF -> IRS)                                                                               |                                 |
|            |                                      | A6.1.18                                    | SetResidentAck, Set Resident acknowledge command (IRS -> CPUIF)                                                                |                                 |
|            |                                      | A6.1.19<br>A6.1.20                         | SetTarget, Set Interrupt Target command (CPUIF -> IRS) Sync, synchronizes previously sent configuration changes (CPUIF -> IRS) |                                 |
|            |                                      | A6.1.21                                    | SyncAck, synchronizes previously sent configuration changes (OF OF 2 inter-                                                    | ,,,00                           |
|            |                                      |                                            | CPUIF)                                                                                                                         | 701                             |
|            |                                      | A6.1.22                                    | UpstreamControl, Upstream Control (CPUIF -> IRS)                                                                               |                                 |
|            |                                      | A6.1.23                                    | UpstreamControlAck, Upstream Control Acknowledge command (IRS -> CPUIF)                                                        |                                 |
|            |                                      | A6.1.24                                    | WakeRequest, Wake request (IRS -> CPUIF)                                                                                       |                                 |
|            | A6.2                                 |                                            | upt Signaling channel                                                                                                          |                                 |
|            |                                      | A6.2.1                                     | INT, Interrupt command (Interrupt Source -> IRS)                                                                               |                                 |
|            |                                      | A6.2.2                                     | Flush, Flush command (IRS -> Interrupt Source)                                                                                 |                                 |
|            |                                      | A6.2.3                                     | FlushAck, Flush acknowledge command (Interrupt Source -> IRS)                                                                  |                                 |
|            |                                      | A6.2.4                                     | Quiesce, Quiesce command (Interrupt Source -> IRS)                                                                             |                                 |
|            |                                      | A6.2.5                                     | QuiesceAck, Quiesce acknowledge command (IRS -> Interrupt Source)                                                              |                                 |
|            |                                      | A6.2.6                                     | Resample, Resample request command (IRS -> Interrupt Source)                                                                   | 711                             |
|            |                                      | A6.2.7                                     | ResampleAck, Resample request acknowledge command (Interrupt                                                                   | 740                             |
|            |                                      | A6.2.8                                     | Source -> IRS)                                                                                                                 |                                 |

#### A6.2.9 ResetAck, Reset acknowledge command (IRS -> Interrupt Source) . . . 714

## Chapter A7 Example sequences

| A7.1 | • | Bringing the Interrupt Handling channel online and taking it offline     | 16 |  |  |  |  |  |  |
|------|---|--------------------------------------------------------------------------|----|--|--|--|--|--|--|
| A7.2 |   | Simple interrupt life-cycle                                              |    |  |  |  |  |  |  |
| A7.3 |   | Replacing the candidate HPPI for an Interrupt Domain, or resident VPE 72 | 22 |  |  |  |  |  |  |
| A7.4 |   | Making a VPE resident                                                    | 25 |  |  |  |  |  |  |
| A7.5 |   | Interrupt configuration                                                  | 28 |  |  |  |  |  |  |
| A7.6 |   | Sending IPIs                                                             | 29 |  |  |  |  |  |  |
| A7.7 |   | 1 of N interrupts                                                        | 30 |  |  |  |  |  |  |

## Part B Litmus tests

| Chapter B1 | Inter | rrupt ord | dering litmus tests                                                   |
|------------|-------|-----------|-----------------------------------------------------------------------|
|            | B1.1  |           | upt litmus test assumptions                                           |
|            | B1.2  | Atom      | icity of interrupt updates by GIC system instructions                 |
|            |       | B1.2.1    | Notes                                                                 |
|            |       | B1.2.2    | Litmus test                                                           |
|            | B1.3  | Multip    | ble updates of the same Interrupt Location                            |
|            |       | B1.3.1    | Notes                                                                 |
|            |       | B1.3.2    | Litmus test with two configuration updates                            |
|            |       | B1.3.3    | Litmus test with an interrupt disable and an interrupt deactivate 735 |
|            |       | B1.3.4    | Litmus test with an interrupt deactivate and an interrupt disable 736 |
|            | B1.4  | Read      | ling back interrupt writes on a single PE                             |
|            |       | B1.4.1    | Notes                                                                 |
|            |       | B1.4.2    | Litmus test with a configuration update                               |
|            |       | B1.4.3    | Litmus test with deactivate                                           |
|            |       | B1.4.4    | Litmus test with acknowledgement                                      |
|            |       | B1.4.5    | Litmus test with two configuration updates                            |
|            | B1.5  | Read      | ling interrupt configurations and subsequent updates                  |
|            |       | B1.5.1    | Notes                                                                 |
|            |       | B1.5.2    | Litmus test with update to priority                                   |
|            |       | B1.5.3    | Litmus test with deactivate                                           |
|            |       | B1.5.4    | Litmus test with acknowledge                                          |
|            | B1.6  | Confi     | guration and acknowledgement                                          |
|            |       | B1.6.1    | Notes                                                                 |
|            |       | B1.6.2    | Litmus test using disable without explicit synchronization            |
|            |       | B1.6.3    | Litmus test using disable with explicit synchronization               |
|            |       | B1.6.4    | Litmus test with deactivate                                           |
|            |       | B1.6.5    | Litmus test using priority without explicit synchronization           |
|            |       | B1.6.6    | Litmus test using priority with explicit synchronization              |
|            | B1.7  | Ackno     | owledge followed by interrupt changes                                 |
|            |       | B1.7.1    | Notes                                                                 |
|            |       | B1.7.2    | Litmus test with deactivate                                           |
|            |       | B1.7.3    | Litmus test with make pending                                         |
|            | B1.8  | Multip    | ble updates with interleaved read                                     |
|            |       | B1.8.1    | Notes                                                                 |
|            |       | B1.8.2    | Litmus test                                                           |
|            | B1.9  | Confi     | guration write and IRQ unmask in PSTATE                               |
|            |       | B1.9.1    | Notes                                                                 |
|            |       | B1.9.2    | Litmus test                                                           |
|            |       | B1.9.3    | Litmus test with initially masked IRQs                                |
|            |       | B1.9.4    | Litmus test with disable of a PPI                                     |
|            | B1.10 | ) Confi   | guration write and exception status on a single PE                    |
|            |       |           |                                                                       |

| B1.10.1                | Notes                                                     | 750 |
|------------------------|-----------------------------------------------------------|-----|
| B1.10.2                | Litmus test without wait for IRQ exception to be signaled |     |
| B1.10.3                | Litmus test with wait for IRQ exception to be signaled    |     |
|                        | nd acknowledgement                                        |     |
| B1.11.1                | Notes                                                     |     |
| B1.11.2                | Litmus test without explicit synchronization              |     |
| B1.11.3                | Litmus test with explicit synchronization                 |     |
|                        | erving multiple writes on a different PE                  |     |
| B1.12.1                | Notes                                                     |     |
| B1.12.2                |                                                           |     |
|                        | I of the configuration of an interrupt                    |     |
| B1.13.1                | Notes                                                     |     |
| B1.13.2                |                                                           |     |
| B1.13.2                |                                                           |     |
|                        | ple reads of the same config                              |     |
| B1.14 Mulu             |                                                           |     |
| B1.14.1<br>B1.14.2     |                                                           |     |
|                        |                                                           |     |
|                        |                                                           |     |
| B1.15.1                |                                                           |     |
| B1.15.2                |                                                           |     |
|                        | bendent reads of independent writes                       |     |
| B1.16.1                | Notes                                                     |     |
| B1.16.2                |                                                           |     |
|                        | sage passing via flag in memory                           |     |
| B1.17.1                | Notes                                                     |     |
| B1.17.2                | Litmus test                                               |     |
|                        | sage passing via interrupt priority configuration         |     |
| B1.18.1                | Notes                                                     |     |
| B1.18.2                | Litmus test                                               |     |
| B1.19 Mess             | age passing with an LPI and a device read                 | 763 |
| B1.19.1                | Notes                                                     |     |
| B1.19.2                | Litmus test                                               |     |
| B1.19.3                | Litmus test with address dependency                       | 763 |
| B1.20 Mess             | age passing with an LPI and a GSB                         | 765 |
| B1.20.1                | Notes                                                     | 765 |
| B1.20.2                | Litmus test                                               | 765 |
| B1.21 Mess             | age passing with an IPI and a GSB                         | 767 |
| B1.21.1                | Notes                                                     | 767 |
| B1.21.2                | Litmus test                                               | 767 |
| B1.22 Mess             | age passing using deactivate                              | 768 |
| B1.22.1                | Notes                                                     | 768 |
| B1.22.2                | Litmus test with explicit synchronization                 |     |
| B1.22.3                | Litmus test with address dependency                       |     |
| B1.22.4                | Litmus test with control dependency                       |     |
| B1.22.5                | Litmus test without explicit synchronization              |     |
| B1.22.6                | Litmus test with a DSB but without a GSB                  |     |
| B1.22.7                | Litmus test without a DSB but with a GSB                  |     |
|                        | dge merging and message passing                           |     |
| B1.23 B1.23.1          | Notes                                                     |     |
| B1.23.2                |                                                           |     |
| -                      | ce edge merging with GSB ACK                              |     |
| В1.24 Devic<br>B1.24.1 |                                                           |     |
| B1.24.1<br>B1.24.2     |                                                           |     |
|                        | iguration read and interrupt acknowledge                  |     |
|                        |                                                           |     |
| B1.25.1                | Notes                                                     | 111 |

| B1.25.2                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| B1.25.3                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
| B1.26 Atom                                                                                                                                              | nicity of interrupt acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
| B1.26.1                                                                                                                                                 | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.26.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
|                                                                                                                                                         | nicity of interrupt disable and acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                |
| B1.27.1                                                                                                                                                 | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.27.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
|                                                                                                                                                         | rupt handler completion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                |
| B1.28.1                                                                                                                                                 | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.28.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
|                                                                                                                                                         | iguration update while disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
| B1.29.1                                                                                                                                                 | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.29.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
|                                                                                                                                                         | nicity of interrupt acknowledge and retarget                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                |
| B1.30.1                                                                                                                                                 | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.30.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
|                                                                                                                                                         | interrupt acknowledge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.31.1                                                                                                                                                 | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.31.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
|                                                                                                                                                         | rgeting interrupts without synchronization                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                |
| B1.32.1                                                                                                                                                 | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.32.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
|                                                                                                                                                         | ding interrupt configuration and exception status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                |
| B1.33.1<br>B1.33.2                                                                                                                                      | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.33.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
|                                                                                                                                                         | ding interrupt configuration and IRQ unmask in PSTATE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.34 Neac                                                                                                                                              | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.34.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
| B1.34.3                                                                                                                                                 | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                |
| B1.34.4                                                                                                                                                 | Litmus test with ISB after unmasking IRQ in PSTATE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                |
|                                                                                                                                                         | activate and system register read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                |
| B1.35.1                                                                                                                                                 | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                |
| B1.35.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
| B1.35.3                                                                                                                                                 | Litmus test with GSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                |
| B1.35.4                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
| B1.36 PPI c                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 792                                                                                            |
| B1.36.1                                                                                                                                                 | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 792                                                                                            |
| B1.36.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 792                                                                                            |
| D1.30.2                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
|                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 793                                                                                            |
|                                                                                                                                                         | acknowledgement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 793<br>793                                                                                     |
| B1.37 PPI a                                                                                                                                             | acknowledgement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                |
| B1.37 PPI a<br>B1.37.1                                                                                                                                  | acknowledgement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 793                                                                                            |
| B1.37 PPI a<br>B1.37.1<br>B1.37.2<br>B1.37.3                                                                                                            | acknowledgement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 793<br>793                                                                                     |
| B1.37 PPI a<br>B1.37.1<br>B1.37.2<br>B1.37.3                                                                                                            | acknowledgement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 793<br>793<br>793                                                                              |
| B1.37 PPI a<br>B1.37.1<br>B1.37.2<br>B1.37.3<br>B1.38 Write                                                                                             | acknowledgement       Notes         Notes       Litmus test         Litmus test       Litmus test         after changing resident VM       Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 793<br>793<br>793<br>793<br>795                                                                |
| B1.37 PPI a<br>B1.37.1<br>B1.37.2<br>B1.37.3<br>B1.38 Write<br>B1.38.1<br>B1.38.2                                                                       | acknowledgement       Notes         Notes       Litmus test         Litmus test       Litmus test         after changing resident VM       Litmus test         Notes       Litmus test         Litmus test       Litmus test                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 793<br>793<br>793<br>795<br>795<br>795                                                         |
| B1.37 PPI a<br>B1.37.1<br>B1.37.2<br>B1.37.3<br>B1.38 Write<br>B1.38.1<br>B1.38.2                                                                       | acknowledgement       Notes         Notes       Litmus test         Litmus test       Litmus test         after changing resident VM       Notes         Litmus test       Litmus test         before changing resident VM       Litmus test                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 793<br>793<br>793<br>795<br>795<br>795<br>795                                                  |
| B1.37 PPI a<br>B1.37.1<br>B1.37.2<br>B1.37.3<br>B1.38 Write<br>B1.38.1<br>B1.38.2<br>B1.39 Write<br>B1.39.1<br>B1.39.2                                  | acknowledgement       Notes         Notes       Litmus test         Litmus test       Litmus test         after changing resident VM       Litmus test         Notes       Litmus test         Litmus test       Litmus test                                                                                                                                                                                                                                                                                                                                                                                      | 793<br>793<br>793<br>795<br>795<br>795<br>795<br>795<br>796                                    |
| B1.37 PPI a<br>B1.37.1<br>B1.37.2<br>B1.37.3<br>B1.38 Write<br>B1.38.1<br>B1.38.2<br>B1.39 Write<br>B1.39.1<br>B1.39.2<br>B1.40 Com                     | acknowledgement       Notes         Notes       Litmus test         Litmus test       Litmus test         after changing resident VM       Litmus test         Notes       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         Plefore changing resident VM       Litmus test         Notes       Litmus test         pletion of GIC and GICR instructions in finite time       Litmus                                                                                                                                                                                                                                                                                                  | 793<br>793<br>795<br>795<br>795<br>795<br>796<br>796                                           |
| B1.37 PPL a<br>B1.37.1<br>B1.37.2<br>B1.37.3<br>B1.38 Write<br>B1.38.1<br>B1.38 B1.38.2<br>B1.39 Write<br>B1.39.1<br>B1.39.2<br>B1.40 Com<br>B1.40.1    | acknowledgement       Notes         Litmus test       Litmus test         Litmus test       Litmus test         after changing resident VM       Litmus test         Notes       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         pletion of GIC and GICR instructions in finite time       Notes                                                                                                                                                                                                                                                                                                                                                                                                                          | 793<br>793<br>795<br>795<br>795<br>795<br>796<br>796<br>796<br>797<br>797                      |
| B1.37 PPI a<br>B1.37.1<br>B1.37.2<br>B1.37.3<br>B1.38 Write<br>B1.38.1<br>B1.38<br>B1.39 Write<br>B1.39.1<br>B1.39.2<br>B1.40 Com<br>B1.40.1<br>B1.40.2 | acknowledgement       Notes         Litmus test       Litmus test         Litmus test       Litmus test         after changing resident VM       Litmus test         Notes       Litmus test         Litmus test       Litmus test         Debefore changing resident VM       Litmus test         Debefore changing resident VM       Litmus test         Debefore changing resident VM       Litmus test         Difference       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test with a priority update observed by a configuration read                                                                                                                                                 | 793<br>793<br>795<br>795<br>795<br>795<br>796<br>796<br>796<br>796<br>797<br>797<br>797        |
| B1.37 PPL a<br>B1.37.1<br>B1.37.2<br>B1.37.3<br>B1.38 Write<br>B1.38.1<br>B1.38 B1.38.2<br>B1.39 Write<br>B1.39.1<br>B1.39.2<br>B1.40 Com<br>B1.40.1    | acknowledgement       Notes         Litmus test       Litmus test         Litmus test       Litmus test         after changing resident VM       Litmus test         Notes       Litmus test         Litmus test       Litmus test         Defore changing resident VM       Litmus test         Notes       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         Litmus test       Litmus test         Litmus test with a priority update observed by a configuration read       Litmus test with an interrupt acknowledge observed by a configuration read | 793<br>793<br>795<br>795<br>795<br>795<br>795<br>796<br>796<br>796<br>797<br>797<br>797<br>797 |

Contents Contents

| Chapter B2 | Effects of disabling a PPI source on the PPI Pending state |                                             |     |
|------------|------------------------------------------------------------|---------------------------------------------|-----|
|            | B2.0.1                                                     | Notes                                       | 799 |
|            | B2.0.2                                                     | Litmus test with disable of the timer state | 799 |
|            |                                                            |                                             |     |

# Part C Model

Chapter C1 Operational model

Glossary

# Preface

### Conventions

#### **Typographical conventions**

The typographical conventions are:

italic

Introduces special terminology, and denotes citations.

#### bold

Denotes signal names, and is used for terms in descriptive lists, where appropriate.

monospace

Used for assembler syntax descriptions, pseudocode, and source code examples.

Also used in the main text for instruction mnemonics and for references to other items appearing in assembler syntax descriptions, pseudocode, and source code examples.

#### SMALL CAPITALS

Used for some common terms such as IMPLEMENTATION DEFINED.

Used for a few terms that have specific technical meanings, and are included in the Glossary.

#### Red text

Indicates an open issue.

#### Blue text

Indicates a link. This can be

- · A cross-reference to another location within the document
- A URL, for example http://developer.arm.com

#### **Numbers**

Numbers are normally written in decimal. Binary numbers are preceded by 0b, and hexadecimal numbers by 0x. In both cases, the prefix and the associated value are written in a monospace font, for example 0xFFFF0000. To improve readability, long numbers can be written with an underscore separator between every four characters, for example  $0xFFFF_0000_0000_0000$ . Ignore any underscores when interpreting the value of a number.

#### **Pseudocode descriptions**

This book uses a form of pseudocode to provide precise descriptions of the specified functionality. This pseudocode is written in a monospace font. The pseudocode language is described in the Arm Architecture Reference Manual.

#### Assembler syntax descriptions

This book contains numerous syntax descriptions for assembler instructions and for components of assembler instructions. These are shown in a monospace font.

Preface Rules-based writing

# **Rules-based writing**

This specification consists of a set of individual content items. A content item is classified as one of the following:

- Declaration
- Rule
- Goal
- Information
- Rationale
- Implementation note
- Software usage

Declarations and Rules are normative statements. An implementation that is compliant with this specification must conform to all Declarations and Rules in this specification that apply to that implementation.

Declarations and Rules must not be read in isolation. Where a particular feature is specified by multiple Declarations and Rules, these are generally grouped into sections and subsections that provide context. Where appropriate, these sections begin with a short introduction.

Arm strongly recommends that implementers read *all* chapters and sections of this document to ensure that an implementation is compliant.

Content items other than Declarations and Rules are informative statements. These are provided as an aid to understanding this specification.

#### **Content item identifiers**

A content item may have an associated identifier which is unique among content items in this specification.

After this specification reaches beta status, a given content item has the same identifier across subsequent versions of the specification.

#### **Content item rendering**

In this document, a content item is rendered with a token of the following format in the left margin: L<sub>iiiii</sub>

- *L* is a label that indicates the content class of the content item.
- *iiiii* is the identifier of the content item.

#### **Content item classes**

#### Declaration

A Declaration is a statement that does one or more of the following:

- · Introduces a concept
- Introduces a term
- Describes the structure of data
- Describes the encoding of data

A Declaration does not describe behavior.

A Declaration is rendered with the label D.

#### Rule

A Rule is a statement that describes the behavior of a compliant implementation.

A Rule explains what happens in a particular situation.

A Rule does not define concepts or terminology.

A Rule is rendered with the label *R*.

#### Goal

A Goal is a statement about the purpose of a set of rules.

- A Goal explains why a particular feature has been included in the specification.
- A Goal is comparable to a "business requirement" or an "emergent property."
- A Goal is intended to be upheld by the logical conjunction of a set of rules.

A Goal is rendered with the label G.

#### Information

An Information statement provides information and guidance as an aid to understanding the specification.

An Information statement is rendered with the label *I*.

#### Rationale

A Rationale statement explains why the specification was specified in the way it was.

A Rationale statement is rendered with the label *X*.

#### Implementation note

An Implementation note provides guidance on implementation of the specification.

An Implementation note is rendered with the label U.

#### Software usage

A Software usage statement provides guidance on how software can make use of the features defined by the specification.

A Software usage statement is rendered with the label S.

## Additional reading

This section lists publications by Arm and by third parties.

See Arm Developer (http://developer.arm.com) for access to Arm documentation.

- [1] Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture. (ARM DDI 0487) Arm Ltd.
- [2] Arm<sup>®</sup> Base System Architecture 1.0C. (ARM DEN 0094C) Arm Ltd.
- [3] Arm<sup>®</sup> Generic Interrupt Controller Architecture Specification, GIC architecture version 3 and version 4. (ARM IHI 0069) Arm Ltd.
- [4] Arm<sup>®</sup> Architecture Reference Manual Supplement, Transactional Memory Extension (TME), for A-profile architecture. (ARM DDI 0617) Arm Ltd.
- [5] *Arm<sup>®</sup> System Memory Management Unit Architecture Specification, SMMU architecture version 3.* (ARM IHI 0070) Arm Ltd.
- [6] Arm<sup>®</sup> Realm Management Extension (RME) System Architecture. (ARM DEN 0029) Arm Ltd.
- [7] AMBA® AXI Protocol Specification. (ARM IHI 0022) Arm Ltd.
- [8] Arm<sup>®</sup> Power State Coordination Interface. (ARM DEN 0022) Arm Ltd.
- [9] PCI Express<sup>®</sup> Base Specification Revision 6.0. PCI-SIG.

- [10] VIRTIO (Virtual I/O) Specification. See https://github.com/oasis-tcs/virtio-spec
- [11] Arm<sup>®</sup> CoreSight<sup>TM</sup> Architecture Performance Monitoring Unit Architecture. (ARM IHI 0091) Arm Ltd.
- [12] Arm<sup>®</sup> CoreSight<sup>TM</sup> Architecture Specification. (ARM IHI 0029) Arm Ltd.
- [13] AMBA<sup>®</sup> AXI-Stream Protocol Specification. (ARM IHI 0051) Arm Ltd.
- [14] Arm<sup>®</sup> Specification Language Reference Manual. (ARM DDI 0612) Arm Ltd.
- [15] *Arm<sup>®</sup> Reliability, Availability, and Serviceability (RAS) System Architecture for A-profile architecture.* (ARM IHI 0100) Arm Ltd.

Preface Feedback

# Feedback

Arm welcomes feedback on its documentation.

### Feedback on this book

If you have any comments or suggestions for additions and improvements create a ticket at https://support.develo per.arm.com. As part of the ticket include:

- The title (Arm® Generic Interrupt Controller Architecture Specification, GIC architecture version 5).
- The number (ARM-AES-0070 00bet0).
- The page numbers to which your comments apply.
- The rule identifiers to which your comments apply, if applicable.
- A concise explanation of your comments.

Arm also welcomes general suggestions for additions and improvements.

#### Note

Arm tests PDFs only in Adobe Acrobat and Acrobat Reader, and cannot guarantee the appearance or behavior of any document when viewed with any other PDF reader.

#### Inclusive terminology commitment

Arm values inclusive communities. Arm recognizes that we and our industry have used terms that can be offensive. Arm strives to lead the industry and create change.

Previous issues of this document included language that can be offensive. We have replaced this language. To report offensive language in this document, email terms@arm.com.

# Chapter 1 Introduction

I<sub>SBNXT</sub>

|                    | common programming interface for translating, configuring, and handling interrupts.                                                                                                                                                                                                     |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>JCSXY</sub> | Sources of interrupts can be peripherals (including PE functions, system components, and the GIC itself), and software running on PEs.                                                                                                                                                  |
| I <sub>JCVZT</sub> | The GICv5 CPU interface provides a common programming interface to manage and handle physical and virtual interrupts.                                                                                                                                                                   |
|                    | Virtual interrupts are handled using the same programming interface as physical interrupts, providing binary compatible virtualization support.                                                                                                                                         |
|                    | The GICv5 CPU interface also supports backwards compatibility for GICv3 virtual machines by providing EL2 controls as well as the GICv3 virtual CPU interface and GICv3 hypervisor control interface. Backward compatibility support in the GICv5 CPU interface is an optional feature. |
| I <sub>nhxnk</sub> | To support virtualization, the GICv5 architecture provides mechanisms for managing interrupts for Virtual Machines (VMs) and virtual PEs (VPEs). The architecture supports multiple VMs, and each VM can contain one or more VPEs.                                                      |
|                    | Software can configure when a VPE becomes resident on a PE through a system register interface. It can also request doorbell notification interrupts when making a VPE non-resident at a later time.                                                                                    |
|                    | The GIC architecture does not define or mandate how a VM boundary is managed by software.                                                                                                                                                                                               |
|                    | The following are examples of VMs that the GICv5 architecture supports:                                                                                                                                                                                                                 |
|                    | • A VM running in Non-secure state at EL1 and EL0, managed by a hypervisor running in Non-secure state at EL2.                                                                                                                                                                          |

The Generic Interrupt Controller version 5 (GICv5) architecture defines requirements for interrupt sources and a

#### Chapter 1. Introduction

- A Realm running in Realm state at EL1 and EL0, and is managed by the Realm Management Monitor (RMM) running in Realm state at EL2.
- A Secure partition running in Secure state at EL1 and EL0, and is managed by the Secure Partition Manager (SPM) running in Secure state at EL2.

A VPE represents an execution context within a VM.

D<sub>QJTJG</sub> A VM is identified by a VM ID.

A VPE is identified by a VPE ID in the context of a VM.

I<sub>NBJJF</sub> VMs are currently specified using a 16-bit identifier. The architecture reserves space to expand to additional bits of VM ID across all registers and data structures in a future version of the architecture. Due to the need to support a VPE doorbell in the LPI INTID space for each VPE in each VM, expanding the number of VMs beyond 24 bits may also require expanding the number of INTID.IDs supported.

D<sub>BJBPZ</sub> A GICv5 CPU interface is connected to the *Interrupt Routing Infrastructure (IRI)*.

The IRI uses either the GICv5 system architecture as described in Chapter 3 *GICv5 system architecture*, or is IMPLEMENTATION DEFINED.

If the IRI is IMPLEMENTATION DEFINED, it must meet the requirements for SPIs and LPIs specified in Chapter 2 *PE architecture*, including the requirements specified in 2.12 *Interrupt ordering model and synchronization requirements*.

D<sub>GMPXJ</sub> In the context of this specification, a GICv5 *system* comprises one or more PEs with support for the GICv5 architecture, each connected to the IRI.

This specification expects that the same OS or hypervisor manages all the PEs in a GICv5 system.

The word system can be used in different contexts to describe a different set of components, for example to include PEs that do not implement support for the GICv5 architecture.

# Chapter 2 **PE architecture**

# 2.1 Architecture features and extensions

| R <sub>PNBFY</sub> | GICv5 defines a new Armv9-A architecture feature, GICv5 CPU interface Extension, represented by FEAT_GCIE.                                                                                                                                     |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | This feature is supported in AArch64 only.                                                                                                                                                                                                     |
| I <sub>gpwsj</sub> | Support for FEAT_GCIE is reported in ID_AA64PFR2_EL1.GCIE.                                                                                                                                                                                     |
| R <sub>JMHXV</sub> | FEAT_GCIE is optional from Armv9.3-A[1].                                                                                                                                                                                                       |
| I <sub>SHDMS</sub> | FEAT_NMI is mandatory from Armv8.8-A and Armv9.3-A. This means that when a PE implements FEAT_GCIE, it also implements FEAT_NMI.                                                                                                               |
| R <sub>KTBJL</sub> | A PE that implements FEAT_GCIE does not implement FEAT_GICv3.                                                                                                                                                                                  |
| R <sub>bqytd</sub> | GICv5 defines an optional Armv9-A architecture feature, GICv5 legacy VPE support, represented by FEAT_GCIE_LEGACY.                                                                                                                             |
| I <sub>bkbqv</sub> | FEAT_GCIE_LEGACY is implemented by a PE if ICC_IDR0_EL1.GCIE_LEGACY is >= 1. Otherwise, FEAT_GCIE_LEGACY is not implemented.                                                                                                                   |
| I <sub>CXTVF</sub> | FEAT_GCIE_LEGACY provides a virtual CPU interface compatible with GICv3.3, including:                                                                                                                                                          |
|                    | <ul> <li>GICv3.3 ICV registers.</li> <li>GICv3.3 ICH registers, with some GICv5 updates.</li> <li>GICv3.3 support for virtual Non-maskable interrupts.</li> <li>GICv3.1 extended INTID range.</li> <li>GICv3 maintenance interrupt.</li> </ul> |

• GICv3 support for separate trapping of ICV\_DIR\_EL1.

#### Chapter 2. PE architecture 2.1. Architecture features and extensions

See 2.10.7 *Legacy virtual CPU interface* for more information.

R<sub>QCWBY</sub> A PE that implements FEAT\_GCIE\_LEGACY also implements FEAT\_GCIE and EL2.

R<sub>VVMRJ</sub> When a PE implements FEAT\_GCIE, SCR\_EL3.IRQ is RES0.

R<sub>JMXDP</sub> When FEAT\_GCIE and FEAT\_EL3 are implemented on a PE, SCR\_EL3.FIQ is RES1.

See also:

- 2.7 Interrupt Prioritization
- 2.9 The physical CPU interface
- 2.9.3 Preemptive interrupts 3.1 Interrupt Domains

# 2.2 The GICv5 CPU interface

 $I_{GNFVQ}$  When FEAT\_GCIE is implemented, the PE implements the GICv5 CPU interface. The GICv5 CPU interface is responsible for:

- Managing configuration and state of Private Peripheral Interrupts (PPIs).
- Masking and signaling of interrupts.
- Providing an interface for software to handle interrupts.
- Providing an interface for software to configure *Shared Peripheral Interrupts* (SPIs) and *Logical Peripheral Interrupts* (LPIs).
- If EL2 is implemented, the CPU interface supports both virtual interrupt and physical interrupts.

A PE with an integrated GICv5 CPU interface is illustrated in Figure 2.1.



#### Figure 2.1: PE with an integrated GICv5 CPU interface.

#### Note

 vFIQ is only signaled by the Legacy virtual CPU interface.

 I\_CMPTD
 The GICv5 CPU interface defines when an interrupt is signaled to the PE.

 The PE architecture supports the IRQ, FIQ, vIRQ, and vFIQ interrupt signals. These interrupts signals can have Superpriority as an additional attribute.

 The PE architecture defines additional rules detailing whether an interrupt signal results in an exception being taken. See Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture[1] for more information.

 I\_PYKTM
 The physical CPU interface is always active and determines whether the IRQ and FIQ interrupts are signaled. See 2.9 The physical CPU interface for more information.

# Chapter 2. PE architecture 2.2. The GICv5 CPU interface

|                    | When executing at Exception levels below EL2, HCR_EL2.IMO is 1, and Legacy operation is not enabled, the virtual CPU interface determines whether the vIRQ interrupt is signaled. See 2.10 <i>The virtual CPU interface</i> for more information.                    |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | When executing at Exception levels below EL2, HCR_EL2.IMO is 1, and Legacy operation is enabled, the Legacy virtual CPU interface determines whether the vIRQ and vFIQ interrupts are signaled. See 2.10.7 <i>Legacy virtual CPU interface</i> for more information. |
|                    | The GICv5 CPU interface never signals the vIRQ or vFIQ interrupts when executing at EL2 or EL3.                                                                                                                                                                      |
| $D_{MJHKK}$        | The GICv5 CPU interface connects to the IRI that manages SPIs and LPIs. The IRI <i>presents</i> a candidate HPPI for each Interrupt Domain to the CPU interface and the CPU interface determines if the candidate HPPI is the HPPI.                                  |
| R <sub>MCVBY</sub> | The mechanism used by the IRI to present a candidate HPPI is IMPLEMENTATION DEFINED.                                                                                                                                                                                 |
| $I_{\rm BTNJQ}$    | Arm recommends that an implementation uses the GICv5 system architecture. See Chapter 3 <i>GICv5 system architecture</i> for more information.                                                                                                                       |
|                    | Arm recommends that an implementation uses the GICv5 Stream Protocol for communication between PEs and the IRI. See Chapter A1 <i>GICv5 Stream Protocol overview</i> for more information.                                                                           |
| R <sub>wkgbt</sub> | Every PE is assigned a unique PE interrupt Affinity ID in the system.                                                                                                                                                                                                |
| I <sub>XDCZN</sub> | The interrupt Affinity ID value for each PE is reported in ICC_IAFFIDR_EL1.IAFFID.                                                                                                                                                                                   |
| R <sub>gxvvj</sub> | The PE interrupt Affinity ID is the same across all Physical Interrupt Domains.                                                                                                                                                                                      |
| R <sub>pxkwk</sub> | Support for bypassing the GICv5 CPU interface to signal interrupts to the PE is IMPLEMENTATION DEFINED. The behavior of System instruction and System registers, if the GICv5 CPU interface is bypassed, is IMPLEMENTATION DEFINED.                                  |
| $R_{TYFBF}$        | All GIC System instructions and GIC System registers defined in this specification are available in Debug state.                                                                                                                                                     |
|                    | See also:                                                                                                                                                                                                                                                            |

• 2.8 Interrupt handling

# 2.3 Interrupt Domains

| D <sub>HJYDR</sub> | An <i>Interrupt Domain</i> provides isolation of interrupt configuration and handling by its association to a Security state.                                  |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $D_{XQLTP}$        | The architecture defines the following <i>Physical Interrupt Domains</i> , each corresponding to an implemented Security state and Exception level:            |
|                    | <ul> <li>The Non-secure Interrupt Domain</li> <li>The Realm Interrupt Domain</li> <li>The Secure Interrupt Domain</li> <li>The EL3 Interrupt Domain</li> </ul> |
| D <sub>TTZCX</sub> | When an interrupt belonging to a Physical Interrupt Domain is signaled, it is signaled as a physical interrupt.                                                |
|                    | See 2.9 The physical CPU interface and 'Asynchronous exception types' in [1] for more information.                                                             |
| D <sub>HXMSH</sub> | The architecture defines the term <i>Non-EL3 Interrupt Domain</i> as any Physical Interrupt Domain apart from the EL3 Interrupt Domain.                        |
| I <sub>NHCWZ</sub> | The Non-secure, Secure, and Realm Interrupt Domains are Non-EL3 Interrupt Domains.                                                                             |
| I <sub>WBZXZ</sub> | Physical PPIs have a per-PE namespace that is shared across the Physical Interrupt Domains.                                                                    |
| I <sub>VWGBP</sub> | Physical SPIs have a single shared namespace across PEs and the Physical Interrupt Domains.                                                                    |
| I <sub>NFQYW</sub> | Physical LPIs have a separate namespace for each Physical Interrupt Domain that is shared across PEs.                                                          |
| R <sub>zmrkx</sub> | The implemented Physical Interrupt Domains depend on the implemented Security states as follows:                                                               |

| Implemented Security states     | Implemented Physical Interrupt Domains |
|---------------------------------|----------------------------------------|
| Non-secure                      | Non-secure                             |
| Secure                          | Secure                                 |
| Non-secure, Secure              | Non-secure, Secure, EL3                |
| Non-secure, Realm, Root         | Non-secure, Realm, EL3                 |
| Non-secure, Realm, Secure, Root | Non-secure, Realm, Secure, EL3         |

R<sub>ZFCXM</sub> The Physical Interrupt Domain associated with a Security state and Exception level is as follows:

| Exception level | Security state              | Physical Interrupt Domain |
|-----------------|-----------------------------|---------------------------|
| EL3             | Secure or Root <sup>a</sup> | EL3                       |
| EL2/1/0         | Secure                      | Secure                    |
| EL2/1/0         | Non-secure                  | Non-secure                |
| EL2/1/0         | Realm                       | Realm                     |

- a. The Security state of EL3 depends on whether FEAT\_RME is implemented. However, EL3 always uses the EL3 Interrupt Domain.
- D<sub>XKSVB</sub> The architecture defines the *Current Physical Interrupt Domain* of a PE as the Physical Interrupt Domain corresponding to the current Exception level and Security state of that PE.

# Chapter 2. PE architecture 2.3. Interrupt Domains

- For example, if a PE is running in EL3 on a system with the Secure and Non-secure Security states, the *Current* IFDPCN Physical Interrupt Domain is the EL3 Interrupt Domain. When EL2 is implemented, the Virtual Interrupt Domain defines the namespace for the virtual interrupts on a PE. Dowvzj When EL2 is not implemented, there is no Virtual Interrupt Domain. The interrupts managed by the IRI for the Virtual Interrupt Domain are selected based on the resident VPE. D<sub>QHMVR</sub> The VM that the VPE belongs to is referred to as the *resident VM*. The resident VPE and resident VM are programmed using ICH\_CONTEXTR\_EL2. IVHGTD See 2.10.5 Selecting the resident VPE for more information. DZWDFY When an interrupt belonging to the Virtual Interrupt Domain is signaled, it is signaled as a virtual interrupt. See 2.10 The virtual CPU interface and 'Asynchronous exception types' in [1] for more information. The Current Interrupt Domain is one of the following: DNSTKG • The Virtual Interrupt Domain, when all of the following are true:
  - The current Exception level is EL1.
  - HCR\_EL2.IMO is 1.
  - ICH\_VCTLR\_EL2.V3 is 0.
  - Otherwise, the Current Physical Interrupt Domain.

See 2.6 *GIC System instructions* for more information about the use of the Current Interrupt Domain for GIC System instructions.

#### Note

The Current Interrupt Domain is not defined when ICH\_VCTLR\_EL2.V3 is 1 and executing at Exception levels below EL2. See 2.10.7 *Legacy virtual CPU interface* for more information.

# 2.4 Interrupt types and identifiers

- D<sub>SHNLW</sub> FEAT\_GCIE supports the following types of interrupts:
  - Private Peripheral Interrupts (PPIs).
  - Logical Peripheral Interrupts (LPIs).
  - Shared Peripheral Interrupts (SPIs).
- D<sub>QDWHN</sub> An *interrupt* is identified by an INTID which comprises the following:
  - INTID.TYPE The type of an interrupt is PPI, LPI, or SPIs.
  - **INTID.ID** The numeric ID of an interrupt.

Each interrupt comprises the following states:

- **Pending** An interrupt is either Pending or Idle. An interrupt is only signaled and acknowledged when it is Pending.
- Active An interrupt is either Active or Inactive. An interrupt is only signaled and acknowledged when it is Inactive.

Each interrupt comprises the following configuration values:

- **Enabled** An interrupt is either Enabled or Disabled. An interrupt is only signaled and acknowledged when it is Enabled.
- **Priority** The priority value of an interrupt. The priority values determine the order in which interrupts are acknowledged and allow masking interrupts of lower priority.
- **Handling mode** The Handling mode of an interrupt is either Edge or Level. When the Handling mode is Edge, the Pending state becomes Idle when an interrupt is acknowledged. When the Handling mode is Level, the Pending state is unchanged when an interrupt is acknowledged.
- Routing mode Targeted or 1ofN.
- Affinity Specifies the destination of an interrupt.
- D<sub>LDFPT</sub> Each interrupt type has a separate INTID.ID namespace.
- I<sub>GTDKF</sub> For example, PPI 15 is a separate interrupt from LPI 15.
- R<sub>PSTJC</sub> The architecture supports up to 24 bits of INTID.ID namespace for each interrupt type.
- I<sub>PBBTX</sub> An implementation may support fewer than 24 bits of INTID.ID namespace.
- I<sub>CTQKK</sub> The implemented INTID.ID namespace width may vary across interrupt types.
- R<sub>GYVWB</sub> Where relevant, the interrupt type is encoded using a 3-bit field as follows:
  - 0b001: Private Peripheral Interrupts (PPIs)
  - 0b010: Logical Peripheral Interrupts (LPIs)
  - 0b011: Shared Peripheral Interrupts (SPIs)

All other values are reserved.

R<sub>TJPHS</sub> The INTID is a numerical value constructed from both the interrupt ID and the type as follows:

- Bits[31:29]: Interrupt type
- Bits[28:24]: RESO
- Bits[23:0]: Interrupt ID

#### I<sub>VCLSH</sub> For example, an LPI with interrupt ID 1024 can be identified using INTID 0x40000400.

# Chapter 2. PE architecture 2.4. Interrupt types and identifiers

The Handling mode of an interrupt specifies whether the Pending state becomes Idle when that interrupt is I<sub>DLGBO</sub> acknowledged. When using the GICv5 system architecture, the IRS specifies a separate Trigger mode for SPIs and the IWB specifies a Trigger mode for input wires, and interrupt events generated by an IWB or an IRS may update the Handling mode of the corresponding interrupt to match the Trigger mode. See Chapter 4 Interrupt routing service (IRS) and Chapter 6 Interrupt Wire Bridge (IWB) for more information. LPIs and SPIs are routed to appropriate PEs based on the Routing mode and Affinity. PPIs are private to a PE and D<sub>CHFFT</sub> therefore always signaled locally on a PE. The Routing mode of each LPI and SPI is either Targeted or 1ofN. IZPODY Support for 1ofN is optional for the IRI. When the GICv5 system architecture is used, the IRS reports whether ILLOVD 10fN is supported in IRS IDR0.ONE N. D<sub>OHNYP</sub> When the Routing mode of an interrupt is 1ofN, the IRI dynamically selects a PE to present the interrupt to, based on information available to the IRI at any point in time. When the Routing mode of an interrupt is Targeted, the IRI is only permitted to present the interrupt to the PE

See 2.6.1 *LPI and SPI configuration* for more information about configuring the routing of LPIs and SPIs.

## 2.4.1 PE-Private Peripheral Interrupts (PPIs)

corresponding to the interrupt Affinity.

| $G_{\text{BGLBP}}$   | GICv5 enables PE local events to be signaled as interrupts without recourse to the IRI.                                                                                                                                                                                                                                                                                                                   |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>PDXVM</sub>   | The GIC CPU Interface Extension defines PPI IDs 0 through 127.                                                                                                                                                                                                                                                                                                                                            |
| I <sub>QTYLP</sub>   | PPIs are generated by the CPU interface, typically by a function within the PE.                                                                                                                                                                                                                                                                                                                           |
| I <sub>YXRMV</sub>   | For example, the Arm Generic Timers generate a PPI when a timer condition is met.                                                                                                                                                                                                                                                                                                                         |
| $R_{LWYBR}$          | The mechanism by which PPI sources signal the CPU interface is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                                                                                                    |
|                      | Updates to the PPI Pending state from a PPI source are <i>autonomous asynchronous events</i> that complete in finite time. See <i>Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture</i> [1] for more information.                                                                                                                                                                 |
| I <sub>DQVMP</sub>   | When a PPI source is programmed using System register writes, even if a direct System register write causes<br>a PPI signal to become asserted or de-asserted, this does not cause an indirect System register write to the<br>ICC_PPI_xPENDR registers. Also in this case, the update from the PPI source to the PPI Pending state is an<br>autonomous asynchronous event that completes in finite time. |
| D <sub>HQXDV</sub>   | Each PPI is private to the PE.                                                                                                                                                                                                                                                                                                                                                                            |
| $D_{BWMGN}$          | Each PE has a private namespace for physical PPIs. The namespace is common across all Physical Interrupt Domains on the PE.                                                                                                                                                                                                                                                                               |
| I <sub>KPGFB</sub>   | Because each PPI is private to the PE, and each PE has a private namespace for PPIs, when separate PEs use the same PPI INTID, they specify separate interrupts.                                                                                                                                                                                                                                          |
|                      | For example, physical PPI 15 on PE 0 is a separate interrupt from physical PPI 15 on PE 1.                                                                                                                                                                                                                                                                                                                |
| $D_{\texttt{LHMTH}}$ | If EL2 is implemented, the CPU interface supports virtual PPIs.                                                                                                                                                                                                                                                                                                                                           |
| D <sub>RGQHS</sub>   | Each PE has a separate namespace for virtual PPIs.                                                                                                                                                                                                                                                                                                                                                        |
| I <sub>zttqt</sub>   | Each virtual PPI is a separate interrupt from the physical PPI with the same INTID on the same PE.                                                                                                                                                                                                                                                                                                        |
|                      | For example, physical PPI 15 on PE 0 is a separate interrupt from virtual PPI 15 on PE 0.                                                                                                                                                                                                                                                                                                                 |
|                      | However, a physical PPI can be assigned to the virtual PPI with the same INTID.                                                                                                                                                                                                                                                                                                                           |
|                      | See 2.10.1 Virtual PPIs for more information.                                                                                                                                                                                                                                                                                                                                                             |

I<sub>ZVRNF</sub> The Handling mode of a PPI is not software programmable but is discoverable through a read-only system register.

 $\mathbb{I}_{\mathbb{WQBLP}} \qquad \text{In GICv5 the configuration and state of PPIs is held in the CPU Interface. This is different to earlier versions of the GIC architecture, where the GIC IRI is responsible for PPI state and configuration.}$ 

See also:

- 2.9.1 Physical PPIs
- 2.10.1 Virtual PPIs

#### 2.4.2 Logical Peripheral Interrupts (LPIs)

LPIs are expected to be provisioned by Hypervisor and OS software according to the needs of the software agent. G<sub>PTPSK</sub> Therefore, LPIs have a private namespace for each Interrupt Domain and typically require memory to be allocated for storing their configuration and state in the IRI. LPIs are so called because of the similarity between how LPIs in GICv3 and LPIs in GICv5 are translated by an IZBOLG ITS and often used for interrupt sources that signal their interrupts as MSIs. The word logical is chosen to reflect the INTID private namespace for each Interrupt Domain. GICv3 used the words locality-specific for historical reasons. Each Physical Interrupt Domain has a private namespace for physical LPIs. DBBVWN The namespace is common across all PEs for the same Physical Interrupt Domain. For example, LPI 15 as seen by PE 0 is the same interrupt as LPI 15 seen by PE 1, in the same Physical Interrupt IPPFTN Domain. The Virtual Interrupt Domain has a separate namespace for virtual LPIs. D<sub>BSNNZ</sub>

The namespace for virtual LPIs is determined by the resident VPE and resident VM.

Each VM has a separate namespace for virtual LPIs. The virtual LPI namespace for a VM is common for all VPEs in a VM.

#### Note

This means that when separate VPEs for the same VM are resident across multiple PEs, the Virtual Interrupt Domains across those PEs share the same virtual LPI namespace.

See 2.10.5 Selecting the resident VPE for more information.

I<sub>FSXHB</sub> For example, LPI 15 as seen by VPE 0 is the same interrupt as LPI 15 seen by VPE 1, in the same VM.

#### 2.4.3 Shared Peripheral Interrupts (SPIs)

G<sub>KCZPX</sub> SPIs are designed to function without being provisioned by software and without requiring memory to be allocated for storing their configuration and state in the IRI.

SPIs are expected to be configured and provisioned when the system is designed and therefore have a common namespace across the Physical Interrupt Domains which allows firmware to configure the Interrupt Domain that each SPI is assigned to.

SPIs are expected to be used in the following scenarios:

- During early-boot where memory is not available to store interrupt state and configuration.
- When supporting RAS or other error handling interrupts which must work correctly even in the presence of memory system failures.

# Chapter 2. PE architecture 2.4. Interrupt types and identifiers

- In real-time sensitive systems, where the worst-case latency of interrupt delivery and handling must meet pre-determined timing requirements.
- D<sub>NNDZX</sub> The Physical Interrupt Domains have a common namespace for physical SPIs. The namespace is common across all PEs for all Physical Interrupt Domains.

This means that there is a single common namespace for physical SPIs in the system.

D<sub>VZHOW</sub> The Virtual Interrupt Domain has a separate namespace for virtual SPIs.

The namespace for virtual SPIs is determined by the resident VPE and resident VM.

Each VM has a separate namespace for virtual SPIs. The virtual SPI namespace for a VM is common for all VPEs in a VM.

#### Note

This means that when separate VPEs for the same VM are resident across multiple PEs, the Virtual Interrupt Domains across those PEs share the same virtual SPI namespace.

See 2.10.5 Selecting the resident VPE for more information.

# 2.5 Inter-Processor Interrupts

The architecture supports inter-processor communications by using *inter-processor interrupts* (IPIs). D<sub>XHRZC</sub> IPIs are either SPIs or LPIs configured as Targeted with the Affinity specifying the destination of the IPI. Arm recommends that interrupts used for IPIs are not signaled by other interrupt sources. In a Physical Interrupt Domain, an IPI is configured and sent from a source PE to a destination PE as follows: 1. A physical interrupt is selected and configured to target the destination PE. 2. The interrupt Handling mode is configured to Edge. 3. Software running on the source PE issues a GIC CDPEND instruction specifying the INTID of the interrupt. For virtual machines, an IPI is configured and sent from a source VPE to a destination VPE as follows: 1. A virtual interrupt is selected and configured to target the destination VPE. 2. The interrupt Handling mode is configured to Edge. 3. Software running on the source VPE issues a GIC CDPEND instruction specifying the INTID of the interrupt. The effect of making an interrupt Pending completes in finite time. ISZFVG This means that when an IPI is made pending, if the interrupt meets the conditions to be signaled by the IRI, it is signaled to the target PE or VPE in finite time. Note When an IPI is signaled to its destination, there is no guarantee that it will generate an interrupt exception and be handled by the destination (V)PE. For example, the destination PE could be masking interrupt exceptions or continuously be handling higher priority interrupts. Arm strongly recommends that the IRI implements a sufficient number of interrupts that are not signaled by other IBXHOK interrupt sources, to send IPIs for each Interrupt Domain. The GICv5 system architecture allows software in each Interrupt Domain to allocate a sufficient number of LPIs and allows implementations to provide a sufficient number of SPIs for IPIs when appropriate. Arm expects software to use LPIs allocated by system software to send IPIs. IWHWNY The architecture also allows the use of SPIs to send IPIs if a sufficient number of SPIs that are not connected to any interrupt sources are available. Software may allocate the number of required LPIs for each PE and establish a mapping from an LPI INTID.ID to SPJWMR a PE and IPI number. If software requires n IPIs for each PE, and the system supports a maximum of m PEs, software would allocate m \* *n* LPIs for IPIs. The LPI IDs used for IPIs is managed by software. However, if software requires a fixed arithmetic mapping for the IPI number on a given PE to an LPI ID, then software can allocate the LPIs 0 through (m \* n) - 1 for IPIs at system boot, and IPI number x on PE y is then given by (y \* n) + x. If SPIs are used to send IPIs, whether it is possible to create a fixed arithmetic mapping depends on the INTIDs for implemented SPIs that can be used for this purpose. Software can send IPIs by using the GIC <domain>AFF, <Xt>, GIC <domain>HM, <Xt> and GIC <domain  $S_{FYVVP}$  $\hookrightarrow$  >PEND, <Xt> instructions to configure interrupts and to make them Pending. Software can configure interrupts for each potential destination PE during boot as follows: • The interrupt Handling mode is configured to be Edge using the GIC <domain>HM, <Xt> instruction.

• The interrupt Routing mode is configured to be Targeted and the Affinity can be programmed to the destination PE using the GIC <domain>AFF, <Xt> instruction.

At runtime, software can send an IPI to a target PE by issuing the GIC <domain>PEND, <Xt> instruction for one of the interrupts targeted to the PE and allocated for IPIs.

See 2.6 GIC System instructions for more information about the GIC System instructions.

# 2.6 GIC System instructions

I<sub>RSVHM</sub> FEAT\_GCIE defines the GIC System instructions for the following purposes:

- Configure LPIs and SPIs managed by the IRI.
- Handle pending interrupts in the CPU interface.
- I<sub>FVJSG</sub> The A64 assembly language syntax for GIC System instructions is one of the following:
  - GIC <operation>, <Xt>.
  - GICR <Xt>, <operation>.

The GIC variant is used when the instruction has the semantics of a write and is an alias of the SYS instruction.

The GICR variant is used when the instruction has the semantics of a read and is an alias of the SYSL instruction.

I<sub>ZCVGT</sub> The <operation> in GIC <operation>, <Xt> and GICR <Xt>, <operation> has the structure of <domain><command>.

Each instruction operates in the Interrupt Domain identified by the domain parameter as described below:

| Domain parameter | Interrupt Domain         |
|------------------|--------------------------|
| CD               | Current Interrupt Domain |
| LD               | Logical Interrupt Domain |
| VD               | Virtual Interrupt Domain |

Each instruction executes a command specified by a command parameter listed below in the identified Interrupt Domain.

| Variant | Command | Name                              |
|---------|---------|-----------------------------------|
| GIC     | AFF     | Interrupt set Affinity            |
| GIC     | RCFG    | Request interrupt configuration   |
| GIC     | DI      | Deactivate interrupt              |
| GIC     | DIS     | Interrupt clear Enable            |
| GIC     | EN      | Interrupt set Enable              |
| GIC     | EOI     | Interrupt Priority drop           |
| GIC     | PEND    | Interrupt set/clear Pending state |
| GIC     | PRI     | Interrupt set Priority            |
| GICR    | IA      | Interrupt acknowledge             |
| GICR    | NMIA    | NMI acknowledge                   |

• The commands for interrupt configuration are described in 2.6.1 LPI and SPI configuration.

• The commands for interrupt handling are described in 2.8 Interrupt handling.

<Xt> encodes additional parameters specific to the requested operation.

R<sub>XCLJC</sub> The effects of a GIC System instruction complete in finite time.

I<sub>BMZKC</sub> GIC System instructions and GSB instructions complete in finite time.

# Chapter 2. PE architecture 2.6. GIC System instructions

| I <sub>MFDQT</sub> | When the GIC System instructions are executed with the <domain> parameter as CD, the operation applies to the Current Interrupt Domain.</domain>                                                                                                                                    |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | The GIC System instructions are not available when ICH_VCTLR_EL2.V3 is 1 and executing at Exception levels below EL2.                                                                                                                                                               |
| I <sub>VNKRX</sub> | When the GIC System instructions are executed with the <domain> parameter as LD, the operation applies to the Physical Interrupt Domain selected by the current value of the SCR_EL3.{NSE,NS} fields.</domain>                                                                      |
|                    | The LD parameter is only available at EL3.                                                                                                                                                                                                                                          |
| D <sub>GBYBF</sub> | An interrupt specified by an INTID is either <i>reachable</i> or <i>unreachable</i> .                                                                                                                                                                                               |
| R <sub>PCDRJ</sub> | GIC System instructions are only permitted to access the configuration and state of reachable interrupts.                                                                                                                                                                           |
|                    | When a GIC System instruction specifies an unreachable interrupt, it is treated as a NOP.                                                                                                                                                                                           |
| R <sub>JRDTL</sub> | A physical PPI is reachable when all of the following are true:                                                                                                                                                                                                                     |
|                    | <ul><li>The PPI is implemented.</li><li>The PPI is assigned to the Physical Interrupt Domain that the instruction operates in.</li></ul>                                                                                                                                            |
|                    | A virtual PPI is reachable when the PPI is implemented.                                                                                                                                                                                                                             |
|                    | Otherwise, the PPI is unreachable.                                                                                                                                                                                                                                                  |
| R <sub>grsys</sub> | A physical SPI is reachable when all of the following are true:                                                                                                                                                                                                                     |
|                    | <ul><li>The SPI is implemented by the IRI.</li><li>The SPI is assigned to the Physical Interrupt Domain that the instruction operates in.</li></ul>                                                                                                                                 |
|                    | A virtual SPI for a VM is reachable when the SPI for the resident VM is reachable by the IRI. See 4.10.2 <i>Virtual SPIs</i> for more information.                                                                                                                                  |
|                    | Otherwise, the SPI is unreachable.                                                                                                                                                                                                                                                  |
| R <sub>TTJYH</sub> | A physical LPI is reachable when all of the following are true:                                                                                                                                                                                                                     |
|                    | • The LPI is within the configured range for the corresponding Physical Interrupt Domain in the IRI. See 4.8.1 <i>Physical LPIs</i> for more information.                                                                                                                           |
|                    | A virtual LPI for a VM is reachable when the LPI for the resident VM is reachable by the IRI. See 4.10.1 <i>Virtual LPIs</i> for more information.                                                                                                                                  |
|                    | Otherwise, the LPI is unreachable.                                                                                                                                                                                                                                                  |
| I <sub>hdthv</sub> | When a GIC System instruction specifies a virtual SPI or LPI, the VM used to define the namespace for the INTID is determined in one of the following ways:                                                                                                                         |
|                    | <ul> <li>If the instruction operation is VDPEND, the VM is specified by the register argument passed to the instruction.</li> <li>If the instruction domain parameter specifies the Current Interrupt Domain or the Virtual Interrupt Domain, the VM is the resident VM.</li> </ul> |
|                    | When a GIC System instruction operates in the Virtual Interrupt Domain and there is no resident VPE, all virtual LPIs and SPIs are unreachable.                                                                                                                                     |
|                    | See 2.10.5 Selecting the resident VPE for more information about managing the resident VPE.                                                                                                                                                                                         |
| I <sub>HZLFG</sub> | The following GIC System instructions are related to interrupt handling and access PPI, LPI, or SPI configuration and state:                                                                                                                                                        |
|                    | • GICR CDIA.<br>• GICR CDNMIA.<br>• GIC <domain>DI.</domain>                                                                                                                                                                                                                        |
|                    | The GIC <domain>DI is treated as a NOP if it specifies an unreachable INTID.</domain>                                                                                                                                                                                               |

# Chapter 2. PE architecture 2.6. GIC System instructions

R<sub>WSSNV</sub> When a GICR CDIA or GICR CDNMIA instruction is executed, its architectural side effects are synchronized by the execution of a GSB ACK instruction.

The side effects of this synchronization include updates to the pending state of the IRQ, FIQ, vIRQ, and vFIQ asynchronous exceptions. An instruction executed after the GSB ACK is guaranteed to observe the updated pending status of these exceptions.

#### Note

The architectural side effects of a GICR CDIA or GICR CDNMIA instruction are synchronized by the execution of a GSB ACK instruction, regardless of whether a PPI, LPI, or SPI is acknowledged.

- If HCR\_EL2.NV is 1, execution at EL1 of a GIC System instruction that specifies VD as the <domain> parameter is trapped to EL2 with ESR\_EL2.EC reporting 0x18.
- I\_ZFDJZ
   A GIC System instruction never successfully executes at EL1 if it specifies the VD as the <domain> parameter.

   The instruction is either UNDEFINED or trapped to EL2 depending on the value of HCR\_EL2.NV.
- I<sub>GMHGR</sub> The architecture supports two barrier instructions used to define ordering between effects of GIC System instructions and other effects in the system:
  - GSB ACK: Provides ordering between the effects of a GICR CDIA instruction in program order before the GSB ACK and other effects.
  - GSB SYS: Provides ordering between the effects of any GIC System instruction in program order before the GSB SYS and other effects.

See 2.12.2 GSB instruction semantics for more information.

See also:

• 2.12 Interrupt ordering model and synchronization requirements

#### 2.6.1 LPI and SPI configuration

- $I_{BFFCW}$  Configuration and state for LPIs and SPIs are managed by the IRI. GIC System instructions are used to update the configuration of an LPIs and SPIs.
- $I_{MBNRN}$  When an INTID whose Type is LPI or SPI specifies an ID which is beyond the range reported in ICC\_IDR0\_EL1.ID\_BITS, the unimplemented upper identifier bits are RES0.
- $I_{KFJNB}$  The GIC System instruction commands that are used to update the configuration and state of interrupts managed by the IRI are listed in the following table:

| Command | Name                              | Description                                 |  |
|---------|-----------------------------------|---------------------------------------------|--|
| AFF     | Interrupt set Affinity            | Set the Affinity for the INTID.             |  |
| DI      | Interrupt clear Active            | Clear Active for the INTID.                 |  |
| DIS     | Interrupt clear Enable            | Clear Enable for the INTID.                 |  |
| EN      | Interrupt set Enable              | Set Enable for the INTID.                   |  |
| PEND    | Interrupt set/clear Pending state | Generate SET or CLEAR events for the INTID. |  |
| PRI     | Interrupt set Priority            | Set the Priority for the INTID.             |  |
| HM      | Interrupt set Handling mode       | Set the Handling mode for the INTID.        |  |

The resulting GIC System instructions are:

- GIC <domain>AFF, <Xt>.
- GIC <domain>EN, <Xt>.
- GIC <domain>DI, <Xt>.
- GIC <domain>DIS, <Xt>.
- GIC <domain>PEND, <Xt>.
- GIC <domain>PRI, <Xt>.
- GIC <domain>HM, <Xt>.

If <Xt> specifies an unreachable LPI or SPI INTID, the instruction is treated as a NOP.

An INTID might be within the implemented INTID width but be unreachable. For example, the system might IWNZLO support 16 bits of INTID but software might have configured a smaller LPI space in the IRI. This is different to specifying an INTID beyond the implemented range, as unimplemented bits of INTID are treated as RESO. The Affinity of an interrupt is configured by issuing the GIC <domain>AFF, <Xt> instruction. IJGZYC The IRM field in <xt> controls the interrupt routing mode. The interrupt routing mode is either Targeted or 1ofN. When the interrupt is Targeted, the target PE is specified in the IAFFID field in <Xt>. If the IRI supports fewer than 16 bits of IAFFID for the PE, unimplemented upper bits are RESO. When the Affinity of an interrupt is configured by the GIC <domain>AFF, <Xt> instruction and the IRM field R<sub>JKYGN</sub> configures the interrupt to be Targeted, all of the following are true: • For a Physical Interrupt Domain, the IAFFID field specifies the PE with the corresponding interrupt Affinity ID. • For the Virtual Interrupt Domain, the IAFFID field specifies the VPE in the VM using the corresponding VPE ID. Arm expects that Hypervisor software emulates a virtual GICv5 implementation where the emulated SWVYLC ICC\_IAFFIDR\_EL1.IAFFID value is the VPE ID of the corresponding VPE. This means that to software running in a VM, configuring the Affinity of a virtual interrupt using the virtualized ICC\_IAFFIDR\_EL1.IAFFID value will have the desired effect. The GIC <domain>PEND, <Xt> instruction has the following effects on the interrupt state: IWI,BBY • If the Pending field is cleared to 0, the IRI is requested to clear the Pending state of the interrupt to 0. • If the Pending field is set to 1, the IRI is requested to set the Pending state of the interrupt to 1. IPKRLN The Handling mode of an interrupt can be configured by issuing the GIC <domain>HM, <Xt> instruction. It is IMPLEMENTATION DEFINED whether the Handling mode of an SPI is RO. R<sub>YCDBY</sub> If the Handling mode of an SPI is RO, all of the following are true: • GIC <domain>HM, <Xt> instructions targeting the SPI have no effect. • The corresponding Trigger mode in the IRI is RO. • The Handling mode corresponds to the Trigger mode. See 4.8.2 *Physical SPIs* for more information. Interrupt configuration managed by an IRI is queried using the System instruction GIC <domain>RCFG and read ITNGVR from the system register ICC\_ICSR\_EL1. On executing a GIC <domain>RCFG System instruction, the PE requests the configuration and state of the  $R_{\text{NPDVH}}$ specified INTID from the IRI for the Interrupt Domain identified by the <domain> parameter. If the INTID is reachable, ICC\_ICSR\_EL1.F is set to 0 and the other fields are populated with the configuration and state of the INTID. If the INTID is unreachable, ICC\_ICSR\_EL1.F is set to 1 and the other fields become UNKNOWN.

# Chapter 2. PE architecture 2.6. GIC System instructions

I<sub>GBYBZ</sub> Where an instruction results in an update to a System register, as is the case with the GIC <domain>RCFG System instruction, explicit synchronization must be performed before the result is guaranteed to be visible. This means that the result of a GIC <domain>RCFG System instruction is not guaranteed to be visible in ICC\_ICSR\_EL1 until after an ISB or other context synchronization event.

See also:

- 2.12 Interrupt ordering model and synchronization requirements
- 4.6 Interrupt configuration and state

### 2.7 Interrupt Prioritization

| I <sub>dqgtj</sub> | The priority of an interrupt is an unsigned value that is used for the following purposes:                                                                                                                                                                                                                                                  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | • Selecting which interrupt to signal among multiple interrupts that can be signaled for an Interrupt Domain.                                                                                                                                                                                                                               |
|                    | • Priority-based masking of interrupts.                                                                                                                                                                                                                                                                                                     |
|                    | • When NMIs are enabled for an Interrupt Domain, configuring an interrupt with a priority value of 0 indicates that the interrupt is an NMI and should be signaled with Superpriority. See 2.9.5 <i>Physical non-maskable interrupts</i> for more information about NMIs.                                                                   |
|                    | • When there are interrupts that can be signaled for multiple Interrupt Domains, the priority may be used to decide whether an interrupt should be signaled using the IRQ or FIQ interrupt exception. See 2.9.3 <i>Preemptive interrupts</i> for more information.                                                                          |
| I <sub>ZCBZT</sub> | The number of implemented priority bits is reported in ICC_IDR0_EL1.PRI_BITS.                                                                                                                                                                                                                                                               |
|                    | The maximum number of implemented priority bits is 5, and the priority of an interrupt is always interpreted as a 5 bit unsigned value. Only bits [4:N] are implemented where $N = (4 - ICC_IDR0_EL1.PRI_BITS)$ . Unimplemented bits are RES0.                                                                                              |
|                    | This means that when fewer than 5 bits of priority is implemented, bits [3 - ICC_IDR0_EL1.PRI_BITS:0] are RES0.                                                                                                                                                                                                                             |
|                    | For example, if 4 bits of priority are implemented, only priority levels 0, 2, 4, 6,, 30 are implemented.                                                                                                                                                                                                                                   |
| I <sub>vwywb</sub> | The number of implemented priority bits may vary between the CPU interface and the IRI. In this case, unimplemented lower order bits are treated as 0 by the component implementing the lowest number of bits. Arm recommends that software only programs priority values within the range supported by both the CPU interface and the IRI. |
| I <sub>CNQYT</sub> | Some operating systems have requirements for a minimum number of interrupt priority levels. These requirements will be captured as part of the <i>Arm<sup>®</sup> Base System Architecture 1.0C</i> [2].                                                                                                                                    |
| I <sub>YQCPV</sub> | The priority value of an interrupt is only interpreted within an Interrupt Domain. Priorities of interrupts belonging to separate Interrupt Domains are never compared against one another.                                                                                                                                                 |
|                    | Therefore, the full implemented priority space is available to prioritize interrupts within each Interrupt Domain.                                                                                                                                                                                                                          |
| I <sub>GDMTN</sub> | The priority value of a virtual interrupt is only interpreted to select higher priority interrupts for that VM. The priority value of a virtual interrupt is never compared against the priority value of a physical interrupt. Priorities of interrupts belonging to separate VMs are never compared against one another.                  |
|                    | Therefore, the full implemented priority space is available to prioritize interrupts within each VM.                                                                                                                                                                                                                                        |
| R <sub>xbqtt</sub> | In the GIC prioritization scheme, lower numbers have higher priority.                                                                                                                                                                                                                                                                       |
|                    | For example, an interrupt with priority value 0 is of higher priority than an interrupt with priority value 16.                                                                                                                                                                                                                             |
| D <sub>ldckk</sub> | The <i>highest priority pending interrupt</i> (HPPI) for an Interrupt Domain is the highest priority interrupt selected among the candidate HPPIs.                                                                                                                                                                                          |
|                    | An HPPI is defined for each Physical Interrupt Domain and the Virtual Interrupt Domain:                                                                                                                                                                                                                                                     |
|                    | <ul> <li>The EL3 physical HPPI.</li> <li>The Secure physical HPPI.</li> <li>The Realm physical HPPI.</li> <li>The Non-secure physical HPPI.</li> <li>The virtual HPPI for the Virtual Interrupt Domain.</li> </ul>                                                                                                                          |
| D <sub>rkwns</sub> | A <i>candidate HPPI</i> is a Pending, Inactive, and Enabled interrupt selected among a subset of interrupts for an Interrupt Domain.                                                                                                                                                                                                        |
|                    | The DE considers the following condidate LIDDIs for each Interment Domain.                                                                                                                                                                                                                                                                  |

The PE considers the following candidate HPPIs for each Interrupt Domain:

## Chapter 2. PE architecture 2.7. Interrupt Prioritization

- The highest priority Pending, Inactive, and Enabled PPI for the Interrupt Domain.
- The candidate HPPI presented by the IRI for the Interrupt Domain.
- R<sub>JXKKZ</sub> When the Pending, Active, or Enabled values of a PPI change, the effects on the HPPI determination complete in finite time.

See 2.9.4 Physical interrupt signaling and 2.10.3 Virtual interrupt signaling for more information.

R<sub>KXFKH</sub> The IRI selects the highest priority Pending, Inactive, and Enabled interrupt for each Interrupt Domain in finite time.

See 4.8.4 *Physical interrupt signaling* and 4.10.4 *Virtual interrupt signaling* for more information about the guarantees provided by the GICv5 system architecture.

See also:

- 2.8 Interrupt handling
- 2.8.1 Interrupt life cycle
- 2.9 The physical CPU interface

### 2.8 Interrupt handling

| D <sub>QWBZR</sub> | When the CPU interface acknowledges an interrupt, the interrupt's priority becomes an active priority.                                                                                                                                                                                                                                                                                                                                                            |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>DWSGL</sub> | Each Interrupt Domain has a <i>running priority</i> , which is the highest active priority for that Interrupt Domain.                                                                                                                                                                                                                                                                                                                                             |
| I <sub>fgfph</sub> | It is possible to have multiple active priorities at the same time.                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | For example, consider the following scenario where an interrupt handler is interrupted by an NMI:                                                                                                                                                                                                                                                                                                                                                                 |
|                    | <ol> <li>Interrupt X with priority 16 is acknowledged. Priority 16 becomes an active priority and the running priority of the Interrupt Domain becomes 16.</li> <li>Another interrupt Y with priority 0 is signaled to the PE.</li> <li>Interrupt Y is acknowledged. Priority 0 becomes an active priority and the running priority of the Interrupt domain becomes 0.</li> </ol>                                                                                 |
|                    | At the end of the sequence above, priorities 16 and 0 are active priorities and the running priority for the Interrupt Domain is 0.                                                                                                                                                                                                                                                                                                                               |
| D <sub>mqkdw</sub> | When there are no active priorities, the <i>running priority</i> is the <i>Idle priority</i> . The <i>Idle priority</i> is 0xFF.                                                                                                                                                                                                                                                                                                                                  |
| I <sub>CFYGY</sub> | Only interrupts with a priority higher than the running priority are signaled by the CPU interface. This prevents a high priority interrupt from being preempted by a low priority interrupt.                                                                                                                                                                                                                                                                     |
| D <sub>vhcmf</sub> | The CPU interface performs a <i>Priority drop</i> when software issues the GIC CDEOI instruction, and the running priority is not the Idle priority.                                                                                                                                                                                                                                                                                                              |
| R <sub>kwmnp</sub> | On a Priority drop, the highest active priority for the Interrupt Domain stops being active.                                                                                                                                                                                                                                                                                                                                                                      |
| I <sub>FGKMJ</sub> | After a Priority drop, because the running priority is defined as the highest active priority, the running priority becomes one of the following:                                                                                                                                                                                                                                                                                                                 |
|                    | <ol> <li>The highest active priority for which there has not been a Priority drop.</li> <li>The Idle priority.</li> </ol>                                                                                                                                                                                                                                                                                                                                         |
| I <sub>XZFHX</sub> | This allows pending interrupts with the previous running priority to be signaled by the CPU interface.                                                                                                                                                                                                                                                                                                                                                            |
| I <sub>QFZWR</sub> | Active priorities stop being active in priority order, from the highest priority to the lowest priority.                                                                                                                                                                                                                                                                                                                                                          |
| I <sub>JFQSN</sub> | GICv5 removes support for the binary point registers used in GICv3 to split the priority field into a preemption level and subpriority.                                                                                                                                                                                                                                                                                                                           |
| I <sub>fyzvd</sub> | Software handles an interrupt signaled by the CPU interface as follows:                                                                                                                                                                                                                                                                                                                                                                                           |
|                    | <ol> <li>Software acknowledges the HPPI for the Current Interrupt Domain and obtains its INTID.</li> <li>Software uses the INTID to locate the handler function for the acknowledged interrupt.</li> <li>Software performs a Priority drop when it is ready to receive other interrupts of the same priority as the acknowledged interrupt.</li> <li>Software deactivates the acknowledged interrupt once it is ready to receive that interrupt again.</li> </ol> |
| I <sub>dfwsm</sub> | FEAT_GCIE defines GIC System instructions to handle interrupts in the CPU interface. Each instruction executes a command that applies to all interrupt types in the Current Interrupt Domain. The commands are listed below:                                                                                                                                                                                                                                      |

| Command | Name                    |
|---------|-------------------------|
| IA      | Interrupt acknowledge   |
| NMIA    | NMI acknowledge         |
| EOI     | Interrupt priority drop |
| DI      | Interrupt deactivate    |

## Chapter 2. PE architecture 2.8. Interrupt handling

The System instructions for interrupt handling are listed below and described in 8.1 *System instructions for the Current Interrupt Domain.* 

- GICR CDIA.
- GICR CDNMIA.
- GIC CDEOI.
- GIC CDDI.
- I\_ZYDVS
   The architecture does not define the order in which the Priority Drop and Interrupt deactivate are performed by software.
- IWDLPR
   The GICR CDIA System instruction acknowledges the HPPI in the Current Interrupt Domain if there is an HPPI with Sufficient priority and it is not an NMI.

The result of the instruction is returned in the <Xt> register.

The VALID field in <Xt> register indicates whether an interrupt was acknowledged by the GICR CDIA instruction.

When the VALID field is 1, the HPPI was acknowledged.

When the VALID field is 0, the HPPI was not acknowledged.

 IXBBNJ
 The GICR CDNMIA system instruction acknowledges the HPPI in the Current Interrupt Domain if there is an HPPI with Sufficient priority and it is an NMI.

The result of the instruction is returned in the <Xt> register.

The VALID field in <Xt> register indicates whether the HPPI was acknowledged.

When the VALID field is 1, the HPPI was acknowledged.

When the VALID field is 0, the HPPI was not acknowledged.

- $R_{WNKKW}$  When an interrupt is acknowledged, all of the following are true:
  - The interrupt becomes Active.
  - If the interrupt Handling mode is Edge, its Pending state is cleared.
  - The interrupt's priority becomes active and the running priority for the Current Interrupt Domain is updated.
  - The INTID of the interrupt is returned in the TYPE and ID fields of the <xt> register.
- I<sub>HBGJV</sub> The GIC CDEOI System instruction performs a Priority drop of the running priority in the Current Interrupt Domain.
- I<sub>RYBDB</sub> Unlike earlier versions of the GIC architecture, the GIC CDEOI System instruction does not take an INTID as an argument.

 I<sub>WPSSR</sub>
 The GIC CDDI System instruction performs an Interrupt deactivate for the specified INTID in the Current Interrupt Domain.

#### 2.8.1 Interrupt life cycle

R<sub>TCZMV</sub> Figure 2.2 shows the interrupt state machine for interrupts whose Handling mode is Edge.

Figure 2.3 shows the interrupt state machine for interrupts whose Handling mode is Level.

The interrupt Handling mode determines the effects on the interrupt state when the CPU Interface acknowledges the interrupt as follows:

- For Edge interrupts, all of the following are true:
  - The Pending state is atomically cleared to Idle.
  - The Active state is set to Active.
- For Level interrupts, The Active state is set to Active.

Chapter 2. PE architecture 2.8. Interrupt handling



Figure 2.3: Interrupt state machine for Level interrupts.

The transitions shown in the figures can be caused by the following reasons:

• Transition A1 or A2: Make Pending

This transition occurs in one of the following situations:

- An LPI or SPI is signaled in the IRI or requested to be made Pending by software.
- Transition B1 or B2: Clear Pending

#### Chapter 2. PE architecture 2.8. Interrupt handling

This transition occurs in one of the following situations:

- A level-sensitive LPI or SPI signal is de-asserted in the IRI or the Pending state is requested to be cleared by software.

#### • Transition C: Acknowledge

This transition occurs when the CPU Interface acknowledges the Interrupt.

For Edge interrupts, the Pending state is cleared, also known as *consumed*, as part of acknowledging the interrupt.

For Level interrupts, the Pending state is not affected as part of acknowledging the interrupt.

#### • Transition D1 or D2: Deactivate

This transition occurs when the CPU Interface deactivates the Interrupt.

IDMXLN

An interrupt cannot be set to Active using any other GIC instruction than GICR CDIA and GICR CDNMIA. An interrupt can be deactivated from any PE. Deactivating an interrupt which is already Inactive has no effect.

### 2.9 The physical CPU interface

### 2.9.1 Physical PPIs

| R <sub>rvczw</sub> | A physical PPI is only considered for being selected as the candidate HPPI in the Physical Interrupt Domain it is assigned to.                                                                                                  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>SHHCL</sub> | The assignment of an architected PPI to a PPI source is defined by the architecture. Unassigned architected PPIs are Reserved.                                                                                                  |
| D <sub>HVJHM</sub> | PPIs in the range of IDs 0 through 63 are referred to as architected PPIs.                                                                                                                                                      |
| R <sub>FSFSL</sub> | The assignment of PPIs in the range of IDs 64 through 127 to their PPI sources is IMPLEMENTATION DEFINED.                                                                                                                       |
| I <sub>YGJWQ</sub> | The assignment of a physical PPI to a Physical Interrupt Domain is done as follows:                                                                                                                                             |
|                    | <ul> <li>Architected PPIs are assigned by programming ICC_PPI_DOMAINR0_EL3 and ICC_PPI_DOMAINR1_EL3.</li> <li>IMPLEMENTATION DEFINED PPIs are assigned by programming ICC_PPI_DOMAINR2_EL3 and ICC_PPI_DOMAINR3_EL3.</li> </ul> |
| R <sub>RHCDS</sub> | When EL3 is not implemented, each physical PPI is assigned to the Interrupt Domain identified by the Effective value of SCR_EL3.NS.                                                                                             |

R<sub>XDVCM</sub> The assignments of architected PPIs to their PPI sources are listed in Table 2.7.

## Table 2.7: Architected PPI ID assignment

| ID | Name      | Source                                                  |
|----|-----------|---------------------------------------------------------|
| 31 | TRBIRQ    | Trace Buffer Unit                                       |
| 30 | CNTP      | EL1 Physical Timer                                      |
| 29 | CNTPS     | EL3 Physical Timer                                      |
| 28 | CNTHV     | Non-secure EL2 Virtual Timer                            |
| 27 | CNTV      | EL1 Virtual Timer                                       |
| 26 | CNTHP     | Non-secure EL2 Physical Timer                           |
| 25 | GICMNT    | GIC maintenance interrupt                               |
| 24 | CTIIRQ    | Generic CTI interrupt trigger event                     |
| 23 | PMUIRQ    | PMU overflow interrupt request                          |
| 22 | COMMIRQ   | Debug communication channel                             |
| 21 | PMBIRQ    | Profiling Buffer management interrupt request           |
| 20 | CNTHPS    | Secure EL2 Physical Timer                               |
| 19 | CNTHVS    | Secure EL2 Virtual Timer                                |
| 15 | HACDBSIRQ | Hardware accelerator for cleaning Dirty state interrupt |
| 3  | SW_PPI    | Reserved for software usage.                            |
| 2  | NS_DB_PPI | Doorbell PPI for a Non-secure Non-preemptive interrupt  |
| 1  | RL_DB_PPI | Doorbell PPI for a Realm Non-preemptive interrupt       |
| 0  | S_DB_PPI  | Doorbell PPI for a Secure Non-preemptive interrupt      |

| R <sub>cfskx</sub> | The Handling modes of architected PPIs are listed in Table 2.8. |  |
|--------------------|-----------------------------------------------------------------|--|
|--------------------|-----------------------------------------------------------------|--|

| ID | Name      | Handling Mode          |
|----|-----------|------------------------|
| 31 | TRBIRQ    | Level                  |
| 30 | CNTP      | Level                  |
| 29 | CNTPS     | Level                  |
| 28 | CNTHV     | Level                  |
| 27 | CNTV      | Level                  |
| 26 | CNTHP     | Level                  |
| 25 | GICMNT    | Level                  |
| 24 | CTIIRQ    | IMPLEMENTATION DEFINED |
| 23 | PMUIRQ    | Level                  |
| 22 | COMMIRQ   | Level                  |
| 21 | PMBIRQ    | Level                  |
| 20 | CNTHPS    | Level                  |
| 19 | CNTHVS    | Level                  |
| 15 | HACDBSIRQ | Level                  |
| 3  | SW_PPI    | Edge                   |
| 2  | NS_DB_PPI | Level                  |
| 1  | RL_DB_PPI | Level                  |
| 0  | S_DB_PPI  | Level                  |

#### Table 2.8: Architected PPI ID Handling modes

 ${\rm I}_{\rm RRGLL}$ 

The configuration and state of PPIs is held in the PE System registers.

For physical PPIs, the following registers are used:

#### Table 2.9: Physical PPI system registers

| Register                      | Name                                    |
|-------------------------------|-----------------------------------------|
| ICC_PPI_SACTIVER <n>_EL1</n>  | Set interrupt Active                    |
| ICC_PPI_CACTIVER <n>_EL1</n>  | Clear interrupt Active                  |
| ICC_PPI_SPENDR <n>_EL1</n>    | Set interrupt Pending                   |
| ICC_PPI_CPENDR <n>_EL1</n>    | Clear interrupt Pending                 |
| ICC_PPI_ENABLER <n>_EL1</n>   | Interrupt Enable and Disable            |
| ICC_PPI_PRIORITYR <n>_EL1</n> | Interrupt Priority                      |
| ICC_PPI_DOMAINR <n>_EL3</n>   | Physical Interrupt Domain allocation    |
| ICC_PPI_HMR <n>_EL1</n>       | Interrupt Handling mode (Level or Edge) |
|                               |                                         |

Register Name The Active state of a PPI can also be updated as a side-effect of executing one of the following GIC System IRBPKR instructions: • GICR CDIA. • GICR CDNMIA. • GIC CDDI. • GIC VDDI. • GIC LDDI. These System instructions are used during interrupt handling and are common across interrupt types. A Context Synchronization event is required before software can rely on the effects of direct writes to a PPI System IZLTKB register to affect instructions appearing in program order after the direct write. See Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture [1] for more information. This applies to the PPI system registers listed in the following tables: • Table 2.9 • Table 2.15 Table 2.16 If the individual enable of a PPI is cleared, a Context synchronization event is sufficient to guarantee that the PPI is R<sub>YRGMH</sub> no longer the HPPI. A PPI might be shared between multiple Security states, and in this case, EL3 is expected to save and restore the configuration of that PPI during a change of Security state. A physical PPI is permitted to be a candidate HPPI for a Physical Interrupt Domain if and only if all of the ICPDGZ following are true: • ICC\_PPI\_ENABLER<n>\_EL1.EN is 1. • ICC\_PPI\_SPENDR<n>\_EL1.PEND is 1. • ICC\_PPI\_SACTIVER<n>\_EL1.ACTIVE is 0. The CPU interface selects the candidate HPPI among the PPIs for each Physical Interrupt Domain by selecting the IHTMYK highest priority PPI that meets the physical candidate HPPI selection criteria. If more than one PPI meets the physical candidate HPPI selection criteria for a Physical Interrupt Domain, it is RJSOBW IMPLEMENTATION DEFINED which of those PPIs becomes the candidate HPPI. Any PPI source may generate an IMPLEMENTATION DEFINED wake event for the PE that they are connected to. I<sub>QMBYG</sub> The architecture does not specify when a PPI source may generate a wake event. Examples of when a PPI source may generate an IMPLEMENTATION DEFINED wake event include the following: I<sub>HYVBT</sub> • A generic timer is kept powered on while the PE is in low-power state and generates a wake event when the timer condition is asserted. • The Cross-Trigger interface is kept powered on while the PE is in a low-power state and asserts an output trigger event. 2.9.2 Physical priority masking

D<sub>MLTJM</sub> The *Physical Priority Mask* is defined as follows:

- The Physical Priority Mask for a Non-EL3 Interrupt Domain is the value stored in the banked copy of ICC\_PCR\_EL1.PRIORITY for that Interrupt Domain.
- The Physical Priority Mask for the EL3 Interrupt Domain is the value stored in ICC\_PCR\_EL3.PRIORITY.

|                                                                | See 9.1 Synchronization requirements for GICv5 System registers for more information about synchronization requirements for updates to the Physical Priority Mask.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>XMBQZ</sub>                                             | The <i>physical running priority</i> is defined as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                                | <ul> <li>The physical running priority for a Non-EL3 Interrupt Domain is the highest active priority stored in the banked copy of ICC_APR_EL1 for that Interrupt Domain.</li> <li>The physical running priority for the EL3 Interrupt Domain is the highest active priority stored in ICC_APR_EL3.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| I <sub>fwvxz</sub>                                             | The physical running priority for the Current Physical Interrupt Domain is reported in ICC_HAPR_EL1.PRIORITY.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| D <sub>MSQKF</sub>                                             | A physical interrupt has Sufficient priority to be signaled when all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                | <ul> <li>The priority of the interrupt is higher than the physical running priority for the Physical Interrupt Domain.</li> <li>The priority of the interrupt is equal to or higher than the Physical Priority Mask for the Physical Interrupt Domain.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| I <sub>QYFVP</sub>                                             | The physical running priority is defined for each Physical Interrupt Domain even though ICC_HAPR_EL1 only shows the running priority for the Current Physical Interrupt Domain.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                | The physical running priority is a factor in determining whether an interrupt has Sufficient priority in an Interrupt Domain for each Physical Interrupt Domain, regardless of whether an Interrupt Domain is the Current Physical Interrupt Domain.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                | For example, when the Current Physical Interrupt Domain is the Non-secure Interrupt Domain, an interrupt in the Secure Interrupt Domain will only have Sufficient priority if the interrupt's Priority is higher than the highest active priority in the Secure banked copy of ICC_APR_EL1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| I <sub>WLVKM</sub>                                             | ICC_DOMHPPIR_EL3 reports if there is an HPPI of Sufficient priority for each Non-EL3 Interrupt Domain.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2.9.3                                                          | Preemptive interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| $G_{\rm LTFJK}$                                                | When the Current Physical Interrupt Domain is not the EL3 Interrupt Domain, and there is an HPPI of Sufficient                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                | priority for another Physical Interrupt Domain, the PE may be configured to take one of the following actions:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                | <ul> <li>priority for another Physical Interrupt Domain, the PE may be configured to take one of the following actions:</li> <li>The Current Physical Interrupt Domain is preempted in order to switch to the Physical Interrupt Domain of the HPPI so that it can be handled immediately. See also 2.9.4 <i>Physical interrupt signaling</i>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                | • The Current Physical Interrupt Domain is preempted in order to switch to the Physical Interrupt Domain of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| D <sub>MQRSB</sub>                                             | <ul> <li>The Current Physical Interrupt Domain is preempted in order to switch to the Physical Interrupt Domain of the HPPI so that it can be handled immediately. See also 2.9.4 <i>Physical interrupt signaling</i>.</li> <li>The Current Physical Interrupt Domain is notified through a separate interrupt that there is an HPPI for a different Physical Interrupt Domain, and the Current Physical Interrupt Domain can switch to the other</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| D <sub>mqrsb</sub><br>I <sub>pjkyp</sub>                       | <ul> <li>The Current Physical Interrupt Domain is preempted in order to switch to the Physical Interrupt Domain of the HPPI so that it can be handled immediately. See also 2.9.4 <i>Physical interrupt signaling</i>.</li> <li>The Current Physical Interrupt Domain is notified through a separate interrupt that there is an HPPI for a different Physical Interrupt Domain, and the Current Physical Interrupt Domain can switch to the other Interrupt Domain when appropriate as defined by a software policy. See also 2.9.6 <i>Doorbell PPIs</i>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                | <ul> <li>The Current Physical Interrupt Domain is preempted in order to switch to the Physical Interrupt Domain of the HPPI so that it can be handled immediately. See also 2.9.4 <i>Physical interrupt signaling</i>.</li> <li>The Current Physical Interrupt Domain is notified through a separate interrupt that there is an HPPI for a different Physical Interrupt Domain, and the Current Physical Interrupt Domain can switch to the other Interrupt Domain when appropriate as defined by a software policy. See also 2.9.6 <i>Doorbell PPIs</i>.</li> <li>The Interrupt Domain selected by ICC_CR0_EL3.PID is called the <i>Preemptive Interrupt Domain</i>.</li> <li>When the value of ICC_CR0_EL3.PID corresponds to an Interrupt Domain that is not implemented, the PE behaves</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| I <sub>pjkyp</sub>                                             | <ul> <li>The Current Physical Interrupt Domain is preempted in order to switch to the Physical Interrupt Domain of the HPPI so that it can be handled immediately. See also 2.9.4 <i>Physical interrupt signaling</i>.</li> <li>The Current Physical Interrupt Domain is notified through a separate interrupt that there is an HPPI for a different Physical Interrupt Domain, and the Current Physical Interrupt Domain can switch to the other Interrupt Domain when appropriate as defined by a software policy. See also 2.9.6 <i>Doorbell PPIs</i>.</li> <li>The Interrupt Domain selected by ICC_CR0_EL3.PID is called the <i>Preemptive Interrupt Domain</i>.</li> <li>When the value of ICC_CR0_EL3.PID corresponds to an Interrupt Domain that is not implemented, the PE behaves as if there is no Preemptive Interrupt Domain.</li> <li>ICC_CR0_EL1.PID indicates whether the Physical Interrupt Domain associated with the Security state selected by</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| I <sub>pjkyp</sub><br>I <sub>vfwfw</sub>                       | <ul> <li>The Current Physical Interrupt Domain is preempted in order to switch to the Physical Interrupt Domain of the HPPI so that it can be handled immediately. See also 2.9.4 <i>Physical interrupt signaling</i>.</li> <li>The Current Physical Interrupt Domain is notified through a separate interrupt that there is an HPPI for a different Physical Interrupt Domain, and the Current Physical Interrupt Domain can switch to the other Interrupt Domain when appropriate as defined by a software policy. See also 2.9.6 <i>Doorbell PPIs</i>.</li> <li>The Interrupt Domain selected by ICC_CR0_EL3.PID is called the <i>Preemptive Interrupt Domain</i>.</li> <li>When the value of ICC_CR0_EL3.PID corresponds to an Interrupt Domain that is not implemented, the PE behaves as if there is no Preemptive Interrupt Domain.</li> <li>ICC_CR0_EL1.PID indicates whether the Physical Interrupt Domain associated with the Security state selected by SCR_EL3.{NSE,NS} is the Preemptive Interrupt Domain.</li> <li>The interrupt priority range of the Preemptive Interrupt Domain is split into two. The priority value used for the split is called the <i>Interrupt Preemptive Priority Threshold (IPPT)</i>. ICC_CR0_EL1.IPPT defines the Interrupt</li> </ul>                                                                                                                                                                                            |
| I <sub>pjkyp</sub><br>I <sub>vfwfw</sub><br>D <sub>nnbml</sub> | <ul> <li>The Current Physical Interrupt Domain is preempted in order to switch to the Physical Interrupt Domain of the HPPI so that it can be handled immediately. See also 2.9.4 <i>Physical interrupt signaling</i>.</li> <li>The Current Physical Interrupt Domain is notified through a separate interrupt that there is an HPPI for a different Physical Interrupt Domain, and the Current Physical Interrupt Domain can switch to the other Interrupt Domain when appropriate as defined by a software policy. See also 2.9.6 <i>Doorbell PPIs</i>.</li> <li>The Interrupt Domain selected by ICC_CR0_EL3.PID is called the <i>Preemptive Interrupt Domain</i>.</li> <li>When the value of ICC_CR0_EL3.PID corresponds to an Interrupt Domain that is not implemented, the PE behaves as if there is no Preemptive Interrupt Domain.</li> <li>ICC_CR0_EL1.PID indicates whether the Physical Interrupt Domain associated with the Security state selected by SCR_EL3.{NSE,NS} is the Preemptive Interrupt Domain.</li> <li>The interrupt priority range of the Preemptive Interrupt Domain is split into two. The priority value used for the split is called the <i>Interrupt Preemptive Priority Threshold (IPPT)</i>. ICC_CR0_EL1.IPPT defines the Interrupt Preemptive Priority Threshold for each Physical Interrupt Domain.</li> <li>The value of ICC_CR0_EL1.IPPT has no effect on the signaling of interrupts for an Interrupt Domain which is not</li> </ul> |

- The interrupt belongs to the Preemptive Interrupt Domain.
- The priority of the interrupt is higher than the IPPT of the Preemptive Interrupt Domain.

Otherwise, the interrupt is a *Non-preemptive interrupt*.

 $\rm S_{YFVLN}$ 

- For example, on a system with Secure and Non-secure Security states, the Secure Interrupt Domain can configure a subset of its interrupts as Preemptive interrupts and the remaining subset as Non-preemptive interrupts:
  - The Preemptive interrupts preempt execution in the Non-secure Interrupt Domain before being handled in the Secure Interrupt Domain.
  - The Non-preemptive interrupts allow the Non-secure Interrupt Domain to yield execution control to the Secure Interrupt Domain where they are handled.

#### 2.9.4 Physical interrupt signaling

I<sub>WVKDZ</sub> The CPU interface determines the physical HPPI for each Physical Interrupt Domain and performs the following actions:

- 1. Applies priority masking based on software configured priority masks and the running priority.
- 2. Determines whether the physical HPPIs signals the IRQ or FIQ interrupt to the PE.
- 3. Determines whether the interrupt is signaled with Superpriority.

This process is illustrated in Figure 2.4:



Figure 2.4: Physical interrupt determination

R<sub>ZSWWN</sub> The CPU interface determines whether there is an HPPI for a Physical Interrupt Domain when the value of ICC\_CR0\_ELx.EN is 1 for the Interrupt Domain.

The HPPI for an Interrupt Domain is determined by selecting the interrupt with the highest priority from the following:

- The candidate HPPI presented by the IRI for the Interrupt Domain.
- The candidate HPPI selected among the physical PPIs for the Interrupt Domain.

If ICC\_CR0\_ELx.EN is 0, the CPU interface behaves as if there are no candidate HPPIs for the Interrupt Domain.

There is no HPPI for an Interrupt Domain if any of the following are true:

- ICC\_CR0\_ELx.EN is 0 for the Interrupt Domain.
- There are no candidate HPPIs for the Interrupt Domain.
- R<sub>VVBPS</sub> If the candidate HPPI presented by the IRI has the same priority as the candidate HPPI selected among the PPIs for a Physical Interrupt Domain, it is IMPLEMENTATION DEFINED which of the two candidate HPPIs is selected as the HPPI for the Physical Interrupt Domain.
- R<sub>XNDSJ</sub> When there is at least one candidate HPPI for a Physical Interrupt Domain, the CPU interface determines the HPPI in finite time.

When there is a change to the candidate HPPIs due to updates to the configuration and state of the physical PPIs, or due to the IRI presenting a new candidate HPPI for the Interrupt Domain, the CPU interface redetermines the HPPI for the Physical Interrupt Domain in finite time.

- R<sub>QLGBG</sub> The CPU interface signals the FIQ interrupt when one of the following is true:
  - There is a Preemptive interrupt of Sufficient priority.
  - All of the following are true:
    - The Current Physical Interrupt Domain is the EL3 Interrupt Domain.
    - There is an HPPI of Sufficient priority for any Interrupt Domain.

R<sub>ZGHMN</sub> The CPU interface signals the IRQ interrupt when all of the following are true:

- The Current Physical Interrupt Domain is a Non-EL3 Interrupt Domain.
- There is no Preemptive interrupt of Sufficient priority.
- There is an HPPI of Sufficient priority for the Current Physical Interrupt Domain.
- $I_{SXXCJ}$  The CPU interface never signals the IRQ and FIQ interrupts at the same time.
- I<sub>RYDXC</sub> The following table illustrates the physical interrupt signal asserted by the CPU interface when the PE is executing at any Exception level below EL3:

| EL3 HPPI of<br>Sufficient priority<br>exists | Non-Current<br>Preemptive Domain<br>HPPI of Sufficient<br>priority exists | Current Domain HPPI<br>of Sufficient priority<br>exists | Interrupt<br>signal |
|----------------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------|---------------------|
| Yes                                          | Х                                                                         | X                                                       | FIQ                 |
| No                                           | Yes                                                                       | Х                                                       | FIQ                 |
| No                                           | No                                                                        | Yes                                                     | IRQ                 |
| No                                           | No                                                                        | No                                                      | n/a                 |

x: The value does not have any impact on which interrupt is signaled.

 ILTYGD
 The following table illustrates the type of physical interrupt signaled by the CPU interface when the PE is executing at EL3:

| EL3 HPPI of<br>Sufficient priority<br>exists | Non-EL3 Preemptive<br>HPPI of Sufficient<br>priority exists | Any non-Preemptive<br>HPPI of Sufficient<br>priority exists | Interrupt<br>signal |
|----------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------|---------------------|
| Yes                                          | х                                                           | Х                                                           | FIQ                 |
| No                                           | Yes                                                         | Х                                                           | FIQ                 |
| No                                           | No                                                          | Yes                                                         | FIQ                 |
| No                                           | No                                                          | No                                                          | n/a                 |

- x: The value does not have any impact on which interrupt is signaled.
- S<sub>MKKWV</sub> Software executing at EL3 can read ICC\_DOMHPPIR\_EL3 to determine if there are HPPIs of Sufficient priority for other Interrupt Domains. For example, this can be useful after taking the FIQ exception to determine what may have caused the exception when execution of the GICR CDIA System instruction returns VALID as 0 in the <Xt> register.

This may also be useful in certain power management scenarios to determine the idle state of the system.

- IHDXLH
   Whether there is an HPPI of Sufficient priority is reported by the following registers based on the current Exception level:
  - When the current Exception level is EL2 or EL1, ICC\_HPPIR\_EL1 reports whether there is an HPPI of Sufficient priority for the Current Physical Interrupt Domain.
  - When the current Exception level is EL3, ICC\_HPPIR\_EL1 reports whether there is an HPPI of Sufficient priority for the Logical Interrupt Domain as selected by SCR\_EL3.{NSE,NS}.

If there is an HPPI of Sufficient priority, it also reports the INTID of that HPPI.

- S<sub>DWXKH</sub> EL3 firmware can use ICC\_DOMHPPIR\_EL3 to determine if a Security state has an HPPI of Sufficient priority. By switching SCR\_EL3.{NSE,NS} to that Security state and subsequently reading ICC\_HPPIR\_EL1, the firmware can identify the INTID of that HPPI. EL3 firmware can use this information to switch to the software component responsible for handling the HPPI in the Security state.
- I<sub>GVRTZ</sub> In GICv3, the ICx\_HPPIRx\_EL1 registers indicate the highest priority pending interrupt for the corresponding interrupt group irrespective of whether the interrupt has sufficient priority to be signaled to the PE.

GICv5 changes this behavior such that the ICx\_HPPIR\_EL1 and ICC\_DOMHPPIR\_EL3 registers return information for an HPPI only if it has Sufficient priority to be signaled.

Arm is not aware of any software component that relies on the GICv3 behavior. The GICv5 behavior helps simplify the PE interface architecture as both the logic for acknowledging an HPPI and reporting information about an HPPI rely on the same condition of Sufficient priority determination.

#### I<sub>SYCYB</sub> ICC\_HPPIR\_EL3 reports whether there is an HPPI of Sufficient priority for the EL3 Interrupt Domain.

I sxGQC In a system which only supports a single Interrupt Domain, the CPU interface never signals the FIQ interrupt.

#### 2.9.5 Physical non-maskable interrupts

R<sub>CSBDX</sub> When there is an HPPI of Sufficient priority for the Current Physical Interrupt Domain, it is signaled to the PE with *Superpriority*[1] when all of the following are true:

- The priority of the HPPI is 0.
- One of the following is true:
  - The Current Physical Interrupt Domain is the EL3 Interrupt Domain and SCTLR\_EL3.NMI is 1.
  - The Current Physical Interrupt Domain is not the EL3 Interrupt Domain and one of the following is true:
     \* Physical IRQs are routed to EL2, and SCTLR\_EL2.NMI is 1.
    - \* Physical IRQs are routed to EL1, and SCTLR\_EL1.NMI is 1.

|                    | Otherwise, the HPPI for the Current Physical Interrupt Domain is not signaled with Superpriority.                                                                                                                                                                                                             |  |  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| R <sub>vhgpr</sub> | When there is a Preemptive interrupt of Sufficient priority, it is IMPLEMENTATION DEFINED whether the interrupt is signaled to the PE with Superpriority, if all the following are true:                                                                                                                      |  |  |
|                    | <ul> <li>The priority of the HPPI is 0.</li> <li>The Preemptive interrupt belongs to the EL3 Interrupt Domain.</li> <li>SCTLR_EL3.NMI is 1.</li> </ul>                                                                                                                                                        |  |  |
|                    | All other Preemptive interrupts are not signaled with Superpriority.                                                                                                                                                                                                                                          |  |  |
| D <sub>SDQJW</sub> | A physical interrupt that is signaled with Superpriority is referred to as a physical NMI.                                                                                                                                                                                                                    |  |  |
| I <sub>rpsfk</sub> | If the priority of the HPPI is 0, but is not signaled with Superpriority due to not meeting the other conditions, then the HPPI is not an NMI.                                                                                                                                                                |  |  |
| I <sub>DLGVX</sub> | An NMI can never be acknowledged by executing the GICR CDIA instruction.                                                                                                                                                                                                                                      |  |  |
|                    | Similarly, an interrupt that is not an NMI can never be acknowledged by executing the GICR CDNMIA instruction. This means that when SCTLR_ELx.NMI is 0 for the current Exception level, the GICR CDNMIA instruction cannot acknowledge an interrupt.                                                          |  |  |
| R <sub>spwcf</sub> | When FEAT_GCIE is implemented, following a Context synchronization event as the result of taking or returning from an exception, changes to whether the CPU interface has asserted or de-asserted the IRQ and FIQ signal for the Interrupt Domain have taken effect and can be observed by a read of ISR_EL1. |  |  |
|                    | See also:                                                                                                                                                                                                                                                                                                     |  |  |

• Chapter C1 Operational model

### 2.9.6 Doorbell PPIs

- R<sub>QCVFJ</sub> Doorbell PPIs are level-sensitive PPIs.
- R<sub>PNYKZ</sub> There is a separate Doorbell PPI for every Non-EL3 Interrupt Domain as described in Table 2.12.

#### Table 2.12: Doorbell PPI definitions

| Non-EL3 Interrupt Domain | Doorbell PPI name |
|--------------------------|-------------------|
| Secure                   | S_DB_PPI          |
| Realm                    | RL_DB_PPI         |
| Non-secure               | NS_DB_PPI         |

R<sub>GSHXH</sub> The level of the NS\_DB\_PPI is asserted when all of the following are true:

- The Current Physical Interrupt Domain is one of the following:
  - Secure Interrupt Domain.
  - Realm Interrupt Domain.
- The NS\_DB\_PPI is assigned to the Current Physical Interrupt Domain.
- There is a Non-preemptive physical HPPI of Sufficient priority for the Non-secure Interrupt Domain.

Otherwise, the level of the NS\_DB\_PPI is not asserted.

The level of the S\_DB\_PPI is asserted when all of the following are true;

- The Current Physical Interrupt Domain is one of the following:
  - Non-secure Interrupt Domain.

- Realm Interrupt Domain.

- The S\_DB\_PPI is assigned to the Current Physical Interrupt Domain.
- There is a Non-preemptive physical HPPI of Sufficient priority for the Secure Interrupt Domain.

Otherwise, the level of the S\_DB\_PPI is not asserted.

The level of the RL\_DB\_PPI is asserted when all of the following are true;

- The Current Physical Interrupt Domain is one of the following:
  - Non-secure Interrupt Domain.
  - Secure Interrupt Domain.
- The RL\_DB\_PPI is assigned to the Current Physical Interrupt Domain.
- There is a Non-preemptive physical HPPI of Sufficient priority for the Realm Interrupt Domain.

Otherwise, the level of the RL\_DB\_PPI is not asserted.

R<sub>LWLPK</sub> When the level of a Doorbell PPI is asserted, it is asserted in finite time.

R<sub>YSCLK</sub> Table 2.13 lists the conditions for when a Doorbell PPI is implemented.

#### Table 2.13: Doorbell PPI implementation

| Doorbell PPI name | Condition                            |
|-------------------|--------------------------------------|
| S_DB_PPI          | EL3 and Secure state are implemented |
| RL_DB_PPI         | FEAT_RME is implemented              |
| NS_DB_PPI         | EL3 is implemented                   |

IWGXJRWhen the Current Physical Interrupt Domain is a Non-EL3 Interrupt Domain, Table 2.14 describes when the level<br/>of a Doorbell PPI is asserted.

#### Table 2.14: Doorbell PPI usage

| Current Physical Interrupt Domain | Doorbell PPI | Asserted when                                                           |
|-----------------------------------|--------------|-------------------------------------------------------------------------|
| Non-secure                        | S_DB_PPI     | There is a Secure Non-preemptive HPPI of Sufficient priority.           |
| Non-secure                        | RL_DB_PPI    | There is a Realm Non-preemptive HPPI of Sufficient priority.            |
| Secure                            | NS_DB_PPI    | There is a Non-secure<br>Non-preemptive HPPI of Sufficient<br>priority. |
| Secure                            | RL_DB_PPI    | There is a Realm Non-preemptive HPPI of Sufficient priority.            |
| Realm                             | S_DB_PPI     | There is a Secure Non-preemptive HPPI of Sufficient priority.           |
| Realm                             | NS_DB_PPI    | There is a Non-secure<br>Non-preemptive HPPI of Sufficient<br>priority. |

Multiple Doorbell PPIs can be asserted at the same time. For example, if the Current Physical Interrupt Domain is the Non-secure Interrupt Domain, and there is a Non-preemptive HPPI of Sufficient priority for both the Secure and Realm Interrupt Domains, then the levels of both S\_DB\_PPI and RL\_DB\_PPI are asserted.

- S<sub>FKVPW</sub> When the Current Physical Interrupt Domain is a Non-EL3 Interrupt Domain, if a Doorbell PPI for another Non-EL3 Interrupt Domain is implemented, it must be assigned to the Current Physical Interrupt Domain so that it can be signaled and handled in the Current Physical Interrupt Domain. This is done by software executing at EL3 as follows:
  - Prior to a switch to the Non-secure Interrupt Domain from the EL3 Interrupt Domain, the S\_DB\_PPI and RL\_DB\_PPI are assigned to the Non-secure Interrupt Domain.
  - Prior to a switch to the Secure Interrupt Domain from the EL3 Interrupt Domain, the NS\_DB\_PPI and RL\_DB\_PPI are assigned to the Secure Interrupt Domain.
  - Prior to a switch to the Realm Interrupt Domain from the EL3 Interrupt Domain, the S\_DB\_PPI and NS\_DB\_PPI are assigned to the Realm Interrupt Domain.
- S<sub>QFPBH</sub> Software can manage Doorbell PPIs the same way as managing any other PPIs, including individually enabling and disabling them, and configuring their priority. Doorbell PPIs can be used to yield control to another Security State at an opportune time according to the scheduling policy in the current Security state.
- R<sub>TCBST</sub> On taking an exception from Exception levels below EL3 to EL3, the CPU interface completes the following sequence:
  - 1. The levels of all Doorbell PPIs are de-asserted.
  - 2. The HPPI for each Physical Interrupt Domain is re-evaluated.

#### See also:

- 2.9.3 *Preemptive interrupts*.
- 2.9.4 *Physical interrupt signaling*.

### 2.10 The virtual CPU interface

- I<sub>XVDWC</sub> When HCR\_EL2.IMO is 1 and ICH\_VCTLR\_EL2.V3 is 0, the GICv5 virtual CPU interface is used and all of the following are true:
  - When executing at EL1, all of the following are true:
    - GICv5 System instruction that specify the Current Interrupt Domain as the domain parameter operate in the Virtual Interrupt Domain.
    - Accesses to GICv5 System registers that share an encoding between the ICC\_\* and ICV\_\* registers access the ICV\_\* registers.
    - Accesses to GICv3.3 Group 0, Group 1, and Common System registers are UNDEFINED.
  - Accesses to ICH\_VMCR\_EL2 use the GICv5 version of the register.

See Chapter 8 System instructions and Chapter 9 System registers for more information.

- S<sub>KFGFJ</sub> The Hypervisor at EL2 configures HCR\_EL2.IMO to control whether the virtual or physical CPU interface is accessed at EL1.
- I<sub>FCTBZ</sub> The value of HCR\_EL2.FMO has no effect on the operation of the GICv5 CPU interface when Legacy operation is disabled because of the following reasons:
  - Since SCR\_EL3.FIQ is RES1 if EL3 is implemented, physical FIQ interrupts are taken to EL3.
  - When Legacy operation is disabled, the GICv5 virtual CPU interface does not signal the virtual FIQ interrupt.

### 2.10.1 Virtual PPIs

- G<sub>WWRGJ</sub> The architecture supports signaling virtual PPIs to software running at Exception levels below EL2. Virtual PPIs may be signaled by hypervisor software emulating a PPI source or directly injected using the corresponding physical PPI.
- R<sub>GZRNG</sub> For each implemented physical PPI, if EL2 is implemented, the corresponding virtual PPI with the same ID is implemented.
- I<sub>QFGQN</sub> For each implemented PPI, the physical and virtual PPI with the same INTID are separate interrupts.
- I<sub>RQBBW</sub> If the Virtual CPU interface is supported, virtual PPIs are configured using the following registers:

#### Table 2.15: Virtual PPI system registers

| Register                      | Name                                    |
|-------------------------------|-----------------------------------------|
| ICV_PPI_SACTIVER <n>_EL1</n>  | Set interrupt Active                    |
| ICV_PPI_CACTIVER <n>_EL1</n>  | Clear interrupt Active                  |
| ICV_PPI_ENABLER <n>_EL1</n>   | Interrupt Enable and Disable            |
| ICV_PPI_HMR <n>_EL1</n>       | Interrupt Handling mode (Level or Edge) |
| ICV_PPI_SPENDR <n>_EL1</n>    | Set interrupt Pending                   |
| ICV_PPI_CPENDR <n>_EL1</n>    | Clear interrupt Pending                 |
| ICV_PPI_PRIORITYR <n>_EL1</n> | Interrupt Priority                      |

I<sub>CBBCV</sub> To enable context switching, the configuration of virtual PPIs is also accessible using the following registers:

#### Table 2.16: Hypervisor configuration PPI system registers

| Register                      | Name                                                                                                          |
|-------------------------------|---------------------------------------------------------------------------------------------------------------|
| ICH_PPI_ACTIVER <n>_EL2</n>   | Interrupt Active, accesses same state as ICV_PPI_SACTIVER <n>_EL1 and ICV_PPI_CACTIVER<n>_EL1.</n></n>        |
| ICH_PPI_DVIR <n>_EL2</n>      | Controls whether Pending physical PPIs are directly injected as virtual PPIs to the Virtual Interrupt Domain. |
| ICH_PPI_ENABLER <n>_EL2</n>   | Alias of ICV_PPI_ENABLER <n>_EL1.</n>                                                                         |
| ICH_PPI_PENDR <n>_EL2</n>     | Interrupt Pending, accesses same state as ICV_PPI_SPENDR <n>_EL1 and ICV_PPI_CPENDR<n>_EL1.</n></n>           |
| ICH_PPI_PRIORITYR <n>_EL2</n> | Alias of ICV_PPI_PRIORITYR <n>_EL1.</n>                                                                       |

| R <sub>pqdyk</sub> | If the Virtual CPU interface is supported, a virtual PPI is permitted to be a candidate HPPI if and only if all of the |
|--------------------|------------------------------------------------------------------------------------------------------------------------|
|                    | following are true:                                                                                                    |
|                    |                                                                                                                        |

- ICV\_PPI\_ENABLER<n>\_EL1.EN is 1.
- ICV\_PPI\_SPENDR<n>\_EL1.PEND is 1.
- ICV\_PPI\_SACTIVER<n>\_EL1.ACTIVE is 0.

# R<sub>JMKJM</sub> The CPU interface selects the virtual candidate HPPI among the virtual PPIs by selecting the highest priority PPI that meets the virtual candidate HPPI selection criteria.

# R<sub>2XWQD</sub> If more than one virtual PPI meet the virtual candidate HPPI selection criteria, it is IMPLEMENTATION DEFINED which of those PPIs becomes the virtual candidate HPPI.

- L<sub>SXKHV</sub> A direct read or write to a PPI System register could cause an indirect write to its alias or a different PPI System register. The indirect write is only guaranteed to be visible to subsequent reads or writes if a Context synchronization event takes place after the direct read or write and before the subsequent reads or writes. See *Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture*[1] for more information.
- $S_{KQQTX}$  When software at EL1 performs a direct write to an ICV\_register, this causes an indirect write to the corresponding ICH\_register. The value returned by a read at EL2 from the ICH\_register is guaranteed to observe the indirect write, only if there is a context synchronization event between the indirect write and the direct read. If FEAT\_ExS is implemented and SCTLR\_EL2.EIS is 0, an exception taken to EL2 is not a context synchronization event, and software at EL2 must issue an ISB before reading the ICH\_registers to observe the latest value written by a guest VM.

For example, ICH\_PPI\_PRIORITYR<n>\_EL2 is an alias of ICV\_PPI\_PRIORITYR<n>\_EL1. A direct write of a priority value for a PPI ID to ICV\_PPI\_PRIORITYR<n>\_EL1 causes an indirect write of the priority value to ICH\_PPI\_PRIORITYR<n>\_EL2 for the same PPI ID. A Context Synchronization Event is required after the write to ICV\_PPI\_PRIORITYR<n>\_EL1 to ensure that a subsequent read of ICH\_PPI\_PRIORITYR<n>\_EL2 returns the latest priority value.

### 2.10.1.1 Direct injection of virtual PPIs

D<sub>QNZMN</sub> The architecture supports *direct injection* of the physical PPI Pending state to the Pending state of a virtual PPI.

- IVRZWD
   When ICH\_PPI\_DVIR<n>\_EL2.DVI is 1, the Pending state of the corresponding physical PPI INTID is directly injected to the Pending state of a virtual PPI.
- R<sub>BMZFB</sub> Unless a timer PPI is redirected under nested virtualization, when the Pending state of a physical PPI is directly injected to the Pending state of a virtual PPI, the INTID of the virtual PPI is the same as the INTID of the physical PPI.

See 2.10.1.2 *PPI redirection under nested virtualization* for more information about redirection of timer PPIs under nested virtualization.

| I <sub>PGRWM</sub> | The Pending state of a virtual PPI is one of the following:                                                                                                                                                                                                                                                                                                                               |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | • If the corresponding physical PPI is not directly injected, the Pending state of the virtual PPI is determined by ICH_PPI_PENDR <n>.PEND<x>.</x></n>                                                                                                                                                                                                                                    |
|                    | • If the corresponding physical PPI is directly injected, the Pending state of the virtual PPI is determined by ICC_PPI_xPENDR <n>.PEND<x>.</x></n>                                                                                                                                                                                                                                       |
|                    | When the Pending state of a physical PPI is directly injected as the Pending state of a virtual PPI, the field in ICV_PPI_xPENDR <n>.PEND<x> corresponding to the virtual PPI becomes an alias of the field in ICC_PPI_xPENDR<n>.PEND<x> corresponding to the physical PPI, and the value of ICH_PPI_PENDR<n>.PEND<x> is IGNORED.</x></n></x></n></x></n>                                 |
| I <sub>XXSHB</sub> | When a physical PPI is directly injected and becomes Pending, both the virtual and physical PPI are Pending and are permitted to be acknowledged in either the corresponding Physical Interrupt Domain or in the Virtual Interrupt Domain.                                                                                                                                                |
|                    | Arm recommends that the physical PPI is disabled when it is directly injected.                                                                                                                                                                                                                                                                                                            |
| I <sub>kkclt</sub> | When the Pending state of a physical PPI is directly injected as the Pending state of a virtual PPI, it is the configuration of the virtual PPI that determines when the PPI is signaled and how the PPI is handled.                                                                                                                                                                      |
| I <sub>bkzqc</sub> | For example, if the Pending state of physical PPI 23 is directly injected as the Pending state of a virtual PPI, all of the following are true:                                                                                                                                                                                                                                           |
|                    | • The Pending state of physical PPI 23 is directly injected as the Pending state of virtual PPI 23.                                                                                                                                                                                                                                                                                       |
|                    | • Virtual PPI 23 may be considered as the candidate HPPI in the Virtual Interrupt Domain when all of the following are true:                                                                                                                                                                                                                                                              |
|                    | <ul> <li>Physical PPI 23 is Pending.</li> <li>ICV_PPI_ENABLER0_EL1.EN23 is 1.</li> <li>ICV_PPI_xACTIVER0_EL1.ACTIVE23 is 0.</li> </ul>                                                                                                                                                                                                                                                    |
|                    | • ICV_PPI_PRIORITYR2_EL1.PRIORITY7 determines the Priority of virtual PPI 23.                                                                                                                                                                                                                                                                                                             |
| R <sub>JBKGB</sub> | If EL2 is not implemented, the Effective value of ICH_PPI_DVIR <n>_EL2.DVI is 0 for all implemented PPIs.</n>                                                                                                                                                                                                                                                                             |
| I <sub>ccldf</sub> | When the Pending state of a physical PPI is directly injected as the Pending state of a virtual PPI, all of the following are true:                                                                                                                                                                                                                                                       |
|                    | <ul> <li>Writes to the corresponding field in ICH_PPI_PENDR<n> update the value of that field.</n></li> <li>Reads from the corresponding field in ICH_PPI_PENDR<n> return the value of that field.</n></li> <li>The value of the corresponding field in ICH_PPI_PENDR<n> does not affect the value of the field corresponding to the virtual PPI in ICV_PPI_xPENDR<n>.</n></n></li> </ul> |
| $S_{\rm SVFBL}$    | Hypervisor software may save and restore the Pending state of a directly injected Edge PPI by accessing to the fields corresponding to the physical PPI INTID in ICC_PPI_xPENDR <n>.</n>                                                                                                                                                                                                  |
| I <sub>NVWGX</sub> | The Effective value of ICH_PPI_DVIR <n>_EL2.DVI is 0 if PPI <x> is not assigned to the Current Physical Interrupt Domain.</x></n>                                                                                                                                                                                                                                                         |
|                    | 2.10.1.2 PPI redirection under nested virtualization                                                                                                                                                                                                                                                                                                                                      |
| R <sub>gygnw</sub> | The outputs of the EL1 physical timer and EL1 virtual timer signal different PPI IDs when all of the following are true:                                                                                                                                                                                                                                                                  |
|                    | <ul> <li>FEAT_GCIE is implemented.</li> <li>HCR_EL2.{NV,NV1} is {1,0}.</li> <li>EL2 is implemented and enabled in the Security state selected by SCR_EL3.{NSE,NS}.</li> </ul>                                                                                                                                                                                                             |
|                    | In this case, all of the following are true:                                                                                                                                                                                                                                                                                                                                              |
|                    |                                                                                                                                                                                                                                                                                                                                                                                           |

When SCR\_EL3.NS is 1, all of the following are true:
If ICH\_PPI\_DVIR0\_EL2.DVI30 is 1, all of the following are true:

- \* Physical PPI 30 is directly injected as virtual PPI 26.
- \* ICV\_PPI\_xPENDR0\_EL2.PEND26 is an alias of ICC\_PPI\_PENDR\_EL2.PEND30.
- \* ICV\_PPI\_xPENDR0\_EL2.PEND30 accesses the Pending state of virtual PPI 30.
- \* ICH\_PPI\_PENDR0\_EL2.PEND26 is IGNORED.
- \* ICH\_PPI\_DVIR0\_EL2.DVI26 is treated as 0 for all other purposes than a direct read of the field.
- If ICH\_PPI\_DVIR0\_EL2.DVI27 is 1, all of the following are true:
  - \* Physical PPI 27 is directly injected as virtual PPI 28.
  - \* ICV\_PPI\_xPENDR0\_EL2.PEND28 is an alias of ICC\_PPI\_PENDR\_EL2.PEND27.
  - \* ICV\_PPI\_xPENDR0\_EL2.PEND27 accesses the Pending state of virtual PPI 27.
  - \* ICH\_PPI\_PENDR0\_EL2.PEND28 is IGNORED.
- \* ICH\_PPI\_DVIR0\_EL2.DVI28 is treated as 0 for all other purposes than a direct read of the field.
- When SCR\_EL3.NS is 0, all of the following are true:
  - If ICH\_PPI\_DVIR0\_EL2.DVI30 is 1, all of the following are true:
    - \* Physical PPI 30 is directly injected as virtual PPI 20.
    - \* ICV\_PPI\_xPENDR0\_EL2.PEND20 is an alias of ICC\_PPI\_PENDR\_EL2.PEND30.
    - \* ICV\_PPI\_xPENDR0\_EL2.PEND30 accesses the Pending state of virtual PPI 30.
    - \* ICH\_PPI\_PENDR0\_EL2.PEND20 is IGNORED.
    - \* ICH\_PPI\_DVIR0\_EL2.DVI20 is treated as 0 for all other purposes than a direct read of the field.
  - If ICH\_PPI\_DVIR0\_EL2.DVI27 is 1, all of the following are true:
    - \* Physical PPI 27 is directly injected as virtual PPI 19.
    - \* ICV\_PPI\_xPENDR0\_EL2.PEND19 is an alias of ICC\_PPI\_PENDR\_EL2.PEND27.
    - \* ICV\_PPI\_xPENDR0\_EL2.PEND27 accesses the Pending state of virtual PPI 27.
    - \* ICH\_PPI\_PENDR0\_EL2.PEND19 is IGNORED.
    - \* ICH\_PPI\_DVIR0\_EL2.DVI19 is treated as 0 for all other purposes than a direct read of the field.
- IQKGXM
   All fields corresponding to implemented PPIs in ICH\_PPI\_PENDR0\_EL2 access the Pending state of the corresponding virtual PPI, regardless of whether a directly injected PPI is being redirected to a different virtual INTID due to nested virtualization. This means that all of the following are true:
  - When Physical PPI 30 is directly injected as virtual PPI 26, all of the following are true:
    - Whether virtual PPI 26 is considered Pending is determined by the Pending state of physical PPI 30.
    - An access to ICH\_PPI\_PENDR0\_EL2.PEND26 accesses the Pending state of virtual PPI 26.
    - The value of ICH\_PPI\_PENDR0\_EL2.PEND26 is IGNORED, meaning that it is not used in determining whether virtual PPI 26 is considered Pending.
  - When Physical PPI 27 is directly injected as virtual PPI 28, all of the following are true:
    - Whether virtual PPI 28 is considered Pending is determined by the Pending state of physical PPI 27.
      An access to ICH\_PPI\_PENDR0\_EL2.PEND28 accesses the Pending state of virtual PPI 28.
    - The value of ICH\_PPI\_PENDR0\_EL2.PEND28 is IGNORED, meaning that it is not used in determining whether virtual PPI 28 is considered Pending.
  - When Physical PPI 30 is directly injected as virtual PPI 20, all of the following are true:
    - Whether virtual PPI 20 is considered Pending is determined by the Pending state of physical PPI 30.
    - An access to ICH\_PPI\_PENDR0\_EL2.PEND20 accesses the Pending state of virtual PPI 20.
    - The value of ICH\_PPI\_PENDR0\_EL2.PEND20 is IGNORED, meaning that it is not used in determining whether virtual PPI 20 is considered Pending.
  - When Physical PPI 27 is directly injected as virtual PPI 19, all of the following are true:
    - Whether virtual PPI 19 is considered Pending is determined by the Pending state of physical PPI 27.
    - An access to ICH\_PPI\_PENDR0\_EL2.PEND19 accesses the Pending state of virtual PPI 19.
    - The value of ICH\_PPI\_PENDR0\_EL2.PEND19 is IGNORED, meaning that it is not used in determining whether virtual PPI 19 is considered Pending.

### 2.10.2 Virtual priority masking

D<sub>BMLRF</sub> The Virtual Priority Mask is the value stored in ICV\_PCR\_EL1.PRIORITY.

IDDQBKSee 9.1 Synchronization requirements for GICv5 System registers for more information about synchronization<br/>requirements for updates to the Virtual Priority Mask.

D<sub>CZRGJ</sub> The *virtual running priority* is defined as the highest active priority stored in ICV\_APR\_EL1.

I<sub>DLHDR</sub> The virtual running priority is reported in ICV\_HAPR\_EL1.PRIORITY.

D<sub>WDGVW</sub> A virtual interrupt has *Sufficient priority* to be signaled when all of the following are true:

- The Priority of the interrupt is higher than the virtual running priority.
- The Priority of the interrupt is equal to or higher than the Virtual Priority Mask.
- ICV\_HPPIR\_EL1 reports if there is a virtual HPPI of Sufficient priority for the Virtual Interrupt Domain. If thereis a virtual HPPI of Sufficient priority, it also reports the INTID of that HPPI.

I<sub>MDDZR</sub> The behavior of ICV\_HPPIR\_EL1 in GICv5 is different from the ICV\_HPPIRx\_EL1 registers in GICv3.

In GICv3, ICV\_HPPIRx\_EL1 return the highest priority interrupt for the corresponding interrupt group irrespective of whether the interrupt has sufficient priority to be signaled to the PE.

GICv5 changes this behavior such that ICV\_HPPIR\_EL1 returns the highest priority interrupt only if it has Sufficient priority to be signaled.

### 2.10.3 Virtual interrupt signaling

IVDEVTWhen the virtual CPU interface is not configured to use legacy operation, the GICv5 CPU interface determines the<br/>virtual HPPI for the Virtual Interrupt Domain from the virtual candidate HPPIs from the IRI and the virtual PPIs<br/>and performs the following actions:

- 1. Applies priority masking based on software configured virtual priority masks and the virtual running priority.
- 2. Determines if the virtual HPPI signals the virtual IRQ interrupt to the PE.
- 3. When the virtual CPU interface signals the virtual IRQ interrupt, it further determines whether the virtual IRQ interrupt is signaled with Superpriority.

When Legacy operation is enabled, the Legacy virtual CPU interface determines the virtual HPPI from the list registers and performs the following actions:

- 1. Applies interrupt grouping and priority masking based on software configured virtual priority masks and the virtual running priority.
- 2. Determines if the virtual HPPI signals the virtual IRQ interrupt or the virtual FIQ interrupt to the PE.
- 3. When the virtual CPU interface signals the virtual IRQ interrupt, it further determines whether the virtual IRQ interrupt should be signaled with Superpriority.

This process is illustrated in Figure 2.5.

See 2.10.7 Legacy virtual CPU interface for more information about the Legacy virtual CPU interface:



Figure 2.5: Virtual interrupt determination

R<sub>ZKPVN</sub> When EL2 is implemented and is enabled in the Security state identified by SCR\_EL3.{NSE, NS} and Legacy operation is disabled, the GICv5 CPU interface determines whether there is an HPPI for the Virtual Interrupt Domain when all of the following are true:

- ICV\_CR0\_EL1.EN is 1.
- ICH\_VCTLR\_EL2.EN is 1.

The HPPI for the Virtual Interrupt Domain is determined by selecting the interrupt with the higher priority from the following:

- The candidate HPPI presented by the IRI for the resident VPE.
- The candidate HPPI selected among the virtual PPIs.

There is no HPPI for the Virtual Interrupt Domain if any of the following are true:

- ICV\_CR0\_EL1.EN is 0.
- ICH\_VCTLR\_EL2.EN is 0.
- There are no candidate HPPIs for the Virtual Interrupt Domain.

#### Note

The candidate HPPI presented by the IRI for the resident VPE is not considered when selecting the HPPI for the Virtual Interrupt Domain when ICH\_CONTEXTR\_EL2.IRICHPPIDIS is 1.

See 2.10.5 Selecting the resident VPE for more information about managing the resident VPE.

R<sub>JKZLR</sub> If EL2 is not implemented, the Effective value of ICH\_VCTLR\_EL2.EN is 0.

- R<sub>XCFJD</sub> If the candidate HPPI presented by the IRI for the resident VPE has the same priority as the candidate HPPI selected among the virtual PPIs, it is IMPLEMENTATION DEFINED which of the two candidate HPPIs is selected as the HPPI for the Virtual Interrupt Domain.
- R<sub>CGYDN</sub> When there is at least one candidate HPPI for the Virtual Interrupt Domain, the CPU interface determines the HPPI for the Virtual Interrupt Domain in finite time.

When there is a change to the candidate HPPIs due to updates to the configuration and state of the virtual PPIs, or due to the IRI presenting a new candidate HPPI for the resident VPE, the CPU interface redetermines the HPPI for the Virtual Interrupt Domain in finite time.

- R<sub>NGHYT</sub> The GICv5 CPU interface signals the vIRQ interrupt when there is an HPPI of Sufficient priority for the Virtual Interrupt Domain.
- $I_{NJPKJ}$  When Legacy operation is disabled, the GICv5 virtual CPU interface does not signal the vFIQ interrupt.

See 2.10.7 Legacy virtual CPU interface for more information.

I<sub>BVMRK</sub> The behavior of the Legacy virtual CPU interface including when virtual interrupts are signaled is described in [3].

#### 2.10.4 Virtual non-maskable interrupts

- $\mathbb{R}_{XKMQC}$  When there is an HPPI of Sufficient priority for the Virtual Interrupt Domain, it is signaled to the PE with *Superpriority*[1] when all of the following are true:
  - The priority of the virtual HPPI is 0.
  - The current Exception level is EL1 or lower.
  - SCTLR\_EL1.NMI is 1.

Otherwise, the virtual HPPI is not signaled with Superpriority.

- D<sub>QPMFG</sub> A virtual interrupt that is signaled with Superpriority is referred to as a *virtual NMI*.
- $I_{MQHTC}$  If the priority of the virtual HPPI is 0, but is not signaled with Superpriority due to not meeting the other conditions, then the virtual HPPI is not a virtual NMI.

#### 2.10.5 Selecting the resident VPE

- G<sub>CQBBT</sub> Hypervisor software manages multiple VMs and VPEs and selects different VPEs to be resident on a PE over time to allow multiplexing VPEs on a single PE.
- G<sub>PBWDL</sub> Separate VPEs from the same VM can be resident on separate PEs at the same time to support VMs with multiple VPEs running concurrently.
- D<sub>JRKYV</sub> The resident VPE is specified by writing the corresponding VPE ID and VM ID to ICH\_CONTEXTR\_EL2.

Each VM has a separate VPE ID namespace which means that two VPEs with the same VPE ID for different VM IDs specify different VPEs.

- Image: MIMSUAt any given time for each PE in the system, there is either one VPE resident or no VPE resident. It is not possible<br/>for multiple VPEs to be resident on the same PE at the same time, even if those VPEs belong to different Security<br/>states.
- I<sub>YSVWR</sub> The VM ID used in this specification is not directly related to the VMSA VMID[1].
- I<sub>BJSFF</sub> When ICH\_CONTEXTR\_EL2.V is 0, no VPE is resident and ICH\_CONTEXTR\_EL2.{VM,VPE} are IGNORED.
- R<sub>XVRCV</sub> If EL2 is not implemented, the Effective value of ICH\_CONTEXTR\_EL2.V is 0.
- IWCHLY ICH\_CONTEXTR\_EL2.IRICHPPIDIS allows software to specify whether the candidate HPPIs presented by the IRI is considered when selecting the HPPI for the Virtual Interrupt Domain.

GIC system instructions that operate in the virtual interrupt domain access the configuration and state of virtual LPIs and SPIs belonging to the resident VM, irrespective of the value of ICH\_CONTEXTR\_EL2.IRICHPPIDIS.

| S <sub>bybkl</sub> | Making a VPE resident with ICH_CONTEXTR_EL2.IRICHPPIDIS set to 1 allows software to emulate an environment where the virtual IRI is disabled by setting ICH_CONTEXTR_EL2.IRICHPPIDIS to 1 for all the VPEs that belong to the same disabled virtual IRI.                                                                          |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $R_{LHFXQ}$        | On a write that sets ICH_CONTEXTR_EL2.V to 1, the VM and VPE are resolved in the Physical Interrupt Domain identified by SCR_EL3.{NSE,NS}.                                                                                                                                                                                        |
| R <sub>CDHXC</sub> | If SCR_EL3.{NSE,NS} is set to a Reserved value, a write that sets ICH_CONTEXTR_EL2.V to 1 has the following CONSTRAINED UNPREDICTABLE behaviors:                                                                                                                                                                                  |
|                    | <ul> <li>No VPE is treated as being resident.</li> <li>SCR_EL3.{NSE,NS} is treated as an UNKNOWN non-reserved value.</li> </ul>                                                                                                                                                                                                   |
| I <sub>fdpdr</sub> | An access by a GIC System instruction to the state or configuration of a virtual LPI or SPI, when the Current Interrupt Domain is the Virtual Interrupt Domain, applies to the resident VM of that PE. Apart from GIC VDPEND, where the target VM is specified as an argument to the instruction.                                 |
| R <sub>RXMNN</sub> | Changing SCR_EL3.{NSE,NS} when there is a resident VPE is CONSTRAINED UNPREDICTABLE with a choice of the following:                                                                                                                                                                                                               |
|                    | <ul> <li>ICH_CONTEXTR_EL2.V is cleared to 0.</li> <li>The CPU interface behaves as if no VPE is resident, but the value of ICH_CONTEXTR_EL2 is unchanged.</li> <li>If ICH_CONTEXTR_EL2.V is subsequently written to 0, ICH_CONTEXTR_EL2.DB is RES0.</li> </ul>                                                                    |
| S <sub>XCDSV</sub> | When switching Security state, Arm expects that software at EL3 writes to ICH_CONTEXTR_EL2 to either make no VPE resident or make a VPE of the new Security state resident.                                                                                                                                                       |
| I <sub>kwfrf</sub> | Following a write that sets ICH_CONTEXTR_EL2.V to 1, one of the following is true:                                                                                                                                                                                                                                                |
|                    | <ul> <li>The VPE becomes resident on the PE and ICH_CONTEXTR_EL2.F is set to 0.</li> <li>The VPE is not resident on the PE and ICH_CONTEXTR_EL2.F is set to 1.</li> </ul>                                                                                                                                                         |
| R <sub>NHCGW</sub> | While ICH_CONTEXTR_EL2.V is 1, if ICH_CONTEXTR_EL2.VM and ICH_CONTEXTR_EL2.VPE select an invalid VPE, all of the following are true:                                                                                                                                                                                              |
|                    | <ul> <li>The IRI behaves as if no VPE is resident on the PE.</li> <li>When a write updates ICH_CONTEXTR_EL2.V from 1 to 0, any doorbell request is ignored.</li> <li>It is CONSTRAINED UNPREDICTABLE whether a read of ICH_CONTEXTR_EL2.V returns 1 or 0.</li> </ul>                                                              |
|                    | See also 2.10.6 Requesting VPE doorbells.                                                                                                                                                                                                                                                                                         |
| $R_{TXVLW}$        | When ICH_CONTEXTR_EL2.V is 1, if the VPE selected by ICH_CONTEXTR_EL2.{VM,VPE} becomes invalid<br>and a new VPE selected by the same values subsequently becomes valid, it is CONSTRAINED UNPREDICTABLE<br>whether the IRI continues to behave as if no VPE is resident on the PE or as if the new VPE had been made<br>resident. |
| $R_{LLMWL}$        | The effect of setting ICH_CONTEXTR_EL2.V to 1 is not guaranteed to be visible until after a Context synchronization event. After the Context synchronization event, if any virtual interrupt from the IRI is visible by reading the CPU interface registers, it is for the new resident VPE.                                      |
| $R_{LJVNC}$        | The Context synchronization event after setting ICH_CONTEXTR_EL2.{V,IRICHPPIDIS} to {1,0} will not complete until the IRI has presented the candidate HPPI for the new resident VPE, or the IRI has confirmed there is currently no candidate HPPI for the new resident VPE.                                                      |
| I <sub>lxzbk</sub> | When using GICv5 Stream Protocol, when the IRS sends the $SetResident_Ack()$ packet it indicates that it has either forwarded the first virtual interrupt for the new resident VPE or that there is no candidate HPPI for the resident VPE.                                                                                       |
| R <sub>WDKXF</sub> | ICH_HPPIR_EL2 returns the HPPI for the Virtual Interrupt Domain.                                                                                                                                                                                                                                                                  |
|                    | If there is no resident VPE, or ICH_CONTEXTR_EL2.IRICHPPIDIS is 1, the value returned represents whether there is a candidate HPPI among the virtual PPIs.                                                                                                                                                                        |
|                    |                                                                                                                                                                                                                                                                                                                                   |

|                    | If there is a resident VPE, the value returned represents whether there is a candidate HPPI among the virtual PPIs and the virtual candidate HPPI presented by the IRI for the resident VPE.                                                                                                      |  |  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| R <sub>JSHCW</sub> | The effect of clearing ICH_CONTEXTR_EL2.V to 0, or setting ICH_CONTEXTR_EL2.IRICHPPIDIS to 1, is not guaranteed to be visible until after a Context synchronization event. After the Context synchronization event, no virtual interrupt from the IRI is visible via the CPU interface registers. |  |  |
| $R_{\rm VFKHN}$    | Changing the value of ICH_CONTEXTR_EL2.VM or ICH_CONTEXTR_EL2.VPE when ICH_CONTEXTR_EL2.V is 1 is CONSTRAINED UNPREDICTABLE with the following permitted behaviors:                                                                                                                               |  |  |
|                    | <ul> <li>The write is ignored, for all other purposes than a direct read of the register.</li> <li>The previously selected VPE is made not resident and the VPE identified by the new ICH_CONTEXTR_EL2.VM and ICH_CONTEXTR_EL2.VPE values is made resident.</li> </ul>                            |  |  |
| S <sub>QPFVS</sub> | To make a VPE no longer resident, software performs the following sequence:                                                                                                                                                                                                                       |  |  |
|                    | <ol> <li>Write ICH_CONTEXTR_EL2, clearing ICH_CONTEXTR_EL2.V from 1 to 0.<br/>ICH_CONTEXTR_EL2.DB controls whether a doorbell interrupt is requested for the previously resident<br/>VPE.</li> <li>Issue an ISB.</li> </ol>                                                                       |  |  |
|                    | To make a VPE resident, software performs the following sequence:                                                                                                                                                                                                                                 |  |  |
|                    | <ol> <li>Write ICH_CONTEXTR_EL2, setting ICH_CONTEXTR_EL2.V from 0 to 1.</li> <li>The ICH_CONTEXTR_EL2.VM and ICH_CONTEXTR_EL2.VPE fields specify which VPE is being<br/>made resident.</li> </ol>                                                                                                |  |  |
|                    | <ol> <li>The Domain for the VPE is taken from SCR_EL3.{NSE,NS}.</li> <li>Issue an ISB.</li> </ol>                                                                                                                                                                                                 |  |  |
|                    | <ol> <li>Optionally read ICH_CONTEXTR_EL2.F to check if the operation succeeded.</li> </ol>                                                                                                                                                                                                       |  |  |
|                    | To change the resident VPE, software must first ensure no VPE is resident, by performing the following sequence:                                                                                                                                                                                  |  |  |
|                    | <ol> <li>Write ICH_CONTEXTR_EL2, clearing ICH_CONTEXTR_EL2.V from 1 to 0.</li> <li>Write ICH_CONTEXTR_EL2, setting ICH_CONTEXTR_EL2.V from 0 to 1 and selecting the new resident VPE.</li> </ol>                                                                                                  |  |  |
|                    | <ol> <li>Issue an ISB.</li> <li>Optionally read ICH_CONTEXTR_EL2.F to check if the operation succeeded.</li> </ol>                                                                                                                                                                                |  |  |
| 2.10.6             | Requesting VPE doorbells                                                                                                                                                                                                                                                                          |  |  |
| D <sub>gfnfw</sub> | When a resident VPE is made non-resident, software can optionally request a VPE doorbell.                                                                                                                                                                                                         |  |  |
|                    | The VPE doorbell is a request for a physical interrupt to signal that there is a candidate HPPI for the VPE when the VPE is not resident on any PE.                                                                                                                                               |  |  |
| I <sub>QYLFV</sub> | When a VPE is made non-resident by writing 0 to ICH_CONTEXTR_EL2.V, software programs whether a VPE doorbell is requested by setting ICH_CONTEXTR_EL2.DB to the appropriate value.                                                                                                                |  |  |
| I <sub>rwsjw</sub> | When a write that sets ICH_CONTEXTR_EL2.V to 0 also sets ICH_CONTEXTR_EL2.DB to 0, any previously requested doorbells are no longer requested.                                                                                                                                                    |  |  |
| I <sub>gvgwj</sub> | ICH_CONTEXTR_EL2.DBPM allows software to specify a <i>VPE Doorbell priority mask</i> . If a VPE doorbell is requested, the corresponding physical interrupt is only signaled if the candidate HPPI for the VPE is greater than or equal to the value written to ICH_CONTEXTR_EL2.DBPM.            |  |  |
| R <sub>VNZRM</sub> | The mechanism to configure the interrupt used for the VPE doorbell is IMPLEMENTATION DEFINED.                                                                                                                                                                                                     |  |  |
|                    | When the GICv5 system architecture is used, the VPE doorbell configuration mechanism is described in 4.10.7 <i>VPE doorbells</i> .                                                                                                                                                                |  |  |

### 2.10.7 Legacy virtual CPU interface

| G <sub>VXDMK</sub> | GICv5 enables the use of unmodified GICv3.3 compatible virtual machines.                                                                                                                                                                                                                                                                                                                                          |  |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| I <sub>bsyyp</sub> | GICv5 provides the optional FEAT_GCIE_LEGACY extension to support GICv3.3 VMs.                                                                                                                                                                                                                                                                                                                                    |  |  |
| D <sub>QHKVW</sub> | When ICH_VCTLR_EL2.V3 is 1, Legacy operation is enabled.                                                                                                                                                                                                                                                                                                                                                          |  |  |
| R <sub>BFNZT</sub> | When FEAT_GCIE_LEGACY is not implemented, the Effective value of ICH_VCTLR_EL2.V3 is 0.                                                                                                                                                                                                                                                                                                                           |  |  |
| D <sub>TPCQT</sub> | When Legacy operation is enabled, the virtual CPU interface functionality is referred to as the Legacy virtual CPU interface.                                                                                                                                                                                                                                                                                     |  |  |
| I <sub>hkxpv</sub> | When FEAT_GCIE_LEGACY is implemented and Legacy operation is enabled, the Legacy virtual CPU interface is managed through the AArch64 virtualization control system registers described in <i>Arm<sup>®</sup> Generic Interrupt Controller Architecture Specification, GIC architecture version 3 and version 4</i> [3].                                                                                          |  |  |
| I <sub>JBZMP</sub> | When Legacy operation is disabled, the Effective value of ICH_HCR_EL2.En is 0 and the Legacy virtual CPU interface is disabled.                                                                                                                                                                                                                                                                                   |  |  |
|                    | When Legacy operation is enabled, ICH_HCR_EL2.En determines whether the Legacy virtual CPU interface is disabled.                                                                                                                                                                                                                                                                                                 |  |  |
|                    | The effects of enabling and disabling the GICv3 Virtual CPU interface using ICH_HCR_EL2.En is described in [3].                                                                                                                                                                                                                                                                                                   |  |  |
| I <sub>tqkbh</sub> | When HCR_EL2.IMO is 1 and Legacy operation is enabled, the Legacy virtual CPU interface is used and all of the following are true:                                                                                                                                                                                                                                                                                |  |  |
|                    | <ul> <li>When executing at EL1, all of the following are true: <ul> <li>All GICv5 System instructions are UNDEFINED.</li> <li>Accesses to GICv5 System registers are UNDEFINED.</li> <li>Accesses to GICv3.3 Group 0, Group 1, and Common System registers are to Legacy virtual CPU interface ICV_* registers.</li> </ul> </li> <li>Accesses to ICH_VMCR_EL2 use the GICv3.3 version of the register.</li> </ul> |  |  |
|                    | See Chapter 8 System instructions and Chapter 9 System registers for more information.                                                                                                                                                                                                                                                                                                                            |  |  |
| $R_{\rm YZMJH}$    | When executing at Exception levels below EL2 and Legacy operation is enabled, the Effective value of HCR_EL2.FMO is determined by HCR_EL2.IMO:                                                                                                                                                                                                                                                                    |  |  |
|                    | <ul> <li>When HCR_EL2.IMO is 0, the Effective value of HCR_EL2.FMO is 0.</li> <li>When HCR_EL2.IMO is 1, the Effective value of HCR_EL2.FMO is 1.</li> </ul>                                                                                                                                                                                                                                                      |  |  |
|                    | This means that when Legacy operation is enabled and executing at EL1, software either interacts entirely with the GICv5 physical CPU interface or entirely with the Legacy virtual CPU interface.                                                                                                                                                                                                                |  |  |
| I <sub>pjwmz</sub> | When Legacy operation is enabled, HCR_EL2.FMO enables GICv3.3 virtual Group 0 interrupts to be signaled as virtual FIQ interrupts.                                                                                                                                                                                                                                                                                |  |  |
| I <sub>nfjyv</sub> | FEAT_GCIE_LEGACY does not provide Interrupt bypass support as described in <i>Arm<sup>®</sup> Generic Interrupt Controller Architecture Specification, GIC architecture version 3 and version 4</i> [3]. Therefore, when Legacy operation is enabled, the ICC_SRE_EL1.{DIB,DFB} field values are RAO/WI.                                                                                                          |  |  |
| I <sub>LDWTK</sub> | FEAT_GCIE_LEGACY only provides a system register interface to the Legacy virtual CPU interface. Therefore, when Legacy operation is enabled, the ICC_SRE_EL1.SRE field value is RAO/WI.                                                                                                                                                                                                                           |  |  |
| R <sub>XXCLD</sub> | When Legacy operation is enabled, the ICV_CTLR_EL1.{ExtRange,RSS} field values are RAZ/WI.                                                                                                                                                                                                                                                                                                                        |  |  |
| I <sub>DQPYT</sub> | When FEAT_GCIE_LEGACY is implemented, if ICH_LR <n>_EL2.HW is set to 1, ICH_LR<n>_EL2.pINTID identifies a PPI in the Current Physical Interrupt Domain.</n></n>                                                                                                                                                                                                                                                   |  |  |
| I <sub>MTYHD</sub> | When FEAT_GCIE_LEGACY is implemented, ICH_VTR_EL2.SEIS and ICH_HCR_EL2.TSEI are RES0, meaning that local generation of system errors and trapping them to EL2 is not supported.                                                                                                                                                                                                                                   |  |  |
| I <sub>shbpg</sub> | When FEAT_GCIE_LEGACY is implemented, ICH_VTR_EL2.PRIbits and ICH_VTR_EL2.PREbits are 0b100, meaning that 5 bits of priority and preemption are available to GICv3 VMs.                                                                                                                                                                                                                                           |  |  |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |

I\_FPLXQGICv3 recorded the active priorities for Group 0 in ICH\_AP0R<n>\_EL2 and active priorities for Group 1 in<br/>ICH\_AP1R<n>\_EL2. In GICv5, the Legacy virtual CPU interface implements the same split, however the<br/>ICH\_AP1R0\_EL2.P<n> fields access the same state as the corresponding fields in ICH\_APR\_EL2.

See also:

- 9.2 CPU interface registers
- 9.6 Hypervisor control registers
- 9.7 Legacy hypervisor control registers

### 2.11 GIC synchronous exception priorities

- $I_{\text{FTLLT}}$  The relative priority of synchronous exceptions is described in R\_ZFGJP of the L.a version of *Arm*<sup>®</sup> *Architecture Reference Manual, for A-profile architecture*[1].
- R<sub>MJLRP</sub> Exceptions that occur as a result of attempting to execute an instruction that is UNDEFINED due to the configuration of ICH\_VCTLR\_EL2.V3 has a priority of 16.
- R<sub>KNQBS</sub> For an exception taken to EL2 as the result of a configuration control in one of the following registers, the exception priority is 22:
  - ICH\_HCR\_EL2.
  - ICH\_HFGITR\_EL2.
  - ICH\_HFGRTR\_EL2.
  - ICH\_HFGWTR\_EL2.

This is the same priority as exceptions due to the other fine-grained trap registers.

### 2.12 Interrupt ordering model and synchronization requirements

This section extends the Definitions of the Arm memory model in Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture[1].

#### **Interrupt Location**

An Interrupt Location comprises all state and configuration values relative to an interrupt. See 2.4 *Interrupt types and identifiers* for more information about interrupt state and configuration values. An Interrupt Location is uniquely identified by an INTID.

#### **Interrupt Effect**

GIC and GICR System instructions might generate Interrupt Effects. An Interrupt Effect is an Interrupt Read Effect or an Interrupt Write Effect. Interrupt Effects can be either Explicit or Implicit. For example, a GIC System instruction with the RCFG command generates an Explicit Interrupt Read Effect, a GICR System instruction generates Implicit Interrupt Read Effects and might also generate an Implicit Interrupt Write Effect.

All Interrupt Write Effects are required to complete in finite time.

- **Coherence order** There is a per-location *Coherence order* relation that provides a total order over all Interrupt Write Effects to that Location, starting with a notional Interrupt Write Effect of the initial value. The Coherence order of an Interrupt Location represents the order in which Interrupt Write Effects to the Interrupt Location arrive at their destination.
- **Reads-from** The *Reads-from* relation couples Interrupt Read and Write Effects to the same Interrupt Location so that each Interrupt Read Effect is paired with exactly one Interrupt Write Effect in the execution of a program. An Interrupt Read Effect  $E_2$  Reads-from an Interrupt Write Effect  $E_1$ , if and only if  $E_1$  and  $E_2$  are to the same Interrupt Location and  $E_2$  takes its data from  $E_1$ .

For two Effects  $E_1$  and  $E_2$  if all of the following apply:

- $E_1$  is an Explicit Interrupt Read Effect generated by a GIC instruction with the RCFG command.
- E<sub>1</sub> appears in program order before E<sub>2</sub>.
- E<sub>1</sub> and E<sub>2</sub> are to the same Interrupt Location.
- E<sub>2</sub> is an Interrupt Write Effect.

then it is architecturally forbidden that  $E_1$  Reads-from  $E_2$ .

**Coherence-before, Coherence-after** An Interrupt Write Effect  $E_1$  is *Coherence-before* an Interrupt Write Effect  $E_2$  to the same Interrupt Location if  $E_1$  is sequenced before  $E_2$  in the Coherence order for the Interrupt Location.

An Interrupt Read Effect  $E_1$  is *Coherence-before* an Interrupt Write Effect  $E_2$  to the same Interrupt Location if  $E_1$  Reads-from an Interrupt Write Effect  $E_3$  and  $E_3$  is Coherence-before  $E_2$ .

An Effect  $E_2$  is Coherence-after an Effect  $E_1$  if  $E_1$  is Coherence-before  $E_2$ .

For two Effects  $E_1$  and  $E_2$  if all of the following apply:

- E<sub>1</sub> is an Implicit Interrupt Write Effect generated by a GICR system instruction.
- E<sub>1</sub> appears in program order before E<sub>2</sub>.
- E<sub>1</sub> and E<sub>2</sub> are to the same Interrupt Location.
- E<sub>2</sub> is an Interrupt Read Effect.

then it is architecturally forbidden that  $E_2$  is Coherence-before  $E_1$ .

For two Effects  $E_1$  and  $E_2$  if all of the following apply:

- $E_1$  is an Implicit Interrupt Write Effect generated by a GIC system instruction with the DI command.
- E<sub>1</sub> appears in program order before E<sub>2</sub>.
- $E_1$  and  $E_2$  are to the same Interrupt Location.
- One of the following applies:
  - $E_2$  is an Explicit Interrupt Read Effect generated by a GIC system instruction with the RCFG command.
  - $E_2$  is an Implicit Interrupt Read Effect generated by a GICR system instruction.

then it is architecturally forbidden that  $E_2$  is Coherence-before  $E_1$ .

For two Effects  $E_1$  and  $E_2$  if all of the following apply:

- E<sub>1</sub> is an Explicit Interrupt Write Effect.
- E<sub>2</sub> is an Explicit Interrupt Read Effect.
- E<sub>1</sub> appears in program order before E<sub>2</sub>.
- E<sub>1</sub> and E<sub>2</sub> are to the same Interrupt Location.

then it is architecturally forbidden that  $E_2$  is Coherence-before  $E_1$ .

#### Successful Read-Modify-Write pair of Interrupt Effects

Two Effects E<sub>1</sub> and E<sub>2</sub> form a Successful Read-Modify-Write pair if and only if all of the following apply:

- E<sub>1</sub> is an Interrupt Read Effect.
- E<sub>2</sub> is an Interrupt Write Effect.
- E<sub>1</sub> and E<sub>2</sub> are to the same Interrupt Location.
- E<sub>1</sub> and E<sub>2</sub> are generated by the same instruction.

All Read-Modify-Write pair of Interrupt Effects generated by GIC and GICR System instructions are Successful Read-Modify-Write pairs of Interrupt Effects.

#### 2.12.1 GIC and GICR ordering semantics

 ISYSPH
 GIC System instructions generate Interrupt Effects as required by the instruction's command. The domain together with the INTID in <Xt> specify the Interrupt Location of the interrupt Effect.

A GIC System instruction with the EOI command does not generate any Interrupt Read Effects or Interrupt Write Effects.

A GIC System instruction with the RCFG command generates an Interrupt Read Effect but no Interrupt Write Effects.

All other GIC System instructions generate a Successful Read-Modify-Write pair of Interrupt Effects.

See 2.6 *GIC System instructions* for more information about the A64 assembly language syntax for the GIC System instructions.

R<sub>ZWSQL</sub>

- A GIC system instruction with the  ${\tt RCFG}$  command generates the following Effects:
  - A Register Read Effect  $E_1$  of the <Xt> register.
  - An Explicit Interrupt Read Effect  $E_2$  to the Interrupt Location determined by the domain and <Xt>.
  - An Indirect Register Write Effect E<sub>3</sub> to the System Register ICC\_ICSR\_EL1.
  - In addition, all of the following apply:
    - There is an Intrinsic Data Dependency from  $E_1$  to  $E_2$ .

| 2.12. | Interrupt ordering | model and | synchronization | requirements |
|-------|--------------------|-----------|-----------------|--------------|
|-------|--------------------|-----------|-----------------|--------------|

| R <sub>MLYCN</sub> | • A GIC system instruction with the DI command generates the following Effects:                                         |
|--------------------|-------------------------------------------------------------------------------------------------------------------------|
|                    | - A Register Read Effect $E_1$ of the <xt> register.</xt>                                                               |
|                    | - An Implicit Interrupt Read Effect $E_2$ to the Interrupt Location determined by the domain and <xt>.</xt>             |
|                    | - An Implicit Interrupt Write Effect $E_3$ to the Interrupt Location determined by the domain and <xt>.</xt>            |
|                    | In addition, all of the following apply:                                                                                |
|                    | - There is an Intrinsic Data Dependency from $E_1$ to $E_2$ .                                                           |
|                    | - There is an Intrinsic Data Dependency from $E_2$ to $E_3$ .                                                           |
|                    | - E <sub>2</sub> and E <sub>3</sub> form a Successful Read-Modify-Write pair.                                           |
| R <sub>XHKDN</sub> | • A GIC system instruction with a command other than RFCG, DI or EOI generates the following Effects:                   |
|                    | - A Register Read Effect $E_1$ of the <xt> register.</xt>                                                               |
|                    | - An Explicit Interrupt Read Effect $E_2$ to the Interrupt Location determined by the domain and <xt>.</xt>             |
|                    | - An Explicit Interrupt Write Effect $E_3$ to the Interrupt Location determined by the domain and <xt>.</xt>            |
|                    | In addition, all of the following apply:                                                                                |
|                    | - There is an Intrinsic Data Dependency from $E_1$ to $E_2$ .                                                           |
|                    | - There is an Intrinsic Data Dependency from $E_2$ to $E_3$ .                                                           |
|                    | – E <sub>2</sub> and E <sub>3</sub> form a Successful Read-Modify-Write pair.                                           |
| R <sub>FDSPZ</sub> | • A GICR system instruction with the IA or NMIA command generates the following Effects:                                |
|                    | - An Indirect System Register Read Effect $E_1$ to ICC_HAPR_ELx.                                                        |
|                    | - Implicit Interrupt Read Effect $E_2, E_3, \ldots, E_n$ to all n Interrupt Locations for the Current Interrupt Domain. |
|                    | - A Branching Effect $E_{n+1}$ that determines the HPPI.                                                                |
|                    | - If there is an HPPI and its priority is higher than the current running priority:                                     |
|                    | * An Implicit Interrupt Write Effect $E_{n+2}$ to the Interrupt Location determined as the HPPI.                        |
|                    | * An Indirect System Register Write Effect $E_{n+3}$ to ICC_HAPR_ELx.                                                   |
|                    | - A Register Write Effect $E_{n+4}$ of the $\langle Xt \rangle$ register.                                               |
|                    | In addition, all of the following apply:                                                                                |
|                    | - There is an Intrinsic Data Dependency from $E_2$ to $E_{n+1}$ .                                                       |
|                    | - There is an Intrinsic Data Dependency from $E_3$ to $E_{n+1}$ .                                                       |
|                    |                                                                                                                         |
|                    | - There is an Intrinsic Data Dependency from $E_n$ to $E_{n+1}$ .                                                       |
|                    | - There is an Intrinsic Control Dependency from $E_{n+1}$ to $E_{n+4}$ .                                                |
|                    | – If there is an HPPI and $E_k$ is the Interrupt Read Effect from its Interrupt Location:                               |
|                    | * There is an Intrinsic Data Dependency from $E_k$ to $E_{n+2}$ .                                                       |
|                    | * There is an Intrinsic Control Dependency from $E_{n+1}$ to $E_{n+2}$ .                                                |
|                    | * There is an Intrinsic Control Dependency from $E_{n+1}$ to $E_{n+3}$ .                                                |
|                    | * $E_k$ and $E_{n+2}$ form a successful Read-Modify-Write pair.                                                         |

### 2.12.2 GSB instruction semantics

D<sub>KZEML</sub> The A64 assembly language syntax for GIC synchronization barrier instructions is one of the following:

- GSB SYS
- GSB ACK

D<sub>DLHHZ</sub> A GSB instruction generates an Effect named after the instruction.

- A GSB SYS instruction generates a GSB SYS Effect.
- A GSB ACK instruction generates a GSB ACK Effect.

### 2.12.3 GIC Ordering Model

#### 2.12.3.1 GIC Ordering Relations

#### GIC-hazard-ordered-before

An Effect  $E_1$  is GIC-hazard-ordered-before an Effect  $E_2$  if and only if all the following apply:

- $E_1$  is an Explicit Interrupt Read Effect generated by a GIC system instruction with the RCFG command.
- E<sub>1</sub> appears in program order before E<sub>3</sub>.
- E<sub>1</sub> and E<sub>3</sub> are to the same Interrupt Location.
- E<sub>3</sub> is an Interrupt Read Effect.
- E<sub>3</sub> is Coherence-before E<sub>2</sub>.
- E<sub>2</sub> is an Explicit Interrupt Write Effect.

If an Effect  $E_1$  is GIC-hazard-ordered-before an Effect  $E_2$  then  $E_1$  is Hazard-ordered-before  $E_2$ .

**GSB-ordered-before** An Effect  $E_1$  is GSB-ordered-before an Effect  $E_2$  if and only if any of the following apply:

- All of the following apply:
  - E<sub>1</sub> is an Implicit Interrupt Effect generated by a GICR system instruction.
  - E<sub>3</sub> is a GSB ACK Effect.
  - $E_1$  appears in program order before  $E_3$ .
  - $E_3$  appears in program order before  $E_2$ .
  - It is not the case that E2 is an Implicit Instruction Memory Read Effect.
- All of the following apply:
  - E<sub>1</sub> is an Interrupt Effect.
  - E<sub>3</sub> is a GSB SYS Effect.
  - $E_1$  appears in program order before  $E_3$ .
  - $E_3$  appears in program order before  $E_2$ .
  - It is not the case that E2 is an Implicit Instruction Memory Read Effect.

If an Effect  $E_1$  is GSB-ordered-before an Effect  $E_2$  then  $E_1$  is Locally-ordered-before  $E_2$ .

If an Effect  $E_1$  is GSB-ordered-before an Effect  $E_2$ ,  $E_2$  is an Instruction Fetch Barrier Effect and  $E_2$  is in program-order before  $E_3$  then  $E_1$  is Instruction-fetch-barrier-ordered-before  $E_3$ .

### 2.12.3.2 Adaptations to existing Ordering relations

The following relations are defined in the chapter "Ordering requirements defined by the formal concurrency model" in *Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture*[1] and adapted to account for the Interrupt Read or Write Effects.

- **Basic Dependency** There is a Basic dependency from an Effect E1 to an Effect E2 if and only if all the following apply:
  - Any of the following applies:
    - E1 is an Explicit Memory Read Effect.
    - E1 is an Interrupt Read Effect.
    - E1 is a Register Read Effect.
  - Any of the following applies:
    - There is a Dependency through registers and memory from E1 to E2.
    - E1 and E2 are the same Effect.
- **Data dependency** There is a Data dependency from an Effect  $E_1$  to an Effect  $E_2$  if and only if all the following apply:
  - Any of the following applies:
    - E<sub>1</sub> is an Explicit Memory Read Effect.
    - E<sub>1</sub> is an Interrupt Effect.
  - There is a Basic dependency from  $E_1$  to  $E_3$ .
  - E<sub>3</sub> affects the data value written by E<sub>2</sub>.
  - There exists a chain of Intrinsic Data Dependency from  $E_3$  to  $E_2$ .
  - E<sub>2</sub> is an Explicit Memory Write Effect.
  - It is not the case that  $E_1$  and  $E_2$  are generated by the same instruction.

#### Address dependency

There is an Address dependency from an Effect  $E_1$  to an Effect  $E_2$  if and only if all the following apply:

- Any of the following applies:
  - E<sub>1</sub> is an Explicit Memory Read Effect.
  - $E_1$  is an Interrupt Read Effect.
- There is a Basic dependency from E<sub>1</sub> to E<sub>3</sub>.
- E<sub>3</sub> affects the address of the Location accessed by E<sub>2</sub>.
- There exists a chain of Intrinsic data dependency from E<sub>3</sub> to E<sub>2</sub>.
- Any of the following applies:
  - E<sub>2</sub> is an Explicit Memory Effect.
  - E<sub>2</sub> is an Implicit Tag Memory Read Effect.
  - E<sub>2</sub> is an Implicit TTD Memory Read Effect.
  - E<sub>2</sub> is a Hardware Update Effect.
  - E<sub>2</sub> is a TLBI Effect.
  - E<sub>2</sub> is a DC CVAU Effect.

- E<sub>2</sub> is an IC IVAU Effect.
- E<sub>2</sub> is an Interrupt Effect
- It is not the case that  $E_1$  and  $E_2$  are generated by the same instruction.
- **Control dependency** There is a Control dependency from an Effect  $E_1$  to an Effect  $E_2$  if and only if all the following apply:
  - Any of the following applies:
    - E<sub>1</sub> is an Explicit Memory Read Effect.
    - $E_1$  is an Interrupt Effect.
  - There is a Basic dependency from  $E_1$  to  $E_3$ .
  - E<sub>3</sub> is a Conditional Branching Effect.
  - E<sub>3</sub> appears in program order before E<sub>2</sub>.
- **Pick Basic dependency** There is a *Pick Basic dependency* from an Effect  $E_1$  to an Effect  $E_2$  if and only if all the following apply:
  - Any of the following applies:
    - E<sub>1</sub> is an Explicit Memory Read Effect.
    - E<sub>1</sub> is a Register Read Effect.
    - $E_1$  is an Interrupt Effect.
  - Any of the following applies:
    - There is a Pick dependency through registers and memory from  $E_1$  to  $E_2$ .
    - $E_1$  and  $E_2$  are the same Effect.
- **Pick Data dependency** There is a Pick Data dependency from an Effect  $E_1$  to an Effect  $E_2$  if and only if all the following apply:
  - Any of the following applies:
    - E<sub>1</sub> is an Explicit Memory Read Effect.
    - E<sub>1</sub> is an Interrupt Read Effect.
  - There is a Pick Basic dependency from E<sub>1</sub> to E<sub>3</sub>.
  - E<sub>3</sub> affects the data value written by E<sub>2</sub>.
  - Any of the following applies:
    - There is an Intrinsic Data Dependency from  $E_3$  to  $E_2$ .
    - There is an Intrinsic Control Dependency from E<sub>3</sub> to E<sub>2</sub>.
    - There exists a chain of Intrinsic Data Dependency or Intrinsic Control Dependency from E<sub>3</sub> to E<sub>2</sub>.
  - E<sub>2</sub> is an Explicit Memory Write Effect.
  - It is not the case that  $E_1$  and  $E_2$  are generated by the same instruction.
- **Pick Address dependency** There is a Pick Address dependency from an Effect  $E_1$  to an Effect  $E_2$  if and only if all the following apply:
  - Any of the following applies:
    - E<sub>1</sub> is an Explicit Memory Read Effect.
    - $E_1$  is an Interrupt Read Effect.

- There is a Pick Basic dependency from  $E_1$  to  $E_3$ .
- $E_3$  affects the address of the Location accessed by  $E_2$ .
- There exists a chain of Intrinsic Data Dependency from  $E_3$  to  $E_2$ .
- Any of the following applies:
  - E<sub>2</sub> is an Explicit Memory Effect.
  - E<sub>2</sub> is an Implicit Tag Memory Read Effect.
  - E2 is an Implicit TTD Memory Read Effect.
  - E<sub>2</sub> is a Hardware Update Effect.
  - E<sub>2</sub> is a TLBI Effect.
  - E<sub>2</sub> is a DC CVAU Effect.
  - E<sub>2</sub> is an IC IVAU Effect.
  - E<sub>2</sub> is an Interrupt Read Effect.
- It is not the case that  $E_1$  and  $E_2$  are generated by the same instruction.
- **Pick Control dependency** There is a Pick Control dependency from an Effect  $E_1$  to an Effect  $E_2$  if and only if all the following apply:
  - Any of the following applies:
    - E<sub>1</sub> is an Explicit Memory Read Effect.
    - $E_1$  is an Interrupt Read Effect.
  - There is a Pick Basic dependency from  $E_1$  to  $E_3$ .
  - E<sub>3</sub> is a Conditional Branching Effect.
  - E<sub>3</sub> appears in program order before E<sub>2</sub>.

### 2.12.3.3 GIC Observation Relations

**GIC-observed-by** An Effect  $E_1$  is GIC-observed-by an Effect  $E_2$  if and only if any of the following apply:

- All of the following apply:
  - $E_1$  is an Interrupt Write Effect.
  - E<sub>2</sub> Reads-from E<sub>1</sub>.
  - E<sub>2</sub> is an Interrupt Read Effect.
- All of the following apply:
  - E<sub>1</sub> is an Explicit Interrupt Effect.
  - $E_1$  is Coherence-before  $E_2$ .
  - $E_1$  and  $E_2$  are from different Processing Elements.
  - E<sub>2</sub> is an Explicit Interrupt Write Effect.

If an Effect  $E_1$  is GIC-observed-by an Effect  $E_2$  then  $E_1$  is Observed-by  $E_2$ .

### 2.12.3.4 Ordering Requirements

#### Atomicity of Successful Read-Modify-Write pair of Interrupt Effects

For two Interrupt Effects  $E_1$  and  $E_2$  if and only if all the following apply:

- E<sub>1</sub> and E<sub>2</sub> form a successful Read-Modify-Write pair.
- There is an Interrupt Write Effect E<sub>3</sub>.

then it is not the case that  $E_1$  is Coherence-before  $E_3$  and  $E_3$  is Coherence-before  $E_2$ .

An architecturally well-formed execution must not exhibit a cycle in the Ordered-before relation as defined in the *Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture*[1] and extended by the definitions in this section GIC Ordering Model.

## 2.13 Effects on the Transactional Memory Extension

|                    | Mnemonic Instruction Behavior                                                                                                                                                                                                                 |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>gqwjm</sub> | While in Transactional state, the effect of GICv5 System instructions is:                                                                                                                                                                     |
| I <sub>XVVBP</sub> | Attempting to read or write any other GIC system register, including the PPI registers, in Transactional state fails the transaction with ERR cause.                                                                                          |
|                    | <ul> <li>ICC_HPPIR0_EL1</li> <li>ICC_HPPIR1_EL1</li> <li>ICC_PMR_EL1</li> <li>ICC_RPR_EL1</li> <li>ICV_PMR_EL1</li> </ul>                                                                                                                     |
|                    | If FEAT_GICv3 or FEAT_GCIE_LEGACY is implemented, the following system registers behave the same in Transactional state as Non-transactional state:                                                                                           |
|                    | <ul> <li>ICC_HAPR_EL1</li> <li>ICC_HPPIR_EL1</li> <li>ICC_PCR_EL3</li> <li>ICC_PCR_EL2</li> <li>ICC_PCR_EL3</li> <li>ICV_PCR_EL1</li> </ul>                                                                                                   |
| R <sub>rnkxd</sub> | If FEAT_GCIE is implemented, the following system registers behave the same in Transactional state as Non-transactional state:                                                                                                                |
|                    | <ul> <li>An unmasked interrupt delivered to a PE leads to the currently executing transaction on the PE to fail.</li> <li>Upon restoring DAIF and the GIC Priority Mask, the interrupt becomes masked again and will not be taken.</li> </ul> |
| R <sub>PVHGH</sub> | A transaction fails with IMP cause and INT set if both of the following happen:                                                                                                                                                               |
| I <sub>dngvs</sub> | Transactional code with sufficient privileges can change the value of DAIF or the GIC Priority Mask to mask or unmask interrupts.                                                                                                             |
|                    | <ul> <li>ICC_PCR_EL3 if in EL3.</li> <li>ICC_PCR_EL2 if in EL2.</li> <li>ICC_PCR_EL1 or ICV_PCR_EL1 if in EL0 or EL1.</li> </ul>                                                                                                              |
|                    | In GICv5, the GIC Priority Mask is:                                                                                                                                                                                                           |
|                    | <ul><li>ICC_PMR_EL1 if in EL2 or EL3.</li><li>ICC_PMR_EL1 or ICV_PMR_EL1 if in EL0 or EL1.</li></ul>                                                                                                                                          |
|                    | In GICv3 and GICv4, or in GICv5 when using legacy mode, the GIC Priority Mask is:                                                                                                                                                             |
| D <sub>nykmg</sub> | GIC Priority Mask is defined to mean the register containing the priority mask for the current interrupt regime.                                                                                                                              |
|                    | <ul> <li>If FEAT_GCIE is implemented, ICC_PCR_EL1, ICV_PCR_EL1, and ICC_PCR_EL3.</li> <li>If FEAT_GCIE_LEGACY is implemented, and ICV_PMR_EL1.</li> </ul>                                                                                     |
| R <sub>pfdpv</sub> | The following registers are added to the subset of AArch64 state included in a transaction checkpoint:                                                                                                                                        |
| I <sub>MCXXC</sub> | The Transactional Memory Extension (TME)[4] defines a set of features to support transactional memory on Armv9-A PEs. This section describes changes made by GICv5 to TME.                                                                    |

#### GSB GICv5 synchronization barrier Same effects as in non-transaction state.

I<sub>NCLRB</sub> The restriction on use of GIC and GICR in Transactional state means that an interrupt cannot be acknowledged, deactivated or re-configured inside a transaction. Additionally, software cannot perform a Priority drop inside a transaction. It also means that the configuration and state of an interrupt cannot be queried within a transaction.

## Chapter 3 GICv5 system architecture

|                    | This section defines the GICv5 system architecture, including its components and interrupt handling behavior.                                        |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| G <sub>BCPXN</sub> | The IRI manages LPIs and SPIs.                                                                                                                       |
|                    | If the PEs in the system implement EL2, the IRI tracks which VMs and VPEs are defined and maintains their virtual interrupt state.                   |
| I <sub>ckljj</sub> | This section describes an IRI implemented using the GICv5 system architecture.                                                                       |
| I <sub>YXYKQ</sub> | The GICv5 system architecture defines the following classes of system component:                                                                     |
|                    | <ol> <li>The Interrupt Routing Service (IRS).</li> <li>The Interrupt Translation Service (ITS).</li> <li>The Interrupt Wire Bridge (IWB).</li> </ol> |
|                    | Figure 3.1 shows an overview of the GICv5 system architecture.                                                                                       |

#### Chapter 3. GICv5 system architecture



Figure 3.1: System overview

D<sub>MZRCX</sub> A GICv5 system using the GICv5 system architecture comprises the following:

- One or more IRSs.
- Zero or more ITSs.
- Zero or more IWBs.
- IBFXPBA GICv5 system has optional support for GIC PMUs. See Chapter 7 GIC Performance Monitoring Unit (PMU)<br/>for more information.
- IZWPSS IRSs and ITSs rely on data structures stored in memory to manage the routing and translation of interrupts.

Software allocates memory for the data structures used by the IRSs and ITSs and configures these components using memory-mapped I/O interfaces.

- D<sub>QJPLJ</sub> An IRS supports the following types of incoming interrupt events from peripherals:
  - **Shared Peripheral Interrupts (SPIs)** SPIs are used for interrupt signals that are directly connected to the IRS, for example, using directly wired connections or via an IMPLEMENTATION DEFINED mechanism. SPIs do not rely on memory for storage and may be used for interrupts that must meet certain early boot, reliability, or real-time guarantees. Whether SPIs provide any guarantees of fixed latency is a property of a given implementation. The number of supported SPIs is a fixed property of a given implementation.
    - **Logical Peripheral Interrupts (LPIs)** LPIs are used for interrupt signals that are translated by an ITS and forwarded to the IRS as well as for VPE doorbells. LPIs are managed by the IRSs in the system and the state and configuration of the LPIs are stored in memory allocated by system software.

Software may also signal interrupts managed by the IRS, for example to support IPIs and software emulated peripherals. See 2.5 *Inter-Processor Interrupts* and 2.6 *GIC System instructions* for more information.

IDWZTMWhen an IRS detects or receives an interrupt event, it updates the Pending state of the LPI or SPI specified by the<br/>interrupt event INTID. An interrupt event can either set or clear the Pending state depending on the interrupt event<br/>type.

The IRS supports IPIs by allowing CPU Interfaces to send commands to the IRS to make an interrupt Pending.

The IRSs keep track of all Pending, Inactive, and Enabled interrupts and route them to the target PEs. An IRS forwards an interrupt to a PE if it meets the following criteria:

- The interrupt targets that PE, either directly or through 1ofN routing.
- The interrupt is Pending, Inactive, and Enabled.
- The interrupt has the highest priority among all interrupts that are Pending, Inactive, and Enabled for that PE.

A system can include one or more IRSs and an implementation manages shared interrupt state across IRSs. Each PE is connected to exactly one IRS and an IRS can be connected to multiple PEs. The GICv5 architecture does not define how multiple IRSs communicate with each other, for example in a multi-chip system. A system with multiple IRSs supports changing the affinity of an interrupt from a PE on one IRS to a PE on another IRS, without losing interrupt state or configuration.

The IRS also manages VM state, supports virtual interrupts, and manages VPE doorbells. The IRS uses data structures stored in memory to manage the state of interrupts and configuration of VMs and VPEs.

- An ITS provides translation of incoming interrupt events into LPI INTIDs and forwards the translation results as interrupt events for an IRS. Interrupt events can be generated from wired interrupt signals connected to an IWB or from Message Signaled Interrupts (MSIs) of other subsystems. For example, an ITS can translate MSIs generated by PCIe endpoints routed through an SMMU. It can also translate MSIs generated by other system-specific subsystems. ITS translations specify whether an event should be signaled as a physical interrupt or as a virtual interrupt that is injected directly into a VM. The ITS uses data structures stored in memory to perform translation of events.
- IAn IWB generates interrupt events from wired interrupt signals and forwards the events to an ITS. An IWBsupports both edge-triggered and level-sensitive wires, and associates each wired interrupt with a Security state.The GICv5 architecture supports systems with zero to any number of IWBs.
- $I_{WWTGL}$  The GICv5 system architecture maintains the Arm CPU architecture security guarantees. As in the PE architecture, the IRSs and ITSs can support multiple Security states and access to memory respect that each location in memory belongs to a separate PAS. For a system that implements the Realm Management Extension (RME), this means all accesses are subject to Granule Protection Checks (GPCs). The GPC mechanism can be implemented in various ways and are outside the scope of this document. Even though the GPC is shown in Figure 3.1 as occurring downstream from the ITS and IRS, it is possible to leverage the SMMU GPC mechanism for this purpose. See *Arm<sup>®</sup> System Memory Management Unit Architecture Specification, SMMU architecture version 3*[5] for more information.

Memory-mapped accesses to the IWB, ITS, and IRS registers are also subject to PAS filtering[6]. PAS filtering For the IWB occurs at the level of individual registers. PAS filtering for the ITS and IRS is performed at page granularity, either internally or externally to the component.

## 3.1 Interrupt Domains

- $I_{LTWNQ}$  In a GICv5 system, the supported Interrupt Domains depend on the Security states implemented by the PEs. See 2.3 *Interrupt Domains* for more information.
- IZGKPPEach GICv5 system component may implement support for a subset of the Interrupt Domains supported by the<br/>PEs, except from the IRS, which implements support for the same set Interrupt Domains as the connected PEs.<br/>See 4.3 IRS Domains for more information.

Note

Implementing different Security state configurations across PEs in a system is not supported. This restriction exists for reasons outside the scope of this specification See [2] for more information.

R<sub>VDTVW</sub> A Physical Interrupt Domain is associated with a Security state and a PAS:

| Physical Interrupt Domain | Security state | PAS        |
|---------------------------|----------------|------------|
| Non-secure                | Non-secure     | Non-secure |
| Secure                    | Secure         | Secure     |
| Realm                     | Realm          | Realm      |

When the EL3 Interrupt Domain is supported, it is either associated with the Secure or Root Security state and PAS as follows:

| Supported Security states       | EL3 Interrupt Domain Security state | EL3 Interrupt Domain PAS |
|---------------------------------|-------------------------------------|--------------------------|
| Non-secure, Secure              | Secure                              | Secure                   |
| Non-secure, Realm, Root         | Root                                | Root                     |
| Non-secure, Realm, Secure, Root | Root                                | Root                     |

I<sub>KGBSN</sub>

The PAS associated with a Physical Interrupt Domain is used in the following scenarios:

- When memory-mapped registers of the IWB, ITS, and IRS are accessed, the PAS defines the Physical Interrupt Domain of the registers being accessed.
- When the ITS and IRS access data structures stored in memory, the access is always associated with a Physical Interrupt Domain and uses the PAS associated with that Physical Interrupt Domain.

If the GIC performs a memory access which fails a GPC, it experiences an external abort. The behavior for each GIC component is described in Chapter 4 *Interrupt routing service (IRS)* and Chapter 5 *Interrupt translation service (ITS)*.

D<sub>VJVNZ</sub> The GICv5 architecture defines the *Most Privileged Security State* (MPSS) and *Most Privileged PAS* (MPPAS) as follows:

| Supported Security states | MPSS       | MPPAS      |
|---------------------------|------------|------------|
| Non-secure                | Non-secure | Non-secure |
| Secure                    | Secure     | Secure     |

Chapter 3. GICv5 system architecture 3.1. Interrupt Domains

| Supported Security states       | MPSS   | MPPAS  |
|---------------------------------|--------|--------|
| Non-secure, Secure              | Secure | Secure |
| Non-secure, Realm, Root         | Root   | Root   |
| Non-secure, Realm, Secure, Root | Root   | Root   |

#### See also:

- 2.3 Interrupt Domains
- Chapter 4 Interrupt routing service (IRS)
- Chapter 5 Interrupt translation service (ITS)
- Chapter 6 Interrupt Wire Bridge (IWB)

## 3.2 Communication between GIC system components

| R <sub>zfcfx</sub> | The mechanisms used for communication between GICv5 system components are IMPLEMENTATION DEFINED.                                                                                                                                      |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | For example, the mechanism used by the ITS to send an interrupt message to the IRS is IMPLEMENTATION DEFINED.                                                                                                                          |
| D <sub>zfvzm</sub> | The architecture supports the following flows of events between GICv5 system components:                                                                                                                                               |
|                    | <ul><li>An IWB can send events to an ITS.</li><li>An ITS can send events to an IRS.</li></ul>                                                                                                                                          |
|                    | Each communication path involves a source and a destination.                                                                                                                                                                           |
|                    | When a source sends an event to the destination, the event is <i>Accepted</i> when the destination has sent a reply to the source confirming that it has received the event.                                                           |
|                    | An Accepted event is not guaranteed to have been handled by the destination. This means that all of the following are true:                                                                                                            |
|                    | <ul><li> If the destination is an ITS, an Accepted event is not guaranteed to have been translated by the ITS.</li><li> If the destination is an IRS, an Accepted event is not guaranteed to have been processed by the IRS.</li></ul> |
|                    | See also Chapter 3 GICv5 system architecture                                                                                                                                                                                           |
| I <sub>VFJSX</sub> | An event is always Accepted by the destination regardless of whether the destination is enabled or disabled.                                                                                                                           |
| I <sub>MNGPV</sub> | An example interconnect of two GICv5 system components is the AMBA® AXI Protocol Specification[7].                                                                                                                                     |
|                    | In this example, the source is a manager and the destination is a subordinate.                                                                                                                                                         |
|                    | The subordinate has Accepted an event when it has sent a Write Response to the manager.                                                                                                                                                |
|                    | Further, in this example, an ITS would send a Write Response to the IWB when the ITS has Accepted an event from the IWB.                                                                                                               |
|                    | In this example, it is assumed that transactions are not Bufferable. This means that AxCACHE[0] is deasserted and therefore no intermediate send a Read or Write Response to the manager.                                              |
| I <sub>MZDPH</sub> | The GICv5 Stream Protocol defines an optional standard interface between an IRS and a CPU interface.                                                                                                                                   |
|                    | The GICV5 Stream Protocol defines a two-way communication mechanism that does not rely on the concept of Accepted as defined in this specification.                                                                                    |
|                    | See Chapter A1 GICv5 Stream Protocol overview for more information.                                                                                                                                                                    |

## 3.3 Coherency considerations for GIC data structures

| D <sub>NCTBH</sub> | PEs and GIC system components communicate using shared data structures.                                                                                             |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>JPHKW</sub> | The GIC system components may be fully coherent with PE caches, IO-coherent, or not coherent.                                                                       |
|                    | Software must take actions to ensure that writes from the PE are visible to the GIC, and vice versa.                                                                |
| $S_{\text{MXSNW}}$ | Arm expects that firmware data structures describe to the OS or hypervisor whether the GIC is cache-coherent with PEs and is in the same Inner Shareability domain. |

 $I_{QGRVW}$  Arm recommends that all GIC system components are in the same Inner Shareability domain as the PEs.

## Chapter 4 Interrupt routing service (IRS)

 IBRKEW
 An IRS implements support for LPIs and SPIs. An IRS is either connected to one or more PEs, or it is stand-alone with no direct PE connections. A system can contain multiple IRSs.

The GICv5 architecture does not define the topological relationship between PEs and IRSs. Each PE is connected to exactly one IRS and an IRS can be connected to multiple PEs. An IRS can also be standalone and not be connected to any PE. This can be useful to support system topologies where an IRS and its associated ITS are located separately from PEs, allowing a more flexible routing of interrupts and power management of components close to the PE.

The mechanisms by which multiple IRSs communicate are IMPLEMENTATION DEFINED. The IRS stores interrupt state and configuration in memory provisioned to the IRS by software. In a system with multiple IRSs, the Affinity of an interrupt in an Interrupt Domain can be changed from a PE connected to an IRS to another one connected to another IRS, without losing interrupt state or configuration, if both IRSs can access the provisioned memory for that Interrupt Domain.

To support interrupt signaling in scenarios where memory is unavailable, such as during early boot, power transitions, or RAS handling, the IRS supports SPIs.

SPIs do not require a data structure allocated by software in order to be signaled, or to be managed and handled by PEs. Every SPI is assigned to an Interrupt Domain and the IRS exposes a programming interface to configure which Interrupt Domain an SPI is assigned to.

The IRS also provides support for virtual interrupts and manages VMs and VPEs. The IRS supports storing interrupt state and configuration in memory-backed data structures.

An IRS is responsible for:

• Generating SET\_EDGE, SET\_LEVEL, and CLEAR interrupt events for SPIs as a result of interrupts connected to the IRS being signaled.

- Receiving SET\_EDGE, SET\_LEVEL, and CLEAR interrupt events from ITSs for LPIs.
- Generating SET\_EDGE LPI interrupt events as a result of writes to the SETLPI register, if implemented.
- Selecting the physical candidate HPPIs among LPIs and SPIs for each PE connected to the IRS.
- Selecting the virtual candidate HPPIs among virtual LPIs and virtual SPIs for each resident VPE on PEs connected to the IRS.
- Delivering virtual and physical HPPIs to the CPU interface.
- Processing Interrupt Effects from GIC System instructions executed on PEs.
- Managing residency state of VPEs on PEs, including:
   Generating doorbell interrupts for non-resident VPEs.
- $I_{NZXZO}$  In this section, the term PE(s) refers to PE(s) connected to the IRS.
- I<sub>FZLBL</sub> Arm strongly recommends that all PEs connected to a GIC are application PEs running a common system software stack.

The architecture permits the PEs connected to an IRS to be a combination of application PEs and non-application PEs, as long as all PEs implement a GICv5 compliant CPU interface.

However, the GIC architecture does not provide features to provide isolation or prevent interference between equally privileged host software running in the same Interrupt Domain. Therefore, if the PEs connected to an IRS are running separate system software stacks, a mechanism to manage the shared IRS and other GIC components must be supported by system software.

- I<sub>QBJVX</sub> The IRSs replace parts of the functionality of the Redistributors and Distributors in GICv3.
- $I_{GCWBM}$  The IRS manages LPIs and SPIs.
- R<sub>FMTPZ</sub> When a system includes more than one IRS, each IRS supports the same number of interrupt ID bits for each interrupt type.
- R<sub>DRRHH</sub> Each PE is associated with exactly one IRS. Zero or more PEs can be connected to a single IRS.
- D<sub>LJQSX</sub> The IRS where an interrupt is signaled is referred to as the *local IRS* for that interrupt.

Similarly, the IRS that a PE is connected to is referred to as the *local IRS* for that PE.

D<sub>CHPRY</sub> A system with more than one IRS is referred to as a *multi-IRS system*.

## 4.1 Communication between the IRS and the CPU interface

- R<sub>HWCBT</sub>
   The mechanism for communication between a CPU interface in a PE and the local IRS is IMPLEMENTATION DEFINED.

   I<sub>NTXCC</sub>
   Arm recommends that an implementation uses the GICv5 Stream Protocol for communication between PEs and IRSs.

   See Chapter A1 *GICv5 Stream Protocol overview* for more information.

   I<sub>LTXQF</sub>
   Access to virtual interrupt configuration and state is made in the context of the resident VPE on the PE. When the PE switches the Current Physical Interrupt Domain, the PE and the IRS must ensure that software cannot access configuration and state for interrupts in the context of a VPE from the previous Physical Interrupt Domain. The GICv5 Stream Protocol avoids this by tagging all commands with the Physical Interrupt Domain.
- I SBMVWThe IRS manages the state and configuration of the LPIs and SPIs, and selects a candidate HPPI from among LPIs<br/>and SPIs for each Interrupt Domain for each connected PE. The PE selects the HPPI for each Interrupt Domain<br/>from the candidate HPPI and the PPIs managed in the PE.

## 4.2 Signaling interrupts

| D <sub>ydndd</sub> | An interrupt event is <i>processed</i> when the Interrupt Effects of the event are Ordered-before an Interrupt Read Effect to the Interrupt Location.                                                                                                                                                                                                                                                                                                                                               |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>klyxv</sub> | An interrupt is <i>signaled</i> to an IRS when one of the following events occurs:                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | <ul> <li>An interrupt connected to the IRS as an SPI is asserted or de-asserted and generates an interrupt event to change the Pending state of the SPI.</li> <li>An ITS associated with the IRS generates an interrupt event to change the Pending state of an LPI.</li> <li>A write to the IRS_SETLPI register occurs to set the Pending state of an LPI.</li> <li>The IRS <i>processes</i> Interrupt Effects of a GIC System instruction that sets the Pending state of an interrupt.</li> </ul> |
| R <sub>JVVSD</sub> | Updates to the Pending state of interrupts occur only in response to defined signaling events. Speculative updates are not permitted.                                                                                                                                                                                                                                                                                                                                                               |
| R <sub>QHGBY</sub> | The mechanism for signaling SPI interrupt events to the IRS is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                                                                                                                                                                                              |
| R <sub>mjnxl</sub> | The mechanism for communication between an ITS and the IRS is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                                                                                                                                                                                               |
| R <sub>fngrt</sub> | When multiple interrupt events of different types are generated for the same Interrupt Location, their Interrupt Effects are ordered in the same order in which the events are generated.                                                                                                                                                                                                                                                                                                           |
| R <sub>vgjbd</sub> | An interrupt event received from an ITS contains the following information:                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | <ul> <li>Interrupt Domain.</li> <li>Physical or virtual interrupt.</li> <li>VM ID for a virtual interrupt.</li> <li>LPI INTID.</li> <li>Event type: SET_EDGE, SET_LEVEL, or CLEAR.</li> </ul>                                                                                                                                                                                                                                                                                                       |
| R <sub>zhjmz</sub> | If more than one mapping for an LPI exists, either in a single ITS or across multiple ITSs, such that both mappings are capable of generating events for the same LPI to one or more IRSs concurrently, all of the following are true for events with multiple mappings:                                                                                                                                                                                                                            |
|                    | <ul> <li>The order in which the events are received by the IRSs is UNKNOWN.</li> <li>The order in which the events are processed by the IRSs is UNKNOWN.</li> <li>It is CONSTRAINED UNPREDICTABLE whether the IRS processes all the events or ignores some of the events.</li> </ul>                                                                                                                                                                                                                |
| R <sub>djdsy</sub> | The following sequence avoids the CONSTRAINED UNPREDICTABLE behavior caused by multiple concurrent ITS mappings to the same LPI:                                                                                                                                                                                                                                                                                                                                                                    |
|                    | <ol> <li>For each ITS where a mapping to the LPI exists, the following sequence is performed:         <ol> <li>The mapping is removed.</li> <li>A synchronization request is issued.</li> <li>A synchronization request is issued to the connected IRS.</li> </ol> </li> <li>A new mapping can be created on an ITS to the LPI.</li> </ol>                                                                                                                                                          |
|                    | See also 5.2.4 ITS synchronization requests and 4.5 IRS synchronization requests.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| I <sub>JNQGW</sub> | An IRS supports the following interrupt events generated for SPIs or received from ITSs to update the state and configuration of an interrupt:                                                                                                                                                                                                                                                                                                                                                      |
|                    | <ul><li>SET_EDGE.</li><li>SET_LEVEL.</li><li>CLEAR.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | An IRS supports the following interrupt events when processing Interrupt Effects of a GIC System instruction that sets the Pending state of an interrupt:                                                                                                                                                                                                                                                                                                                                           |
|                    | • SET.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

• CLEAR.

## Chapter 4. Interrupt routing service (IRS) 4.2. Signaling interrupts

|                    | When a write to IRS_SETLPI occurs, the IRS generates a SET_EDGE event locally for the specified LPI.                                                                                                                                                                                                                                                                                                          |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>HHKMN</sub> | When the IRS processes an interrupt event, there is an Interrupt Write Effect to the interrupt state as follows:                                                                                                                                                                                                                                                                                              |
|                    | <ul> <li>For a SET event, the interrupt Pending state is set to Pending.</li> <li>For a SET_EDGE event, the interrupt Handling mode is set to Edge and the Pending state is set to Pending.</li> <li>For a SET_LEVEL event, the interrupt Handling mode is set to Level and the interrupt Pending state is set to Pending.</li> <li>For a CLEAR event, the interrupt Pending state is set to Idle.</li> </ul> |
| I <sub>drnmd</sub> | As interrupts are asynchronous, the Interrupt Write Effects of an operation by a PE might be overwritten by a subsequent event received from the interrupt source.                                                                                                                                                                                                                                            |
|                    | For SPIs where the Trigger mode is level-sensitive and where an interrupt signal is physically connected to the SPI, updates to the Pending state from GIC System instruction executed on a PE are permitted to be ignored by the IRS, as the Pending state may be determined by the current state of signal.                                                                                                 |
| R <sub>qkyqm</sub> | When a mapping for an LPI exists and the mapping is for events generated by an IWB, and the events are for a wire that is configured as level-sensitive in the IWB, the IRS is permitted to generate a CLEAR event for the LPI when the ITS mapping is updated or when the wire is assigned to a different Interrupt Domain in the IWB.                                                                       |
| R <sub>dqtdv</sub> | The SET_EDGE and SET_LEVEL interrupt events generate the following Interrupt Write Effects:                                                                                                                                                                                                                                                                                                                   |
|                    | <ul> <li>An Interrupt Write Effect E<sub>1</sub> that updates the Handling mode.</li> <li>An Interrupt Write Effect E<sub>2</sub> that updates the Pending state.</li> </ul>                                                                                                                                                                                                                                  |
|                    | For these events, $E_1$ is Ordered-before $E_2$ .                                                                                                                                                                                                                                                                                                                                                             |
| I <sub>NFMBM</sub> | The IRS_SETLPI register can be used in a system that does not support virtualization to support MSIs without the use of an ITS.                                                                                                                                                                                                                                                                               |
|                    | A hypervisor can also emulate this architected functionality to allow a VM to program a device assigned to the VM to generate an MSI without requiring the hypervisor to emulate an ITS.                                                                                                                                                                                                                      |
| $R_{LCSNJ}$        | If an interrupt event specifies an unreachable INTID at the IRS where it is signaled, the event has no effect on any interrupt.                                                                                                                                                                                                                                                                               |
| I <sub>XZDTX</sub> | If an interrupt event specifies an unreachable INTID, and software error reporting is supported, this is reported with an appropriate error code in IRS_SWERR_STATUSR.                                                                                                                                                                                                                                        |
|                    | See also:                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | • 2.2 The GICv5 CPU interface                                                                                                                                                                                                                                                                                                                                                                                 |

• Chapter 5 Interrupt translation service (ITS)

Chapter 4. Interrupt routing service (IRS) 4.3. IRS Domains

### 4.3 IRS Domains

- R<sub>TCWZB</sub> The IRSs support interrupt routing and delivery with separate configurations for each supported Interrupt Domain.
- D<sub>LDYMZ</sub> The GICv5 architecture defines an *IRS Domain* that provides interrupt routing and management services for an Interrupt Domain. An IRS Domain comprises register state and interrupt configuration structures across all IRSs in the system. Each IRS Domain is configured independently from other IRS Domains. The IST and the VM table are shared between all IRSs for the same IRS Domain, but are not shared across IRS Domains. The data structures are accessed with the PAS associated with the IRS Domain.
- I<sub>FGLKF</sub> Figure 4.1 shows an overview of the IRS Domains and the register frames for each IRS Domain for a single-IRS system.



Figure 4.1: IRS Domains in a single-IRS system.

- R<sub>GSNPJ</sub> Each IRS implements a separate IRS Domain for each Security state supported by the PEs in the system. Every PE connected to an IRS implements the same set of Security states.
  - See 3.1 *Interrupt Domains* for more information about the relationship between Security states and Interrupt Domains.
- I<sub>KZGKR</sub> An IRS Domain is associated with the PAS of its corresponding Interrupt Domain.
- R<sub>XXWDT</sub> An IRS exposes separate IRS configuration register frames for each IRS Domain.
- I<sub>CKHSF</sub> The IRS Domain for an IRS configuration register frame is reported by IRS\_IDR0.INT\_DOM.
- I<sub>TCTJK</sub> A VM is associated with exactly one IRS Domain which defines the Security state of the VM and its virtual interrupts.

Similarly, the VPEs in the VM are associated with the IRS Domain and Security state of the VM.

For example, a VPE in a Non-secure VM receives Non-secure virtual interrupts, and a VPE in a Realm VM receives Realm virtual interrupts.

## Chapter 4. Interrupt routing service (IRS) 4.3. IRS Domains

R<sub>NKVFJ</sub> Each non-EL3 Physical Interrupt Domain has a separate namespace for Virtual Machines (VMs).

 R<sub>MHKVK</sub>
 VMs are supported for the Secure, Realm, or Non-secure Interrupt Domains. VMs are not supported in the EL3 Interrupt Domain.

See also:

• 3.1 Interrupt Domains

## 4.4 IRS Configuration

| R <sub>JJPMF</sub> | For each Interrupt Domain, each IRS exposes the following register frames:                                                                                                                                                                                     |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | • IRS_CONFIG_FRAME: An IRS configuration frame for settings that are common to all PEs connected to the IRS.                                                                                                                                                   |
|                    | • IRS_SETLPI_FRAME: If IRS_IDR0.SETLPI is 1, a SETLPI register frame.                                                                                                                                                                                          |
|                    | For each Interrupt Domain for each IRS, the IRS configuration register frame occupies a 64KB region in the system address space.                                                                                                                               |
|                    | For each Interrupt Domain for each IRS, if IRS_IDR0.SETLPI is 1, the IRS SETLPI register frame occupies a 64KB region in the system address space.                                                                                                             |
|                    | Each register frame is 64KB-aligned.                                                                                                                                                                                                                           |
|                    | See 10.2 IRS register frames for more information.                                                                                                                                                                                                             |
| I <sub>gvftm</sub> | There is at most one SETLPI register frame for each IRS for an Interrupt Domain.                                                                                                                                                                               |
| I <sub>MZDWR</sub> | The SETLPI register frame is not implemented when support for physical LPIs is not implemented.                                                                                                                                                                |
| S <sub>MTWNL</sub> | The base addresses of the IRS configuration frame and the IRS SETLPI register frame, if implemented, for each IRS and Interrupt Domain, are provided to software by firmware.                                                                                  |
| R <sub>QHDWM</sub> | The value of IRS_IDR0.SETLPI is the same for all IRSs and all Interrupt Domains in the system.                                                                                                                                                                 |
| I <sub>NCXKF</sub> | Each IRS has a unique IRSID which is reported in IRS_IDR0.IRSID. The IRSID is unique for each IRS in the system. The IRSID reported in IRS_IDR0.IRSID is the same for each IRS_CONFIG_FRAME that belongs the same IRS.                                         |
| I <sub>NRPRB</sub> | The number of PEs connected to an IRS is reported by IRS_IDR1.PE_CNT.                                                                                                                                                                                          |
| R <sub>frrgd</sub> | Every PE is assigned a unique PE interrupt Affinity ID across all IRSs in the system.                                                                                                                                                                          |
| R <sub>gskqz</sub> | The PE interrupt Affinity ID is the same across all implemented Interrupt Domains.                                                                                                                                                                             |
| R <sub>YBQML</sub> | If a system is reset with the same configuration, each PE has the same interrupt Affinity as before the reset.                                                                                                                                                 |
| I <sub>XDFPV</sub> | If a system is reset and reconfigured in a way that presents a different system, for example by physically partitioning IRSs and PEs in a different topology after the system reset, each PE may be assigned a new interrupt Affinity ID in the new topology.  |
| I <sub>CWCZR</sub> | The PE interrupt Affinity ID is reported by the PE in ICC_IAFFIDR_EL1.                                                                                                                                                                                         |
| I <sub>kzcqc</sub> | The PE interrupt Affinity ID is used to configure the target PE for Targeted interrupts.                                                                                                                                                                       |
|                    | It can also be used to discover which IRS a PE is connected to and vice versa.                                                                                                                                                                                 |
| I <sub>LXNBN</sub> | Information about each PE connected to an IRS may be accessed by writing to IRS_PE_SELR to select a PE and accessing the following registers:                                                                                                                  |
|                    | <ul><li>IRS_PE_STATUSR.</li><li>IRS_PE_CR0.</li></ul>                                                                                                                                                                                                          |
|                    | IRS_PE_STATUSR.IDLE reports whether the effects of a write to any of the above registers, including IRS_PE_SELR, have completed.                                                                                                                               |
|                    | IRS_PE_STATUSR.V reports whether the value written to IRS_PE_SELR selects a valid PE connected to the IRS.                                                                                                                                                     |
|                    | IRS_PE_CR0 provides access to configuration settings for the selected PE.                                                                                                                                                                                      |
| $\rm S_{HHSMP}$    | To configure a PE connected to an IRS, software performs the following sequence:                                                                                                                                                                               |
|                    | <ol> <li>Software selects the PE by writing to IRS_PE_SELR.</li> <li>Software polls IRS_PE_STATUSR.IDLE until it reads as 1 and ensures that IRS_PE_STATUSR.V is 1.</li> <li>Software can access the configuration of a PE by accessing IRS_PE_CR0.</li> </ol> |

# Chapter 4. Interrupt routing service (IRS) 4.4. IRS Configuration

|                    | 4. If software wrote to the PE configuration register, software polls IRS_PE_STATUSR.IDLE until it reads as 1 to ensure the effects of the write are complete.                                                                                                                                                                                                                                                                                        |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>KCZYL</sub> | When an IRS is reset, each PE connected to the IRS is reset as follows:                                                                                                                                                                                                                                                                                                                                                                               |
|                    | • If the IRS supports 1ofN interrupt routing, 1ofN PE selection is enabled for the PE.                                                                                                                                                                                                                                                                                                                                                                |
| I <sub>PPXSP</sub> | The configuration of each PE at IRS reset is consistent with a read of IRS_PE_CR0.DPS returning 0 when the PE is selected in IRS_PE_SELR and there was no write to IRS_PE_CR0 since the reset.                                                                                                                                                                                                                                                        |
| I <sub>MCXJN</sub> | Arm expects that firmware describes the association of PEs to an IRS to system software using firmware data structures.                                                                                                                                                                                                                                                                                                                               |
|                    | The architecture also provides a mechanism for software to discover the association of PEs to an IRS which may be useful for system bring-up and debugging.                                                                                                                                                                                                                                                                                           |
| $S_{\text{BCBQP}}$ | Software can discover the association of IRSs and PEs by following this sequence:                                                                                                                                                                                                                                                                                                                                                                     |
|                    | <ol> <li>When a PE is powered on, software reads ICC_IAFFIDR_EL1 to obtain the Interrupt Affinity ID for that PE.</li> <li>For each IRS, software writes the Interrupt Affinity ID for that PE to IRS_PE_SELR and performs the following actions:         <ol> <li>Poll IRS_PE_STATUSR.IDLE until it reads as 1.</li> <li>Read IRS_PE_STATUSR.V. If the value returned is 1, the IAFFID specifies a valid PE connected to that</li> </ol> </li> </ol> |
|                    | IRS.<br>3. Otherwise, continue to the next IRS.                                                                                                                                                                                                                                                                                                                                                                                                       |
| I <sub>HTTRN</sub> | The number of supported IAFFID bits for physical interrupts is reported in IRS_IDR1.IAFFID_BITS.                                                                                                                                                                                                                                                                                                                                                      |
| R <sub>GCGDD</sub> | The number of supported IAFFID bits for physical interrupts is the same across all IRSs and Interrupt Domains.                                                                                                                                                                                                                                                                                                                                        |
| I <sub>ZFSNT</sub> | The number of supported IAFFID bits is sufficient to uniquely identify all physical PEs in the system.                                                                                                                                                                                                                                                                                                                                                |
| I <sub>kvxQw</sub> | The number of supported VPE ID bits for virtual interrupts is reported in IRS_IDR4.VPE_ID_BITS.                                                                                                                                                                                                                                                                                                                                                       |
| $R_{\text{NPTWH}}$ | When processing an Interrupt Write Effect generated by a GIC System instruction that updates the Affinity of an interrupt, all of the following are true:                                                                                                                                                                                                                                                                                             |
|                    | • If the interrupt is a physical interrupt, unimplemented upper bits of IAFFID above IRS_IDR1.IAFFID_BITS                                                                                                                                                                                                                                                                                                                                             |
|                    | <ul><li>are RES0.</li><li>If the interrupt is a virtual interrupt, unimplemented upper bits of IAFFID above IRS_IDR4.VPE_ID_BITS are RES0.</li></ul>                                                                                                                                                                                                                                                                                                  |
|                    | See 4.9.2 <i>The VPE table</i> for more information about the relationship between the IAFFID of a virtual interrupt and the VPE ID.                                                                                                                                                                                                                                                                                                                  |
| R <sub>QQCXG</sub> | When IRS_CR0.IRSEN is 1 and IRS_CR0.IDLE is 1, an IRS is <i>enabled</i> for the Interrupt Domain and the IRS selects a candidate HPPI for each connected PE for the Interrupt Domain, following the rules in this chapter.                                                                                                                                                                                                                            |
|                    | Otherwise, the IRS is <i>disabled</i> for the Interrupt Domain and the IRS does not select any candidate HPPI for the connected PEs for the Interrupt Domain.                                                                                                                                                                                                                                                                                         |
| I <sub>ZYYLL</sub> | An IRS can access data structures to which it has a valid pointer, irrespective of whether the IRS is enabled for the corresponding Interrupt Domain.                                                                                                                                                                                                                                                                                                 |
| $\rm S_{SMLQY}$    | To quiesce IRS accesses to IRS data structure, software makes the physical IST and VM table invalid, and polls the relevant status bits to ensure that all IRS memory accesses to these data structures have completed.                                                                                                                                                                                                                               |
| $R_{GQZNP}$        | An IRS processes incoming interrupt events irrespective of the value of IRS_CR0.IRSEN.                                                                                                                                                                                                                                                                                                                                                                |
| $R_{LKCZP}$        | An IRS processes Interrupt Effects generated by GIC System instructions, irrespective of the value of IRS_CR0.IRSEN.                                                                                                                                                                                                                                                                                                                                  |

 $I_{TQMVQ}$  Interrupts may need to be delivered to an IRS before the IRS has been enabled.

For example, an edge-triggered SPI may cause wake-up of an IRS that is in a low power mode and the signal should result in the Pending state of the SPI being updated as soon as the IRS is powered on.

See 4.11 IRS power management for more information.

See also:

- 2.6.1 LPI and SPI configuration
- 4.4.1 Enabling and disabling the IRS
- 4.6 Interrupt configuration and state
- 4.7 The interrupt state table (IST)
- 4.8 Physical interrupts
- 4.9 Virtualization data structures

#### 4.4.1 Enabling and disabling the IRS

R<sub>JHYGJ</sub> When a write to IRS\_CR0.IRSEN changes the value from 0 to 1, the IRS begins a transition from disabled to enabled for the Interrupt Domain.

The transition from disabled to enabled is complete when IRS\_CR0.IDLE is 1.

The transition from disabled to enabled completes in finite time.

Enabling an IRS does not affect the state and configuration of LPIs.

R<sub>SBXYL</sub> When a write to IRS\_CR0.IRSEN changes the value from 1 to 0, the IRS begins a transition from enabled to disabled for the Interrupt Domain.

The transition from enabled to disabled is complete when IRS\_CR0.IDLE is 1.

The transition from enabled to disabled completes in finite time.

When the transition from enabled to disabled is complete, for each candidate HPPIs that were previously selected by the IRS for connected PEs for the Interrupt Domain while the IRS was enabled, one of the following is true:

- The candidate HPPI is acknowledged by the PE before the IRS is disabled.
- The candidate HPPI is not acknowledged and is no longer selected as the candidate HPPI for the PE.
- I\_ZMIMZ
   The architecture allows enabling an IRS for an Interrupt Domain either before or after software provisions a valid physical IST. See 4.8.1 *Physical LPIs* for more information.

See also:

- 4.7 The interrupt state table (IST)
- 4.9 Virtualization data structures

### 4.5 IRS synchronization requests

R<sub>HHDTJ</sub> Software can request synchronization of interrupt events for the IRS Domain by writing 1 to IRS\_SYNCR.SYNC.

Writing 1 to IRS\_SYNCR.SYNC requests synchronization of interrupt events and ensures that the following events for the IRS Domain are processed:

- All interrupt events generated as a result of an SPI being asserted or de-asserted before the write to IRS\_SYNCR.
- All interrupt events Accepted by the IRS before the write to IRS\_SYNCR.
- All interrupt events generated as a result of a write to IRS\_SETLPI before the write to IRS\_SYNCR.
- All VPE doorbell events generated before the write to IRS\_SYNCR.

Following a write to IRS\_SYNCR.SYNC that requests synchronization, when IRS\_SYNC\_STATUSR.IDLE is 1, all of the following are true:

- Any Interrupt Write Effect  $E_1$  to an Interrupt Location from a processed event is Ordered-before an Interrupt Read Effect  $E_2$ , when all of the following are true:
  - There is a Memory Read Effect E<sub>3</sub> to IRS\_SYNC\_STATUSR that reads IRS\_SYNC\_STATUSR.IDLE is 0.
  - $E_1$  is Ordered-before  $E_3$ .
  - E<sub>3</sub> is Ordered-before E<sub>2</sub>.

See 2.12 *Interrupt ordering model and synchronization requirements* for more information about observability of Interrupt Effects by PEs.

#### Note

An interrupt that meets the candidate HPPI conditions after an interrupt event has been processed is not required to be acknowledged by an interrupt acknowledge instruction executed on a PE following an IRS synchronization request. This is because selecting the candidate HPPI is only required to happen in finite time. See 4.8.4 *Physical interrupt signaling* and 4.10.4 *Virtual interrupt signaling* for more information.

- I<sub>MJPSN</sub> An interrupt event generates the following Interrupt Write Effects:
  - If the interrupt event type is SET\_EDGE or SET\_LEVEL, an Interrupt Write Effect  $E_1$  that updates the Pending state and an Interrupt Write Effect  $E_2$  that updates the Handling mode.
  - If the interrupt event type is SET or CLEAR, an Interrupt Write Effect that updates the Pending state.

Software can use synchronization of events to ensure that interrupt events have been processed before repurposing an interrupt.

For example, if software disables a PCIe function, it can ensure that no additional Interrupt Effects originate from that function by performing the following sequence:

- 1. Ensure that all MSIs have completed from the PCIe function.
- 2. Issue a synchronization request to the ITS and poll for completion.
- 3. Issue a synchronization request to the IRS and poll for completion.

After this sequence, software can remove any old translations in the ITS and create new translations to the same INTID, knowing that Interrupt Effects to the INTID can only come from the new translations.

I<sub>MXYLG</sub> In a multi-IRS system, an IRS synchronization request applies to all IRSs in the system for the IRS Domain.

R<sub>ZPNFL</sub> If a write to IRS\_SYNCR occurs when IRS\_SYNC\_STATUSR.IDLE is 0 on any other IRS for the same IRS Domain, it is CONSTRAINED UNPREDICTABLE whether the write synchronizes any interrupt events.

See also:

• 3.2 Communication between GIC system components

Chapter 4. Interrupt routing service (IRS) 4.5. IRS synchronization requests

- Chapter 5 Interrupt translation service (ITS)
- 5.2.4 ITS synchronization requests

## 4.6 Interrupt configuration and state

| I <sub>JVVTZ</sub>   | The IRS manages the following states and configurations for each LPI and SPI:                                                                                                                                                                                                 |  |  |  |  |  |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                      | Pending.                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|                      | <ul><li>Active.</li><li>Enabled.</li></ul>                                                                                                                                                                                                                                    |  |  |  |  |  |
|                      | • Handling mode.                                                                                                                                                                                                                                                              |  |  |  |  |  |
|                      | • Priority.                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|                      | <ul><li>Routing mode.</li><li>Affinity.</li></ul>                                                                                                                                                                                                                             |  |  |  |  |  |
| I <sub>BWPPP</sub>   | The IRS further manages the following for each SPI:                                                                                                                                                                                                                           |  |  |  |  |  |
|                      | • Trigger mode.                                                                                                                                                                                                                                                               |  |  |  |  |  |
|                      | • Interrupt Domain assignment.                                                                                                                                                                                                                                                |  |  |  |  |  |
|                      | • VM assignment.                                                                                                                                                                                                                                                              |  |  |  |  |  |
| $D_{\mathrm{HJCLV}}$ | An INTID specifying an LPI or SPI is <i>reachable</i> if the INTID.ID is within the configured range for the interrupt type and if the IRS can access its configuration and state. Otherwise, the INTID is <i>unreachable</i> .                                               |  |  |  |  |  |
| $R_{PGDXN}$          | When the PE executes any of the following GIC System instructions to request the configuration of an unreachable INTID, the IRS indicates a failure in the response to the PE:                                                                                                |  |  |  |  |  |
|                      | • GIC CDRCFG.                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|                      | • GIC VDRCFG.                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|                      | • GIC LDRCFG.                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|                      | When the PE executes any other GIC System instruction that accesses the state and configuration of an unreachable INTID, there are no Interrupt Effects generated as a result of executing the instruction.                                                                   |  |  |  |  |  |
| I <sub>srpzd</sub>   | The maximum number of INTID.ID bits supported by an IRS is reported by IRS_IDR2.ID_BITS.                                                                                                                                                                                      |  |  |  |  |  |
| R <sub>svdyq</sub>   | The value of IRS_IDR2.ID_BITS is the same for all IRSs for all Interrupt Domains in the system.                                                                                                                                                                               |  |  |  |  |  |
| I <sub>YKSNC</sub>   | Arm recommends that an IRS supports a number of INTID.ID bits greater than or equal to the number of INTID.ID bits supported by the PEs connected to the IRS.                                                                                                                 |  |  |  |  |  |
| $R_{\rm BBZWX}$      | RBBZWX       If an IRS supports fewer INTID.ID bits than a connected PE and the PE that specifies an INTID.ID beyor         INTID.ID range supported by the IRS, the INTID specifies an unreachable interrupt.                                                                |  |  |  |  |  |
|                      | See also 2.6.1 LPI and SPI configuration.                                                                                                                                                                                                                                     |  |  |  |  |  |
| I <sub>GTVLX</sub>   | Support for physical LPIs is optional. Whether the IRS supports physical LPIs is reported in IRS_IDR2.LPI.                                                                                                                                                                    |  |  |  |  |  |
| I <sub>bndtt</sub>   | Arm recommends that IRSs in a system designed to run standard operating systems implements support for physical LPIs. If physical LPIs are not implemented, sufficient physical SPIs that are not connected to any interrupt sources must be implemented to be used for IPIs. |  |  |  |  |  |
| I <sub>ykqdj</sub>   | Arm expects that support for LPIs is required for GICv5 systems in a future version of the <i>Arm<sup>®</sup> Base System Architecture 1.0C</i> [2].                                                                                                                          |  |  |  |  |  |
| R <sub>MGQGH</sub>   | When the IRSs do not implement support for LPIs, there are no ITSs or IWBs in the system.                                                                                                                                                                                     |  |  |  |  |  |
| R <sub>rcgpt</sub>   | The value of IRS_IDR2.LPI is the same for all IRSs for all Interrupt Domains in the system.                                                                                                                                                                                   |  |  |  |  |  |
| I <sub>zkljr</sub>   | The minimum number of LPI INTID.ID bits supported by an IRS is reported in IRS_IDR2.MIN_LPI_ID_BITS.                                                                                                                                                                          |  |  |  |  |  |
|                      | Arm expects that most hardware implementations will not require a minimum number of LPI INTID.ID bits.<br>However, specifying a minimum number of LPI INTID.ID bits is useful for virtualization.                                                                             |  |  |  |  |  |
| R <sub>YHQLW</sub>   | The value of IRS_IDR2.MIN_LPI_ID_BITS is the same for all IRSs for all Interrupt Domains in the system.                                                                                                                                                                       |  |  |  |  |  |
| -                    |                                                                                                                                                                                                                                                                               |  |  |  |  |  |

# Chapter 4. Interrupt routing service (IRS) 4.6. Interrupt configuration and state

The definition of reachable and unreachable interrupts applies to both physical and virtual interrupts. IPQBVF The conditions for when a physical interrupt is reachable differ from when a virtual interrupt is reachable. See 4.8.1 *Physical LPIs* and 4.8.2 *Physical SPIs* for more information about when physical interrupts are reachable. See 4.10 Virtual interrupts for more information about when virtual interrupts are reachable. The Handling mode property of an interrupt controls whether the interrupt should be handled using edge-triggered R<sub>ZMRVR</sub> or level-sensitive semantics as follows: • When the interrupt Handling mode is Edge, the IRS clears the Pending state when the interrupt is acknowledged by the PE. • When the interrupt Handling mode is Level, the IRS does not clear the Pending state when the interrupt is acknowledged by the PE. The Priority property stores the Priority of an Interrupt. IXBVHV The number of implemented Priority bits in the IRS is reported by IRS\_IDR1.PRI\_BITS, and the minimum is 1 bit. IXWHLD The number of Priority bits supported may be different across Interrupt Domains. Some operating systems have requirements for a minimum number of interrupt priority levels. These requirements IFRYMO will be captured as part of the Arm<sup>®</sup> Base System Architecture 1.0C[2]. For each Interrupt Domain, the number of supported Priority bits for the Interrupt Domain is the same across all R<sub>TZYHS</sub> IRSs in the system.

## 4.7 The interrupt state table (IST)

| I <sub>LQMKQ</sub> | An Interrupt State Table (IST) is used by the IRS to store interrupt state and configuration.                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| D <sub>PDQBB</sub> | An IST uses either a linear or 2-level structure.                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|                    | For a linear IST, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|                    | <ul><li>The level 1 IST is omitted.</li><li>The IST consists of a single level 2 IST.</li></ul>                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| D <sub>XTNLJ</sub> | An IST is used to manage the state and configuration of interrupts in each of the following IST contexts:                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|                    | <ul> <li>Physical LPI IST context: Used to manage physical LPIs for each Interrupt Domain. See 4.8.1 <i>Physical LPIs</i> for more information.</li> <li>Virtual LPI IST context: Used to manage virtual LPIs for VMs. See 4.10.1 <i>Virtual LPIs</i> for more information.</li> <li>Virtual SPI IST context: Used to manage virtual SPIs for VMs. See 4.10.2 <i>Virtual SPIs</i> for more information.</li> </ul> |  |  |  |  |  |
| D <sub>VBJJZ</sub> | For a linear IST, the base address of the IST specifies the location of the level 2 IST.                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|                    | For a 2-level IST, the base address of the IST specifies the location of the level 1 IST.                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|                    | Figure 4.2 shows an overview of the linear and 2-level structure.                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |

Chapter 4. Interrupt routing service (IRS) 4.7. The interrupt state table (IST)



Figure 4.2: IST structure overview.

| $S_{\rm NWLKP}$    | Software is responsible for allocating the IST from memory in the PAS associated with the Interrupt Domain where the IST is used. |  |  |  |  |  |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| I <sub>MWLZJ</sub> | An IST is indexed using the INTID.ID for an interrupt within the configured range for the IST.                                    |  |  |  |  |  |  |
| D <sub>BXYVH</sub> | An IST is either considered valid or invalid.                                                                                     |  |  |  |  |  |  |
|                    | The mechanism that determines whether the IST is valid or invalid depends on the IST context used.                                |  |  |  |  |  |  |
|                    | When the IST transitions from being invalid to being valid, the IST becomes valid.                                                |  |  |  |  |  |  |
|                    | When the IST transitions from being valid to being invalid, the IST becomes invalid.                                              |  |  |  |  |  |  |
| I <sub>VVKXF</sub> | An IST is either valid or invalid across all IRSs.                                                                                |  |  |  |  |  |  |
| R <sub>SCLJY</sub> | When an IST is valid, the IRS Domain is permitted to access the IST for any reason, including speculative reads.                  |  |  |  |  |  |  |
|                    | When an IST is invalid, the IRS Domain does not access the IST.                                                                   |  |  |  |  |  |  |
| D <sub>XQVBD</sub> | An IST stores a number of INTIDs for a single INTID. Type.                                                                        |  |  |  |  |  |  |
|                    | The mechanism that determines the number of INTIDs stored in an IST depends on the IST context used.                              |  |  |  |  |  |  |

IXTPFF

context used. The configuration of an IST is controlled by the following parameters: INOBVH STRUCTURE Selects if the IST uses a linear or 2-level structure. **ID BITS** Selects how many INTIDs are stored in the IST. The number of INTIDs stored in the IST determines the size of the single level 2 IST when using a linear table and the size of the level 1 IST when using a 2-level table. The number of INTIDs stored in the IST also limits the supported size of each level 2 IST entry when the IRS stores metadata in the IST. L2SZ For a 2-level IST, selects the size of each level 2 IST. The number of INTIDs stored in each level 2 IST depends on the size of a level 2 IST entry. Arm recommends a linear IST is used when the total number of INTIDs can be stored in a single level 2 IST. Level 2 IST entry size Selects the size of each level 2 IST entry. The supported entry sizes depend on the number of INTIDs stored in the IST as well as the IRS requirements for storing metadata in the IST. See 4.7.4 IST metadata for more information. These parameters are programmed in a way that is specific to the IST context used. For the physical IST context, each parameter is programmed in the physical IST base and configuration registers. For the virtual IST context, each parameter is programmed in the VM table entry. See 4.8.1 Physical LPIs, 4.10.1 Virtual LPIs, and 4.10.2 Virtual SPIs for more information. The size of the IST is calculated based on the number of INTIDs and the size of each entry, including any metadata D<sub>TWFKY</sub> if implemented, as follows: • For a linear IST, the size of the level 2 IST is (Number of INTIDs) \* (Level 2 IST entry size). • For a 2-level IST, the size of the level 1 IST is ((Number of INTIDs) / (Level 2 IST size / Level 2 IST entry size)) \* (Level 1 IST entry size). IRS\_IDR2.IST\_LEVELS reports whether 2-level IST support is implemented. IOBVSN The value of IRS\_IDR2.IST\_LEVELS is the same for all IRSs for all Interrupt Domains in the system. R<sub>ZGTCN</sub> For a 2-level IST, an implementation may only implement support for a subset of the possible L2SZ values. The INCSITH supported L2SZ values are reported by IRS\_IDR2.IST\_L2SZ. The value of IRS\_IDR2.IST\_L2SZ is the same for all IRSs for all Interrupt Domains in the system. R<sub>HVLTJ</sub> I<sub>PSTQD</sub> Arm strongly recommends that an implementation implements the L2SZ values corresponding to the stage 1 and stage 2 translation granule sizes in the PEs in the same system. See also: • 4.8.1 Physical LPIs • 4.10.1 Virtual LPIs • 4.10.2 Virtual SPIs 4.7.1 Level 2 IST management A level 2 IST is considered *valid*, if the IST is valid and one of the following is true: D<sub>HMZZP</sub>

An IST is used to manage the state and configuration for each INTID in the configured interrupt range for the IST

- The IST uses a linear structure.
- The IST uses a 2-level structure and the corresponding L1\_ISTE.VALID is 1.

Otherwise, the level 2 IST is considered *invalid*.

# Chapter 4. Interrupt routing service (IRS) 4.7. The interrupt state table (IST)

| D <sub>LWRCC</sub> | A level 2 IST becomes valid in any of the following scenarios:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                    | <ul> <li>The IST uses a linear structure and the IST becomes valid.</li> <li>The IST uses a 2-level structure and any of the following occur: <ul> <li>A write to the level 2 IST map register for the IST context makes the level 2 IST valid.</li> <li>The IST becomes valid and the corresponding L1_ISTE.VALID is 1.</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| I <sub>XLXLR</sub> | The level 2 IST map register to use depends on the IST context used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|                    | See 4.8.1 Physical LPIs, 4.10.1 Virtual LPIs, and 4.10.2 Virtual SPIs for more information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| I <sub>ZDJBW</sub> | When a 2-level IST becomes valid, if L1_ISTE.VALID is 1 for more than one level 1 IST entry, more than one level 2 IST may become valid at the same time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| R <sub>CWRMM</sub> | When the IST is valid and uses a 2-level structure, if software writes to an invalid level 1 IST entry and sets L1_ISTE.VALID to 1, the behavior of the IRS Domain is UNPREDICTABLE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|                    | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| R <sub>lfymv</sub> | If software performs a write to any field in a valid level 1 IST entry, the IRS Domain behavior is UNPREDICTABLE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|                    | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| R <sub>ddpxh</sub> | To recover from UNPREDICTABLE behavior resulting from an incorrect write to a level 1 IST entry, the IST made invalid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| I <sub>fsytk</sub> | The architecture does not support making an individual level 2 IST invalid when using a 2-level structure for an IST.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| $R_{FKYJV}$        | When a write to the level 2 IST map register for the IST context makes the corresponding level 2 IST valid, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|                    | <ul> <li>The IRS generates the following Effects: <ul> <li>A Register Write Effect E<sub>1</sub> to the status register for the IST context which sets the IDLE field to 0.</li> <li>A Memory Write Effect E<sub>2</sub> to the Location corresponding to the level 1 IST entry which updates L1_ISTE.VALID from 0 to 1.</li> <li>A Register Write Effect E<sub>3</sub> to the status register for the IST context which sets the IDLE field to 1.</li> </ul> </li> <li>There is an Intrinsic order dependency from the Register Write Effect E<sub>1</sub> to the Register Write Effect E<sub>2</sub>.</li> <li>There is an Intrinsic order dependency from the Memory Write Effect E<sub>2</sub> to the Register Write Effect E<sub>3</sub>.</li> </ul> |  |  |  |  |  |
|                    | This means that if there is a Memory Read Effect $E_4$ which Reads-from the Register Write Effect $E_3$ , then $E_2$ is Ordered-before $E_4$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| ILNDTY             | When the IST is valid and uses a 2-level structure, a level 2 IST is made valid by the following sequence:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|                    | <ol> <li>Software writes the address of the new level 2 IST to L1_ISTE.L2_ADDR, with L1_ISTE.VALID remaining to be 0.</li> <li>Software writes to the level 2 IST map register for the IST context.</li> <li>The IRS performs a write to the level 1 IST entry that updates L1_ISTE.VALID from 0 to 1.</li> <li>The IRS reports that the effects of the write to the level 2 IST map register for the IST context are complete.</li> </ol>                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|                    | See 3.3 <i>Coherency considerations for GIC data structures</i> for more information about ensuring that memory accesses are coherent between the IRS and a PE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| R <sub>SDVFP</sub> | When the IST is valid and uses a 2-level structure, if software writes to the level 1 IST entry when the status register IDLE field is 0 for the IST context, it is CONSTRAINED UNPREDICTABLE whether the IRS writes back the entry using the updated or old level 1 IST entry value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|                    | The CONSTRAINED UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |

D<sub>XCRJV</sub> A level 2 IST *becomes invalid* when the IST becomes invalid.

### 4.7.2 Initialization of level 2 IST entries

| $R_{\rm LXJHZ}$    | When a level 2 IST becomes valid, the behavior is UNPREDICTABLE if all of the following are true:                                                                                                                                                |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>IRS_IDR2.ISTMD is 1.</li> <li>The metadata area of one or more level 2 IST entries are non-zero. See 4.7.4 <i>IST metadata</i> for more information about the metadata area.</li> </ul>                                                 |
|                    | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .              |
| $R_{\rm XJJYH}$    | To recover from UNPREDICTABLE behavior resulting from a level 2 IST containing non-zero metadata becoming valid, the IST is made invalid.                                                                                                        |
| I <sub>BNPSN</sub> | A level 2 IST with non-zero metadata may become valid as part of an IMPLEMENTATION DEFINED IRS restore mechanism. See 4.11 <i>IRS power management</i> and 4.7.4 <i>IST metadata</i> for more information.                                       |
| $R_{\rm ZFBKH}$    | When a level 2 IST becomes valid and L2_ISTE.HWU is not 0b00 for one or more level 2 IST entries, the behavior is UNPREDICTABLE.                                                                                                                 |
|                    | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .              |
| R <sub>XZWJX</sub> | To recover from UNPREDICTABLE behavior resulting from a level 2 IST containing entries with a non-zero HWU field becoming valid, the IST is made invalid.                                                                                        |
| I <sub>GXNWY</sub> | A level 2 IST with non-zero HWU values may become valid as part of an IMPLEMENTATION DEFINED IRS restore mechanism. See 4.11 <i>IRS power management</i> for more information.                                                                   |
| R <sub>gxljr</sub> | When a level 2 IST becomes valid and L2_ISTE.Pending is 1 for one or more level 2 IST entries, it is CONSTRAINED UNPREDICTABLE whether the INTID is selected as the candidate HPPI even though it meets the candidate HPPI conditions.           |
| I <sub>clsgt</sub> | If a level 2 IST containing entries with a non-zero Pending field becomes valid, once the corresponding interrupts are made Pending as a result of an interrupt being signaled, the IRS considers the interrupt when selecting a candidate HPPI. |
| $I_{\rm XBHGH}$    | See 4.8.4 <i>Physical interrupt signaling</i> and 4.10.4 <i>Virtual interrupt signaling</i> for more information about the candidate HPPI conditions.                                                                                            |
| I <sub>HMFBP</sub> | A level 2 IST containing Pending interrupts may become valid as part of an IMPLEMENTATION DEFINED IRS restore mechanism. See 4.11 <i>IRS power management</i> for more information.                                                              |
| $R_{\text{PFQHM}}$ | When a level 2 IST becomes valid, the behavior is UNPREDICTABLE if all of the following are true for one or more level 2 IST entries:                                                                                                            |
|                    | <ul> <li>L2_ISTE.IRM is 1.</li> <li>L2_ISTE.IAFFID is not 0.</li> </ul>                                                                                                                                                                          |
|                    | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .              |
| R <sub>vzcqm</sub> | To recover from UNPREDICTABLE behavior resulting from a level 2 IST containing entries with a non-zero lofN interrupt hint becoming valid, the IST is made invalid.                                                                              |
| I <sub>KJLYK</sub> | A level 2 IST containing non-zero 1ofN interrupt hints may become valid as part of an IMPLEMENTATION DEFINED IRS restore mechanism. See 4.11 <i>IRS power management</i> for more information.                                                   |

### 4.7.3 INTID state and configuration

## Chapter 4. Interrupt routing service (IRS) 4.7. The interrupt state table (IST)

| D <sub>ptgrk</sub> | For each INTID in the configured range for an IST, there is a corresponding level 2 IST entry, if the IST is and one of the following is true:                                                                                      |  |  |  |  |  |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                    | <ul><li>The IST uses a linear structure.</li><li>The IST uses a 2-level structure and the level 2 IST is valid.</li></ul>                                                                                                           |  |  |  |  |  |  |
|                    | Otherwise, there is no level 2 IST entry corresponding to the INTID.                                                                                                                                                                |  |  |  |  |  |  |
| R <sub>rfgxl</sub> | When a level 2 IST becomes valid, the configuration of each INTID is consistent with the values stored in the corresponding IST entry.                                                                                              |  |  |  |  |  |  |
| R <sub>rfxnd</sub> | When the IST is valid, the state and configuration of each INTID in the configured range for the IST are coherent across all IRSs.                                                                                                  |  |  |  |  |  |  |
| R <sub>NQXGQ</sub> | After a level 2 IST becomes valid, the values stored in the level 2 IST entries are UNKNOWN.                                                                                                                                        |  |  |  |  |  |  |
|                    | The values stored in the level 2 IST entries remain UNKNOWN after the IST becomes invalid.                                                                                                                                          |  |  |  |  |  |  |
| R <sub>btymb</sub> | If software performs a write to a level 2 IST entry when the IST is valid, the behavior is UNPREDICTABLE.                                                                                                                           |  |  |  |  |  |  |
|                    | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> . |  |  |  |  |  |  |
| $R_{\rm XLYLQ}$    | To recover from UNPREDICTABLE behavior resulting from an incorrect write to a level 2 IST entry, the IST is made invalid.                                                                                                           |  |  |  |  |  |  |

### 4.7.4 IST metadata

| I <sub>rcftt</sub> | IRS_IDR2.ISTMD reports whether an IRS stores metadata in the level 2 IST entries.                                                                                                            |  |  |  |  |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| D <sub>JKSZH</sub> | If an IRS stores metadata in the level 2 IST entries, the bytes containing the metadata is called the metadata area.                                                                         |  |  |  |  |
| R <sub>WDNFJ</sub> | The value of IRS_IDR2.ISTMD is the same for all IRSs for each Interrupt Domain in the system.                                                                                                |  |  |  |  |
| I <sub>hpjwb</sub> | The size of a level 2 IST entry is 4 bytes, 8 bytes, or 16 bytes.                                                                                                                            |  |  |  |  |
|                    | If the size of a level 2 IST entry is more than 4 bytes, the higher address bytes are RESO.                                                                                                  |  |  |  |  |
|                    | The layout of the 4 lowest address bytes is defined by the architecture in 11.2.4 <i>L2_ISTE</i> , <i>Level 2 interrupt state table entry</i> .                                              |  |  |  |  |
| I <sub>CMFVK</sub> | The metadata area is stored in the highest address bytes of the IST entry.                                                                                                                   |  |  |  |  |
| I <sub>QRFDQ</sub> | IRS_IDR2.ISTMD_SZ describes the minimum number of INTID.ID bits which requires a level 2 IST entry size of 16 bytes to store metadata.                                                       |  |  |  |  |
| R <sub>THDPW</sub> | The value of IRS_IDR2.ISTMD_SZ is the same for all IRSs for all Interrupt Domains in the system.                                                                                             |  |  |  |  |
| I <sub>FFWQC</sub> | The minimum size of the level 2 IST entries used for the physical IST depends on the whether the IRS stores metadata in the level 2 IST entries and on the number of LPIs stored in the IST. |  |  |  |  |
|                    | IRS_IDR2.ISTMD reports whether the IRS stores metadata in the level 2 IST entries.                                                                                                           |  |  |  |  |
|                    | The minimum size of the level 2 IST entries is 4 bytes, 8 bytes, or 16 bytes as follows:                                                                                                     |  |  |  |  |
|                    | • If the IRS does not store metadata in the IST, the minimum size of the level 2 IST entries is 4 bytes.                                                                                     |  |  |  |  |

- If the IRS stores metadata in the IST and the number of INTID.ID bits is less than the value in IRS\_IDR2.ISTMD\_SZ, the minimum size of the level 2 IST entries is 8 bytes.
- If the IRS stores metadata in the IST and the number of INTID.ID bits is greater than or equal to IRS\_IDR2.ISTMD\_SZ, the minimum size of the level 2 IST entries is 16 bytes.

#### 4.7.5 Example IST structures

I<sub>SSCKN</sub> The size of a level 1 IST entry is 8 bytes and the size of a level 2 IST entry may scale with the number of INTIDs stored in the IST.

Table 4.1 shows some example IST structures for an implementation that does not require storing metadata in the IST and therefore the size of the level 2 IST entry does not scale with the configured number of INTIDs.

Table 4.2 shows some example IST structures for an implementation that requires storing metadata in the IST. The examples assume that the size of a level 2 IST entry is 8 bytes up to and including 16 bits of LPI ID, and 16 bytes for more than 16 bits of LPI ID.

S<sub>BRMDG</sub> The L1 size and L2 size columns in Table 4.1 and Table 4.2 indicate the required maximum physically contiguous allocation by software for the configuration.

| STRUCTURE LPI_ID_BITS L2_ISTE si |    | L2_ISTE size | L2SZ          | L1 size | L2 size | Maximum number of LPIs |
|----------------------------------|----|--------------|---------------|---------|---------|------------------------|
| Linear                           | 10 | 4 bytes      | -             | -       | 4 KB    | 1024                   |
| Linear                           | 14 | 4 bytes      | -             | -       | 64 KB   | 16,384                 |
| Linear                           | 16 | 4 bytes      | -             | -       | 256 KB  | 65,536                 |
| 2-level                          | 19 | 4 bytes      | 0b00, 10 bits | 4 KB    | 4 KB    | 524,288                |
| 2-level                          | 24 | 4 bytes      | 0b00, 10 bits | 128 KB  | 4 KB    | 16,777,216             |
| 2-level                          | 16 | 4 bytes      | 0b01, 12 bits | 128 B   | 16 KB   | 65,536                 |
| 2-level                          | 24 | 4 bytes      | 0b01, 12 bits | 32 KB   | 16 KB   | 16,777,216             |
| 2-level                          | 16 | 4 bytes      | 0b10, 14 bits | 32 B    | 64 KB   | 65,536                 |
| 2-level                          | 24 | 4 bytes      | 0b10, 14 bits | 8 KB    | 64 KB   | 16,777,216             |

#### Table 4.1: Example IST structures without metadata storage

#### Table 4.2: Example IST structures with metadata storage

| STRUCTU | RE LPI_ID_BITS | L2_ISTE size | L2SZ                 | L1 size | L2 size | Maximum number of LPIs |
|---------|----------------|--------------|----------------------|---------|---------|------------------------|
| Linear  | 9              | 8 bytes      | -                    | -       | 4 KB    | 512                    |
| Linear  | 13             | 8 bytes      | -                    | -       | 64 KB   | 8,192                  |
| Linear  | 16             | 8 bytes      | -                    | -       | 512 KB  | 65,536                 |
| 2-level | 16             | 8 bytes      | 0b00, 9 bits         | 1 KB    | 4 KB    | 65,536                 |
| 2-level | 17             | 16 bytes     | 0b00, 8 bits         | 4 KB    | 4 KB    | 131,072                |
| 2-level | 24             | 16 bytes     | 0b00, 8 bits         | 512 KB  | 4 KB    | 16,777,216             |
| 2-level | 16             | 8 bytes      | 0b01, 11 bits        | 256 B   | 16 KB   | 65,536                 |
| 2-level | 24             | 16 bytes     | 0b01, <b>10 bits</b> | 128 KB  | 16 KB   | 16,777,216             |
| 2-level | 16             | 8 bytes      | 0b10, <b>13 bits</b> | 64 B    | 64 KB   | 65,536                 |
| 2-level | 24             | 16 bytes     | 0b10, 12 bits        | 32 KB   | 64 KB   | 16,777,216             |

# Chapter 4. Interrupt routing service (IRS) 4.7. The interrupt state table (IST)

- IFor a 2-level IST, an implementation may only implement support for a subset of the possible L2SZ values. The<br/>supported L2SZ values are reported by IRS\_IDR2.IST\_L2SZ.
- R<sub>FVVBH</sub> The value of IRS\_IDR2.IST\_L2SZ is the same for all IRSs for all Interrupt Domains in the system.
- Immediate IRS\_IDR2.{MIN\_LPI\_ID\_BITS,ID\_BITS} report the range of valid values for IRS\_IST\_CFGR.LPI\_ID\_BITS. See also:
  - 11.2 IRS Data Structures

## 4.8 Physical interrupts

- D<sub>RVLFH</sub>
   Physical interrupts are interrupts that belong to a Physical Interrupt Domain.

   R<sub>ZQGCF</sub>
   A physical interrupt is only permitted to be selected as the candidate HPPI for the corresponding Physical Interrupt Domain.
- I<sub>NYGDM</sub> For a description of how the IRS supports virtualization, see 4.10 *Virtual interrupts*.

### 4.8.1 Physical LPIs

- The physical IST contains the configuration and state for the physical LPIs in an IRS Domain. R<sub>VWVXB</sub> When support for physical LPIs is not implemented, there is no physical IST. IRS\_IDR2.LPI reports whether IBHYYV support for physical LPIs is implemented. See 4.6 Interrupt configuration and state for more information. The number of LPIs in an IRS Domain is configured in IRS IST CFGR.LPI ID BITS. I<sub>X7.P.TV</sub> Software allocates the physical IST for an IRS Domain by writing a valid address to IRS\_IST\_BASER.ADDR and writing 1 to IRS\_IST\_BASER.VALID to make the IST valid. The physical IST is indexed using an INTID.ID value in the physical LPI range, from 0 to (2 ^ R<sub>QSXDB</sub> IRS IST CFGR.LPI ID BITS) - 1. When an IRS accesses the physical IST, the IRS does not access any memory location derived from an INTID R<sub>TXDPZ</sub> which is outside the configured LPI range. This includes situations where the INTID is programmed in the parameters of a GIC System instruction executed on a PE or the INTID is stored in the IST metadata areas. An INTID specifying an LPI in the Physical Interrupt Domain is reachable, if all of the following are true:  $R_{\rm LFZVT}$ • Support for physical LPIs is implemented. • The physical IST is valid. • There is a level 2 IST entry corresponding to the INTID. • The INTID is in the configured physical LPI range for the IRS Domain. Otherwise, the INTID is unreachable. In the physical LPI IST context, the base address of the physical IST for an IRS Domain is stored in I<sub>MZRSK</sub> IRS\_IST\_BASER.ADDR. In the physical LPI IST context, IRS\_IST\_BASER.VALID determines whether the physical IST is valid. IXCVJT A write to IRS IST BASER completes when IRS IST STATUSR.IDLE is 1. IKYYPW The architecture relies on making a physical IST valid or invalid to support the following software sequences:  $S_{\rm KMPNW}$ **Initial configuration after system reset** Software is expected to make the IST valid as part of the boot process. **Soft reboot** Software can reclaim the memory used for the IST by making the IST invalid. Making an IST valid or invalid is not intended to be used in power management sequences. See 4.11 IRS power management for more information about power management of an IRS. In a multi-IRS system, the physical IST is shared across all IRSs for an IRS Domain. IZRRXD The physical IST becomes valid when a write that updates IRS\_IST\_BASER.VALID from 0 to 1 completes. D<sub>MRGCV</sub> The physical IST becomes invalid when a write that updates IRS\_IST\_BASER.VALID from 1 to 0 completes. See 4.7 The interrupt state table (IST) for more information about an IST becoming valid and invalid. In a multi-IRS system, when a write to IRS\_IST\_BASER.VALID completes, a subsequent read of any of the R<sub>NSNNN</sub> following registers on any IRS in the IRS Domain returns the same value.
  - IRS\_IST\_BASER.

• IRS IST CFGR. If a write occurs to IRS\_IST\_BASER.VALID when IRS\_IST\_STATUSR.IDLE is 0 on any other IRS for the same R<sub>KLBCH</sub> IRS Domain, it is CONSTRAINED UNPREDICTABLE which configuration and base address is used for the IST. The CONSTRAINED UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the IRS Domain or in an access to memory that does not follow the behaviors described in 4.12 IRS memory access rules. When the physical IST becomes invalid and an LPI for the IRS Domain is selected as the candidate HPPI for a PE R<sub>SSTWT</sub> for the Interrupt Domain, one of the following is true: • The candidate HPPI is acknowledged by the PE before the IST becomes invalid. • The candidate HPPI is not acknowledged and is no longer selected as the candidate HPPI for the PE. When the physical IST becomes invalid, if there are Accepted events for physical LPIs that are not yet processed, R<sub>LJXGD</sub> all of the following are true: • The events are dropped and have no effect on any interrupt. • If software error reporting is supported, the IRS is permitted to report an error. When the physical IST is valid, all IRSs are permitted to access the physical IST for any reason, including IKQGDP speculative reads. When the physical IST is invalid, the IRSs do not access the physical IST. See 4.7 The interrupt state table (IST) for more information. The configuration of the physical IST is controlled using the following register fields: IJVVMS • IRS IST CFGR.STRUCTURE. • IRS\_IST\_CFGR.LPI\_ID\_BITS. IRS\_IST\_CFGR.L2SZ. IRS\_IST\_CFGR.ISTSZ. When IRS\_IDR2.IST\_levels is 0, IRS\_IST\_CFGR.STRUCTURE is RES0. IMBKRT ICLPKT IRS\_IDR2.{MIN\_LPI\_ID\_BITS, ID\_BITS} report the range of valid values for IRS\_IST\_CFGR.LPI\_ID\_BITS. In the physical LPI IST context, when the physical IST is valid and uses a 2-level structure, a physical level 2 IST ITOCYG is made valid by writing to IRS\_MAP\_L2\_ISTR. The effects of the write are complete when IRS IST STATUSR.IDLE is 1. If a write occurs to IRS\_MAP\_L2\_ISTR when IRS\_IST\_STATUSR.IDLE is 0 on any other IRS for the same IRS  $R_{\text{CMYTZ}}$ Domain, it is CONSTRAINED UNPREDICTABLE whether any effects of any of the writes complete successfully. See also: • 4.7 The interrupt state table (IST) • 11.2 IRS Data Structures 4.8.2 **Physical SPIs** 

 G<sub>BJJKB</sub>
 SPIs are designed to enable implementations to meet the following requirements:

 • SPIs can be used to connect interrupt signals directly to an IRS, without recourse to an ITS.

 • SPIs can generate interrupts to PEs without requiring memory being allocated to the IRS.

 • SPIs can reliably generate interrupts to PEs in the presence of memory system errors.

 • SPIs can be implemented to provide predictable low latency guarantees for interrupt delivery.

 • SPIs can be assigned to VMs to support system partitioning using virtualization techniques.

 R<sub>TLLZS</sub>

 The storage location for physical SPIs is IMPLEMENTATION DEFINED.

 I<sub>ZFRNY</sub>

 The number of SPIs across all IRSs in the system across all Interrupt Domains is reported by IRS\_IDR5.SPI\_RANGE.

| R <sub>kxmtr</sub> | The value reported by IRS_IDR5.SPI_RANGE is the same across all Interrupt Domains across all IRSs in a system.                                                                                                     |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>mhrzt</sub> | An INTID specifying an SPI in a Physical Interrupt Domain is reachable, when all of the following are true:                                                                                                        |
|                    | <ul> <li>The SPI is implemented.</li> <li>The SPI is assigned to the Interrupt Domain.</li> <li>The SPI is not assigned to a VM.</li> <li>The INTID.ID is less than or equal to IRS_IDR5.SPI_RANGE - 1.</li> </ul> |
|                    | Otherwise, the INTID is unreachable.                                                                                                                                                                               |
| I <sub>BVXHP</sub> | See 4.10.2.1 Assigning physical SPIs to VMs for more information about assigning an SPI to a VM.                                                                                                                   |
| I <sub>HZSKP</sub> | The configuration and state of a reachable SPI can be accessed via the GIC instructions on the PE.                                                                                                                 |
| D <sub>KZSTV</sub> | An SPI is <i>managed</i> by a single IRS.                                                                                                                                                                          |
|                    | This means that an SPI can be assigned to an Interrupt Domain and to a VM only on the IRS where the SPI is managed.                                                                                                |
| R <sub>VDLHR</sub> | Each SPI is identified by a unique INTID.                                                                                                                                                                          |
| I <sub>XYNMZ</sub> | The range of SPIs managed by an IRS is reported in IRS_IDR6.SPI_IRS_RANGE                                                                                                                                          |
|                    | If IRS_IDR6.SPI_IRS_RANGE is 0, the IRS does not manage any SPIs, and IRS_IDR7.SPI_BASE is RES0.                                                                                                                   |
|                    | The minimum INTID.ID of the SPIs managed by an individual IRS is reported by IRS_IDR7.SPI_BASE.                                                                                                                    |
|                    | The range of SPI INTIDs managed by the IRS can be calculated as IRS_IDR7.SPI_BASE + IRS_IDR6.SPI_IRS_RANGE - 1.                                                                                                    |
| I <sub>YMKMH</sub> | If IRS_IDR5.SPI_RANGE is 0, no SPIs are implemented on any IRS, and all of the following are true:                                                                                                                 |
|                    | <ul> <li>IRS_IDR6.SPI_IRS_RANGE is res0.</li> <li>IRS_IDR7.SPI_BASE is res0.</li> </ul>                                                                                                                            |
| R <sub>gcvxz</sub> | Not all SPIs in the range reported by IRS_IDR7.SPI_BASE and IRS_IDR6.SPI_IRS_RANGE are required to be implemented.                                                                                                 |
| R <sub>csqhp</sub> | The number reported by IRS_IDR6.SPI_IRS_RANGE is the same across all Interrupt Domains.                                                                                                                            |
|                    | The number reported by IRS_IDR7.SPI_BASE is the same across all Interrupt Domains.                                                                                                                                 |
| R <sub>zygst</sub> | For each IRS, all of the following are true for the range reported by IRS_IDR7.SPI_BASE and IRS_IDR6.SPI_IRS_RANGE:                                                                                                |
|                    | <ul> <li>The range does not overlap with the range reported by other IRSs in the system.</li> <li>The minimum and maximum SPI INTID included in the range are less than IRS_IDR5.SPI_RANGE.</li> </ul>             |
| I <sub>QNBQC</sub> | It is permitted to implement SPIs that are not connected to any interrupt input signal. Such SPIs can only be made Pending as a result of receiving a SET interrupt event from a PE.                               |
|                    | This may be useful to support IPIs without requiring the configuration and state for IPIs to be stored in memory.                                                                                                  |
|                    | See also 2.5 Inter-Processor Interrupts.                                                                                                                                                                           |
| R <sub>pdmtj</sub> | When an SPI is assigned to an Interrupt Domain, all of the following are true:                                                                                                                                     |
|                    | <ul><li>The SPI is only considered for a candidate HPPI in the Interrupt Domain that the SPI is assigned to.</li><li>The SPI is only reachable in the Interrupt Domain that the SPI is assigned to.</li></ul>      |
| I <sub>YTLRC</sub> | This means that an SPI is unreachable from any Interrupt Domain other than the SPI is assigned to.                                                                                                                 |
| D <sub>HWBBY</sub> | The <i>SPI IRS configuration</i> for each SPI consists of the following configurations, which are separate from the SPI INTID configuration and state:                                                             |
|                    | • The assignment of an SPI to an Interrupt Domain.                                                                                                                                                                 |

- The assignment of an SPI to a VM.
- The Trigger mode of the SPI.
- R<sub>ZYJHT</sub> The SPI IRS configuration for an SPI can be accessed from the following IRS Domains:
  - The IRS Domain correponding to the Interrupt Domain that the SPI is assigned to.
  - The EL3 IRS Domain.
- I<sub>SZZNP</sub>
   Software accesses the SPI IRS configuration state using one of the following registers after selecting an implemented

   SPI managed by the IRS:
   SPI managed by the IRS:
  - IRS\_SPI\_CFGR.
  - IRS\_SPI\_DOMAINR.
  - IRS\_SPI\_VMR.

Software selects an SPI by writing the SPI INTID to IRS\_SPI\_SELR.

IRS\_SPI\_STATUSR.IDLE reports whether the effects of a write to any of these registers is completed.

IRS\_SPI\_STATUSR.V reports whether the value written to IRS\_SPI\_SELR selects an implemented SPI that is managed by the IRS and where the configuration can be accessed in the IRS Domain.

IRS\_SPI\_STATUSR.V is updated on a write to any of the following registers:

- IRS\_SPI\_CFGR.
- IRS\_SPI\_SELR.
- IRS\_SPI\_VMR.

If an SPI is assigned to a new Interrupt Domain after being selected by IRS\_SPI\_SELR, then a subsequent write to any of the registers above in the old Interrupt Domain causes IRS\_SPI\_STATUSR.V to become 0.

IRSFPYWhen an SPI is selected using IRS\_SPI\_SELR and IRS\_SPI\_STATUSR.{V,IDLE} is {1,1}, IRS\_SPI\_CFGR.TMprovides access to the Trigger mode of the SPI.

The Trigger mode of an SPI determines when the IRS generates events for an SPI and defines the type of the events.

Following a write that updates IRS\_SPI\_CFGR.TM to 1, the effects of the write are complete when IRS\_SPI\_STATUSR. $\{V,IDLE\}$  is  $\{1,1\}$ .

See 4.6 Interrupt configuration and state for more information about the Handling mode.

 $R_{QBXXV}$  When the Trigger mode of an SPI is edge-triggered, the IRS generates a SET\_EDGE event when the interrupt signal connected to an SPI is asserted.

When the Trigger mode of an SPI is level-sensitive, the IRS generates a SET\_LEVEL event when the interrupt signal connected to an SPI is asserted and a CLEAR event when the signal is de-asserted.

The IRS does not generate a CLEAR event when the Trigger mode is edge-triggered and the signal is de-asserted.

I<sub>BGJKL</sub> For each SPI, it is IMPLEMENTATION DEFINED whether the Trigger mode can be programmed by software.

- If the Trigger mode cannot be programmed by software, access to the corresponding field is RO.
- S<sub>DCPVJ</sub> Software can detect that the Trigger mode of an SPI cannot be programmed by attempting to update the Trigger mode and reading it back. If the Trigger mode cannot be programmed, the Trigger mode is not updated.

R<sub>KBPXL</sub> When the Trigger mode of an SPI is updated from level-sensitive to edge-triggered and the interrupt signal is asserted, the IRS generates a CLEAR event for the SPI.

For an SPI connected to an interrupt signal, when the Trigger mode of the SPI is updated from edge-triggered to level-sensitive, the IRS generates a SET\_LEVEL event if the interrupt signal is asserted, and a CLEAR event if the signal is de-asserted.

For an SPI not connected to an interrupt signal, when the Trigger mode of the SPI is updated from edge-triggered to level-sensitive, the IRS generates a CLEAR event for the SPI.

When an update of the Trigger mode of an SPI generates an Interrupt Write Effect  $E_1$  to the SPI Interrupt Location, all of the following are true:

- There is a Register Write Effect E<sub>2</sub> to IRS\_SPI\_STATUSR which updates the IDLE field from 1 to 0.
- There is a Register Write Effect E<sub>3</sub> to IRS\_SPI\_STATUSR which updates the IDLE field from 0 to 1.
- There is an Intrinsic order dependency from the Register Write Effect  $E_2$  to the Interrupt Write Effect  $E_1$ .
- There is an Intrinsic order dependency from the Interrupt Write Effects E<sub>1</sub> to the Register Write Effect E<sub>3</sub>.

This means that if there is a Memory Read Effect  $E_4$  which Reads-from the Register Write Effect  $E_3$ , then  $E_1$  is Ordered-before  $E_4$ .

# R<sub>LKBBQ</sub> When the Trigger mode of an SPI is level-sensitive and connected to an interrupt input signal, the IRS is permitted to IGNORE SetPending commands received from PEs specifying that SPI.

D<sub>XKYXL</sub> A write to IRS\_SPI\_RESAMPLER causes the IRS to *resample* the signal connected to an SPI, if all of the following are true:

- The SPI is managed on the IRS where the write occurs.
- The SPI IRS configuration can be accessed in the IRS Domain where the write occurs.

Otherwise, the write has no effect beyond reporting a software error using EC 0x2B if supported.

#### R<sub>DMTFM</sub> When the signal of an SPI is resampled, all of the following are true:

- If the SPI Trigger mode is level-sensitive, all of the following are true:
  - If the signal is asserted at the time of the resample, the IRS generates a SET\_LEVEL event.
  - If the signal is de-asserted at the time of the resample, the IRS generates a CLEAR event.
- If the SPI Trigger mode is edge-triggered, all of the following are true:
  - If the signal is asserted at the time of the resample, the IRS generates a SET\_EDGE event.
  - If the signal is de-asserted at the time of the resample, the IRS generates no events.

# $R_{VYMHB}$ When a resample of an SPI generates an Interrupt Write Effects $E_1$ to the SPI Interrupt Location, all of the following are true:

- There is a Register Write Effect E<sub>2</sub> to IRS\_SPI\_STATUSR which updates the IDLE field from 1 to 0.
- There is a Register Write Effect E<sub>3</sub> to IRS\_SPI\_STATUSR which updates the IDLE field from 0 to 1.
- There is an Intrinsic order dependency from the Register Write Effect  $E_2$  to the Interrupt Write Effects  $E_1$ .
- There is an Intrinsic order dependency from the Interrupt Write Effects  $E_1$  to the Register Write Effect  $E_3$ .

This means that if there is a Memory Read Effect  $E_4$  which Reads-from the Register Write Effect  $E_3$ , then  $E_1$  is Ordered-before  $E_4$ .

S<sub>SNRXG</sub> Software may need to resample the state of an SPI to ensure that the Pending state of the SPI INTID corresponds to the state of the signal connected to the SPI. For example, if software has updated the Pending state or Handling mode of the SPI using GIC system instructions, it can use the resample mechanism to recover from this scenario.

Software may also need to resample an SPI if configuring the SPI for a source with level-sensitive semantics as Edge-triggered. In this case, software can resample the SPI after handling each event to ensure that interrupt events are not lost if the signal remained asserted while handling the interrupt.

D<sub>YGLYC</sub> The reset state of the SPI IRS configuration is the following:

- If the SPI Trigger mode can be programmed by software, it is reset to edge-triggered.
- The SPI is not assigned to a VM.
- The SPI is assigned to the Interrupt Domain corresponding to the MPSS supported by the IRS.

### D<sub>TVVRZ</sub> The *reset state of an SPI INTID* is the following:

- The interrupt is Disabled.
- The interrupt is Inactive.
- The interrupt is Idle.
- If 1ofN interrupt routing is not supported, the SPI Routing mode is Targeted.
- All other interrupt configuration and state are UNKNOWN.

| R <sub>QRHKF</sub> | When an IRS is reset, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul><li>All SPI INTIDs are reset to their reset state.</li><li>The IRS configuration for each SPI is reset to its reset state.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| $S_{\rm HZPVX}$    | To configure the assignment of an SPI to a VM, software performs the following sequence:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | <ol> <li>Software selects the SPI by writing to IRS_SPI_SELR.</li> <li>Software polls IRS_SPI_STATUS.IDLE until it reads as 1 and ensures that IRS_SPI_STATUS.V is 1.</li> <li>Software accesses the VM assignment of the SPI by accessing IRS_SPI_VMR.</li> <li>Following a write to IRS_SPI_VMR, software polls IRS_SPI_STATUS.IDLE until it reads as 1, and ensures that IRS_SPI_STATUS.V is 1, to ensure the effects of the write are complete.</li> </ol>                                                                                                                                                                    |
| $\rm S_{GQDWY}$    | To configure the assignment of an Interrupt Domain, software performs the following sequence using the EL3 Interrupt Domain IRS configuration frame:                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | <ol> <li>Software selects the SPI by writing to IRS_SPI_SELR.</li> <li>Software polls IRS_SPI_STATUS.IDLE until it reads as 1 and ensures that IRS_SPI_STATUS.V is 1.</li> <li>Software accesses the Interrupt Domain assignment of the SPI by accessing IRS_SPI_DOMAINR.</li> <li>Following a write to IRS_SPI_DOMAINR, software polls IRS_SPI_STATUS.IDLE until it reads as 1.</li> </ol>                                                                                                                                                                                                                                       |
|                    | To check whether an SPI is statically assigned to an Interrupt Domain or it can be dynamically assigned to an Interrupt Domain, software can attempt to update the assignment of the SPI to an Interrupt Domain and read back the assigned domain from IRS_SPI_DOMAINR.DOMAIN when IRS_SPI_STATUSR.IDLE is 1.                                                                                                                                                                                                                                                                                                                     |
| I <sub>DMFCZ</sub> | An SPI may be statically assigned to an Interrupt Domain.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| I <sub>bcqrt</sub> | Arm recommends only statically assigning SPIs to an Interrupt Domain when it is known that the interrupt can only be handled in that Domain. For example, RAS interrupts may be statically assigned to the EL3 Domain. Statically assigning interrupts to a Domain may restrict how that interrupt can be used. For example, static assignment may prevent the interrupt from being directly assigned to Realms.                                                                                                                                                                                                                  |
| R <sub>JJHJX</sub> | When an SPI is assigned to a new Interrupt Domain as a result of selecting the SPI by writing to IRS_SPI_SELR and writing to IRS_SPI_DOMAINR.DOMAIN, the effects of the write are complete when IRS_SPI_STATUSR.IDLE is 1.                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | When the effects are complete, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | • If the SPI was selected as the candidate HPPI for a PE in the old Interrupt Domain, one of the following is true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | <ul> <li>The SPI is acknowledged in the old Interrupt Domain before the SPI is assigned to the new Interrupt Domain.</li> <li>The SPI is not acknowledged in the old Interrupt Domain and no longer selected as the candidate HPPI in the old Interrupt Domain.</li> <li>If the SPI was assigned to a VM in the old Interrupt Domain, it is CONSTRAINED UNPREDICTABLE whether the configuration and state of the virtual SPI INTID is UNKNOWN or reset to its reset state.</li> <li>The SPI is not assigned to a VM in the new Interrupt Domain.</li> <li>The SPI is not assigned to a VM in the new Interrupt Domain.</li> </ul> |
|                    | See also:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | <ul> <li>3.1 Interrupt Domains</li> <li>4.6 Interrupt configuration and state</li> <li>4.7 The interrupt state table (IST)</li> <li>4.8.4 Physical interrupt signaling</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4.8.3              | Physical interrupt routing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

### 4.8.3 Physical interrupt routing

R<sub>LFYMS</sub> The Routing mode of a physical interrupt determines how the target PE is selected for the interrupt in the following ways:

• If the Routing mode is Targeted, the target PE is the PE specified by the interrupt Affinity.

|                    | • If the Routing mode is 1ofN, the target PE is determined dynamically.                                                                                                                                                                                                                           |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>vbqjg</sub> | When an interrupt Routing mode is Targeted and the interrupt Affinity specifies a PE, the interrupt is said to be <i>targeted to</i> that PE.                                                                                                                                                     |
| R <sub>hgpQH</sub> | IRS support for 1ofN interrupt routing is optional.                                                                                                                                                                                                                                               |
| D <sub>VPZNM</sub> | An interrupt whose Routing mode is <i>lofN</i> is referred to as a <i>lofN interrupt</i> .                                                                                                                                                                                                        |
| I <sub>GHKQS</sub> | IRS_IDR0.ONE_N reports whether 1ofN interrupt routing is supported.                                                                                                                                                                                                                               |
| R <sub>fgvhx</sub> | The value of IRS_IDR0.ONE_N is the same for all IRSs for all Interrupt Domains in the system.                                                                                                                                                                                                     |
| R <sub>zmtlr</sub> | If 1ofN interrupt routing is not supported, all of the following are true:                                                                                                                                                                                                                        |
|                    | <ul> <li>If a GIC System instruction generates an Interrupt Effect that updates the Routing mode of a physical interrupt, the Routing mode is set to Targeted regardless of the value provided in <xt>.</xt></li> <li>L2_ISTE.IRM is treated as 0 when the physical IST becomes valid.</li> </ul> |
| R <sub>gjngf</sub> | Each physical 1ofN interrupt can be acknowledged by at most one PE.                                                                                                                                                                                                                               |
| R <sub>STMZL</sub> | The storage location for the Affinity of physical 1ofN interrupts may be used for an IMPLEMENTATION DEFINED purpose to handle routing of physical 1ofN interrupts, with the restriction that an Affinity value of 0 has no IMPLEMENTATION DEFINED meaning.                                        |
| R <sub>QZWMR</sub> | An IRS is permitted to update the Affinity of physical 1ofN interrupts.                                                                                                                                                                                                                           |
| $R_{DJNNR}$        | A PE may only be selected as the target for a 1ofN interrupt, if 1ofN PE selection is enabled for the PE for the Interrupt Domain                                                                                                                                                                 |
| R <sub>CDXNW</sub> | An IRS Domain selects a target PE for a reachable 1ofN interrupt in finite time, when all of the following are true:                                                                                                                                                                              |
|                    | <ul> <li>The interrupt is Pending.</li> <li>The interrupt is Inactive.</li> <li>The interrupt is Enabled.</li> <li>At least one IRS is enabled.</li> <li>At least one PE connected to an enabled IRS has 1ofN PE selection enabled.</li> </ul>                                                    |
| R <sub>TMBZH</sub> | An IRS Domain may select a new target PE for a physical 1ofN interrupt at any time.                                                                                                                                                                                                               |
| I <sub>dbqsc</sub> | Selecting a target PE does not guarantee that the interrupt is selected as the candidate HPPI for the target PE. For example, the selected target PE may be masking the interrupt or another interrupt may be the candidate HPPI for the selected target PE.                                      |
|                    | See 4.8.4 <i>Physical interrupt signaling</i> for more information about selecting the physical candidate HPPI.                                                                                                                                                                                   |
| $R_{FYRLW}$        | The mechanism that an IRS uses to select a target PE among several possible target PEs is IMPLEMENTATION DEFINED.                                                                                                                                                                                 |
| I <sub>LZSJY</sub> | The architecture does not require that higher priority 1ofN interrupt are delivered before lower priority 1ofN interrupts.                                                                                                                                                                        |
|                    | For example, the following situation may occur:                                                                                                                                                                                                                                                   |
|                    | <ul> <li>The IRS selects PE 0 for a high priority 1ofN interrupt (INTID A).</li> <li>The IRS selects PE 1 for a low priority 1ofN interrupt (INTID B).</li> <li>There are several interrupts with higher priority than INTID A that are Targeted to PE 0.</li> </ul>                              |
|                    | In this situation, PE 1 may handle INTID B before PE 0 handles INTID A.                                                                                                                                                                                                                           |
| I <sub>XRMBH</sub> | Whether a PE has 1ofN PE selection enabled or disabled is configured separately for each IRS Domain.                                                                                                                                                                                              |
|                    | This configuration setting is accessed using the following sequence:                                                                                                                                                                                                                              |
|                    | <ol> <li>Select the PE using IRS_PE_SELR on the IRS where the PE is connected.</li> <li>Poll IRS_PE_STATUSR.IDLE until it reads as 1.</li> <li>Access IRS_PE_CR0.DPS.</li> </ol>                                                                                                                  |

4. Poll IRS\_PE\_STATUSR.IDLE until it reads as 1.

| $R_{LQMBW}$        | When 1ofN selection is disabled for PE for an Interrupt Domain, the corresponding PE is not selected as the target for 1ofN interrupts belonging to that Interrupt Domain.                                                                                                                                                                                                                     |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>shqtf</sub> | When IRS_PE_CR0.DPS is updated for a PE, and a physical 1ofN interrupt is selected as the physical candidate HPPI for the PE, one of the following is true:                                                                                                                                                                                                                                    |
|                    | <ul><li>The PE acknowledges the interrupt before IRS_PE_STATUSR.IDLE is 1.</li><li>The PE does not acknowledge the interrupt.</li></ul>                                                                                                                                                                                                                                                        |
|                    | See 4.8.4 <i>Physical interrupt signaling</i> for more information.                                                                                                                                                                                                                                                                                                                            |
| 4.8.4              | Physical interrupt signaling                                                                                                                                                                                                                                                                                                                                                                   |
| $R_{\rm LXYDJ}$    | The Pending state of a physical LPI identified by an INTID is updated when all of the following are true:                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>The physical LPI as identified by the INTID is reachable.</li> <li>Any of the following occur: <ul> <li>An ITS generates an interrupt event that specifies the INTID.</li> <li>A write to the IRS_SETLPI register specifies the INTID.</li> <li>An IRS processes an Interrupt Effect generated by a GIC System instruction that updates the LPI Pending state.</li> </ul> </li> </ul> |
|                    | Otherwise, the physical LPI Pending state is not updated.                                                                                                                                                                                                                                                                                                                                      |
| I <sub>dzsfl</sub> | The Interrupt Domain of an LPI that is being signaled is determined by how the interrupt is signaled as follows:                                                                                                                                                                                                                                                                               |
|                    | <ul> <li>The Interrupt Domain is specified as part of the interrupt event received from the ITS.</li> <li>The Interrupt Domain as reported in IRS_IDR0.INT_DOM for the IRS where a write to IRS_SETLPI occurs.</li> <li>The Interrupt Domain that the GIC System instruction operates in.</li> </ul>                                                                                           |
| $R_{\rm XYLLD}$    | The Pending state of a physical SPI identified by an INTID is updated when all of the following are true:                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>The physical SPI as identified by the INTID is reachable.</li> <li>Any of the following occur: <ul> <li>An interrupt connected to an IRS as an SPI is asserted or de-asserted and generates an interrupt event for the physical SPI.</li> <li>An IRS processes an Interrupt Effect generated by a GIC System instruction that updates the SPI Pending state.</li> </ul> </li> </ul>   |
|                    | Otherwise, the physical SPI Pending state is not updated.                                                                                                                                                                                                                                                                                                                                      |
| I <sub>sknhh</sub> | The Interrupt Domain of an SPI that is being signaled is determined by the Interrupt Domain that the SPI is assigned to.                                                                                                                                                                                                                                                                       |
|                    | See 4.8.2 <i>Physical SPIs</i> and 4.2 <i>Signaling interrupts</i> for more information.                                                                                                                                                                                                                                                                                                       |
| I <sub>szzvx</sub> | If an SPI that is assigned to a VM is signaled, the SPI is a virtual SPI and the rules for when its Pending state is updated are different. See 4.10 <i>Virtual interrupts</i> and 4.10.4 <i>Virtual interrupt signaling</i> for more information.                                                                                                                                             |
| D <sub>NFYQX</sub> | The IRS Domain selects a physical candidate HPPI for a PE for an Interrupt Domain if, and only if, at least one physical interrupt meets the physical <i>candidate HPPI conditions</i> :                                                                                                                                                                                                       |
|                    | <ul> <li>The interrupt is Enabled.</li> <li>The interrupt is Pending.</li> <li>The interrupt is Inactive.</li> <li>One of the following is true: <ul> <li>The interrupt Routing mode is Targeted and the interrupt Affinity specifies the PE.</li> </ul> </li> </ul>                                                                                                                           |

The interrupt Routing mode is Targeted and the interrupt Affinity specifies the PE.
 The interrupt Routing mode is 1ofN and the PE is selected as the target PE for the interrupt.

| R <sub>WSBLV</sub> | For a PE and an Interrupt Domain, all of the following apply to the physical candidate HPPI selection:                                                                                                                                                                                                                                                                                                                                         |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | • If at least one interrupt satisfies the physical candidate HPPI conditions, the IRS Domain selects one of these as the physical candidate HPPI in finite time.                                                                                                                                                                                                                                                                               |
|                    | • If no interrupts satisfy the physical candidate HPPI conditions, the IRS Domain does not select any interrupt as the physical candidate HPPI.                                                                                                                                                                                                                                                                                                |
| R <sub>hgtsh</sub> | If more than one interrupt satisfies the physical candidate HPPI conditions for a PE for an Interrupt Domain, the IRS Domain selects the interrupt with the highest Priority as the physical candidate HPPI in finite time.                                                                                                                                                                                                                    |
|                    | If there is more than one physical candidate HPPI with the same Priority, it is IMPLEMENTATION DEFINED which of those interrupts is selected as the physical candidate HPPI.                                                                                                                                                                                                                                                                   |
| I <sub>bgbfd</sub> | The architecture only requires that the highest Priority interrupt that satisfies the candidate HPPI conditions is selected in finite time, because the set of interrupts that satisfy the conditions changes over time as the state and configuration of interrupts are updated. An implementation may need to consider the Priority of all the interrupts that satisfy the conditions which may require processing time.                     |
| R <sub>kfybx</sub> | When at least one physical interrupt meets the physical <i>candidate HPPI conditions</i> for a PE for an Interrupt Domain, and the IRS is enabled for the Interrupt Domain, the IRS selects a physical candidate HPPI in finite time.                                                                                                                                                                                                          |
| I <sub>PZVZZ</sub> | See 4.11 <i>IRS power management</i> for information about the IRS behavior if it has selected a physical candidate HPPI for a PE and the PE is offline.                                                                                                                                                                                                                                                                                       |
| I <sub>ZPJZL</sub> | An interrupt might be signaled on one IRS and be targeted to a PE connected to a different IRS. Whether that interrupt can be selected as the physical candidate HPPI for the PE depends only on the configuration of the IRS local to the PE. If the IRS on which the interrupt was originally signaled is subsequently disabled, that has no effect on whether the interrupt is selected as the physical candidate HPPI for the targeted PE. |
| R <sub>xwwnp</sub> | When a physical interrupt that has been selected as the physical candidate HPPI for a PE for an Interrupt Domain is no longer selected as the physical candidate HPPI, the PE will either acknowledge the old physical candidate HPPI within finite time, or the old physical candidate HPPI will not be acknowledged.                                                                                                                         |
| R <sub>CHNVV</sub> | If the IRS updates the configuration of an interrupt that has been selected as the physical candidate HPPI for an Interrupt Domain for a PE, and the interrupt configuration data was communicated to the PE, the IRS will select the same or a new physical interrupt as the physical candidate HPPI.                                                                                                                                         |
|                    | The IRS then communicates the selected physical candidate HPPI to the PE, including any updated interrupt configuration data, in finite time.                                                                                                                                                                                                                                                                                                  |
|                    | For more information about ordering of such events, see 2.12 Interrupt ordering model and synchronization requirements and Chapter B1 Interrupt ordering litmus tests.                                                                                                                                                                                                                                                                         |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                |

### Note

The following sequence is an example of the IRS communicating updated interrupt configuration data because there was an update to the configuration data that was communicated to a PE:

- 1. An interrupt is selected as the physical candidate HPPI for a PE and its Priority is communicated to the PE.
- 2. The PE executes a GIC System instruction that updates the Priority of the interrupt.
- 3. The IRS selects the same interrupt as the physical candidate HPPI for the PE.
- 4. The IRS communicates that the interrupt is still the candidate HPPI with the updated Priority value to the PE.

I<sub>TMRWF</sub> Updates to interrupt state or configuration can lead to the IRS selecting a different candidate HPPI. For example, the current candidate HPPI may become Disabled, or a higher priority interrupt may be updated to meet the candidate HPPI conditions. In such scenarios, the IRS selects a new candidate HPPI in finite time. However, the PE may acknowledge the old candidate HPPI before the IRS communicates to the PE that a new candidate HPPI has been selected.

### 4.9 Virtualization data structures



Figure 4.3: IRS virtualization structures

D<sub>CCSJV</sub> The GICv5 architecture defines the following *virtualization data structures* used by an IRS:

- The Virtual Machine Table (VM table).
- The Virtual PE Table (VPE table).

Each level 2 entry in the VM table describes the configuration of a VM and contains pointers to the following child data structures:

- A VM descriptor, if required.
- A VPE table.
- A virtual LPI IST.
- A virtual SPI IST.

Each entry in the VPE table describes the configuration of the VPE and contains pointers to the VPE descriptor for each VPE in the VM.

- IA VM supports virtual LPIs, virtual SPIs, or both.
- $I_{YTSWN}$  Virtual LPIs and virtual SPIs are stored in separate virtual ISTs.
- S<sub>WXHNY</sub> Software is responsible for allocating the virtualization data structures from memory in the PAS associated with the IRS Domain where the VM table is used.

See also:

- 4.7 *The interrupt state table (IST)*
- 4.10 Virtual interrupts
- 11.2 IRS Data Structures

### 4.9.1 The VM table

| I <sub>PVHPD</sub> | The VM table contains the configuration of the VMs defined in an IRS Domain.                                                                                                                              |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I VIII D           | For each VM, the VM table contains pointers to other data structures associated with that VM.                                                                                                             |
|                    | In a multi-IRS system, the VM table is shared between all IRSs for the IRS Domain.                                                                                                                        |
| D <sub>pzxmy</sub> | The VM table uses either a linear or 2-level structure.                                                                                                                                                   |
|                    | For a linear VM table, all of the following are true:                                                                                                                                                     |
|                    | <ul><li>The level 1 VM table is omitted.</li><li>The VM table consists of a single level 2 VM table.</li></ul>                                                                                            |
| I <sub>dspsd</sub> | IRS_IDR3.VMT_LEVELS reports whether 2-level VM table support is implemented.                                                                                                                              |
| R <sub>kqykz</sub> | The levels supported for the VM table are the same across all Interrupt Domains, except for the EL3 Interrupt Domain, where VMs are not supported.                                                        |
|                    | The levels supported for the VM table are the same across all IRSs.                                                                                                                                       |
| D <sub>NRLZZ</sub> | For a linear VM table, the base address of the VM table specifies the location of the level 2 VM table.                                                                                                   |
|                    | For a 2-level VM table, the base address of the VM table specifies the location of the level 1 VM table.                                                                                                  |
| D <sub>lspbk</sub> | When the VM table uses a 2-level table structure, the size of each level 2 VM table is 4 KB.                                                                                                              |
| R <sub>MKPCF</sub> | The structure of the VM table is controlled using the following register fields:                                                                                                                          |
|                    | • IRS_VMT_CFGR.STRUCTURE:                                                                                                                                                                                 |
|                    | Selects if the VM table uses a linear or 2-level structure.                                                                                                                                               |
|                    | • IRS_VMT_CFGR.VM_ID_BITS:                                                                                                                                                                                |
|                    | Selects how many VMs the IRS Domain supports. This impacts the size of the level 2 VM table when using a linear structure and the size of the level 1 VM table when using a 2-level structure.            |
| I <sub>HCGJW</sub> | The VM table is indexed using a VM ID ranging from 0 through (2 ^ IRS_VMT_CFGR.VM_ID_BITS) - 1.                                                                                                           |
| $R_{NXJZZ}$        | When an IRS accesses the VM table for an IRS Domain, the IRS does not access any memory location derived from a VM ID which is outside the configured VM ID range for the IRS Domain.                     |
|                    | This includes situations where the VM ID is programmed in the parameters to a GIC System instruction, the VM ID is received from an ITS, or the VM ID is stored in a physical SPI VM assignment register. |
| I <sub>zkgtx</sub> | The maximum VM ID range supported is reported by IRS_IDR3.VM_ID_BITS.                                                                                                                                     |
| R <sub>XYKND</sub> | The maximum number of VM ID bits are the same across all Interrupt Domains, except for the EL3 Interrupt Domain, where VMs are not supported.                                                             |
|                    | The maximum number of VM ID bits is the same across all IRSs.                                                                                                                                             |
|                    | 4.9.1.1 The VM table base address and configuration registers                                                                                                                                             |
| I <sub>GMXKS</sub> | The base address of the VM table is stored in IRS_VMT_BASER.ADDR.                                                                                                                                         |
| I <sub>JLYPB</sub> | IRS_VMT_BASER.VALID determines whether the VM table is valid.                                                                                                                                             |
| I <sub>BNSSH</sub> | A write to IRS_VMT_BASER completes when IRS_VMT_STATUSR.IDLE is 1.                                                                                                                                        |
| I <sub>yjkrp</sub> | In a multi-IRS system, the VM table is shared across all IRSs for an IRS Domain.                                                                                                                          |
| D <sub>VJFSP</sub> | The VM table becomes valid when a write that updates IRS_VMT_BASER.VALID from 0 to 1 completes.                                                                                                           |
|                    | The VM table becomes invalid when a write that updates IRS_VMT_BASER.VALID from 1 to 0 completes.                                                                                                         |

| R <sub>RLYYJ</sub> | In a multi-IRS system, when a write to IRS_VMT_BASER.VALID completes, the values of the following registers on that IRS are returned on a subsequent read on any IRS in the IRS Domain:                                                                                                                                                  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul><li>IRS_VMT_BASER.</li><li>IRS_VMT_CFGR.</li></ul>                                                                                                                                                                                                                                                                                   |
| R <sub>wxtkp</sub> | If a write occurs to IRS_VMT_BASER.VALID when IRS_VMT_STATUSR.IDLE is 0 on any other IRS for the same IRS Domain, it is CONSTRAINED UNPREDICTABLE which configuration and base address is used for the VM table.                                                                                                                         |
|                    | The CONSTRAINED UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the IRS Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .                                                                                                |
| R <sub>QRSZL</sub> | When the VM table is valid, all IRSs are permitted to access the virtualization data structures for any reason, including speculative reads.                                                                                                                                                                                             |
|                    | When the VM table is invalid, the IRSs do not access the virtualization data structures table.                                                                                                                                                                                                                                           |
|                    | See 4.9 Virtualization data structures for the definition of virtualization data structures.                                                                                                                                                                                                                                             |
|                    | 4.9.1.2 Level 2 VM table management                                                                                                                                                                                                                                                                                                      |
| D <sub>YPLVV</sub> | A level 2 VM table is considered valid, if the VM table is valid and one of the following is true:                                                                                                                                                                                                                                       |
|                    | <ul><li>The VM table uses a linear structure.</li><li>The VM table uses a 2-level structure and the corresponding L1_VMTE.VALID is 1.</li></ul>                                                                                                                                                                                          |
|                    | Otherwise, the level 2 VM table is considered <i>invalid</i> .                                                                                                                                                                                                                                                                           |
| D <sub>QGKXL</sub> | A level 2 VM table becomes valid in any of the following scenarios:                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>The VM table uses a linear structure and the VM table becomes valid.</li> <li>The VM table uses a 2-level structure and any of the following occur: <ul> <li>A write to IRS_VMAP_L2_VMTR makes the level 2 VM table valid.</li> <li>The VM table becomes valid and the corresponding L1_VMTE.VALID is 1.</li> </ul> </li> </ul> |
| I <sub>csryh</sub> | When a 2-level VM table becomes valid, if L1_VMTE.VALID is 1 for more than one level 1 VM table entry, more than one level 2 VM table may become valid at the same time.                                                                                                                                                                 |
| R <sub>bxwbf</sub> | When the VM table is valid and uses a 2-level structure, if software writes to an invalid level 1 VM table entry and sets L1_VMTE.VALID to 1, the behavior of the IRS Domain is UNPREDICTABLE.                                                                                                                                           |
|                    | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .                                                                                                      |
| R <sub>xbdxw</sub> | For a 2-level VM table, if a write updates a valid level 1 VM table entry, the IRS Domain behavior is UNPRE-<br>DICTABLE.                                                                                                                                                                                                                |
|                    | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the IRS Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .                                                                                                            |
| I <sub>dpcrg</sub> | The architecture does not support making an individual level 2 VM table invalid when using a 2-level structure for the VM table.                                                                                                                                                                                                         |
| R <sub>rnsyr</sub> | To recover from UNPREDICTABLE behavior resulting from an incorrect write to a level 1 VM table entry, the VM table is made invalid.                                                                                                                                                                                                      |
| R <sub>tzwtx</sub> | When a write to IRS_VMAP_L2_VMTR makes the corresponding level 2 VM table valid, all of the following are true:                                                                                                                                                                                                                          |
|                    | <ul> <li>The IRS generates the following Effects:</li> <li>A Register Write Effect E<sub>1</sub> to IRS_VMT_STATUSR which sets the IDLE field to 0.</li> <li>A Memory Write Effect E<sub>2</sub> to the Location corresponding to the level 1 VM table entry which updates L1_VMTE.VALID from 0 to 1.</li> </ul>                         |

- A Register Write Effect E<sub>3</sub> to IRS\_VMT\_STATUSR which sets the IDLE field to 1.

- There is an Intrinsic order dependency from the Register Write Effect  $E_1$  to the Memory Write Effect  $E_2$ .
- There is an Intrinsic order dependency from the Memory Write Effect E2 to the Register Write Effect E3.

This means that if there is a Memory Read Effect  $E_4$  which Reads-from the Register Write Effect  $E_3$ , then  $E_2$  is Ordered-before  $E_4$ .

I<sub>YTWVR</sub> When the VM table is valid and uses a 2-level structure, a level 2 VM table is made valid by the following sequence:

- 1. Software writes the address of the new level 2 VM table to L1\_VMTE.L2\_ADDR, with L1\_VMTE.VALID remaining to be 0.
- 2. Software writes to IRS\_VMAP\_L2\_VMTR.
- 3. The IRS performs a write to the level 1 VM table entry that updates L1\_VMTE.VALID from 0 to 1.
- 4. The IRS reports that the effects of the write to IRS\_VMAP\_L2\_VMTR are complete.

See 3.3 *Coherency considerations for GIC data structures* for more information about ensuring that memory accesses are coherent between the IRS and a PE.

R<sub>KZZPQ</sub> When the VM table is valid and uses a 2-level structure, if software writes to the level 1 VM table entry when IRS\_VMT\_STATUSR.IDLE is 0, it is CONSTRAINED UNPREDICTABLE whether the IRS writes back the entry using the updated or old level 1 entry value.

The CONSTRAINED UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 *IRS memory access rules*.

- R<sub>KGTMJ</sub> If a write occurs to IRS\_VMAP\_L2\_VMTR when IRS\_VMT\_STATUSR.IDLE is 0 on any other IRS for the same IRS Domain, it is CONSTRAINED UNPREDICTABLE whether any effects of any of the writes complete successfully.
- D<sub>CFNYD</sub> A level 2 VM table *becomes invalid* when the VM table becomes invalid.

### 4.9.1.3 VM management

D<sub>VBQTG</sub> A VM and the corresponding level 2 VM table entry are considered *valid* when all of the following are true:

- The level 2 VM table is valid.
- The corresponding L2\_VMTE.VALID is 1.

Otherwise the VM and the corresponding level 2 VM table entry are considered invalid.

RYBMTV If a VM ID is outside the configured VM ID range for the IRS Domain, the VM ID is treated as invalid.

- I JOFYM When a VM is valid, all of the following are true:
  - Virtual interrupts in the VM can be signaled.
  - VPEs can become resident.
    - VPEs can access the configuration and state of reachable virtual interrupts.

When a VM is invalid, none of the above are true.

I<sub>JFWCL</sub> When the VM table is invalid, all of the following are true:

- All VM IDs specify invalid VMs.
- All VPEs are invalid.
- The IRS does not select any virtual candidate HPPIs to the PEs connected to the IRS.
- When a PE executes a GIC System instruction that operates in the Virtual Interrupt Domain, all Interrupt Effects generated by that instruction, that are Ordered-after the VM table becomes invalid, are IGNORED.

See Chapter 2 *PE architecture* for more information about the relationship between a resident VPE and the Virtual Interrupt Domain.

 $\mathsf{D}_{\mathsf{QXMZT}}$ 

- A VM becomes valid in any of the following scenarios:
  - A write to IRS\_VMAP\_VMR makes the VM valid.
  - The level 2 VM table becomes valid and the corresponding L2\_VMTE.VALID is 1.

R<sub>VQKZB</sub> When a level 2 VM table is valid, if software writes to an invalid level 2 VM table entry and sets L2\_VMTE.VALID to 1, the behavior of the IRS Domain is UNPREDICTABLE.

The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 *IRS memory access rules*.

- R<sub>HPDGY</sub> To recover from UNPREDICTABLE behavior resulting from a write to an invalid level 2 VM table entry that sets L2\_VMTE.VALID to 1, the VM table is made invalid.
- R<sub>KBKBF</sub> When a write to IRS\_VMAP\_VMR makes the corresponding VM valid, all of the following are true:
  - The IRS generates the following Effects:
    - A Register Write Effect E<sub>1</sub> to IRS\_VMT\_STATUSR which sets the IDLE field to 0.
    - A Memory Write Effect E<sub>2</sub> to the Location corresponding to the level 1 VM table entry which updates L2\_VMTE.VALID from 0 to 1.
    - A Register Write Effect E<sub>3</sub> to IRS\_VMT\_STATUSR which sets the IDLE field to 1.
  - There is an Intrinsic order dependency from the Register Write Effect  $E_1$  to the Memory Write Effect  $E_2$ .
  - There is an Intrinsic order dependency from the Memory Write Effect E<sub>2</sub> to the Register Write Effect E<sub>3</sub>.

This means that if there is a Memory Read Effect  $E_4$  which Reads-from the Register Write Effect  $E_3$ , then  $E_2$  is Ordered-before  $E_4$ .

- I<sub>LTQMV</sub> When a level 2 VM table is valid, a VM is made valid by the following sequence:
  - 1. Software initializes the corresponding level 2 VM table entry, with L2\_VMTE.VALID remaining to be 0.
  - 2. Software writes to IRS\_VMAP\_VMR.
  - 3. The IRS performs a write to the level 2 VM table entry that updates L2\_VMTE.VALID from 0 to 1.
  - 4. The IRS reports that the effects of the write to IRS\_VMAP\_VMR are complete.

See 3.3 *Coherency considerations for GIC data structures* for more information about ensuring that memory accesses are coherent between the IRS and a PE.

I<sub>PYJLW</sub>

- When a VM becomes valid, the following fields are interpreted by the IRS Domain:
  - L2\_VMTE.VMD\_ADDR
  - L2\_VMTE.VPE\_ID\_BITS
  - L2\_VMTE.VPET\_ADDR
  - L2\_VMTE.LPI\_IST\_VALID
  - L2\_VMTE.SPI\_IST\_VALID

If the L2\_VMTE.LPI\_IST\_VALID field is 1 when the VM becomes valid, the following fields are interpreted by the IRS Domain:

- L2\_VMTE.LPI\_ID\_BITS
- L2\_VMTE.LPI\_IST\_STRUCTURE
- L2\_VMTE.LPI\_IST\_ADDR
- L2\_VMTE.LPI\_ISTSZ

If the L2\_VMTE.SPI\_IST\_VALID field is 1 when the VM becomes valid, the following fields are interpreted by the IRS Domain:

- L2\_VMTE.SPI\_ID\_BITS
- L2\_VMTE.SPI\_IST\_STRUCTURE
- L2\_VMTE.SPI\_IST\_ADDR
- L2\_VMTE.SPI\_ISTSZ

See 4.9.2 *The VPE table* for information about valid entries in the VPE table when a VM becomes valid.

R<sub>byjym</sub>

- For a write to a valid level 2 VM table entry, all of the following are true:
  - If L2\_VMTE.LPI\_IST\_VALID is 0, the following fields are permitted to be updated:
    - L2\_VMTE.LPI\_ID\_BITS.
    - L2\_VMTE.LPI\_IST\_STRUCTURE.

- L2\_VMTE.LPI\_IST\_ADDR.
- L2\_VMTE.LPI\_ISTSZ.
- If L2\_VMTE.SPI\_IST\_VALID is 0, the following fields are permitted to be updated:
  - L2\_VMTE.SPI\_ID\_BITS.
  - L2\_VMTE.SPI\_IST\_STRUCTURE.
  - L2\_VMTE.SPI\_IST\_ADDR.
  - L2\_VMTE.SPI\_ISTSZ.

Updating any other field in a valid level 2 VM table entry results in UNPREDICTABLE behavior.

The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the IRS Domain or in an access to memory that does not follow the behaviors described in 4.12 *IRS memory access rules*.

ISee 4.10.1 Virtual LPIs and 4.10.2 Virtual SPIs for information about how the virtual ISTs become valid and the<br/>corresponding L2\_VMTE.LPI\_IST\_VALID and L2\_VMTE.SPI\_IST\_VALID are updated for a valid VM.

R<sub>LDKSX</sub> When a level 2 VM table is valid, the IRS behavior is UNPREDICTABLE if there is a write to the level 2 VM table entry when IRS\_VMT\_STATUSR.IDLE is 0 because of a write to any of the following registers:

- IRS\_VMAP\_VMR.
- IRS\_VMAP\_VPER.
- IRS\_VMAP\_VISTR.
- IRS\_VMAP\_L2\_VISTR.

The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 *IRS memory access rules*.

- R<sub>FFCKZ</sub> If a write occurs to any of the following registers when IRS\_VMT\_STATUSR.IDLE is 0 on any other IRS for the same IRS Domain, it is CONSTRAINED UNPREDICTABLE whether any effects of any of the writes complete successfully:
  - IRS\_VMAP\_VMR.
  - IRS\_VMAP\_VPER.
  - IRS\_VMAP\_VISTR.
  - IRS\_VMAP\_L2\_VISTR.

D<sub>BTKBB</sub> A VM *becomes invalid* in any of the following scenarios:

- A write to IRS\_VMAP\_VMR makes the VM invalid.
- The VM table becomes invalid.
- R<sub>KFTFZ</sub> To recover from UNPREDICTABLE behavior resulting from an incorrect write to a valid level 2 VM table entry, the VM is made invalid by a write to IRS\_VMAP\_VMR that sets IRS\_VMAP\_VMR.U to 1.

R<sub>XXVLZ</sub> If a VM becomes invalid and a VPE in the VM is resident on a PE, the resident VPE is treated as belonging to an invalid VM and all of the following are true:

- If a virtual candidate HPPI was selected for the VPE, one of the following is true:
  - The virtual candidate HPPI is acknowledged in finite time.
  - The virtual candidate HPPI is not acknowledged.
- GIC System instructions operating in the Virtual Interrupt Domain and specify the VM are treated as specifying an invalid VM.
- Doorbell requests from the PE where the VPE is resident are IGNORED.

If the VM with the same VM ID subsequently becomes valid, then it's CONSTRAINED UNPREDICTABLE whether the resident VPE is still treated as being resident and belonging to the new VM, or is treated as belonging to an invalid VM.

S<sub>WKTGN</sub> Software can make a VM invalid and reclaim all resources related to the VM by performing the following sequence:

- 1. Make all VPEs non-resident.
- 2. Unmap and invalidate all ITS mappings that target the VM.
- 3. Unassign all SPIs assigned to the VM.

| 4. Make the VM invalid by writing to IRS_VMA | P_VMR. |
|----------------------------------------------|--------|
|----------------------------------------------|--------|

### 4.9.1.4 The VM descriptor

| I <sub>ZVXTY</sub> | An implementation may require a VM descriptor for each VM.                                                                                                                                                                          |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Whether a VM descriptor is required is reported by IRS_IDR3.VMD.                                                                                                                                                                    |
| I <sub>QYYFH</sub> | The VM descriptor is memory provided by software to the IRS Domain to manage the VM. The content and usage of the VM descriptor is IMPLEMENTATION DEFINED. The VM descriptor cannot be moved once the VM is made valid.             |
| I <sub>YBLTD</sub> | If a VM descriptor is required, a valid L2_VMTE contains the base addresses of the VM descriptor.                                                                                                                                   |
| R <sub>BWKBG</sub> | If a VM descriptor is required, when a VM becomes valid, the memory pointed to by L2_VMTE.VMD_ADDR is expected to contain all zeros.                                                                                                |
|                    | If the VM descriptor does not contain all zeros, all of the following are true:                                                                                                                                                     |
|                    | <ul> <li>It is CONSTRAINED UNPREDICTABLE whether the IRS Domain selects a target VPE for virtual 1ofN interrupts for the VM.</li> <li>The VM configuration, including the doorbell settings, is reset to UNKNOWN values.</li> </ul> |
| R <sub>hqprd</sub> | The format and content of the VM descriptor is IMPLEMENTATION DEFINED.                                                                                                                                                              |
| I <sub>BBCFD</sub> | The size of the VM descriptor is reported by IRS_IDR3.VMD_SZ.                                                                                                                                                                       |
| R <sub>VNVHD</sub> | Whether a VM descriptor is required, and its size, is the same across all Interrupt Domains, except for the EL3 Interrupt Domain, where VMs are not supported.                                                                      |
|                    | Whether a VM descriptor is required, and its size, is the same across all IRSs.                                                                                                                                                     |
|                    | 4.9.1.5 Example VM table structures                                                                                                                                                                                                 |
| I <sub>bspbv</sub> | The size of a level 1 VMTE is 8 bytes and the size of a level 2 VMTE is 32 bytes.                                                                                                                                                   |
|                    |                                                                                                                                                                                                                                     |

Table 4.3 shows some example VM table structures.

S<sub>VKKQW</sub> The L1 size and L2 size columns in Table 4.3 indicate the required maximum physically contiguous allocation by software for the configuration.

| STRUCTURE | VM_ID_BITS | L1 size | L2 size | Maximum number of VMs |
|-----------|------------|---------|---------|-----------------------|
| Linear    | 7          | -       | 4 KB    | 128                   |
| Linear    | 11         | -       | 64 KB   | 2,048                 |
| Linear    | 15         | -       | 1 MB    | 32,768                |
| Linear    | 16         | -       | 2 MB    | 65,536                |
| 2-level   | 16         | 4 KB    | 4 KB    | 65,536                |

### Table 4.3: Example VM table structures

### 4.9.2 The VPE table

I<sub>BGKFQ</sub>

The VPE table contains the configuration of the VPEs defined for a VM.

For each VPE, the VPE table contains pointers to other data structures associated with that VPE.

In a multi-IRS system, the VPE table is shared between all IRSs for the IRS Domain.

The VPE table is not permitted to be shared across multiple VMs.

# Chapter 4. Interrupt routing service (IRS) 4.9. Virtualization data structures

 $\mathsf{D}_{\mathsf{PFHDR}}$ 

 $\mathsf{D}_{\mathsf{MPMBR}}$ 

The VPE table uses a linear structure.

The base address of the VPE table specifies the location of the VPE table.

| I <sub>WXRZV</sub> | L2_VMTE.VPE_ID_BITS selects maximum number of VPEs for the VM.                                                                                                                                                                                                                                                                       |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $S_{PLJRT}$        | When a VM is made valid, it is configured to support a maximum number of VPEs. This value cannot be modified once the VM is made valid. If more VPEs are required than the maximum configured in the L2_VMTE.VPE_ID_BITS field, then the VM can be made invalid and a new VM can be made valid with a larger maximum number of VPEs. |
|                    | Note                                                                                                                                                                                                                                                                                                                                 |
|                    | L2_VMTE.VPE_ID_BITS specifies the maximum number of entries in the VPE table. For some of those entries, VPETE.VALID may be 0, and therefore the number of valid VPEs in the VM may be smaller than the value specified by L2_VMTE.VPE_ID_BITS.                                                                                      |
| I <sub>drhqp</sub> | The VPE table is indexed using a VPE ID ranging from 0 to (2 ^ L2_VMTE.VPE_ID_BITS) - 1.                                                                                                                                                                                                                                             |
| $R_{WSDXY}$        | When an IRS accesses the VPE table for a VM, the IRS does not access any memory location derived from a VPE ID which is outside the configured VPE ID range for the VM.                                                                                                                                                              |
|                    | This includes situations where the VPE ID is programmed in the parameters to a GIC System instruction, written to a GIC System register, or the VPE ID is stored in a virtualization data structure entry.                                                                                                                           |
| I <sub>QCQBD</sub> | The maximum supported VPE ID is reported by IRS_IDR4.VPE_ID_BITS.                                                                                                                                                                                                                                                                    |
| $R_{\rm HBNVF}$    | The number of supported VPE ID bits is the same across all Interrupt Domains, except for the EL3 Interrupt Domain, where VMs are not supported.                                                                                                                                                                                      |
|                    | The number of supported VPE ID bits is the same across all IRSs.                                                                                                                                                                                                                                                                     |
| R <sub>NQDMK</sub> | For virtual interrupts, when an Interrupt Affinity ID is specified, it is interpreted as the VPE ID.                                                                                                                                                                                                                                 |
| $\rm S_{RMDNH}$    | A virtual Interrupt Affinity ID is interpreted as the VPE ID for virtual interrupts and used directly to index into the VPE table.                                                                                                                                                                                                   |
|                    | Arm expects that hypervisor software at EL2 presents a virtual IRS with an emulated virtual IRS_PE_SELR register. The value written to the emulated IRS_PE_SELR.IAFFID field should select the emulated configuration registers corresponding to the VPE with the corresponding IAFFID and VPE ID.                                   |
|                    | 4.9.2.1 The VPE table base address and configuration                                                                                                                                                                                                                                                                                 |
| I <sub>CFPXL</sub> | The base address of the VPE table for a VM is stored in the corresponding L2_VMTE.VPET_ADDR.                                                                                                                                                                                                                                         |
|                    | See 4.9.1.3 VM management for more information.                                                                                                                                                                                                                                                                                      |
| I <sub>LTQZN</sub> | A VPE table becomes valid when its VM becomes valid.                                                                                                                                                                                                                                                                                 |
|                    | When a VPE table becomes valid, the VPE table can contain all invalid entries, a combination of valid and invalid entries, or all valid entries.                                                                                                                                                                                     |
| R <sub>psyqv</sub> | When VPETE.VALID is 1, the IRS may speculatively access any memory location derived from the address and configuration data in the VPE table entry.                                                                                                                                                                                  |
|                    | See 4.12 IRS memory access rules for more information.                                                                                                                                                                                                                                                                               |
|                    | 4.9.2.2 VPE management                                                                                                                                                                                                                                                                                                               |
| D <sub>BKCHX</sub> | A VPE for a VM, and the corresponding VPE table entry, are considered <i>valid</i> when all of the following are true:                                                                                                                                                                                                               |
|                    | • The VM is would                                                                                                                                                                                                                                                                                                                    |

- The VM is valid.
- The corresponding VPETE.VALID is 1.

|                                          | Otherwise, the VPE and the corresponding VPE table entry are considered invalid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>JKDCN</sub>                       | If a VPE ID is outside the configured VPE ID range for the VM, the VPE ID is treated as specifying an invalid VPE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| $G_{\text{QNPPW}}$                       | The architecture supports multiple ways to create a VM:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                          | <ul> <li>A VM can be made valid without containing any valid VPEs, and each VPE is subsequently made valid.</li> <li>A VM can be made valid with pre-configured valid VPEs to reduce the overhead of setting up a new VM.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| D <sub>HNRJX</sub>                       | A VPE becomes valid in any of the following scenarios:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                          | <ul> <li>A write to IRS_VMAP_VPER makes the VPE valid for an already valid VM.</li> <li>A VM becomes valid and VPETE.VALID is 1 for the corresponding VPE table entry for the VM.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| $R_{LSYNH}$                              | When a VPE table is valid, if software writes to an invalid VPE table entry and sets VPETE.VALID to 1, the behavior of the IRS Domain is UNPREDICTABLE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                          | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| R <sub>XRNSL</sub>                       | When a write to IRS_VMAP_VPER makes the corresponding VPE valid, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                          | <ul> <li>The IRS generates the following Effects: <ul> <li>A Register Write Effect E<sub>1</sub> to IRS_VMT_STATUSR which sets the IDLE field to 0.</li> <li>A Memory Write Effect E<sub>2</sub> to the Location corresponding to the level 1 VM table entry which updates VPETE.VALID from 0 to 1.</li> <li>A Register Write Effect E<sub>3</sub> to IRS_VMT_STATUSR which sets the IDLE field to 1.</li> </ul> </li> <li>There is an Intrinsic order dependency from the Register Write Effect E<sub>1</sub> to the Memory Write Effect E<sub>2</sub>.</li> <li>There is an Intrinsic order dependency from the Memory Write Effect E<sub>2</sub> to the Register Write Effect E<sub>3</sub>.</li> </ul>                                                                                    |
|                                          | This means that if there is a Memory Read Effect $E_4$ which Reads-from the Register Write Effect $E_3$ , then $E_2$ is Ordered-before $E_4$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| I <sub>sbdhk</sub>                       | When a VPE table is valid, a VPE is made valid by the following sequence:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                          | <ol> <li>Software initializes the corresponding VPE table entry, with VPETE.VALID remaining to be 0.</li> <li>Software writes to IRS_VMAP_VPER.</li> <li>The IRS performs a write to the VPE table entry that updates VPETE.VALID from 0 to 1.</li> <li>The IRS reports that the effects of the write to IRS_VMAP_VPER are complete.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                          | See 3.3 <i>Coherency considerations for GIC data structures</i> for more information about ensuring that memory accesses are coherent between the IRS and a PE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| I <sub>TTRHV</sub>                       | When the VPE becomes valid, the corresponding VPETE.VPED_ADDR specifies the location of the VPE descriptor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                          | See 4.9.2.3 <i>The VPE descriptor</i> for more information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| R <sub>YLKWF</sub>                       | See 4.9.2.3 <i>The VPE descriptor</i> for more information.<br>When a VPE table is valid, the IRS behavior is UNPREDICTABLE if there is a write to the VPE table entry when IRS_VMT_STATUSR.IDLE is 0 because of a write to IRS_VMAP_VPER.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| R <sub>YLKWF</sub>                       | When a VPE table is valid, the IRS behavior is UNPREDICTABLE if there is a write to the VPE table entry when                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| R <sub>YLKWF</sub><br>R <sub>LJJVP</sub> | When a VPE table is valid, the IRS behavior is UNPREDICTABLE if there is a write to the VPE table entry when IRS_VMT_STATUSR.IDLE is 0 because of a write to IRS_VMAP_VPER.<br>The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                          | When a VPE table is valid, the IRS behavior is UNPREDICTABLE if there is a write to the VPE table entry when IRS_VMT_STATUSR.IDLE is 0 because of a write to IRS_VMAP_VPER.<br>The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i> .                                                                                                                                                                                                                                                                                                                                                                            |
|                                          | <ul> <li>When a VPE table is valid, the IRS behavior is UNPREDICTABLE if there is a write to the VPE table entry when IRS_VMT_STATUSR.IDLE is 0 because of a write to IRS_VMAP_VPER.</li> <li>The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i>.</li> <li>If a write updates any field in a valid VPE table entry, the IRS Domain behavior is UNPREDICTABLE.</li> <li>The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the IRS</li> </ul>                                                                                                                       |
| $R_{LJJVP}$                              | <ul> <li>When a VPE table is valid, the IRS behavior is UNPREDICTABLE if there is a write to the VPE table entry when IRS_VMT_STATUSR.IDLE is 0 because of a write to IRS_VMAP_VPER.</li> <li>The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i>.</li> <li>If a write updates any field in a valid VPE table entry, the IRS Domain behavior is UNPREDICTABLE.</li> <li>The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the IRS Domain or in an access to memory that does not follow the behaviors described in 4.12 <i>IRS memory access rules</i>.</li> </ul> |

### 4.9.2.3 The VPE descriptor

- I YWLWM
   The VPE descriptor is memory provided by software to the IRSs to manage the VPE. The content and usage of the VPE descriptor is IMPLEMENTATION DEFINED. The VPE descriptor cannot be moved once the VPE is created, for as long as the VM remains valid.
- R<sub>DLKTX</sub> When a VPE becomes valid, the memory pointed to by VPETE.VPED\_ADDR is expected to contain all zeros.

If the VPE descriptor does not contain all zeros, all of the following are true:

- It is CONSTRAINED UNPREDICTABLE whether the IRS Domain selects a virtual candidate HPPI for the VPE.
- The VPE configuration, including the doorbell settings, is reset to UNKNOWN values.
- R<sub>DHCDH</sub> The format and content of the VPE descriptor is IMPLEMENTATION DEFINED.
- I<sub>QPDNG</sub> The size of the VPE descriptor is reported by IRS\_IDR4.VPED\_SZ.
- R<sub>TJMHJ</sub> The size of the VPE descriptor is the same across all Interrupt Domains, except for the EL3 Interrupt Domain, where VMs are not supported.

The size of the VPE descriptor is the same across all IRSs.

### 4.9.2.4 Example VPE table structures

I<sub>LFWWJ</sub> The size of a VPE table entry is 8 bytes.

Table 4.4 shows some example VPE table structures.

The VP\_ID\_BITS column represents the value stored in the L2\_VMTE.VPE\_ID\_BITS field for the VM containing the VPE table.

| Maximum number of VPEs | VPE table size | VPE_ID_BITS |
|------------------------|----------------|-------------|
| 4                      | 32 B           | 2           |
| 8                      | 64 B           | 3           |
| 16                     | 128 B          | 4           |
| 128                    | 1 KB           | 7           |
| 512                    | 4 KB           | 9           |
| 16,384                 | 128 KB         | 14          |
| 65,536                 | 512 KB         | 16          |
|                        |                |             |

Table 4.4: Example VPE table sizes

## 4.10 Virtual interrupts

| D <sub>yjqkx</sub> | Virtual interrupts are interrupts that belong to a VM.                                                                                                             |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $R_{\rm XKHNL}$    | A virtual interrupt is only permitted to be selected as the candidate HPPI for the Virtual Interrupt Domain.                                                       |
| I <sub>bnpqr</sub> | The IRS supports the following types of virtual interrupts for VMs:                                                                                                |
|                    | <ul><li>Virtual LPIs.</li><li>Virtual SPIs.</li></ul>                                                                                                              |
|                    | Both types of virtual interrupts are stored in virtual ISTs.                                                                                                       |
| I <sub>ZDNVV</sub> | Virtual interrupts are routed to a target VPE and selected as the virtual candidate HPPI for the PE where the target VPE is resident.                              |
|                    | See 4.10.6 VPE residency and 4.10.3 Virtual interrupt routing for more information.                                                                                |
| $R_{\rm KPKLS}$    | IRS support for virtualization is optional.                                                                                                                        |
| I <sub>FYJLC</sub> | IRS_IDR0.VIRT indicates whether virtualization is supported.                                                                                                       |
| R <sub>DGHCV</sub> | IRS_IDR0.VIRT is 0 for the EL3 Interrupt Domain.                                                                                                                   |
| R <sub>KDSPG</sub> | When at least one PE connected to an IRS implements EL2, IRS_IDR0.VIRT is 1 for all IRSs for all Interrupt Domains other than the EL3 Interrupt Domain.            |
|                    | When none of the PEs in the system implement EL2, IRS_IDR0.VIRT is 0 for all IRSs for all Interrupt Domains.                                                       |
| $R_{JJPQJ}$        | The value of IRS_IDR0.VIRT is the same for all IRSs for the same Interrupt Domain in the system.                                                                   |
| R <sub>tqfct</sub> | When virtualization is not supported, the IRS does not select any virtual candidate HPPIs to the PEs and any virtual interrupts signaled to the IRS are IGNORED.   |
| R <sub>tzbqy</sub> | The number of Priority bits supported for virtual interrupts corresponds to the number of Priority bits supported in the Interrupt Domain where the VM is defined. |
|                    | See 4.6 Interrupt configuration and state for more information about the number of supported Priority bits.                                                        |
| 4.10.1             | Virtual LPIs                                                                                                                                                       |
| Dawara             | The virtual LPIs for a VM are stored in the virtual LPI IST for the VM                                                                                             |

| $D_{\rm JXYLG}$    | The virtual LPIs for a VM are stored in the <i>virtual LPI IST</i> for the VM.                                                                                                     |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>RMNHL</sub> | The virtual LPI IST is allocated separately for each VM.                                                                                                                           |
|                    | The virtual LPI IST for a VM is shared across all IRSs in the system.                                                                                                              |
|                    | A virtual LPI IST is not permitted to be shared across multiple VMs.                                                                                                               |
| I <sub>wphxh</sub> | The number of virtual LPIs in a VM is configured in L2_VMTE.LPI_ID_BITS.                                                                                                           |
|                    | Software allocates and provides the virtual LPI IST for a VM by writing a valid address to L2_VMTE.LPI_IST_ADDR and writing 1 to L2_VMTE.LPI_IST_VALID.                            |
| I <sub>wpzyd</sub> | The virtual LPI IST is indexed using the INTID.ID in the range from 0 to (2 ^ L2_VMTE.LPI_ID_BITS) - 1.                                                                            |
| R <sub>cjyyo</sub> | When an IRS accesses the virtual LPI IST for a VM, the IRS does not access any memory location derived from an INTID which is outside the configured virtual LPI range for the VM. |
|                    | This includes situations where the INTID is programmed in the parameters to a GIC System instruction or the INTID is stored in the IST metadata areas.                             |
| R <sub>djzrm</sub> | A virtual LPI specified by an INTID for a VM specified by a VM ID is reachable when all of the following are true:                                                                 |
|                    | <ul> <li>The VM ID is valid.</li> <li>The INTID is within the configured virtual LPI range for the VM.</li> <li>The virtual LPI IST for the VM is valid.</li> </ul>                |

|                    | • There is a level 2 IST entry corresponding to the INTID in the virtual LPI IST.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | Otherwise, the virtual LPI is unreachable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| I <sub>gqqsw</sub> | In the virtual LPI IST context, the base address of the virtual LPI IST for a VM is stored in L2_VMTE.LPI_IST_ADDR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| I <sub>JKPTM</sub> | In the virtual LPI IST context, L2_VMTE.LPI_IST_VALID determines if the virtual LPI IST is valid for a VM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| D <sub>WDHDY</sub> | A virtual LPI IST for a VM becomes valid in one of the following scenarios:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | <ul> <li>The VM becomes valid and L2_VMTE.LPI_IST_VALID is 1 in the corresponding level 2 VM table entry.</li> <li>The VM is valid and a write to IRS_VMAP_VISTR makes the virtual LPI IST valid.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                    | See 4.7 The interrupt state table (IST) for more information about an IST becoming valid and invalid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| R <sub>xkgxc</sub> | When a write to IRS_VMAP_VISTR makes the corresponding LPI IST for the VM valid or invalid, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | <ul> <li>The IRS generates the following Effects: <ul> <li>A Register Write Effect E<sub>1</sub> to IRS_VMT_STATUSR which sets the IDLE field to 0.</li> <li>A Memory Write Effect E<sub>2</sub> to the Location corresponding to the level 2 VM table entry which updates L2_VMTE.LPI_IST_VALID.</li> <li>A Register Write Effect E<sub>3</sub> to IRS_VMT_STATUSR which sets the IDLE field to 1.</li> </ul> </li> <li>There is an Intrinsic order dependency from the Register Write Effect E<sub>1</sub> to the Memory Write Effect E<sub>2</sub>.</li> <li>There is an Intrinsic order dependency from the Memory Write Effect E<sub>2</sub> to the Register Write Effect E<sub>3</sub>.</li> </ul> |
|                    | This means that if there is a Memory Read Effect $E_4$ which Reads-from the Register Write Effect $E_3$ , then $E_2$ is Ordered-before $E_4$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| I <sub>ztsbx</sub> | When a VM is valid, the virtual LPI IST is made valid by the following sequence:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | <ol> <li>Software configures the virtual LPI IST by writing to the corresponding level 2 VM table entry, with L2_VMTE.LPI_IST_VALID remaining to be 0.</li> <li>Software writes to IRS_VMAP_VISTR.</li> <li>The IRS performs a write to the level 2 VM table entry that updates L2_VMTE.LPI_IST_VALID from 0 to 1.</li> <li>The IRS reports that the effects of the write to IRS_VMAP_VISTR are complete.</li> </ol>                                                                                                                                                                                                                                                                                     |
|                    | See 3.3 <i>Coherency considerations for GIC data structures</i> for more information about ensuring that memory accesses are coherent between the IRS and a PE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | See 4.9.1.3 VM management for more information about which fields are permitted to be updated when the VM is valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| I <sub>BHBYF</sub> | See 4.9.1.3 <i>VM management</i> for more information about updates to a level 2 VM table entry and the use of the virtual map registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| S <sub>KBXNL</sub> | The architecture supports the following ways to configure virtual LPIs for a VM:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | <ul> <li>Software can write a valid IST pointer and IST configuration data to the level 2 VM table entry after the VM is made valid and write to the map virtual IST register.</li> <li>Software can provide a valid IST pointer in the level 2 VM table entry when the VM is made valid.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | Adding an IST to add virtual LPI support for a VM can, for example, be done in response to a guest operating system booting and configuring a virtual IRS emulated by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | Providing a valid IST pointer at the time the VM is made valid can be used to support VM migration, or to support suspend and resume of VMs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| I <sub>sydwq</sub> | When a virtual LPI IST becomes valid, the following fields are interpreted by the IRS Domain:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | <ul> <li>L2_VMTE.LPI_ID_BITS</li> <li>L2_VMTE.LPI_IST_STRUCTURE</li> <li>L2_VMTE.LPI_IST_ADDR</li> <li>L2_VMTE.LPI_ISTSZ</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| I <sub>LTXVZ</sub> | When IRS_IDR2.IST_levels is 0, L2_VMTE.LPI_IST_STRUCTURE is treated as 0.                                                                                                                                                                                     |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>NMFLD</sub> | IRS_IDR2.{MIN_LPI_ID_BITS,ID_BITS} report the range of valid values for L2_VMTE.LPI_ID_BITS.                                                                                                                                                                  |
|                    | In a multi-IRS system, when the virtual LPI IST is valid for a VM, and the VM table is valid, all IRSs are permitted to access the virtual LPI IST for any reason, including speculative reads.                                                               |
|                    | See 4.9.1.1 The VM table base address and configuration registers for more information.                                                                                                                                                                       |
| R <sub>TDTCJ</sub> | When the virtual LPI IST is invalid for a VM, the IRS Domain does not access the virtual LPI IST.                                                                                                                                                             |
| D <sub>PCVXZ</sub> | A virtual LPI IST for a VM becomes invalid in one of the following scenarios:                                                                                                                                                                                 |
|                    | <ul> <li>The VM becomes invalid.</li> <li>The VM is valid and a write to IRS_VMAP_VISTR makes the virtual LPI IST invalid.</li> </ul>                                                                                                                         |
|                    | See 4.7 The interrupt state table (IST) for more information about an IST becoming valid and invalid.                                                                                                                                                         |
| I <sub>QFTNB</sub> | When a VM is valid, the virtual LPI IST is made invalid by the following sequence:                                                                                                                                                                            |
|                    | <ol> <li>Software writes to IRS_VMAP_VISTR.</li> <li>The IRS performs a write to the level 2 VM table entry that updates L2_VMTE.LPI_IST_VALID from 1 to 0.</li> <li>The IRS reports that the effects of the write to IRS_VMAP_VISTR are complete.</li> </ol> |
|                    | See 3.3 <i>Coherency considerations for GIC data structures</i> for more information about ensuring that memory accesses are coherent between the IRS and a PE.                                                                                               |
| R <sub>CXWBT</sub> | If a virtual LPI IST for a VM becomes invalid, a VPE in the VM is resident on a PE, and a virtual LPI is the candidate HPPI for the Virtual Interrupt Domain, one of the following is true:                                                                   |
|                    | <ul><li>The candidate HPPI is acknowledged by the PE before the IST becomes invalid.</li><li>The candidate HPPI is not acknowledged and is no longer selected as the candidate HPPI for the VPE.</li></ul>                                                    |
| R <sub>KYMTZ</sub> | When a virtual LPI IST becomes invalid, if there are Accepted events for virtual LPIs targeting the VM that are not yet processed, all of the following are true:                                                                                             |
|                    | <ul><li>The events are dropped and have no effect on any interrupt.</li><li>If software error reporting is supported, the IRS is permitted to report an error.</li></ul>                                                                                      |
| S <sub>BWSKR</sub> | If hypervisor software wishes to update the configuration of a virtual LPI IST, for example as the result of guest software programming emulated IRS registers, software should perform the following sequence:                                               |
|                    | <ol> <li>Make the virtual LPI IST invalid.</li> <li>Update the relevant fields in the level 2 VM table entry.</li> <li>Make the virtual LPI IST valid.</li> </ol>                                                                                             |
| I <sub>PCNMM</sub> | In the virtual LPI IST context, when the virtual LPI IST is valid and uses a 2-level structure, a virtual level 2 IST is made valid by writing to IRS_VMAP_L2_VISTR.                                                                                          |
|                    | The write specifies that the map applies to the LPI IST by setting IRS_VMAP_L2_VISTR.TYPE to LPI.                                                                                                                                                             |
|                    | The effects of the write are complete when IRS_VMT_STATUSR.IDLE is 1.                                                                                                                                                                                         |
|                    | See 4.7.1 Level 2 IST management for more information.                                                                                                                                                                                                        |
| I <sub>SBDCY</sub> | See 4.9.1.3 <i>VM management</i> for more information about the restrictions for the use of IRS_VMAP_L2_VIST concurrently with updates to the virtualization data structures for the VM and the use of other virtual map registers across IRSs.               |
|                    | See also:                                                                                                                                                                                                                                                     |
|                    | <ul> <li>4.7 The interrupt state table (IST)</li> <li>4.9 Virtualization data structures</li> </ul>                                                                                                                                                           |

### 4.10.2 Virtual SPIs

| D <sub>JSJKN</sub> | The virtual SPIs for a VM are stored in the virtual SPI IST for the VM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>YZPNL</sub> | The virtual SPI IST is allocated separately for each VM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | The virtual SPI IST for a VM is shared across all IRSs in the system.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                    | A virtual SPI IST is not permitted to be shared across multiple VMs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| I <sub>PVHMD</sub> | The number of virtual SPIs in a VM is configured in L2_VMTE.SPI_ID_BITS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | Software allocates and provides the virtual SPI IST for a VM by writing a valid address to L2_VMTE.SPI_IST_ADDR and writing 1 to L2_VMTE.SPI_IST_VALID.                                                                                                                                                                                                                                                                                                                                                                                                           |
| I <sub>DXXHY</sub> | The virtual SPI IST is indexed using the INTID.ID in the range from 0 through (2 ^ L2_VMTE.SPI_ID_BITS) - 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| R <sub>JQZKY</sub> | When an IRS accesses the virtual SPI IST for a VM, the IRS does not access any memory location derived from an INTID which is outside the configured virtual SPI range for the VM.                                                                                                                                                                                                                                                                                                                                                                                |
|                    | This includes situations where the INTID is programmed in the parameters of a GIC System instruction executed on a PE or the INTID is stored in the IST metadata areas.                                                                                                                                                                                                                                                                                                                                                                                           |
| $R_{\rm MYLWH}$    | A virtual SPI specified by an INTID for a VM specified by a VM ID is reachable when all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                    | <ul> <li>The VM is valid.</li> <li>The virtual SPI IST for the VM is valid.</li> <li>The INTID is within the configured virtual SPI range for the VM.</li> <li>There is a level 2 IST entry corresponding to the INTID in the virtual SPI IST.</li> </ul>                                                                                                                                                                                                                                                                                                         |
|                    | Otherwise, the virtual SPI is unreachable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| I <sub>hrdgp</sub> | In the virtual SPI IST context, the base address of the virtual SPI IST for a VM is stored in L2_VMTE.SPI_IST_ADDR.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| I <sub>csnjm</sub> | In the virtual SPI IST context, L2_VMTE.SPI_IST_VALID determines if the virtual SPI IST is valid for a VM.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| D <sub>BKKXD</sub> | A virtual SPI IST for a VM becomes valid in one of the following scenarios:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | <ul> <li>The VM becomes valid and L2_VMTE.SPI_IST_VALID is 1 in the corresponding level 2 VM table entry.</li> <li>The VM is valid and a write to IRS_VMAP_VISTR makes the virtual SPI IST valid.</li> </ul>                                                                                                                                                                                                                                                                                                                                                      |
|                    | See 4.7 The interrupt state table (IST) for more information about an IST becoming valid and invalid.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| $R_{\text{MLTBD}}$ | When a write to IRS_VMAP_VISTR makes the corresponding SPI IST for the VM valid or invalid, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | <ul> <li>The IRS generates the following Effects: <ul> <li>A Register Write Effect E<sub>1</sub> to IRS_VMT_STATUSR which sets the IDLE field to 0.</li> <li>A Memory Write Effect E<sub>2</sub> to the Location corresponding to the level 2 VM table entry which updates L2_VMTE.SPI_IST_VALID.</li> <li>A Register Write Effect E<sub>3</sub> to IRS_VMT_STATUSR which sets the IDLE field to 1.</li> </ul> </li> <li>There is an Intrinsic order dependency from the Register Write Effect E<sub>1</sub> to the Memory Write Effect E<sub>3</sub>.</li> </ul> |
|                    | This means that if there is a Memory Read Effect $E_4$ which Reads-from the Register Write Effect $E_3$ , then $E_2$ is Ordered-before $E_4$ .                                                                                                                                                                                                                                                                                                                                                                                                                    |
| I <sub>cdtql</sub> | When a VM is valid, the virtual SPI IST is made valid by the following sequence:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | <ol> <li>Software configures the virtual SPI IST by writing to the corresponding level 2 VM table entry, with L2_VMTE.SPI_IST_VALID remaining to be 0.</li> <li>Software writes to IRS_VMAP_VISTR.</li> <li>The IRS performs a write to the level 2 VM table entry that updates L2_VMTE.SPI_IST_VALID from 0 to 1.</li> <li>The IRS reports that the effects of the write to IRS_VMAP_VISTR are complete.</li> </ol>                                                                                                                                              |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

|                    | See 3.3 <i>Coherency considerations for GIC data structures</i> for more information about ensuring that memory accesses are coherent between the IRS and a PE.                                                                                               |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | See 4.9.1.3 <i>VM management</i> for more information about which fields are permitted to be updated when the VM is valid.                                                                                                                                    |
| $\rm S_{LHQJY}$    | Arm expects that hypervisor software provides a valid virtual SPI when a VM is made valid with a fixed number of SPIs for the lifetime of the VM. This is analogous to how SPIs work on a physical system.                                                    |
| I <sub>ZZGXF</sub> | When a virtual SPI IST becomes valid, the following fields are interpreted by the IRS Domain:                                                                                                                                                                 |
|                    | <ul> <li>L2_VMTE.SPI_ID_BITS</li> <li>L2_VMTE.SPI_IST_STRUCTURE</li> <li>L2_VMTE.SPI_IST_ADDR</li> <li>L2_VMTE.SPI_ISTSZ</li> </ul>                                                                                                                           |
| I <sub>zktzx</sub> | When IRS_IDR2.IST_levels is 0, L2_VMTE.SPI_IST_STRUCTURE is treated as 0.                                                                                                                                                                                     |
| I <sub>rgnrj</sub> | IRS_IDR2.ID_BITS reports the maximum value for L2_VMTE.SPI_ID_BITS.                                                                                                                                                                                           |
| I <sub>TWRCJ</sub> | See 4.9.1.3 <i>VM management</i> for more information about updates to a level 2 VM table entry and the use of the virtual map registers.                                                                                                                     |
|                    | In a multi-IRS system, when the virtual SPI IST is valid for a VM, and the VM table is valid, all IRSs are permitted to access the virtual SPI IST for any reason, including speculative reads.                                                               |
|                    | See 4.9.1.1 The VM table base address and configuration registers for more information.                                                                                                                                                                       |
| R <sub>kyyyr</sub> | When the virtual SPI IST is invalid for a VM, the IRS Domain does not access the virtual SPI IST.                                                                                                                                                             |
| D <sub>fykvt</sub> | A virtual SPI IST for a VM becomes invalid in one of the following scenarios:                                                                                                                                                                                 |
|                    | <ul><li>The VM becomes invalid.</li><li>The VM is valid and a write to IRS_VMAP_VISTR makes the virtual SPI IST invalid.</li></ul>                                                                                                                            |
|                    | See 4.7 The interrupt state table (IST) for more information about an IST becoming valid and invalid.                                                                                                                                                         |
| I <sub>PZQWR</sub> | When a VM is valid, the virtual SPI IST is made invalid by the following sequence:                                                                                                                                                                            |
|                    | <ol> <li>Software writes to IRS_VMAP_VISTR.</li> <li>The IRS performs a write to the level 2 VM table entry that updates L2_VMTE.SPI_IST_VALID from 1 to 0.</li> <li>The IRS reports that the effects of the write to IRS_VMAP_VISTR are complete.</li> </ol> |
|                    | See 3.3 <i>Coherency considerations for GIC data structures</i> for more information about ensuring that memory accesses are coherent between the IRS and a PE.                                                                                               |
| R <sub>JZQCG</sub> | If a virtual SPI IST for a VM becomes invalid, a VPE in the VM is resident on a PE, and a virtual SPI is the candidate HPPI for the Virtual Interrupt Domain, one of the following is true:                                                                   |
|                    | <ul><li>The candidate HPPI is acknowledged by the PE before the IST becomes invalid.</li><li>The candidate HPPI is not acknowledged and is no longer selected as the candidate HPPI for the VPE.</li></ul>                                                    |
| R <sub>sglwk</sub> | When a virtual SPI IST becomes invalid, if there are Accepted events for virtual SPIs targeting the VM that are not yet processed, all of the following are true:                                                                                             |
|                    | <ul><li>The events are dropped and have no effect on any interrupt.</li><li>If software error reporting is supported, the IRS is permitted to report an error.</li></ul>                                                                                      |
| I <sub>gvqdh</sub> | In the virtual SPI IST context, when the virtual SPI IST is valid and uses a 2-level structure, a virtual level 2 IST is made valid by writing to IRS_VMAP_L2_VISTR.                                                                                          |
|                    | The write specifies that the map applies to the SPI IST by setting IRS_VMAP_L2_VISTR.TYPE to SPI.                                                                                                                                                             |
|                    | The effects of the write are complete when IRS_VMT_STATUSR.IDLE is 1.                                                                                                                                                                                         |
|                    | See 4.7.1 Level 2 IST management for more information.                                                                                                                                                                                                        |

See also:

- 4.7 *The interrupt state table (IST)*
- 4.9 Virtualization data structures

### 4.10.2.1 Assigning physical SPIs to VMs

| D <sub>WGVHQ</sub> | A physical SPI is assigned to a VM when all of the following are true:                                                                                                                                         |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>A write sets IRS_SPI_VMR.VIRT to 1.</li> <li>The write specifies a valid VM.</li> <li>The write completes successfully as indicated by IRS_SPI_STATUSR.{V,IDLE} being {1,1}.</li> </ul>               |
| I <sub>KJJNL</sub> | Assigning SPIs to a VM is only supported when IRS_IDR0.VIRT is 1.                                                                                                                                              |
| ROOME              | When IRS_IDR0.VIRT is 0, IRS_SPI_VMR is RAZ/WI.                                                                                                                                                                |
| I <sub>bsyvr</sub> | When an SPI is statically assigned to the EL3 Interrupt Domain, it is not possible to assign the SPI to a VM.                                                                                                  |
|                    | Access to IRS_SPI_VMR is RAZ/WI when the SPI is assigned to the EL3 Interrupt Domain.                                                                                                                          |
| R <sub>pysml</sub> | For each SPI that is not statically assigned to the EL3 Interrupt Domain, it is IMPLEMENTATION DEFINED whether the SPI can be assigned to a VM.                                                                |
|                    | When support for assigning an SPI to a VM is implemented, the SPI is assigned to a VM in the Interrupt Domain where the SPI is assigned.                                                                       |
|                    | When support for assigning an SPI to a VM is not implemented, access to IRS_SPI_VMR, when that SPI is selected, is RAZ/WI.                                                                                     |
| I <sub>lkyqr</sub> | Arm recommends that when IRS_IDR0.VIRT is 1, for all SPIs that are connected to an interrupt input signal, that support for assigning the SPI to a VM is implemented.                                          |
| R <sub>NZFQQ</sub> | When an SPI is assigned to a VM, all of the following are true for the physical SPI:                                                                                                                           |
|                    | <ul><li>The SPI is not considered for a physical candidate HPPI.</li><li>The SPI is unreachable.</li></ul>                                                                                                     |
|                    | The effects on virtual SPIs to which physical SPIs are assigned are described in 4.10.4 Virtual interrupt signaling.                                                                                           |
| R <sub>nsthn</sub> | If a physical SPI is assigned to a VM, GIC System instructions that update the Pending state of the physical SPI are IGNORED.                                                                                  |
| R <sub>vynsp</sub> | When a physical SPI is assigned to a virtual SPI, the virtual SPI INTID is reset to its reset state.                                                                                                           |
|                    | If virtual 1ofN interrupt routing is not supported, the reset state of Routing mode for a virtual SPI is Targeted.                                                                                             |
|                    | When a physical SPI is unassigned from a virtual SPI, all of the following are true:                                                                                                                           |
|                    | <ul><li>The physical SPI INTID is reset to its reset state.</li><li>The virtual SPI INTID is reset to its reset state.</li></ul>                                                                               |
| I <sub>bgssv</sub> | The Trigger mode of an SPI determines the type of the events that the IRS generates for the SPI, regardless of whether the SPI is assigned to a VM.                                                            |
| R <sub>HHBSB</sub> | If IRS_SPI_VMR.VM_ID does not specify a valid VM for an SPI written to IRS_SPI_SELR, it is CONSTRAINED UNPREDICTABLE whether the SPI is treated as not being assigned to any VM, or assigned to an invalid VM. |
|                    | If the SPI is treated as being assigned to an invalid VM, all of the following are true:                                                                                                                       |
|                    | <ul><li>The SPI is not considered for the physical or virtual candidate HPPI for any PE.</li><li>The SPI is unreachable.</li></ul>                                                                             |

### 4.10.3 Virtual interrupt routing

| D <sub>PMQVK</sub> | The Routing mode of a virtual interrupt determines how the target VPE is selected for that interrupt in the following ways:                                                                                                                                                                            |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul><li> If the Routing mode is Targeted, the target VPE is the VPE specified by the interrupt Affinity.</li><li> If the Routing mode is 1ofN, the target VPE is determined dynamically.</li></ul>                                                                                                     |
| D <sub>szxhc</sub> | When an interrupt Routing mode is Targeted and the interrupt Affinity specifies a VPE, the interrupt is said to be <i>targeted to</i> that VPE.                                                                                                                                                        |
| I <sub>vsdpm</sub> | If the Routing mode of a virtual interrupt is Targeted, the interrupt Affinity specifies the target VPE. If the Routing mode of a virtual interrupt is 1ofN, the interrupt Affinity is IMPLEMENTATION DEFINED.                                                                                         |
| R <sub>bfgyb</sub> | IRS support for virtual 1ofN interrupt routing is optional.                                                                                                                                                                                                                                            |
| I <sub>JQMTB</sub> | IRS_IDR0.VIRT_ONE_N reports whether virtual 1ofN interrupt routing is supported.                                                                                                                                                                                                                       |
| R <sub>XLGVV</sub> | The value of IRS_IDR0.VIRT_ONE_N is the same across all Interrupt Domains, except for the EL3 Interrupt Domain, where VMs are not supported.                                                                                                                                                           |
|                    | The value of IRS_IDR0.VIRT_ONE_N is the same across all IRSs.                                                                                                                                                                                                                                          |
| R <sub>JCSBY</sub> | If virtual 1ofN interrupt routing is not supported, all of the following are true:                                                                                                                                                                                                                     |
|                    | <ul> <li>If a GIC System instruction generates an Interrupt Effect that sets the Routing mode of a virtual interrupt, the Routing mode remains set to Targeted regardless of the value provided in <xt>.</xt></li> <li>L2_ISTE.IRM is treated as 0 when a virtual IST becomes valid.</li> </ul>        |
| S <sub>qqdnd</sub> | When virtual 1ofN interrupt routing is not supported, the IRM field in the value encoded in the <xt> parameter of the GIC xDAFF System instruction is RESO and GIC xDRCFG instructions always return 0 in the IRM field in ICC_ICSR_EL1 when requesting the configuration of a virtual interrupt.</xt> |
|                    | This means that virtual 1ofN interrupts are treated as Targeted interrupts and are always delivered to the VPE specified by the interrupt Affinity.                                                                                                                                                    |
|                    | Hypervisor software can support virtual 1ofN interrupt routing in systems where virtual 1ofN interrupt routing is not implemented by emulating the 1ofN behavior.                                                                                                                                      |
|                    | Hypervisor software can emulate virtual 1ofN by trapping guest access to the configuration of virtual interrupts and maintain a shadow configuration of each interrupt used by the physical IRS and updating the target VPE of the shadow 1ofN interrupts to emulate a 1ofN selection algorithm.       |
| R <sub>tbbtw</sub> | Each virtual 1ofN interrupt can be acknowledged by at most one VPE.                                                                                                                                                                                                                                    |
| R <sub>fhdfl</sub> | The storage location for the Affinity of virtual 1ofN interrupts may be used for an IMPLEMENTATION DEFINED purpose to handle routing of virtual 1ofN interrupts, with the restriction that an Affinity value of 0 has no IMPLEMENTATION DEFINED meaning.                                               |
| R <sub>frmxl</sub> | An IRS is permitted to update the Affinity of virtual 1ofN interrupts.                                                                                                                                                                                                                                 |
| I <sub>byxvc</sub> | When virtual 1ofN is supported, the VPE can be configured to have 1ofN PE selection enabled or disabled by accessing IRS_VPE_CR0.DPS.                                                                                                                                                                  |
| R <sub>scwsj</sub> | When virtual 1ofN is supported, an IRS does not choose a VPE which has 1ofN PE selection disabled as the target VPE for a 1ofN interrupt.                                                                                                                                                              |
| R <sub>xmnzs</sub> | When virtual 1ofN is supported, the IRS Domain selects a target VPE for a reachable virtual 1ofN interrupt belonging to a valid VM in finite time, when all of the following are true:                                                                                                                 |
|                    | <ul> <li>The interrupt is Enabled.</li> <li>The interrupt is Pending.</li> <li>The interrupt is Inactive.</li> <li>At least one IRS is enabled.</li> <li>At least one VPE in the VM has 1ofN PE selection enabled.</li> </ul>                                                                          |

The target VPE is selected among the VPEs in the VM that the virtual 1ofN interrupt belongs to.

|                    | Note                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | The target VPE selection behavior does not guarantee that the interrupt is selected as the virtual candidate HPPI for a PE. For example, the selected target VPE may be masking the interrupt, the VPE may not be resident, another virtual interrupt may be the virtual candidate HPPI for the target VPE.                                                                                  |
| R <sub>skvbz</sub> | An IRS Domain may select a new target VPE for a virtual 1ofN interrupt at any time.                                                                                                                                                                                                                                                                                                          |
| R <sub>qyksh</sub> | When virtual 1ofN is supported, the mechanism that an IRS uses to select a target VPE among several possible target VPEs is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                          |
| $S_{RBXBB}$        | When virtual 1ofN is supported, the VPE 1ofN PE selection enable control may be used to support virtualization of IRS_PE_CR0.DPS.                                                                                                                                                                                                                                                            |
|                    | Arm expects that hypervisor software at EL2 traps the guest programming of the virtual IRS_PE_CR0.DPS field and configures the VPE accordingly.                                                                                                                                                                                                                                              |
| I <sub>DWNMY</sub> | When IRS_VPE_CR0.DPS is updated for a VPE that is resident on a PE, and a virtual 1ofN interrupt is selected as the virtual candidate HPPI for the VPE, one of the following is true:                                                                                                                                                                                                        |
|                    | <ul><li>The PE acknowledges the interrupt before IRS_VPE_STATUSR.IDLE is 1.</li><li>The PE does not acknowledge the interrupt.</li></ul>                                                                                                                                                                                                                                                     |
|                    | See 4.10.4 Virtual interrupt signaling for more information.                                                                                                                                                                                                                                                                                                                                 |
| 4.10.4             | Virtual interrupt signaling                                                                                                                                                                                                                                                                                                                                                                  |
| $R_{\text{GMMHX}}$ | The Pending state of a virtual LPI identified by an INTID and a VM ID is updated when all of the following are true:                                                                                                                                                                                                                                                                         |
|                    | <ul> <li>The virtual LPI as identified by the INTID is reachable.</li> <li>The VM as identified by the VM ID is valid.</li> <li>Any of the following occur: <ul> <li>An ITS generates an interrupt event that specifies the VM ID and INTID.</li> <li>A GIC System instruction generates an Interrupt Write Effect that updates the Pending state of the virtual LPI.</li> </ul> </li> </ul> |
|                    | Otherwise, the virtual LPI Pending state is not updated.                                                                                                                                                                                                                                                                                                                                     |
| Iydcmb             | The IRS SETLPI register does not support signaling virtual interrupts.                                                                                                                                                                                                                                                                                                                       |
| R <sub>cqtdt</sub> | The Pending state of a virtual SPI identified by an INTID and a VM ID is updated when all of the following are true:                                                                                                                                                                                                                                                                         |
|                    | <ul> <li>The virtual SPI as identified by the INTID is reachable.</li> <li>The VM as identified by the VM ID is valid.</li> <li>Any of the following occur: <ul> <li>An interrupt connected to an IRS as an SPI is asserted or de-asserted and generates an interrupt event for the virtual SPI because the SPI is assigned to the VM.</li> </ul> </li> </ul>                                |

 A GIC System instruction generates an Interrupt Write Effect that updates the Pending state of the virtual SPI.

Otherwise, the virtual SPI Pending state is not updated.

IBZFTGWhen a virtual interrupt is signaled to the IRS, the IRS updates the Pending state of the virtual interrupt regardless<br/>of whether the target VPE is resident or non-resident.

The IRS selects a virtual candidate HPPI for a VPE for an Interrupt Domain, when at least one virtual interrupt D<sub>HCZPD</sub> meets the virtual candidate HPPI conditions: • The interrupt is Enabled. • The interrupt is Pending. • The interrupt is Inactive. • One of the following is true: - The interrupt Routing mode is Targeted and the interrupt Affinity specifies the VPE. - The interrupt Routing mode is 1ofN and the VPE is selected as the target VPE for the interrupt. For a virtual Targeted interrupt whose interrupt Affinity specifies an invalid VPE that is updated from invalid to R<sub>bfymp</sub> valid, whether the interrupt is considered for the virtual candidate HPPI selection for the VPE depends on whether there is an update to the following states and configurations for the virtual interrupt: • Pending. • Active. • Enabled. · Routing mode. • Affinity. If there is no update to any of the mentioned states and configurations of the virtual interrupt after the VPE becomes valid, it is CONSTRAINED UNPREDICTABLE whether the interrupt is considered for the virtual candidate HPPI selection for the VPE. If there is an update to any of the mentioned states and configurations for the virtual interrupt after the VPE becomes valid, the virtual interrupt is considered for the virtual candidate HPPI selection for the VPE: For a VPE in a VM, all of the following apply to the virtual candidate HPPI selection: R<sub>CPCCK</sub> • If at least one interrupt satisfies the virtual candidate HPPI conditions, the IRS selects one of these as the virtual candidate HPPI in finite time. • If no interrupts satisfy the virtual candidate HPPI conditions, the IRS does not select any interrupt as the virtual candidate HPPI. R<sub>ZDTYM</sub> If more than one interrupt satisfies the virtual candidate HPPI conditions for a VPE in a VM, the IRS selects the interrupt with the highest Priority as the virtual candidate HPPI in finite time. If there is more than one virtual candidate HPPI with the same Priority, it is IMPLEMENTATION DEFINED which of those interrupts is selected as the virtual candidate HPPI. An IRS selects a virtual candidate HPPI for a connected PE in finite time, when all of the following are true: R<sub>VBPZM</sub> • There is a resident VPE on the PE. • The IRS is enabled for the Physical Interrupt Domain corresponding to the resident VPE. • There is at least one virtual interrupt that meets the virtual *candidate HPPI conditions* for the VPE. If the IRS Domain has selected a virtual candidate HPPI for a non-resident VPE, it might generate a VPE doorbell. I<sub>WZNJR</sub> See 4.10.7 VPE doorbells for more information. When a virtual candidate HPPI that has been selected for a VPE is no longer the virtual candidate HPPI for the R<sub>XBNGN</sub> VPE, and if the VPE is resident on a PE, one of the following is true: • The PE acknowledges the old virtual candidate HPPI within finite time. • The old virtual candidate HPPI is not acknowledged. If the IRS updates the configuration of an interrupt that has been selected as the virtual candidate HPPI for the R<sub>ZFVRC</sub> Virtual Interrupt Domain for a PE, and the interrupt configuration data was communicated to the PE, the IRS will select the same or a new virtual interrupt as the virtual candidate HPPI. The IRS then communicates the selected virtual candidate HPPI to the PE, including any updated interrupt configuration data, in finite time.

For more information about ordering of such events, see 2.12 Interrupt ordering model and synchronization requirements and Chapter B1 Interrupt ordering litmus tests.

See also:

• 4.8.4 Physical interrupt signaling

### 4.10.5 VPE selection and configuration

ISoftware accesses the configuration and samples the HPPI of a VPE by selecting the VPE and accessing one of the<br/>following registers:

- IRS\_VPE\_CR0.
- IRS\_VPE\_DBR.
- IRS\_VPE\_HPPIR.

Software selects a VPE by writing the VM ID and VPE ID to IRS\_VPE\_SELR.{VM\_ID,VPE\_ID} and writing 1 to IRS\_VPE\_SELR.S.

IRS\_VPE\_STATUSR.IDLE reports whether the effects of the write IRS\_VPE\_SELR.S are complete.

IRS\_VPE\_STATUSR.V reports whether the value written to IRS\_VPE\_SELR selected a valid VPE.

IRS\_VPE\_STATUSR.V is updated on a write to any of the following registers:

- IRS\_VPE\_CR0.
- IRS\_VPE\_DBR.
- IRS\_VPE\_HPPIR.
- IRS\_VPE\_SELR.

R<sub>MVDZK</sub> If a VPE is selected on more than one IRS in a multi-IRS system, and a write occurs to any of the VPE configuration registers on one IRS while IRS\_VPE\_STATUSR.IDLE is 0 on any other IRS for the same IRS Domain due to a write to the configuration registers, it is CONSTRAINED UNPREDICTABLE which one of the following is true:

- The write does not successfully update the VPE and IRS\_VPE\_STATUSR.V is 0 on one of the IRSs where a write occurs.
- None of the writes updates the VPE configuration.
- Both of the writes successfully update the VPE configuration in UNKNOWN order.
- R<sub>RLHSL</sub> When a VPE becomes valid, the VPE configuration is reset to the following values:
  - If virtual 1ofN is supported, the VPE can receive both Targeted and 1ofN interrupts.
  - If virtual 1ofN is not supported, the VPE can only receive Targeted interrupts.
  - There are no doorbell settings for the VPE.
- I<sub>MFSZW</sub> The configuration of a VPE when it becomes valid is consistent with a read of IRS\_VPE\_CR0.DPS returning 0, assuming the VPE is selected in IRS\_VPE\_SELR and there was no write to IRS\_VPE\_CR0 since the VPE became valid.
- $I_{HHWBZ}$  A write to any of the VPE configuration registers is only guaranteed to have successfully completed when IRS\_VPE\_STATUSR.{V,IDLE} is {1,1}.

If the VPE becomes invalid after the VPE is selected, a write to any of the VPE configuration registers results in IRS\_VPE\_STATUSR.V being 0.

I<sub>RXTXP</sub> A read of IRS\_VPE\_HPPIR returns whether there is a candidate HPPI for the selected VPE.

If there is a candidate HPPI for the selected VPE, IRS\_VPE\_HPPIR.{TYPE,ID} returns the INTID of the candidate HPPI.

IRS\_VPE\_HPPIR reports the virtual candidate HPPI for a VPE. When virtual 1ofN interrupt routing is not supported, the reported candidate HPPI is a targeted interrupt. When virtual 1ofN interrupt routing is supported, the reported candidate HPPI may be either a targeted or 1ofN virtual interrupt.

### 4.10.6 VPE residency

- D<sub>YTZXF</sub> The IRS tracks, for each VPE, whether the VPE is resident VPE, and if it is resident, which PE it is resident on. If a VPE is not resident on any PE, the VPE is *non-resident*.
- I LGVMO A VPE is made resident or non-resident on a PE as a result of a write to ICH\_CONTEXTR\_EL2.
- R<sub>ZFXNN</sub> If a write to ICH\_CONTEXTR\_EL2 to make a VPE resident specifies an invalid VPE, the write does not cause a VPE to be considered resident by the IRS.
- R<sub>JJKJV</sub> If a PE requests that a VPE is made resident on a PE when the VPE is already resident on another PE, it is CONSTRAINED UNPREDICTABLE which one of the following applies:
  - The request is IGNORED.
  - The request completes and all of the following are true:
    - It is CONSTRAINED UNPREDICTABLE which of the PEs are allowed to acknowledge and configure interrupts from the VPE context.
    - It is CONSTRAINED UNPREDICTABLE whether making a VPE non-resident from some or all of the PEs results in the VPE being resident on any PEs or non-resident.

To recover from the CONSTRAINED UNPREDICTABLE behavior, software makes the VPE non-resident on all PEs where it was previously made resident, and the VPE can subsequently be made resident on a single PE.

See also:

• 4.9 Virtualization data structures

### 4.10.7 VPE doorbells

G<sub>MGLGB</sub> The architecture provides a mechanism to signal a physical interrupt when a virtual interrupt is available for a non-resident VPE. This allows a hypervisor to make scheduling decisions about when to run a VPE.

- D<sub>JNQYP</sub> A *VPE doorbell* is the mechanism that generates a physical interrupt event when the VPE doorbell conditions are met.
- R<sub>CWZMW</sub> A VPE doorbell event is generated for a VPE, when all of the following *VPE doorbell conditions* are true:
  - The VPE is not resident on any PE.
  - The VPE doorbell settings are valid for the VPE.
  - A VPE doorbell is requested for the VPE.
  - Any of the following are true:
    - There is at least one Targeted virtual interrupt for the VPE that is Pending, Inactive, and Enabled.
    - The 1ofN doorbell conditions are met for the VM and the VPE is the 1ofN VPE doorbell target. See 4.10.8 *lofN doorbells* for more information.
  - The interrupt causing the doorbell event to be generated has a priority greater than or equal to the doorbell priority mask.

#### Note

The VPE doorbell priority mask is checked both when there is a Targeted virtual interrupt causing the VPE doorbell to be generated, and when the VPE doorbell is generated because the 1ofN doorbell conditions are met.

This means that when the 1ofN doorbell conditions are met, they only cause a VPE doorbell event to be generated when the virtual 1ofN interrupt Priority is greater than or equal to the doorbell priority mask.

R<sub>PCXCN</sub>

When a VPE is created, the doorbell settings for the VPE are not valid. The doorbell settings become valid when the VPE is selected using IRS\_VPE\_SELR and a write to IRS\_VPE\_DBR occurs.

| R <sub>KDQNS</sub> | When support for LPIs is implemented, VPE doorbells generate SET_EDGE targeting physical LPIs in the same Interrupt Domain as where the VPE is defined. Otherwise, the mechanism to signal a VPE doorbell is IMPLEMENTATION DEFINED. |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>GBLPY</sub> | An LPI used for a VPE doorbell can be configured the same way as any other LPI including configuring its Priority, Enabled value, Routing mode, and Affinity when relevant.                                                          |
| I <sub>KTNWK</sub> | The doorbell settings of a VPE can be accessed by selecting the VPE by writing its VM ID and VPE ID to IRS_VPE_SELR and accessing IRS_VPE_DBR.                                                                                       |
| I <sub>MZXXV</sub> | The interrupt used for the VPE doorbell is programmed by writing to IRS_VPE_DBR.INTID.                                                                                                                                               |
| $D_{MGQPJ}$        | A VPE doorbell is <i>requested</i> when IRS_VPE_DBR.REQ_DB is 1.                                                                                                                                                                     |
| I <sub>CVJVS</sub> | A VPE doorbell is requested in any of the following ways:                                                                                                                                                                            |
|                    | <ul> <li>When software makes a VPE non-resident, it can program whether a VPE doorbell is requested.</li> <li>Software can access IRS_VPE_DBR.REQ_DB using the VPE selection and configuration interface on an IRS.</li> </ul>       |
| R <sub>WTZVF</sub> | Once a VPE doorbell event is generated, the doorbell is no longer requested for the VPE.                                                                                                                                             |

#### Note

The above rules mean that if a VPE doorbell is requested and a corresponding event is generated, an event is only generated once, until it is requested again, because the doorbell stops being requested when an event is generated.

- Once a VPE doorbell event has been generated, no further VPE doorbell events will be generated for that VPE SRGZBY until the VPE doorbell is requested again. The VPE doorbell may be requested again by hypervisor software after m aking the VPE resident and subsequently making it non-resident. IRS VPE DBR.REQ DB reflects the value of ICH CONTEXTR EL2.DB when the VPE was last made ISRMLF non-resident, or the last write to IRS\_VPE\_DBR.REQ\_DB, whichever happened last. Once a VPE doorbell event is generated, this bit is cleared. A doorbell priority mask is set when the PE makes a VPE non-resident and requests a VPE doorbell. The IRS IBWQVY Domain only generates a VPE doorbell if there is a virtual interrupt for the VPE with a priority greater than or equal to the minimum priority programmed in the doorbell priority mask, accessible via IRS\_VPE\_DBR.DBPM. When making a VPE non-resident, ICH CONTEXTR EL2.DBPM sets the minimum priority for a virtual interrupt SWWFWZ to trigger the VPE doorbell. Software can use this field to ensure that doorbells are only generated for virtual interrupts which would be handled by the VPE if it were resident. When the VPE doorbell conditions are met, the VPE doorbell interrupt event is generated in finite time. RDXSYV If the VPE doorbell conditions are met for a short amount of time and are then no longer met, for example due to a reconfiguration of an interrupt, and the VPE doorbell event was not yet generated, it is IMPLEMENTATION DEFINED whether a VPE doorbell event is generated.
- R<sub>RFWPN</sub> If a VPE doorbell event is generated for an INTID that is unreachable, the event is treated as any other interrupt event for an unreachable INTID and the event does not make any interrupt Pending.
- $I_{XJQLG}$  If a VPE doorbell event is generated for an INTID that is unreachable, the doorbell is no longer requested for the VPE.
- I<sub>DTTDM</sub> If a VPE doorbell event is generated for an INTID that is unreachable, and software error reporting is supported, this error is reported in IRS\_SWERR\_STATUSR.

- R<sub>DHHRM</sub> If a VPE doorbell uses an LPI where any of the following are true, it is CONSTRAINED UNPREDICTABLE whether the IRS makes the LPI Pending when the VPE doorbell event is generated, and whether any IRS synchronization requests affect the LPI:
  - There is an ITS mapping to the LPI.
  - There is another VPE doorbell that uses the LPI.

See also:

• 2.10.6 *Requesting VPE doorbells* 

### 4.10.8 1ofN doorbells

- G<sub>THLBD</sub> The architecture supports generating a VPE doorbell event when there is a virtual 1ofN interrupt for a VM and there are no resident VPEs with 1ofN PE selection enabled for the VM. This allows a hypervisor to make scheduling decisions about when to run a VPE to handle a 1ofN interrupt.
- D<sub>FJTLC</sub> A *lofN doorbell* is the mechanism that generates a VPE doorbell when the lofN doorbell conditions are met. The VPE doorbell is generated for the *lofN VPE doorbell target*.
- I<sub>JRYKN</sub> The 1ofN doorbell configuration for a VM is managed by selecting the VM and accessing IRS\_VM\_DBR.

Software selects a VM by writing the VM ID to IRS\_VM\_SELR.VM\_ID.

IRS\_VM\_STATUSR.IDLE reports whether the effects of the write IRS\_VM\_SELR are complete.

IRS\_VM\_STATUSR.V reports whether the value written to IRS\_VM\_SELR selects a valid VM.

IRS\_VM\_STATUSR.V is updated on a write to any of the following registers:

- IRS\_VM\_SELR.
- IRS\_VM\_DBR.
- I<sub>NWBYP</sub> Whether 1ofN doorbells are enabled or disabled for the VM is programmed in IRS\_VM\_DBR.EN.
- I<sub>FKZMP</sub> The 1ofN VPE doorbell target is programmed in IRS\_VM\_DBR.VPE\_ID.
- D<sub>QTNVT</sub> The *lofN doorbell conditions* are met when all of the following are true:
  - Virtual 1ofN interrupt routing is supported.
  - There is no VPE belonging to the VM where all of the following are true:
    - The VPE is resident.
    - The VPE has 1ofN PE selection enabled.
  - 1ofN doorbells are enabled for the VM.
  - There is at least one virtual 1ofN interrupt for the VM that is Pending, Inactive, and Enabled.

See 4.10.7 VPE doorbells for more information about additional conditions for generating a VPE doorbell event.

 $R_{VVLPV}$  When a VM is made valid, 1ofN doorbells are disabled for the VM.

### 4.10.9 Save and restore of virtual interrupts

G<sub>NSYHS</sub> The architecture is designed to support saving the state and configuration of all virtual interrupts in a VM to memory, and restoring the saved state and configuration from memory.

This is to support common virtualization use cases such as VM live migration across physical hosts, snapshotting of VM state, and provisioning of VMs from a pre-booted state.

D<sub>CZQCL</sub> This chapter refers to saving the state of a *source* VM and restoring it to a *destination* VM.

This is regardless of whether the source and destination VMs are running on separate physical machines, are separate VMs with distinct VM IDs on the same physical machine, or are separate instances of a VM executing at different times with the same VM ID on the same physical machine.

| A VM is <i>Quiesced</i> if all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>No VPEs in the VM are resident.</li> <li>There is no change in the Pending state of any virtual interrupt for the VM.</li> <li>There is no change to the number of valid PEs in the VM.</li> <li>The VM does not become invalid.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| To Quiesce a VM, software should ensure that all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <ul> <li>The Pending states of LPIs are not updated by events from an ITS.</li> <li>The Pending states of SPIs are not updated by events generated by the IRS.</li> <li>The Pending states of LPIs or SPIs are not updated as a result of executing the GIC xDPEND instruction on a PE.</li> <li>No VPE is resident.</li> <li>The virtual LPI IST and virtual SPI IST do not become valid or invalid.</li> <li>No VPE in the VM is made valid.</li> <li>The VM is not made invalid.</li> </ul>                                                                                                                                                                                                                                                                                                                                             |
| Software can prevent updates to virtual interrupts belonging to a VM when saving the state of virtual interrupts by using any of the following mechanisms:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <ul> <li>Preventing devices from generating interrupts for the VM.</li> <li>Unmapping ITS events that are mapped to virtual interrupts belonging to the VM.</li> <li>Issuing a synchronization request on every ITS that had events mapped to virtual interrupts belonging to the VM.</li> <li>Unassigning SPIs that are assigned to virtual SPIs in the VM.</li> <li>Issuing a synchronization request on all IRSs in the system.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                              |
| To support saving the state of a source VM and restoring it to a destination VM, software is expected to perform the following steps:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| <ol> <li>Quiesce the source VM.</li> <li>Save the state and configuration of all virtual interrupts to the virtual ISTs.</li> <li>Save a copy of the virtual IST from the source VM.</li> <li>Scan the copy of the virtual IST and record which virtual interrupts are Pending.</li> <li>Update all entries in the copy of the virtual IST as follows:         <ol> <li>Set the L2_ISTE.Pending field to 0.</li> <li>Set the metadata area to 0 if IRS_IDR0.ONE_N is 1.</li> <li>Set the metadata area to 0 if IRS_IDR2.ISTMD is 1.</li> </ol> </li> <li>Configure the destination VM to use the copy of the virtual IST as the new IST.</li> <li>Make the new virtual IST valid.</li> <li>For each virtual interrupt that was recorded as Pending, make the virtual interrupt Pending using the GIC VDPEND System instruction.</li> </ol> |
| The destination VM must be configured with valid VPEs before making the virtual interrupts Pending to ensure that the interrupts are considered for the virtual candidate HPPI for the VPEs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| The state and configuration of virtual interrupts is written to the virtual ISTs by writing the VM ID to IRS_SAVE_VMR.VM_ID and writing 1 to IRS_SAVE_VMR.S when the VM is Quiesced.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| The operation is complete when IRS_SAVE_VM_STATUSR.IDLE is 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Following a write that sets IRS_SAVE_VMR.S or IRS_SAVE_VMR.Q to 1, IRS_SAVE_VM_STATUSR.Q reports whether the VM is Quiesced since the last write that set IRS_SAVE_VMR.S to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

Saving the state and configuration of virtual interrupts applies to the ISTs that are valid for the VM. For example,

|                    | if a VM does not have a virtual SPI IST, but does have a valid virtual LPI IST, writing 1 to IRS_SAVE_VMR.S saves the state of the virtual LPIs to the virtual LPI IST.                                                                                                                                         |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $R_{XPMBB}$        | Following a write that sets IRS_SAVE_VMR.S to 1, for as long as the specified VM is Quiesced, the values stored in the virtual ISTs are consistent with the state and configuration of the virtual interrupts.                                                                                                  |
| I <sub>dbsgd</sub> | Saving the state and configuration of virtual interrupts is requested on any IRS and saves the state of all virtual interrupts for the VM to the virtual IST. In a multi-IRS system, an implementation coordinates this operation across all IRSs.                                                              |
| R <sub>CFDQJ</sub> | If a write occurs to IRS_SAVE_VMR when IRS_SAVE_VM_STATUSR.IDLE is 0 on any other IRS for the same IRS Domain, it is CONSTRAINED UNPREDICTABLE whether the state and configuration of virtual interrupts are saved to the virtual ISTs and the value returned in IRS_SAVE_VM_STATUSR.Q is UNKNOWN on both IRSs. |
| I <sub>SYNGG</sub> | Following a write that sets IRS_SAVE_VMR.S to 1, the state and configuration of virtual interrupts are stored in the virtual ISTs using the format defined in 11.2.4 <i>L2_ISTE, Level 2 interrupt state table entry</i> .                                                                                      |

### 4.11 IRS power management

| G <sub>CRTDH</sub> | The architecture supports implementations that enable the following power management operations:                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>System suspend and resume: All interrupt state and configuration, and register state of all IRSs in the system for all Interrupt Domains, is stored to memory on suspend and restored from memory on resume.</li> <li>Opportunistic power management: The system may decide to power down one or more IRSs while preserving the illusion to software that the IRSs are fully operational.</li> </ul>                                                                                                           |
| R <sub>FYSXL</sub> | Support for system suspend and resume is supported using an IMPLEMENTATION DEFINED sequence.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | The IMPLEMENTATION DEFINED sequence must support saving all of the following to memory for all Interrupt Domains:                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | <ul> <li>Physical LPI state and configuration.</li> <li>Physical SPI state and configuration.</li> <li>If virtualization is supported in the Interrupt Domain, GIC-managed state related to the VM table, including all of the following: <ul> <li>State and configuration of virtual interrupts stored in the virtual ISTs.</li> <li>State stored in the VM descriptors, including the configuration of VMs.</li> <li>State stored in the VPE descriptors, including the configuration of VPEs.</li> </ul> </li> </ul> |
|                    | The IMPLEMENTATION DEFINED sequence must support restoring all of the information from memory to the values saved during suspend.                                                                                                                                                                                                                                                                                                                                                                                       |
| I <sub>XHGLK</sub> | Data structures used by mechanisms for IRS save and restore for system suspend are IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                                                                                                                                                                                              |
| S <sub>NWXQM</sub> | Arm expects that system suspend and resume is managed by system-specific software.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| $R_{HJFWL}$        | Support for opportunistic power management is IMPLEMENTATION DEFINED. The opportunistic power management sequence must preserve the illusion to software that the IRSs remain powered on.                                                                                                                                                                                                                                                                                                                               |
| D <sub>bgyzw</sub> | Each PE connected to an IRS is either offline or online.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                    | Arm expects that a PE is offline when the PE is physically powered off and is unable to execute GIC System instructions or write to GIC System registers.                                                                                                                                                                                                                                                                                                                                                               |
| I <sub>TCRZH</sub> | Whether a PE is online or offline is reported in IRS_PE_STATUSR.ONLINE for the PE selected in IRS_PE_SELR.                                                                                                                                                                                                                                                                                                                                                                                                              |
| R <sub>PMSHG</sub> | The mechanism to detect whether a PE is offline or online is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| D <sub>xgkck</sub> | When a PE is offline, the IRS generates a Wake Request to a PE to bring it online.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| R <sub>CLDWD</sub> | The mechanism through which an IRS generates a Wake Request to a PE is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| R <sub>hpcry</sub> | When the IRS generates a Wake Request to a PE, the request is generated in finite time.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                    | The Wake Request does not guarantee that the PE becomes online. The Wake Request is treated as a hint to the power control subsystem.                                                                                                                                                                                                                                                                                                                                                                                   |
| I <sub>FYYJF</sub> | When a PE becomes offline, and the PE is not expected to become online when receiving a Wake Request, Arm strongly recommends that the system is configured to avoid sending Wake Requests to the PE.                                                                                                                                                                                                                                                                                                                   |
|                    | The system is configured not to generate Wake Requests to the PE when all of the following are true for all IRS Domains:                                                                                                                                                                                                                                                                                                                                                                                                |
|                    | <ul><li>No Targeted interrupts are programmed to target the PE.</li><li>10fN PE selection is disabled for the PE.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                             |
|                    | An example of when a PE is not expected to become online when receiving a Wake Request is PSCI_CPU_OFF. See <i>Arm<sup>®</sup> Power State Coordination Interface</i> [8] for more information about PSCI.                                                                                                                                                                                                                                                                                                              |
| $R_{\rm YPBHL}$    | When a PE is offline, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                    | • The PE does not execute any instructions that generate Interrupt Effects.                                                                                                                                                                                                                                                                                                                                                                                                                                             |

• If the IRS has selected a physical candidate HPPI for a PE for any Interrupt Domain, and the IRS is enabled for that Interrupt Domain, the IRS generates a Wake Request to the PE.

When a PE is online, the IRS does not generate any Wake Requests to the PE.

R<sub>FVFKC</sub> When a PE becomes offline and the IRS has selected any candidate HPPIs for the PE, each candidate HPPI is either acknowledged before the PE becomes offline or is not acknowledged while the PE is offline.

When the PE subsequently becomes online, any selected candidate HPPIs for the PE for enabled Interrupt Domains, can be acknoweldged by the PE.

## 4.12 IRS memory access rules

| R <sub>vhrsj</sub> | All IRS data structures are little-endian.                                                                                                                                                                                                                                                                                                         |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>frxxQ</sub> | The IRS accesses all its data structures using Normal memory types. See [1] for more information about memory access types.                                                                                                                                                                                                                        |
| S <sub>XFKQH</sub> | Software allocates memory for the data structures and programs the physical address of the allocated data structures in IRS registers. Arm expects that such allocations will typically be done from Conventional memory.                                                                                                                          |
| I <sub>dpjzk</sub> | IRS_CR1 specifies the Shareability and Cacheability attributes for memory accesses performed by the IRS.                                                                                                                                                                                                                                           |
|                    | Changes to IRS_CR1 can only be made when the IRS does not access memory, specifically when no data structures are valid on the IRS.                                                                                                                                                                                                                |
|                    | The most recent values written to IRS_CR1 are used when the IRS accesses memory following a write to make any data structure valid.                                                                                                                                                                                                                |
|                    | Arm recommends that IRS_CR1 is initialized with the same Shareability and Cacheability attributes on all IRSs in the system for an IRS Domain before making any data structures valid.                                                                                                                                                             |
| R <sub>XKMVR</sub> | An IRS does not access any memory location which is not derived from address and configuration data stored in registers and structures belonging to the IRS Domain.                                                                                                                                                                                |
|                    | When a memory address is stored in an address field in a register or data structure entry, and that register or entry includes a field indicating that the address is not valid, the IRS does not derive any memory location from that address field.                                                                                              |
|                    | This includes scenarios in which the IRS behavior is CONSTRAINED UNPREDICTABLE, UNPREDICTABLE, or IMPLEMENTATION DEFINED.                                                                                                                                                                                                                          |
| I <sub>GTTMT</sub> | When a memory address is stored in a data structure, and that entry includes a field indicating whether the address is valid, the address only becomes invalid as a result of a write to an IRS map register.                                                                                                                                      |
|                    | In this case, IRS Domain is guaranteed to not derive an address from the entry once the effects of the write to the map register are complete.                                                                                                                                                                                                     |
| R <sub>CPXND</sub> | When the IRS accesses an IRS data structure, and the contents of that data structure are not defined as UNKNOWN at the time of the access, the access must be a 64-bit aligned, single-copy atomic access of at least 64 bits in size.                                                                                                             |
|                    | For data structures where the entries are smaller than 64 bits, accesses are permitted to be smaller than 64 bits, provided that each access is:                                                                                                                                                                                                   |
|                    | <ul> <li>Single-copy atomic,</li> <li>exactly the size of the entry, and</li> <li>aligned to the size of the entry.</li> </ul>                                                                                                                                                                                                                     |
| R <sub>LRRFV</sub> | If an IRS access to any IRS data structure is performed into any PCIe address space, then the IRS is permitted to return an UNKNOWN value or terminate the access and report the error.                                                                                                                                                            |
|                    | In this case, the IRS is permitted to stop the operation as follows:                                                                                                                                                                                                                                                                               |
|                    | <ul> <li>If the operation was due to an incoming interrupt event, the IRS is permitted to drop the interrupt event.</li> <li>If the operation was requested as the result of executing a GIC System instruction or writing to a GIC System register, the IRS is permitted to indicate a failure back to the PE or IGNORE the operation.</li> </ul> |
| R <sub>rfylf</sub> | When an IRS accesses a memory location in a PAS, it relies on information stored in registers and data structures structures that are accessible only within the same PAS to validate that the access is permitted.                                                                                                                                |
|                    | This includes scenarios in which the IRS behavior is CONSTRAINED UNPREDICTABLE, UNPREDICTABLE, or IMPLEMENTATION DEFINED.                                                                                                                                                                                                                          |

For example, an IRS access to a data structure is permitted only if the memory location lies within a region defined by a base address and size held in a register or another data structure entry, where that defining information resides in the same PAS as the access itself.

This prevents software running in a Security state from directing the IRS to access any memory location using another PAS than the one associated with the software's Security state.

IFJRHT If the IRS experiences an external abort during a memory access to an IRS data structure, the IRS stops the operation.

If software error reporting is supported, the error is reported with IRS\_SWERR\_STATUSR.EC.

- R<sub>LVNHK</sub> If the IRS experiences an external abort during a memory access to an IRS data structure, it is IMPLEMENTATION DEFINED whether the IRS reports a RAS error using an IMPLEMENTATION DEFINED mechanism.
- R<sub>GZJNW</sub> If the IRS experiences an external abort as part of an operation that occurs as a result of a GIC System instruction or write to a GIC System register on a PE, the effects of the instruction are UNKNOWN and the IRS may optionally report an error.
- For example, if the IRS experiences an external abort when trying to access the IST as part of handling a GIC  $\rightarrow$  xDDIS instruction, the instruction is permitted to execute as a NOP and the IRS is permitted to report an error using the software error reporting mechanism and by raising IMPLEMENTATION DEFINED RAS errors if the abort is caused by a memory system error.
- IDPEMSAs another example, if the IRS experiences an external abort when trying to access the IST as part of handling<br/>a GIC xDRCFG instruction, the IRS is permitted to indicate a failure to the PE that results in ICC\_ICSR\_EL1.F<br/>being set to 1, and the IRS may optionally report an error.
- R<sub>KMZHR</sub> If the IRS experiences an external abort as part of processing an interrupt that is being signaled, the effects on the state and configuration of the signaled interrupt is UNKNOWN and the IRS is permitted to drop the event. The IRS may optionally report an error using the software error reporting mechanism and by raising IMPLEMENTATION DEFINED RAS errors if the abort is caused by a memory system error.
- R<sub>ZRWQP</sub> If an IRS data structure overlaps with any other IRS or ITS data structure, the IRS behavior is UNPREDICTABLE. This applies to both IRS data structures for physical and virtual interrupts.

The UNPREDICTABLE behavior may result in loss of interrupt configuration and state, but must not result in access to memory outside the PAS associated with the IRS Domain or in access to any memory location which is not derived from address and configuration data in valid IRS registers.

Software can recover from this situation by performing the following sequence:

- 1. Disabling the ITS.
- 2. Making the corresponding data structures invalid in the IRS.
- 3. Reconfigure the base addresses of the data structure to avoid any overlap.

See also 5.3 Translation structures.

 $I_{QTYKR}$  The following changes to system state when an interrupt event is processed by an IRS are not required to result in a write to memory:

- Interrupt Write effects generated by interrupt events.
- Interrupt Write effects generated by GIC System instructions executed on a PE.
- Configuration changes generated by GIC System instructions executed on a PE.
- Configuration changes generated by writes to IRS registers.

In these cases, the change to system state does not correspond directly to any Memory Write effect to IRS data structures.

However, the change may cause an update to architecturally invisible IRS caches and Memory Write effects to write back cached data to IRS data structures where the content of the data structure is described as UNKNOWN.

# Chapter 4. Interrupt routing service (IRS) 4.12. IRS memory access rules

R<sub>FZBVM</sub> An IRS is permitted to implement caching of interrupt state, VMs, and VPE configurations using architecturally invisible IRS-specific caches.

The IRS caches are not considered data or system caches belonging to the memory system, meaning they are not managed by any cache maintenance instructions issued by a PE.

When an IRS data structure is invalid, the IRS does not cache previously accessed data in IRS-specific caches.

## 4.13 IRS support for MPAM

 $I_{LKQJP}$  The Memory System Resource Partitioning and Monitoring Memory, MPAM, architecture defines per-transaction attributes that affect system behavior of the behavior of components that the transactions pass through or Completers that satisfy a transaction [1].

The additional attributes are two identifiers:

- Partition ID, or PARTID.
- Performance Monitoring Group, or PMG.

The PARTID and PMG are both interpreted within a PARTID space. The PARTID space used depends on the Security state associated with an IRS Domain, and the PARTID and PMG values used may be programmed independently for each IRS Domain. See [1] for more information about MPAM information bundles.

| I <sub>WXHXM</sub> | In the IRS, support for MPAM, is indicated in IRS_IDR0.MPAM.                                                                      |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------|
|                    | If MPAM is supported, the supported PARTID and PMG width is indicated in IRS_MPAM_IDR.{PARTID_MAX,PMG_MAX}.                       |
| $R_{\rm RMZLS}$    | If MPAM is supported, IRS accesses to memory are associated with the PARTID and PMG programmed in IRS_MPAM_PARTID_R.{PARTID,PMG}. |
| I <sub>NSQVT</sub> | In systems without support for RME, the PARTID space used by the IRS is determined by the memory system attribute MPAM_NS.        |
|                    | In systems with support for RME, the PARTID space used by the IRS is determined by the memory system attribute MPAM_SP.           |
| I <sub>hhrjr</sub> | The IRS architecture has optional support for MPAM PARTID space selection indicated by IRS_MPAM_IDR.HAS_MPAM_SP.                  |
|                    | If IRS_MPAM_IDR.HAS_MPAM_SP is 0, each IRS for each Interrupt Domain uses a default MPAM PARTID space.                            |

The following table shows the MPAM PARTID space used for accesses made by the IRSs for each Interrupt Domain if IRS\_MPAM\_IDR.HAS\_MPAM\_SP is 0 and the system does not support RME:

| Interrupt Domain | MPAM PARTID space       |  |  |
|------------------|-------------------------|--|--|
| Secure           | Secure PARTID space     |  |  |
| Non-Secure       | Non-secure PARTID space |  |  |
| EL3              | Secure PARTID space     |  |  |

The following table shows the MPAM PARTID space used for accesses made by the IRSs for each Interrupt Domain if IRS\_MPAM\_IDR.HAS\_MPAM\_SP is 0 and the system supports RME:

| Interrupt Domain | MPAM PARTID space       |  |  |  |
|------------------|-------------------------|--|--|--|
| Secure           | Secure PARTID space     |  |  |  |
| Non-Secure       | Non-secure PARTID space |  |  |  |
| EL3              | Root PARTID space.      |  |  |  |
| Realm            | Realm PARTID space.     |  |  |  |

# Chapter 4. Interrupt routing service (IRS) 4.13. IRS support for MPAM

If IRS\_MPAM\_IDR.HAS\_MPAM\_SP is 1, the IRS uses the MPAM PARTID specified by IRS\_MPAM\_PARTID\_R.MPAM\_SP.

R<sub>NWLJQ</sub> If an IRS without support for MPAM is integrated in a system that supports MPAM, the PARTID and PMG used for each IRS for each Interrupt Domain is IMPLEMENTATION DEFINED.

## 4.14 IRS support for Memory Encryption Contexts

| I <sub>fpymt</sub> | The Memory Encryption Contexts feature, FEAT_MEC, provides finer-grained memory encryption contexts, within the Realm physical address space, to be assigned to Realms, with policy controlled by Realm EL2 [1].                                                                                                                                                                                                                                                                                                                            |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $G_{\rm HJFYY}$    | The GICv5 architecture ensures that an IRS can function correctly in systems with support for Memory Encryption Contexts (MEC).                                                                                                                                                                                                                                                                                                                                                                                                             |
| I <sub>hjnxc</sub> | In a system with support for MEC, data may be shared between the PEs and an IRS in the following scenarios:                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                    | <ul><li>A PE allocates and initializes data structures used by an IRS.</li><li>An IRS writes the contents of virtual ISTs to memory to support VM migration.</li></ul>                                                                                                                                                                                                                                                                                                                                                                      |
|                    | In such a system, all IRS Realm data structures are managed and configured by Realm EL2, and virtualized software running at EL1 is not expected to have direct access to the IRS configuration registers. Therefore, the IRS only supports configuration of a single MECID used for all IRS memory accesses to the Realm PAS. This allows software running at Realm EL2 to initialize data structures that are read by the IRS and allows the IRS to write the content of the virtual ISTs that are read by software running at Realm EL2. |
| I <sub>YQFXX</sub> | Support for Memory Encryption Contexts (MEC) for an IRS is indicated in IRS_IDR0.MEC for the Realm Interrupt Domain. If the MEC feature is supported, the supported MECID width is indicated in IRS_MEC_IDR.MECIDSIZE for the Realm Interrupt Domain.                                                                                                                                                                                                                                                                                       |
|                    | Arm strongly recommends that the MECID bit width supported by the IRS matches or exceeds the width supported by the PEs in the system.                                                                                                                                                                                                                                                                                                                                                                                                      |
| R <sub>ygvpr</sub> | If the MEC feature is supported, IRS accesses to memory are associated with a MECID that identifies the Memory Encryption Context of the access.                                                                                                                                                                                                                                                                                                                                                                                            |
| R <sub>qkqqw</sub> | Accesses made by the IRS for Secure, Non-secure, and Root PA spaces are issued with the default MECID of zero.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| I <sub>tkdgt</sub> | Accesses made by the IRS to Realm PA space are associated with the global Realm PAS IRS MECID programmed in IRS_MEC_MECID_R.MECID.                                                                                                                                                                                                                                                                                                                                                                                                          |
| R <sub>KCCQN</sub> | If an IRS without support for the Realm Interrupt Domain is integrated in a system that supports MEC, all IRS accesses for that IRS are treated as having the default MECID of zero.                                                                                                                                                                                                                                                                                                                                                        |
| R <sub>gmpjj</sub> | In a multi-IRS system, if all of the following are true, the IRS Domain behavior is UNPREDICTABLE:                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | <ul> <li>One of the following is true:</li> <li>IRS_IST_BASER.VALID is 1.</li> <li>IRS_VMT_BASER.VALID is 1.</li> <li>An IRS uses a different MECID than another IRS, for the same PA space.</li> </ul>                                                                                                                                                                                                                                                                                                                                     |
|                    | The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                |

The UNPREDICTABLE behavior must not result in access to memory outside the PAS associated with the Interrupt Domain or in an access to memory that does not follow the behaviors described in 4.12 *IRS memory access rules*.

To recover from the UNPREDICTABLE behavior, the IRS data structures are made invalid and the same MECID is configured across all IRSs for the same PA space.

## 4.15 IRS support for software error reporting

| I <sub>gzrss</sub> | The IRS specifies a mechanism to report errors because of incorrect programming.                                                                                                                                                                                                                                                                                                                                       |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>QWVQB</sub> | The IRS detects software errors when it performs any of the following operations:                                                                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>The IRS processes an interrupt event in response to a signaled interrupt.</li> <li>The IRS accesses state and configuration of interrupts in response to any of the following events: <ul> <li>A system register access in the PE interface.</li> <li>Execution of a GIC system instruction in the PE interface.</li> <li>An MMIO access via the IRS configuration register frame.</li> </ul> </li> </ul>     |
| I <sub>tqqts</sub> | Updates to the state and configuration of interrupts via the PE interface or the MMIO interface can be cached in the IRS caches. The IRS could experience an external abort, when it commits the cached information to the IRS data structures in memory at a specified address. The IRS uses the software error reporting mechanism to indicate such errors.                                                          |
|                    | For example, an update to the configuration of a physical LPI is cached in the IRS caches. The address of the physical IST in IRS_IST_BASER.ADDR is invalid, and the IRS experiences an external abort when it commits the cached information to the L2_ISTE in memory. The IRS sets IRS_SWERR_STATUSR.EC to report this error.                                                                                        |
|                    | Due to the effects of caching, this error could be reported after the operation to update the configuration of the physical LPI has completed from software's perspective. This means that two reads of IRS_SWERR_STATUSR can report errors without any interrupts or GIC System instructions executed on a PE having been processed by the IRS between the two reads.                                                 |
| R <sub>YHKJZ</sub> | IRS support for software error reporting is optional.                                                                                                                                                                                                                                                                                                                                                                  |
| I <sub>NMHQJ</sub> | IRS_IDR0.SWE reports whether software error reporting is supported.                                                                                                                                                                                                                                                                                                                                                    |
| R <sub>hwqtk</sub> | The value of IRS_IDR0.SWE is the same for all Interrupt Domains in an IRS in the system.                                                                                                                                                                                                                                                                                                                               |
| I <sub>ZTBKN</sub> | When IRS_IDR0.SWE is 1, the IRS uses the IRS_SWERR_STATUSR.IMP_EC to report any IMPLEMENTATION DEFINED errors detected by the IRS.                                                                                                                                                                                                                                                                                     |
| I <sub>NLLSH</sub> | IRS_SWERR_STATUSR.EC is 0 when an IMPLEMENTATION DEFINED error is reported by the IRS.                                                                                                                                                                                                                                                                                                                                 |
| I <sub>YMQZW</sub> | Software error information can be read on each IRS for each Interrupt Domain via the following registers:                                                                                                                                                                                                                                                                                                              |
|                    | <ul> <li>IRS_SWERR_STATUSR.</li> <li>IRS_SWERR_SYNDROMER0.</li> <li>IRS_SWERR_SYNDROMER1.</li> </ul>                                                                                                                                                                                                                                                                                                                   |
| I <sub>fcyct</sub> | When a software error is reported, the value of IRS_SWERR_STATUSR.V is 1. Otherwise, no software error is reported and fields in this register are UNKNOWN.                                                                                                                                                                                                                                                            |
| I <sub>ZLMMJ</sub> | When the value of IRS_SWERR_STATUSR.V is 1, all of the following are true:                                                                                                                                                                                                                                                                                                                                             |
|                    | <ul> <li>IRS_SWERR_STATUSR.EC specifies the fault that caused the software error.</li> <li>IRS_SWERR_STATUSR.S0V indicates whether IRS_SWERR_SYNDROMER0 contains valid error syndrome information.</li> <li>IRS_SWERR_STATUSR.S1V indicates whether IRS_SWERR_SYNDROMER1 contains valid error syndrome information.</li> <li>IRS_SWERR_STATUSR.OF indicates whether multiple software errors were detected.</li> </ul> |
| I <sub>DMCGM</sub> | When IRS_SWERR_STATUSR.SOV is 1, IRS_SWERR_SYNDROMER0 reports the following information for the software error:                                                                                                                                                                                                                                                                                                        |
|                    | <ul><li>The type and ID of the interrupt that resulted in the software error.</li><li>Whether the interrupt is virtual or physical.</li></ul>                                                                                                                                                                                                                                                                          |

• If the interrupt is virtual, the VM ID of the VM that the interrupt is assigned to.

- I<sub>HQSCK</sub> When IRS\_SWERR\_STATUSR.S1V is 1, IRS\_SWERR\_SYNDROMER1 reports the address of the IRS data structure associated with the software error.
- R<sub>XBYRF</sub> For each reported error, the values of IRS\_SWERR\_STATUSR.{S0V,S1V} are IMPLEMENTATION DEFINED and set independently.
- S<sub>MTHCH</sub> Arm recommends that software performs the following sequence to either clear the last error, or detect whether new errors were reported:
  - 1. Read IRS\_SWERR\_STATUSR and determine which fields need to be cleared to zero.
  - 2. In a single-copy atomic write to IRS\_SWERR\_STATUSR:
    - 1. Write ones to all the W1C fields that are nonzero in the read value.
    - 2. Write zero to all the W1C fields that are zero in the read value.
    - 3. Write zero to all the RW fields.
  - 3. Read back IRS\_SWERR\_STATUSR after the write. If the value read back is the same as the value that was written, all W1C fields that were non-zero are cleared, and no new errors were reported. Otherwise, one or more new errors were reported.

#### See also:

- 10.2.1.32 IRS\_SWERR\_STATUSR.
- 10.2.1.33 IRS\_SWERR\_SYNDROMER0.
- 10.2.1.34 IRS\_SWERR\_SYNDROMER1.

# Chapter 5 Interrupt translation service (ITS)

D<sub>MBMKY</sub> The Interrupt Translation Service (ITS) is responsible for generating *ITS events* and translating them into *interrupt events* for delivery to the associated Interrupt Routing Service (IRS) in each Interrupt Domain.

Each translation specifies whether the resulting interrupt is physical or virtual, the associated Interrupt Domain, the interrupt's INTID, and, if the interrupt is virtual, the VMID of the target VM.

The ITS uses translation structures in the form of a Device Table (DT) and Interrupt Translation Tables (ITT). These translation structures reside in memory and may be partially cached by the ITS. For more information, see 5.3 *Translation structures*.

Figure 5.1 illustrates the overall ITS translation flow.

00bet0



Figure 5.1: GICv5 ITS translation flow

| I <sub>VHDBC</sub> | Translation of an ITS event may involve internal cache lookups and memory accesses to retrieve translation data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>QQNWW</sub> | An example of the ITS translating an event into an interrupt occurs when a Message Signaled Interrupt (MSI) is generated by a device. In this case, the MSI write targets an ITS translation register. The ITS captures the write and generates an ITS event. This event contains the DeviceID of the originator of the write and the EventID value provided in the write data. The ITS uses the programmed entries in the Device Table (DT) and Interrupt Translation Table (ITT) to translate the ITS event into an interrupt. The resulting interrupt is then forwarded to the associated IRS for delivery to a PE. |
| R <sub>zzqcc</sub> | An ITS event is generated by the ITS when any of the following occurs:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                    | <ul> <li>A memory write to ITS_TRANSLATER or ITS_RL_TRANSLATER.</li> <li>A write to ITS_GEN_EVENTR.</li> <li>An IWB forwards an event using an IMPLEMENTATION DEFINED communication mechanism.</li> <li>A system peripheral forwards an event using an IMPLEMENTATION DEFINED communication mechanism.</li> </ul>                                                                                                                                                                                                                                                                                                      |
| D <sub>XCCZK</sub> | An ITS event contains all of the following information:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                    | <ul> <li>DeviceID.</li> <li>EventID.</li> <li>Interrupt event type.</li> <li>Originating Interrupt Domain.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| D <sub>ZVRSC</sub> | The originating Interrupt Domain of an ITS event is determined as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                    | <ul> <li>If the event is generated by a write to ITS_TRANSLATER, ITS_RL_TRANSLATER, or ITS_GEN_EVENTR, the originating Interrupt Domain is the ITS Domain associated with the PAS of the register.</li> <li>If the event is generated by an IWB, the originating Interrupt Domain is the Interrupt Domain that the corresponding wire is assigned to.</li> <li>If the event is generated by a system peripheral using an IMPLEMENTATION DEFINED mechanism, the originating Interrupt Domain is determined using an IMPLEMENTATION DEFINED mechanism.</li> </ul>                                                        |
|                    | Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                    | The originating Interrupt Domain may not correspond to the ITS Domain that translates the event. See 5.1 <i>ITS Domains</i> for more information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| R <sub>rtvbf</sub> | When multiple SET_LEVEL and CLEAR events are received for the same DeviceID and EventID, they must be translated and forwarded to the IRS in the order in which they are received.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ARM-AES-0          | 0070 Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. 152                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Non-confidential

#### Chapter 5. Interrupt translation service (ITS)

| R <sub>bztjm</sub> | When the ITS receives a memory write transaction to ITS_TRANSLATER, the ITS generates an ITS event that translated by the ITS in finite time.                                                                                |  |  |  |  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| I <sub>nbtnk</sub> | ITS events can be Message Signaled Interrupts (MSIs), for example generated by PCIe endpoints, or can be events generated by IWBs or other system components.                                                                |  |  |  |  |  |
|                    | Arm expects that MSIs are typically generated as a result of an MSI source performing a write to ITS_TRANSLATER.                                                                                                             |  |  |  |  |  |
| S <sub>HFCND</sub> | Software ensures that a PCIe posted write to an ITS_TRANSLATER_FRAME is Accepted by the ITS, by ensuring that the PCIe subsystem issues a Completion TLP following the posted MSI write.                                     |  |  |  |  |  |
|                    | See PCI Express <sup>®</sup> Base Specification Revision 6.0[9] for more information on the PCIe TLP ordering rules.                                                                                                         |  |  |  |  |  |
| R <sub>chryr</sub> | For an incoming memory write transaction to ITS_TRANSLATER Accepted by the ITS, the ITS handles the incoming write independently from the state of the source.                                                               |  |  |  |  |  |
| I <sub>CNGJZ</sub> | The ITS Accepts an incoming memory write transaction to ITS_TRANSLATER without waiting for the IRS to Accept a corresponding interrupt event and without waiting for the IRS to present the corresponding interrupt to a PE. |  |  |  |  |  |
|                    | The IRS separates the process of making an interrupt Pending from signaling the interrupt to the PE.                                                                                                                         |  |  |  |  |  |
|                    | See Chapter 4 Interrupt routing service (IRS) for more information.                                                                                                                                                          |  |  |  |  |  |
| I <sub>YDBCQ</sub> | Interrupt events sent by an ITS to the associated IRS contain all of the following:                                                                                                                                          |  |  |  |  |  |
|                    | <ul> <li>LPI ID.</li> <li>Physical or virtual interrupt.</li> <li>VM ID if virtual.</li> <li>Interrupt event type.</li> <li>Interrupt Domain.</li> </ul>                                                                     |  |  |  |  |  |
| R <sub>nyjrf</sub> | An Interrupt event is never sent to the associated IRS speculatively. It is only sent when an ITS event is generated and translated by the ITS.                                                                              |  |  |  |  |  |
| I <sub>PTZXC</sub> | The mechanism used by the ITS to communicate events to the IRS is IMPLEMENTATION DEFINED. See 3.2 <i>Communication between GIC system components</i> for more information.                                                   |  |  |  |  |  |
| R <sub>hpdky</sub> | An ITS is associated with a single IRS and all interrupt events generated by an ITS are sent to that IRS.                                                                                                                    |  |  |  |  |  |
| R <sub>dxdfc</sub> | The DeviceID in an ITS event is a unique identifier within the DeviceID namespace of each ITS. The DeviceID is unique for each device that can generate events to the ITS.                                                   |  |  |  |  |  |
|                    | For example, Arm expects that the 16-bit Requester ID from a PCIe Root Complex is used to derive the DeviceID.                                                                                                               |  |  |  |  |  |
|                    | Note                                                                                                                                                                                                                         |  |  |  |  |  |
|                    | Each ITS has a separate namespace for the DeviceID which is shared across the Interrupt Domains.                                                                                                                             |  |  |  |  |  |
| R <sub>djzvx</sub> | The number of DeviceID bits supported by an ITS is in the range from 0 to 32 inclusively, and is reported by ITS_IDR1.DEVICEID_BITS.                                                                                         |  |  |  |  |  |
| I <sub>vcjft</sub> | An ITS can support 0 DeviceID bits, which means that the ITS only supports a single device.                                                                                                                                  |  |  |  |  |  |
| R <sub>wxgdp</sub> | The DeviceID namespace is unique for each ITS.                                                                                                                                                                               |  |  |  |  |  |
|                    | For example, DeviceID 0 on ITS A identifies a device distinct from the device identified by DeviceID 0 on ITS B.                                                                                                             |  |  |  |  |  |
| R <sub>cmztw</sub> | The number of EventID bits supported by an ITS is in the range from 0 to 16 inclusively, and is reported by ITS_IDR2.EVENTID_BITS.                                                                                           |  |  |  |  |  |

R<sub>WCDFX</sub> The EventID namespace is separate for each ITS DeviceID.

For example, EventID 0 for DeviceID 0 on ITS A identifies an event distinct from the event identified by EventID 0 for DeviceID 1 on ITS A.

 I<sub>TNTVS</sub>
 The number of EventID bits supported for a DeviceID is programmed in L2\_DTE.EVENTID\_BITS. See 5.3.2

 *The Interrupt Translation Table (ITT)* for more information.

R<sub>RYJGM</sub> The mechanism by which a DeviceID is communicated to the ITS is IMPLEMENTATION DEFINED.

However, a unique DeviceID is provided for each requesting device, and the DeviceID is presented to the ITS when a write to the ITS translation registers occurs in a manner that cannot be spoofed by any agent capable of performing writes.

G<sub>TTLHL</sub> The ITS translation mechanism supports *interrupt isolation*.

This allows an untrusted software agent such as a virtual machine to directly control the EventID used by an interrupt source without being able to generate interrupts with INTIDs used for other interrupt sources.

- $\mathbb{I}_{\mathbb{R} \mathbb{W} J \mathbb{X} \mathbb{V}}$  Interrupt isolation can be achieved through the use of an ITS by only allowing the hypervisor to control the ITS. The hypervisor therefore controls the translation of each DeviceID and EventID value pair into an INTID for the Physical Interrupt Domain or a specified VM. In this scenario, the ITS only translates EventIDs programmed by the hypervisor for a given DeviceID, and since the DeviceID is not under control of the VM, the hypervisor fully controls which INTIDs can be signaled irrespective of the EventID programmed by the VM.
- R<sub>QWVTC</sub> For the interrupt isolation mechanism to work, the DeviceID used to identify a device context assigned to untrusted software must be static and not under direct or indirect control of the untrusted software.
- IEach ITS has a unique ITSID which is reported in ITS\_IDR0.ITSID. The ITSID is unique for each ITS in the<br/>system.

# 5.1 ITS Domains

| G <sub>QYXKS</sub> | An ITS operates independently for each Interrupt Domain.                                                                                                                                                                                                                                                                                                                          |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D <sub>WNGLR</sub> | The GICv5 architecture defines an <i>ITS Domain</i> which provides translation services for an Interrupt Domain. An <i>ITS Domain</i> comprises register state and translation structures independently configured from other ITS Domains on the same ITS.                                                                                                                        |
|                    | An ITS Domain is associated with an Interrupt Domain and its corresponding PAS.                                                                                                                                                                                                                                                                                                   |
| I <sub>PXYHF</sub> | Each ITS Domain implements a separate ITS_CONFIG_FRAME. The ITSID reported in ITS_IDR0.ITSID is the same for each ITS_CONFIG_FRAME that belongs to the same ITS.                                                                                                                                                                                                                  |
| R <sub>PMQQB</sub> | The ITS Domain that translates an ITS event is determined as follows:                                                                                                                                                                                                                                                                                                             |
|                    | <ul> <li>If the ITS event is generated by a write to ITS_TRANSLATER, the ITS Domain is the originating Interrupt Domain.</li> <li>If the ITS event is generated by a write to ITS_GEN_EVENTR, the ITS Domain is the ITS Domain specified</li> </ul>                                                                                                                               |
|                    | <ul> <li>If the ITS event is generated by a write to ITS_GEN_EVENTR, the ITS Domain is the ITS Domain specified by ITS_GEN_EVENTR.TARGET_DOMAIN.</li> <li>If the ITS event is generated by a write to ITS_RL_TRANSLATER, the ITS Domain is the Realm ITS Domain.</li> <li>If the ITS event is generated by an IWB, the ITS Domain is the originating Interrupt Domain.</li> </ul> |
|                    | • If the event is generated by a system peripheral using an IMPLEMENTATION DEFINED mechanism, the ITS Domain is the ITS Domain that corresponds to the originating Interrupt Domain.                                                                                                                                                                                              |
| $R_{\rm YJNYY}$    | If an ITS is associated with an IWB, the ITS provides an ITS Domain for each Interrupt Domain implemented by the IWB.                                                                                                                                                                                                                                                             |
| R <sub>dzymw</sub> | An ITS does not support any Interrupt Domain not supported by the IRSs.                                                                                                                                                                                                                                                                                                           |
| I <sub>xcbrd</sub> | The IRS associated with the ITS implements support for all the ITS Domains provided by the ITS, because an IRS implements support for all the Interrupt Domains supported by the PEs in the system.                                                                                                                                                                               |
| I <sub>kfvmt</sub> | An ITS exposes separate control register frames for each ITS Domain.                                                                                                                                                                                                                                                                                                              |
| I <sub>kkyff</sub> | An ITS exposes separate translation register frames for each ITS Domain.                                                                                                                                                                                                                                                                                                          |
| I <sub>NJHMG</sub> | An ITS implements at least one ITS translate register frame, ITS_TRANSLATE_FRAME, for each ITS Domain. If an ITS Domain implements more than one translate register frame, the DeviceID space is shared across all the translate register frames belonging to the same ITS.                                                                                                       |
| R <sub>FGHHH</sub> | Each ITS Domain can have a maximum of 256 ITS translate register frames.                                                                                                                                                                                                                                                                                                          |
| R <sub>tzmyp</sub> | Each ITS translate register frame has an 8 bit identifier that is unique within an ITS Domain.                                                                                                                                                                                                                                                                                    |
| I <sub>CXPWJ</sub> | The ITS translation register frame identifier is used by software when issuing ITS synchronization requests.                                                                                                                                                                                                                                                                      |
|                    | See 5.2.4 ITS synchronization requests for more information about synchronization requests.                                                                                                                                                                                                                                                                                       |
| $\rm S_{HPMNL}$    | Arm expects that the ITS translation register frame identifier, as well as the relationship between ITS translate register frames and an ITS Domain and its configuration register frame, is communicated to system software via firmware data structures.                                                                                                                        |
| I <sub>TNYVZ</sub> | The ITS does not provide a mechanism to identify via registers which ITS translation register frames are associated with which ITS configuration register frames.                                                                                                                                                                                                                 |
| I <sub>GCJFM</sub> | Different from GICv3, the GICv5 architecture does not require the control register frame and translation register frame to be contiguous with respect to each other.                                                                                                                                                                                                              |
| I <sub>YCFZC</sub> | The base address of each register frame for each ITS Domain should be provided to software by firmware.                                                                                                                                                                                                                                                                           |
| I <sub>XFTTF</sub> | The ITS Domain for a register frame is reported in ITS_IDR0.INT_DOM.                                                                                                                                                                                                                                                                                                              |

# Chapter 5. Interrupt translation service (ITS) 5.1. ITS Domains

R<sub>PSXLG</sub> All memory accesses performed by the ITS are subject to GPT checks.

An access is performed using the PAS associated with the ITS Domain where the translation is requested.

I<sub>DRTD2</sub> Figure 5.2 shows an overview of the ITS Domain registers and translation structures.



### Figure 5.2: GICv5 ITS Domains

Translation structures are only shown for the Non-secure domain but exist separately for each ITS Domain.

I<sub>SRZCQ</sub> Arm expects an interrupt source to be configured to use the translation register frame of an ITS Domain corresponding to the Security state and PAS that manages the device. This allows end-to-end isolation of interrupt events and interrupt configuration within a Security state. For example, a device managed by Software in the Secure state can generate MSIs to the Secure ITS Domain in the Secure PAS, and only software with access to the Secure PAS can configure this interrupt, and only that specific device can generate a Secure interrupt with the configured INTID.

R<sub>SXLJQ</sub> The following ITS Domains support virtual interrupts:

- Non-secure.
- Realm.
- Secure.

The EL3 ITS Domain does not support virtual interrupts.

R<sub>NTTVJ</sub> An event can only be translated to generate interrupt events for a VM in the Interrupt Domain corresponding to the ITS Domain. This is a consequence of the VM ID namespace being separate in each Interrupt Domain.

See also:

• 3.1 Interrupt Domains

### 5.1.1 Supporting Realm interrupts from Non-secure writes

G<sub>YLHMP</sub> The GICv5 architecture supports direct injection of MSIs generated by Non-secure devices to Realms.

- IBGWGHAn ITS event is translated in the Realm ITS Domain, even though the event is generated as a result of a write to a<br/>register in the Non-secure PAS, if any of the following are true:
  - The event is generated in response to a write to ITS\_RL\_TRANSLATER.
  - The event is generated in response to a write to ITS\_GEN\_EVENTR in the Non-secure PAS, and the write sets ITS\_GEN\_EVENTR.TARGET\_DOMAIN to 0b01.

# Chapter 5. Interrupt translation service (ITS) 5.1. ITS Domains

I<sub>JKXQV</sub> Software in the Realm Security state controls whether an ITS event generated by a write to an ITS register in the Non-secure PAS is permitted to be translated in the Realm ITS Domain by programming L2\_ITTE.DAC to allow such a translation.

See 5.3.2 The Interrupt Translation Table (ITT) for more information about the DAC field.

S<sub>GYSSD</sub> When an untrusted PCIe function is assigned to a VM, its MSI-X vectors are programmed to generate MSI writes to ITS\_TRANSLATER. The MSI writes use the Non-secure PAS.

The ITS events are generated as a result of the write to a register in the Non-secure Interrupt Domain and translated in the Non-secure ITS Domain. If the translation is successful, LPIs are generated in the Non-secure Interrupt Domain.

When the function is assigned to Realm, its MSI-X vectors can be programmed to generate MSI writes to the ITS\_RL\_TRANSLATER. The MSI writes still use the Non-secure PAS, however, they are translated in the Realm ITS Domain. If the translation is successful, LPIs are generated in the Realm Interrupt Domain.

S<sub>SZVBR</sub> On a system that implements the Realm Management Extension, for an untrusted device that is assigned to Realm, there are scenarios where the host hypervisor must be able to inject a virtual LPI into Realm. The host hypervisor and the target VPE of Realm could be running on different PEs.

For example, an untrusted VirtIO[10] device is assigned to Realm. The device is emulated in the host hypervisor. The host hypervisor must be able to inject virtual LPIs into Realm.

The host hypervisor can write to ITS\_GEN\_EVENTR with TARGET\_DOMAIN set to 0b01 in the Non-secure PAS to generate these ITS events translated by the Realm ITS Domain.

See also:

- 5.3.2 The Interrupt Translation Table (ITT).
- 10.3.2.2 *ITS\_RL\_TRANSLATER*.
- 11.1.4 L2\_ITTE, Level 2 interrupt translation table entry.

## 5.2 Operation

R<sub>SXWCM</sub> When ITS\_CR0.ITSEN is 1, the ITS Domain is *enabled* and all of the following are true:

- The ITS translates ITS events and may generate corresponding interrupt messages to the associated IRS.
- The ITS Domain may perform memory accesses to the ITS Domain's translation structures as part of processing ITS events or as a result of handling ITS register accesses.

When ITS\_CR0.ITSEN is 0 and ITS\_CR0.IDLE is 1, the ITS Domain is *disabled* and all of the following are true:

- The ITS does not process ITS events; ITS events are dropped and have no effects on the ITS.
- The ITS Domain does not generate outgoing interrupt events to the associated IRS.
- The ITS Domain does not perform memory accesses to the ITS Domain's translation structures.

#### $R_{RNQHC}$ An ITS event is ignored if it cannot be translated by the ITS.

- I<sub>XFFRW</sub> If software error reporting is supported, the ITS reports if an ITS event cannot be translated using the appropriate error code in ITS\_SWERR\_STATUSR.EC.
- I<sub>HYKFL</sub> A change to ITS\_CR0.ITSEN is not guaranteed to be observed by the ITS until ITS\_CR0.IDLE is 1.

See also:

• 5.2.1 Enabling and disabling the ITS

### 5.2.1 Enabling and disabling the ITS

 $R_{\rm FXDRJ}$ 

When a write to ITS\_CR0.ITSEN changes the value from 0 to 1, the ITS Domain begins a transition from disabled to enabled, and all of the following are true:

- The transition completes in finite time.
- The transition is complete when ITS\_CR0.IDLE is 1.
- The ITS will process all events that are Accepted after the transition is complete.

#### Note

While the ITS is transitioning from disabled to enabled, transactions arriving at the ITS will observe the ITS being enabled or disabled. The architecture only guarantees transactions arriving after the transition from disabled to enabled is complete to observe that the ITS is enabled.

#### Rysgff

When a write to ITS\_CR0.ITSEN changes the value from 1 to 0, the ITS Domain begins a transition from enabled to disabled, and all of the following are true:

- The transition completes in finite time.
- The transition is complete when ITS\_CR0.IDLE is 1.
- All ITS events, Accepted before the transition is complete, are processed.
- All outgoing interrupt events generated for the associated IRS before the transition is complete, are Accepted by the IRS.

#### Note

While the ITS is transitioning from enabled to disabled, transactions arriving at the ITS will observe the ITS as being enabled or disabled. The architecture only guarantees that transactions arriving after the transition from enabled to disabled is complete to observe that the ITS is disabled.

S<sub>DNGJG</sub> When ITS\_CR0.ITSEN is 1, the ITS accesses the translation structures described in 5.3 *Translation structures*. Software is expected to initialize the base address and configuration registers for the structures before enabling the ITS.

For example, software can provide a device table where all entries are invalid, or it can be a device table with valid entries containing the addresses of one or more valid ITTs, and initialize the ITS\_DT\_BASER and ITS\_DT\_CFGR to point to the device table.

S<sub>ZFWSP</sub> When the ITS Domain is disabled, the ITS Domain no longer accesses translation structures and software can reclaim the memory used to hold the translation structures.

See also:

• 5.3 Translation structures

### 5.2.2 Interrupt event types

D<sub>CBDTC</sub> The *type* of an interrupt event generated by the ITS for an IRS is one of the following:

- SET\_EDGE: The IRS should make the interrupt Pending and set its Handling mode to Edge.
- SET\_LEVEL: The IRS should make the interrupt Pending and set its Handling mode to Level.
- CLEAR: The IRS should make the interrupt Idle.

R<sub>JFGLF</sub> A write to ITS\_TRANSLATER generates a SET\_EDGE event to the ITS.

- ILKLYH
   The ITS only supports MSI sources that generate interrupts with edge-triggered semantics. MSI sources that are designed to signal interrupts with level-sensitive semantics using message based writes are not supported by the ITS.
- R<sub>PQCKZ</sub> SET\_LEVEL events are only supported for events generated by an IWB.
- R<sub>TDXLR</sub> The interrupt event type generated to the IRS is the same as the ITS event type.
- $I_{LQZSR}$  When a write updates an ITS translation structure entry, the ITS does not generate a CLEAR event as a result of the update to the translation structures. For EventIDs that represent Level interrupts and that had a valid translation before the update, if those EventIDs do not have a valid translation after the update, the corresponding interrupts may still be in the Pending state in the IRS. See 5.3 *Translation structures* for more information.
- S<sub>KSFMZ</sub> Software must disable or explicitly clear the Pending state of a Level interrupt in the IRS after unmapping the event in the ITS to avoid that the interrupt is signaled to a PE. An Edge interrupt may also remain Pending after being unmapped in the ITS, but its Pending state would be cleared when the interrupt is acknowledged.

### 5.2.3 Software generated ITS events

 $I_{QTNPX}$  Software may generate an ITS event for an EventID and DeviceID in an ITS Domain via the following ITS registers:

- ITS\_GEN\_EVENT\_DIDR. A write to this register selects the DeviceID of the event.
- ITS\_GEN\_EVENT\_EIDR. A write to this register selects the EventID of the event.
- ITS\_GEN\_EVENTR. The TARGET\_DOMAIN field in this register selects the ITS Domain where the ITS event is translated.
- A write of 1 to the R field requests the ITS to generate an ITS event of the selected type for the specified EventID and DeviceID.
- ITS\_GEN\_EVENT\_STATUSR. A read of this register reports when generation of an ITS event is complete.

S<sub>VKLMK</sub> An event generated by writing to ITS\_GEN\_EVENTR may be synchronized once the write is complete to ensure that the corresponding interrupt event has been Accepted by the IRS by writing 1 to ITS\_SYNCR.SYNC and polling ITS\_SYNC\_STATUSR.IDLE until it is 1.

Chapter 5. Interrupt translation service (ITS) 5.2. Operation

## 5.2.4 ITS synchronization requests

I<sub>TWLSC</sub> Software requests synchronization of ITS events for the ITS by writing 1 to ITS\_SYNCR.SYNC.

ITS\_SYNCR.SYNCALL specifies whether the synchronization request should apply to all Accepted ITS events or is only required to apply to those specified by ITS\_SYNCR.DEVICE\_ID.

See 10.3.1.28 *ITS\_SYNCR* for more information about the effects of a write to ITS\_SYNCR.SYNC.

S<sub>KDJBY</sub> Software can use synchronization of events to ensure that the Pending state of Level interrupts is cleared by the IRS.

This is, for example, useful when changing the Interrupt Domain association of a wire in the IWB.

See also:

- 3.2 Communication between GIC system components
- 4.5 IRS synchronization requests
- 6.2 IWB support for multiple Interrupt Domains

## 5.3 Translation structures

| I <sub>KBTLK</sub> | The GICv5 architecture defines two translation structures which can be used by an ITS:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul><li>The <i>Device Table</i> (DT).</li><li>The <i>Interrupt Translation Table</i> (ITT).</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| R <sub>sdbrm</sub> | All ITS translation structures are little-endian.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| R <sub>svkhy</sub> | The ITS accesses its translation structures using Normal memory types. See [1] for more information about memory access types.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| S <sub>KZJVX</sub> | Software allocates memory for the translation structures and programs the physical address of the allocated translation structures in ITS registers. Arm expects that such allocations will typically be done from Conventional memory [1].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| I <sub>XTRLS</sub> | ITS_CR1 specifies the Shareability and Cacheability attributes for memory accesses performed by the ITS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | ITS_CR1 is read-only when the ITS is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | The most recent values written to ITS_CR1 are used when the ITS accesses memory following a write that enables the ITS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| D <sub>ZQBDN</sub> | The GICv5 architecture defines two types of translation structures entries:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | <ul><li>An entry in a DT, a <i>device table entry</i> (DTE).</li><li>An entry in an ITT, an <i>interrupt translation table entry</i> (ITTE).</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| D <sub>YMZNC</sub> | The VALID field of an ITS translation structure entry defines the validity of the entry:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | <ul><li>When the VALID field is 1, the entry is a <i>valid</i> entry.</li><li>When the VALID field is 0, the entry is an <i>invalid</i> entry.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| $R_{MJPHW}$        | The DT translates a DeviceID into an ITT base address. The DeviceID is used as an index into the DT.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| R <sub>xhkfy</sub> | The ITT translates a per-device EventID into an LPI ID, a physical/virtual qualifier, and a VM ID for virtual interrupts. The EventID is used as an index into the ITT.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| R <sub>tltpv</sub> | An ITS Domain has a valid translation for the DeviceID and EventID of an ITS event, if all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                    | <ul> <li>One of the following is true: <ul> <li>The DT does not use a 2-level table structure.</li> <li>The level 1 DTE for the DeviceID is valid.</li> </ul> </li> <li>The level 2 DTE for the DeviceID is valid.</li> <li>One of the following is true: <ul> <li>The ITT does not use a 2-level table structure.</li> <li>The level 1 ITTE for the EventID is valid.</li> </ul> </li> <li>The level 2 ITTE for the EventID is valid.</li> <li>One of the following is true: <ul> <li>The level 2 ITTE for the EventID is valid.</li> </ul> </li> <li>The level 2 ITTE for the EventID is valid.</li> <li>One of the following is true: <ul> <li>The event is generated by a write to a register in the PAS native to the ITS Domain.</li> <li>The event is generated by a write to a register in the Non-secure PAS, and all of the following are true: <ul> <li>The event is translated in the Realm ITS Domain.</li> <li>L2_ITTE.DAC is 0b01 in the L2_ITTE for the EventID.</li> </ul> </li> </ul></li></ul> |
|                    | Otherwise, if any of the above conditions are false, the ITS Domain does not have a valid translation for the ITS event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| R <sub>PGCPL</sub> | If any of the following is true, it is CONSTRAINED UNPREDICTABLE whether any events are sent to the IRS:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | <ul><li>The ITS Domain has more than one valid translation to the same physical INTID.</li><li>The ITS Domain has more than one valid translation to the same virtual INTID with the same VM ID.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | See also:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

• 11.1 ITS Data Structures

## 5.3.1 The Device Table (DT)

| D <sub>XJQMP</sub>            | The DT structure is either linear or 2-level.                                                                                                                                              |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>GRMKZ</sub>            | ITS_IDR1.DT_LEVELS reports whether 2-level DT support is implemented.                                                                                                                      |
| R <sub>wkpkd</sub>            | The value of ITS_IDR1.DT_LEVELS is the same for all ITS Domains for an ITS in the system.                                                                                                  |
| IVZYWW                        | Arm strongly recommends that an implementation that supports more than 9 bits of DeviceID implements 2-level device tables.                                                                |
| I <sub>SWCZW</sub>            | The GICv5 architecture defines the formats of the level 1 DTE and level 2 DTE.                                                                                                             |
| I <sub>ZMRVW</sub>            | The base address of the DT is stored in ITS_DT_BASER.ADDR.                                                                                                                                 |
| I <sub>VZVJN</sub>            | When ITS_CR0.ITSEN is 1, accesses to fields in ITS_DT_BASER and ITS_DT_CFGR are RO.                                                                                                        |
| $\mathtt{I}_{\mathtt{WBLVK}}$ | When the DT uses a 2-level table structure, the address stored in ITS_DT_BASER.ADDR is the base address of the level 1 table.                                                              |
|                               | When the DT uses a linear table structure, the address stored in ITS_DT_BASER.ADDR is the base address of the array of level 2 DTEs.                                                       |
| $\rm S_{LDVFG}$               | Software is responsible for allocating the DT from memory in the PAS associated with the ITS Domain where the DT is used.                                                                  |
| I <sub>krkbh</sub>            | The structure of the DT is controlled using the following register and translation structure fields:                                                                                       |
|                               | • ITS_DT_CFGR.DEVICEID_BITS:                                                                                                                                                               |
|                               | Selects how many bits of DeviceID the DT can translate. This impacts the size of the level 2 DT when using a linear structure and the size of the level 1 DT when using 2-level structure. |
|                               | • ITS_DT_CFGR.STRUCTURE:                                                                                                                                                                   |
|                               | Selects if the DT uses a linear or 2-level structure.                                                                                                                                      |
|                               | • ITS_DT_CFGR.L2SZ:                                                                                                                                                                        |
|                               | When using a 2-level DT, this field configures the number of DeviceID bits resolved by each level 2 DT.                                                                                    |
|                               | • L1_DTE.SPAN:                                                                                                                                                                             |
|                               | When using a 2-level DT, for the level 1 entry corresponding to a range of DeviceIDs, this field configures the number of entries in the level 2 DT.                                       |
| I <sub>PZYZM</sub>            | The supported values for ITS_DT_CFGR.L2SZ are reported in ITS_IDR1.L2SZ.                                                                                                                   |

I<sub>NTYVG</sub> The size of a level 1 DTE and a level 2 DTE is 8 bytes.

Table 5.1 shows some example DT structures:

### Table 5.1: Example DT structures.

| STRUCTURE | DEVICEID_BITS | L2SZ         | L1 size | L2 size | Maximum number of devices |
|-----------|---------------|--------------|---------|---------|---------------------------|
| Linear    | 4             | -            | -       | 128 B   | 16                        |
| Linear    | 9             | -            | -       | 4 KB    | 512                       |
| Linear    | 13            | -            | -       | 64 KB   | 8,192                     |
| Linear    | 18            | -            | -       | 2 MB    | 262,144                   |
| 2-level   | 18            | 0b00, 9 bits | 4 KB    | 4 KB    | 262,144                   |

Chapter 5. Interrupt translation service (ITS) 5.3. Translation structures

| STRUCTURE | DEVICEID_BITS | L2SZ          | L1 size | L2 size | Maximum number of devices |
|-----------|---------------|---------------|---------|---------|---------------------------|
| 2-level   | 27            | 0b00, 9 bits  | 2 MB    | 4 KB    | 134,217,728               |
| 2-level   | 22            | 0b01, 11 bits | 16 KB   | 16 KB   | 4,194,304                 |
| 2-level   | 26            | 0b10, 13 bits | 64 KB   | 64 KB   | 67,108,864                |
| 2-level   | 32            | 0b10, 13 bits | 4 MB    | 64 KB   | 4,290,000,000             |

In the table above, the L2SZ column shows the value of ITS\_DT\_CFGR.L2SZ along with its interpretation in bits of DeviceID resolved by each level.

See 11.1 ITS Data Structures and 10.3.1.6 ITS\_DT\_CFGR for more information.

- S<sub>YMMZX</sub> The L1 size and L2 size columns in Table 5.1 indicate the required maximum physically contiguous allocation by software for the configuration. Arm expects that for large systems with many devices, a 2-level structure with a large level 1 table can be allocated by software on system boot.
- S<sub>FGKBW</sub> L1\_DTE.SPAN field is used to limit the amount of storage required for the level 2 DT. For example, if the L2SZ is configured at 9 bits, and only two devices are differentiated using bit 0 of the DeviceID for the DeviceID space defined by bits N:9, then a SPAN of 1 can be used to only require that two level 2 DTEs are allocated. See Figure 5.3 for an illustration where the L2SZ is configured at 9 bits and where two level 1 DTEs use different SPAN values.



### Figure 5.3: Example device table using L1\_DTE.SPAN

S<sub>CQRVC</sub> ITS\_DT\_CFGR.DEVICEID\_BITS determines the number of level 2 DTEs the DT contains. When using a 2-level structure, the number of DeviceID bits resolved by each level 2 table is decided by ITS\_DT\_CFGR.L2SZ, and software must allocate enough level 1 DTEs to cover the full DeviceID space for the DT.

D<sub>QFTBH</sub> A DeviceID is considered *invalid* if any of the following is true:

- The DeviceID is larger than (2 ^ ITS\_DT\_CFGR.DEVICEID\_BITS) 1.
- DeviceIDs which do not have a corresponding level 2 DTE because of how the L1\_DTE.SPAN field is configured.
- R<sub>HGKJK</sub> Events signaled with an invalid DeviceID are ignored and are not translated by the ITS.

# Chapter 5. Interrupt translation service (ITS) 5.3. Translation structures

| I <sub>XSFXB</sub> | A level 1 DT is aligned to the size of the level 1 table.                                                                                                                                                                                                                                                                                               |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | A level 2 DTE array is aligned to the size of the array.                                                                                                                                                                                                                                                                                                |
|                    | See 10.3.1.5 <i>ITS_DT_BASER</i> for more information.                                                                                                                                                                                                                                                                                                  |
| I <sub>CFRYB</sub> | When limiting a level 2 DT size by using the level 1 SPAN field, the level 2 DT address is aligned to the size of the level 2 DTE array.                                                                                                                                                                                                                |
| $R_{\rm XNJYG}$    | When an ITS Domain is enabled, a write to any field in a valid level 2 DTE other than when setting the L2_DTE.VALID field to 0, results in CONSTRAINED UNPREDICTABLE behavior with a choice of:                                                                                                                                                         |
|                    | <ul><li>The old values are used for the device.</li><li>The new values are used for the device.</li><li>A combination of the old and new values is used for the device.</li></ul>                                                                                                                                                                       |
| I <sub>DHHJN</sub> | When the ITS Domain is enabled, changing the address of an ITT for a valid level 2 DTE, requires performing the following series of actions to avoid UNPREDICTABLE behavior:                                                                                                                                                                            |
|                    | <ol> <li>Performing a write that sets the L2_DTE.VALID field to 0.</li> <li>Ensuring that the write is visible to the ITS Domain by performing the necessary cache invalidation.</li> <li>Writing the address and configuration fields of the new ITT to the level 2 DTE.</li> <li>Performing a write that sets the L2_DTE.VALID field to 1.</li> </ol> |
|                    | See 5.4.2 ITS cache management for DeviceIDs for more information about ITS device cache management.                                                                                                                                                                                                                                                    |
| 5.3.2 The          | e Interrupt Translation Table (ITT)                                                                                                                                                                                                                                                                                                                     |
| D <sub>PPZDD</sub> | The ITT structure is either linear or 2-level.                                                                                                                                                                                                                                                                                                          |
| I <sub>RPQVS</sub> | ITS_IDR1.ITT_LEVELS reports whether 2-level ITT support is implemented.                                                                                                                                                                                                                                                                                 |
| R <sub>TJCMV</sub> | The value of ITS_IDR1.ITT_LEVELS is the same for all ITS Domains in an ITS in the system.                                                                                                                                                                                                                                                               |
| I <sub>PLTFB</sub> | The GICv5 architecture defines the formats of the level 1 ITTE and level 2 ITTE.                                                                                                                                                                                                                                                                        |
| I <sub>QJTXY</sub> | The base address of the ITT is stored in L2_DTE.ITT_ADDR.                                                                                                                                                                                                                                                                                               |
| I <sub>FMQQL</sub> | When the ITT uses a 2-level table structure, the address stored in L2_DTE.ITT_ADDR is the base address of the level 1 table.                                                                                                                                                                                                                            |
|                    | When the ITT uses a linear table structure, the address stored in L2_DTE.ITT_ADDR is the base address of the array of level 2 ITTEs.                                                                                                                                                                                                                    |
| D <sub>CFDKB</sub> | A level 2 ITT <i>overlaps</i> with another level 2 ITT, if the same address for a level 2 ITTE can be reached via separate DTs or ITTs.                                                                                                                                                                                                                 |
|                    | For example, a level 2 ITT overlaps with another level 2 ITT, if any of the following are true:                                                                                                                                                                                                                                                         |
|                    | <ul> <li>Two separate level 2 DTEs point to the same level 1 ITT.</li> <li>Two separate level 2 DTEs point to the same level 2 ITT.</li> <li>Two separate level 1 ITTEs point to the same level 2 ITT.</li> <li>The base address of a level 2 ITT is between the base and end addresses of another level 2 ITT.</li> </ul>                              |
| R <sub>XGPSP</sub> | If any part of either a level 1 or level 2 ITT overlaps with another ITT, the ITS behavior is CONSTRAINED UNPREDICTABLE with any of the following:                                                                                                                                                                                                      |
|                    | <ul> <li>Any ITS cache invalidation by DeviceID or EventID may not work as expected.</li> <li>ITS events may not be translated.</li> <li>The ITS may translate an ITS event resulting in sending an interrupt event to the IRS with UNKNOWN data.</li> </ul>                                                                                            |
|                    | Software can recover from this situation by disabling the ITS and configuring the translation structures without any overlap before re-enabling the ITS.                                                                                                                                                                                                |

See 5.5 ITS memory access rules for more information.

# Chapter 5. Interrupt translation service (ITS) 5.3. Translation structures

S<sub>YDTKM</sub> Software is responsible for allocating the ITT from memory in the PAS associated with the ITS Domain where the ITT is used.

I<sub>SRXXT</sub> The structure of the ITT is controlled using the following fields in the ITS translation structures:

• L2\_DTE.EVENTID\_BITS:

Selects how many bits of EventID the ITT can translate. This impacts the size of the level 2 ITT when using a linear structure and the size of the level 1 ITT when using 2-level structure.

• L2\_DTE.ITT\_STRUCTURE:

Selects if the ITT uses a linear or 2-level structure.

• L2\_DTE.ITT\_L2SZ:

When using a 2-level ITT, this field configures the number of EventID bits resolved by each level 2 ITT.

• L1\_ITTE.SPAN:

When using a 2-level ITT, for the level 1 entry corresponding to a range of EventIDs, this field configures the number of entries in the level 2 ITT.

I<sub>HPWVL</sub> The supported values for L2\_DTE.ITT\_L2SZ are reported in ITS\_IDR1.L2SZ.

 $I_{NJHFT}$  The size of a level 1 ITTE and a level 2 ITTE is 8 bytes.

Table 5.2 shows some example ITT structures:

| STRUCTURE | EVENTID_BITS | L2SZ         | L1 size | L2 size | Maximum number of events |
|-----------|--------------|--------------|---------|---------|--------------------------|
| Linear    | 4            | -            | -       | 128 B   | 16                       |
| Linear    | 9            | -            | -       | 4 KB    | 512                      |
| Linear    | 11           | -            | -       | 16 KB   | 2,048                    |
| Linear    | 13           | -            | -       | 64 KB   | 8,192                    |
| Linear    | 16           | -            | -       | 512 KB  | 65,536                   |
| 2-level   | 11           | 0b00, 9 bits | 32 B    | 4 KB    | 2,048                    |
| 2-level   | 16           | 0b00, 9 bits | 1 KB    | 4 KB    | 65,536                   |

#### Table 5.2: Example ITT structures.

In the table above, the L2SZ column shows the value of L2\_DTE.ITT\_L2SZ field along with its interpretation in bits of EventID resolved by each level.

See 11.1 ITS Data Structures for more information.

S<sub>FYKKL</sub> The L1 size and L2 size columns in Table 5.2 indicate the required maximum physically contiguous allocation by software for the configuration. Arm expects that 4KB allocations will satisfy the capabilities of most devices. For example, PCIe MSI-X supports a maximum of 2,048 events for a device. 2,048 events can either be supported with a linear 16KB table or using a 2-level structure with 4 level 1 entries each pointing to 4KB level 2 tables.

SYSMWPThe L1\_ITTE.SPAN field can be used to limit the amount of storage required for the level 2 ITT. For example, if a<br/>2-level ITT contains entries for 544 events and the L2SZ is configured at 9 bits, then the last level 1 ITTE can<br/>configure a SPAN of 5 such that the second level 2 ITT only contains 32 entries.

S<sub>ZFWKT</sub> L2\_DTE.EVENTID\_BITS determines the number of level 2 ITTEs that the ITT contains. When using a 2-level structure, the number of EventID bits resolved by each level 2 table is decided by L2\_DTE.ITT\_L2SZ, and software must allocate enough level 1 ITTEs to cover the full EventID space for the ITT.

# Chapter 5. Interrupt translation service (ITS) 5.3. Translation structures

| D <sub>XVTYL</sub> | An EventID is considered <i>invalid</i> if any of the following is true:                                                                                                                                                                                                                                                                 |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>The EventID is larger than (2 ^ L2_DTE.EVENTID_BITS) - 1.</li> <li>EventIDs which are not described by level 2 ITTEs because of how the L1_ITTE.SPAN field is configured.</li> </ul>                                                                                                                                            |
| R <sub>XJGWV</sub> | Events signaled with an invalid EventID are ignored and are not translated by the ITS.                                                                                                                                                                                                                                                   |
| I <sub>xrkxz</sub> | If software error reporting is supported, the ITS reports if an ITS event cannot be translated due to an invalid EventID using the appropriate error code in ITS_SWERR_STATUSR.EC.                                                                                                                                                       |
| R <sub>fvjtg</sub> | The ITTs are always aligned to the size of the table.                                                                                                                                                                                                                                                                                    |
| I <sub>WBPQX</sub> | When limiting a level 2 ITT size by using the level 1 SPAN field, the level 2 ITT address is aligned to the size of the level 2 ITTE array.                                                                                                                                                                                              |
| I <sub>ckrkw</sub> | Software may configure the ITS to translate an ITS event, generated by a write to a register in the Non-secure PAS, using the Realm ITS Domain. Such an event does not violate the separation between Interrupt Domains, because the event is only translated successfully in the Realm ITS Domain if L2_ITTE.DAC is 0b01 for the event. |
|                    | See also:                                                                                                                                                                                                                                                                                                                                |
|                    | • 5.1.1 Supporting Realm interrupts from Non-secure writes.                                                                                                                                                                                                                                                                              |
| I <sub>TSBSN</sub> | Software may read translation information for an EventID and DeviceID in an ITS Domain via the following ITS registers:                                                                                                                                                                                                                  |
|                    | • ITS_DIDR. A write to this register selects the DeviceID of the event.                                                                                                                                                                                                                                                                  |
|                    | • ITS EIDR. A write to this register selects the EventID of the event.                                                                                                                                                                                                                                                                   |

- ITS\_READ\_EVENTR. A write of 1 to the R field requests that the ITS returns translation information for the selected event.
- ITS\_STATUSR. A read of this register reports when the translation information for the event is available.
- ITS\_READ\_EVENT\_DATAR. A read of this register provides the translation information for the event once it is available.

See also:

- 10.3.1.4 *ITS\_DIDR*.
- 10.3.1.7 *ITS\_EIDR*.
- 10.3.1.8 *ITS\_GEN\_EVENTR*.
- 10.3.1.9 *ITS\_GEN\_EVENT\_STATUSR*.
- 10.3.1.10 *ITS\_GEN\_EVENT\_EIDR*.
- 10.3.1.11 *ITS\_GEN\_EVENT\_DIDR*.
- 10.3.1.22 *ITS\_READ\_EVENTR*.
- 10.3.1.23 *ITS\_READ\_EVENT\_DATAR*.
- 10.3.1.24 *ITS\_STATUSR*.

## 5.4 ITS cache management

| An ITS is permitted to cache any part of the ITS translation structures at any time when they are accessible by the ITS.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| The ITS caches are not considered data or system caches belonging to the memory system, meaning they are not managed by any cache maintenance instructions issued by a PE.                                                                                                                                                                                                                                                                                                                                                                           |
| Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| This means that information from all of level 1 DTEs, level 2 DTEs, level 1 ITTEs, and level 2 ITTEs may be cached by the ITS.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| An ITS is permitted to cache both valid and invalid entries of ITS translation structures.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Entries held in ITS caches are associated with the ITS Domain that contains the ITS translation structures used to derive the entry.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| This ensures isolation between ITS Domains and ensures that modifying translation structures and performing cache maintenance for one ITS Domain does not affect the behavior of another ITS Domain.                                                                                                                                                                                                                                                                                                                                                 |
| When an ITS Domain is disabled, the ITS caches contain no data from ITS translation structures associated with that ITS Domain.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Cached information from an ITS translation structure entry is not guaranteed to remain in the ITS caches.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Cached information from an ITS translation structure entry is not guaranteed to remain in the ITS caches. This means that when the ITS caches an ITS translation structure entry with different values than what is stored in memory, the ITS may naturally evict the cached entry and read the updated translation structure entry from memory, without any ITS cache invalidation operation having been performed.                                                                                                                                 |
| An update to an ITS translation structure entry is not guaranteed to be visible to the ITS until an appropriate cache invalidation operation has completed.                                                                                                                                                                                                                                                                                                                                                                                          |
| When software updates the fields in an ITS translation structure entry, the ITS is permitted to cache both the old and the new entry. For as long as both entries exist in the ITS cache, each translation of a DeviceID and EventID affected by the updated entry is permitted to use either the old or the new entry.                                                                                                                                                                                                                              |
| To avoid the ITS using the old translation entries, software should perform the following steps:                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| <ol> <li>Ensure that no events are generated for that DeviceID.</li> <li>Synchronize events Accepted by the ITS that use the old translation structures. See also 5.2.4 <i>ITS synchronization requests</i> for more information.</li> <li>Update the fields in the ITS translation structure entry and perform the appropriate cache invalidation operation. See also 5.4.1 <i>ITS cache management for EventIDs</i> and 5.4.2 <i>ITS cache management for DeviceIDs</i> for more information.</li> <li>Enable events for that DeviceID.</li> </ol> |
| ITS cache invalidation is done for a device or an event. A device is identified by its DeviceID. An event is identified by its DeviceID and EventID.                                                                                                                                                                                                                                                                                                                                                                                                 |
| The ITS provides cache invalidation operations that apply to any cached information from ITS translation structure entries for the specified device or event. An invalidation operation applies to the cached information from ITS translation structures irrespective of the values stored in the ITS translation structures in memory.                                                                                                                                                                                                             |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

For example, for an event, the state of the corresponding level 2 ITTE could be as follows:

- There is cached information from a valid level 2 ITTE for that event.
- There is no cached information from the level 2 DTE for the DeviceID of the event.
- The level 2 DTE for the DeviceID of the event is invalid.

The ITS cache invalidation operation for that event invalidates the cached information from the valid level 2 ITTE even though the level 2 DTE is invalid.

- ILNLHV ITS cache invalidation operations invalidate cached information regardless of the value of the VALID field in the cached translation structure entry.
- $I_{WZQQN}$  The effects of ITS cache invalidation operations are complete when ITS\_STATUSR.IDLE is 1.
- R<sub>ZXXJF</sub> When ITS\_STATUSR.IDLE transitions from 0 to 1, any ITS event that used information from ITS translation structure entries prior to the invalidate have been Accepted by the IRS.

### 5.4.1 ITS cache management for EventIDs

| I <sub>RPBTZ</sub> | An ITS cache invalidation operation for a single EventID is performed as follows:                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ol> <li>The EventID is written to ITS_EIDR.EVENT_ID and the DeviceID to ITS_DIDR.DEVICE_ID.</li> <li>A write to ITS_INV_EVENTR is performed with the fields set to the following:         <ul> <li>ITS_INV_EVENTR.L1 is set to 0.</li> <li>ITS_INV_EVENTR.I is set to 1.</li> </ul> </li> </ol>                                                                                                                                                               |
| $R_{KYPHL}$        | An ITS cache invalidation operation for an EventID invalidates all cached information from the L2 ITTE corresponding to the EventID.                                                                                                                                                                                                                                                                                                                           |
| I <sub>GLSYM</sub> | The ITS supports invalidating a range of EventIDs corresponding to the number of EventIDs described by a single level 2 ITT. The size of the range is selected using ITS_INV_EVENTR.ITT_L2SZ.                                                                                                                                                                                                                                                                  |
|                    | An ITS cache invalidation operation for a range of EventIDs is performed as follows:                                                                                                                                                                                                                                                                                                                                                                           |
|                    | <ol> <li>Any EventID within the range is written to ITS_EIDR.EVENT_ID and the DeviceID is written to ITS_DIDR.DEVICE_ID.</li> <li>A write to ITS_INV_EVENTR is performed with the fields set to the following:         <ul> <li>ITS_INV_EVENTR.L1 is set to 1.</li> <li>ITS_INV_EVENTR.ITT_L2SZ is set to the size of a level 2 ITT corresponding to the range of EventIDs that are invalidated.</li> <li>ITS_INV_EVENTR.I is set to 1.</li> </ul> </li> </ol> |
| $R_{PBJYK}$        | An ITS cache invalidation operation for a range of EventIDs invalidates all cached information from the L1 ITTE and L2 ITTEs for the DeviceID corresponding to the invalidate operation's DeviceID and for the EventID bits[15:N] corresponding to the invalidate operation's EventID's bits[15:N], where N equals (9 + 2 * ITS_INV_EVENTR.ITT_L2SZ).                                                                                                          |
|                    | Note                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                    | An ITS cache invalidation for a range of EventIDs applies to cached information from that range of EventIDs, regardless of whether a linear or 2-level structure is used for the ITT when the information is cached.                                                                                                                                                                                                                                           |
| I <sub>jnkrh</sub> | In an invalidation operation for a range of EventIDs, for each EventID in the range, the ITS invalidates the same cached information as when an invalidate operation is performed for a single EventID. See rule KYPHL for more information.                                                                                                                                                                                                                   |

I<sub>FLZSK</sub> The effects of a write to ITS\_INV\_EVENTR are complete when ITS\_STATUSR.IDLE is 1.

See also:

- 10.3.1.4 *ITS\_DIDR*.
- 10.3.1.7 *ITS\_EIDR*.

Chapter 5. Interrupt translation service (ITS) 5.4. ITS cache management

- 10.3.1.17 *ITS\_INV\_EVENTR*.
- 10.3.1.24 *ITS\_STATUSR*.

## 5.4.2 ITS cache management for DeviceIDs

ITKFBL An ITS cache invalidation operation for a single DeviceID is performed as follows: 1. The DeviceID is written to ITS DIDR.DEVICE ID. 2. A write to ITS\_INV\_DEVICER is performed with the fields set to the following: • ITS\_INV\_DEVICER.L1 is set to 0. • ITS\_INV\_DEVICER.EVENTID\_BITS is set to the number of EventID bits to which the invalidation operation applies. • ITS\_INV\_DEVICER.I is set to 1. An ITS cache invalidation operation for a DeviceID invalidates all of the following: R<sub>NWHYF</sub> • All cached information from the L2 DTE that corresponds to the DeviceID. • All cached information from all L1 ITTEs that correspond to the DeviceID. • All cached information from L2 ITTEs for the DeviceID where the EventID is less than 2 ^ ITS INV DEVICER.EVENTID BITS. The ITS supports invalidating a range of DeviceIDs corresponding to the number of DeviceIDs described by a IDWLGT single level 2 DT. An ITS cache invalidation operation for a range of DeviceIDs is performed as follows: 1. A DeviceID within the range is written to ITS\_DIDR.DEVICE\_ID. 2. A write to ITS\_INV\_DEVICER is performed with the fields set to the following: • ITS\_INV\_DEVICER.L1 is set to 1. • ITS\_INV\_DEVICER.I is set to 1. An ITS cache invalidation operation for a range of DeviceIDs invalidates all cached information from the L1 DTE, R<sub>FWYGP</sub> L2 DTEs, L1 ITTEs, and L2 ITTEs for DeviceID bits[31:N] corresponding to the invalidate operation's DeviceID bits[31:N], where N equals (9 + 2 \* ITS\_DT\_CFGR.L2SZ) and the effective value of EVENTID\_BITS is the value reported in ITS\_IDR2.EVENTID\_BITS. When a cache invalidation operation for a range of DeviceIDs is performed, the Effective value of EVENTID\_BITS INTHYD used to invalidate each DeviceID is the maximum implemented number of EventID bits reported in ITS IDR2.EVENTID BITS. In an invalidation operation for a range of DeviceIDs, for each DeviceID in the range, the ITS invalidates the same IXBVDN cached information as when an invalidate operation is performed for a single DeviceID. This means that cached information from the following translation structures is invalidated for each DeviceID when invalidating a range of DeviceIDs: The L2 DTE that corresponds to the DeviceID. • All L1 ITTEs that correspond to the DeviceID. • All L2 ITTEs that correspond to the DeviceID. See rule NWHYF for more information. The effects of a write to ITS\_INV\_DEVICER are complete when ITS\_STATUSR.IDLE is 1. IWWODF IONNOG When a write to a level 1 DTE sets VALID to 0, and there is cached information from a valid level 2 DTE for a DeviceID in the range covered by that level 1 DTE, the ITS may also contain cached information of the previously valid level 1 DTE. This means that the ITS is permitted to treat the DeviceID either as valid or invalid, and to ensure the ITS treats the DeviceID as invalid, the level 1 DTE cache entries for the DeviceID range must be invalidated. See also:

Chapter 5. Interrupt translation service (ITS) 5.4. ITS cache management

- 10.3.1.6 *ITS\_DT\_CFGR*.
- 10.3.1.16 *ITS\_INV\_DEVICER*.
- 10.3.1.24 *ITS\_STATUSR*.

## 5.5 ITS memory access rules

| R <sub>bxbxj</sub> | If an ITS access to any ITS translation structure occurs in PCIe address space, then the ITS is permitted to return<br>an UNKNOWN value or terminate the access and report the error.                                                                                                           |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | In this case, the ITS is permitted to drop the translation and not send any outgoing interrupt events to the IRS.                                                                                                                                                                               |
| R <sub>grxyb</sub> | When an ITS accesses a memory location in a PAS, it relies on information stored in registers and translation structures that are accessible only within the same PAS to validate that the access is permitted.                                                                                 |
|                    | This includes scenarios in which the ITS behavior is CONSTRAINED UNPREDICTABLE, UNPREDICTABLE, or IMPLEMENTATION DEFINED.                                                                                                                                                                       |
|                    | For example, an ITS access to a translation structure is permitted only if the memory location lies within a region defined by a base address and size held in a register or another translation structure entry, where that defining information resides in the same PAS as the access itself. |
|                    | This prevents software running in a Security state from directing the ITS to access any memory location using another PAS than the one associated with the software's Security state.                                                                                                           |
| R <sub>BLYPY</sub> | An ITS does not access any memory location which is not derived from address and configuration data in the ITS registers and translation structures.                                                                                                                                            |
|                    | When a memory address is stored in an address field in a register or translation structure entry, and that register or entry contains a field indicating that the address is not valid, the ITS does not derive any memory location from that address field.                                    |
|                    | This includes scenarios in which the ITS behavior is CONSTRAINED UNPREDICTABLE, UNPREDICTABLE, or IMPLEMENTATION DEFINED.                                                                                                                                                                       |
| $R_{LTFQT}$        | When the ITS accesses an ITS translation structure, the access must be a 64-bit aligned, single-copy atomic access of at least 64 bits in size.                                                                                                                                                 |
| I <sub>JXSPX</sub> | If the ITS experiences an external abort during a memory access to an ITS translation structure, the ITS stops the operation and reports the error.                                                                                                                                             |
|                    | If software error reporting is supported, the error is reported with ITS_SWERR_STATUSR.EC in the range from 0x00 to 0x04.                                                                                                                                                                       |
| R <sub>lscdt</sub> | If the ITS experiences an external abort as part of translating an event, the translation is dropped and no outgoing interrupt event is sent to the IRS.                                                                                                                                        |
| R <sub>pgrjq</sub> | If an ITS translation structure overlaps with any other ITS or IRS translation structure, the ITS behavior is UNPREDICTABLE.                                                                                                                                                                    |
|                    | The UNPREDICTABLE behavior may result in loss of interrupt configuration and state, but must not result in access to memory outside the PAS associated with the ITS Domain or in access to any memory location which is not derived from address and configuration of the DT or ITT.            |
|                    | For more information about the IRS translation structures, see 4.7 <i>The interrupt state table (IST)</i> and 4.9 <i>Virtualization data structures</i> .                                                                                                                                       |
|                    | Software can recover from this situation by performing the following sequence:                                                                                                                                                                                                                  |

- 1. Disabling the ITS.
- 2. Making the corresponding translation structures invalid in the IRS.
- 3. Reconfigure the base addresses of the translation structure to avoid overlap.

## 5.6 ITS support for MPAM

 IXZGHC
 The Memory System Resource Partitioning and Monitoring Memory, MPAM, architecture defines per-transaction attributes that affect system behavior or the behavior of components that the transactions pass through or Completers that satisfy a transaction [1].

The ITS supports MPAM with the following additional attributes:

- Partition ID, or PARTID.
- Performance Monitoring Group, or PMG.

The PARTID and PMG are both interpreted within a PARTID space. The PARTID space used depends on the Security state associated with an ITS Domain, and the PARTID and PMG values used may be programmed independently for each ITS Domain. See [1] for more information about MPAM information bundles.

 $I_{FBPMW}$  In the ITS, support for MPAM is indicated by ITS\_IDR0.MPAM.

If MPAM is supported, the supported PARTID and PMG width is indicated in ITS\_MPAM\_IDR. {PARTID\_MAX, PMG\_MAX

- R<sub>FCMHZ</sub> If MPAM is supported, ITS accesses to memory are associated with the PARTID and PMG programmed in ITS\_MPAM\_PARTID\_R.{PARTID,PMG}.
- In systems without support for RME, the PARTID space used by the ITS is determined by the memory system attribute MPAM\_NS.

In systems with support for RME, the PARTID space used by the ITS is determined by the memory system attribute MPAM\_SP.

IVCSKZ The ITS architecture has optional support for MPAM PARTID space selection indicated by ITS\_MPAM\_IDR.HAS\_MPAM\_S

If ITS\_MPAM\_IDR.HAS\_MPAM\_SP is 0, each ITS Domain uses a default MPAM PARTID space.

The following table shows the MPAM PARTID space used for accesses made by the ITS Domains if ITS\_MPAM\_IDR.HAS\_MPAM\_SP is 0 and the system does not support RME:

| ITS Domain | MPAM PARTID space       |
|------------|-------------------------|
| Secure     | Secure PARTID space     |
| Non-Secure | Non-secure PARTID space |
| EL3        | Secure PARTID space     |

The following table shows the MPAM PARTID space used for accesses made by the ITS Domains if ITS\_MPAM\_IDR.HAS\_MPAM\_SP is 0 and the system supports RME:

| ITS Domain | MPAM PARTID space       |
|------------|-------------------------|
| Secure     | Secure PARTID space     |
| Non-Secure | Non-secure PARTID space |
| EL3        | Root PARTID space.      |
| Realm      | Realm PARTID space.     |

If ITS\_MPAM\_IDR.HAS\_MPAM\_SP is 1, the ITS uses the MPAM PARTID specified by ITS\_MPAM\_PARTID\_R.MPAM\_SP

R<sub>BJQFG</sub>

If an ITS without support for MPAM is integrated in a system that supports MPAM, the PARTID and PMG used for each ITS Domain is IMPLEMENTATION DEFINED.

# 5.7 ITS support for Memory Encryption Contexts

| I <sub>prbcl</sub> | The Memory Encryption Contexts feature, FEAT_MEC, provides finer-grained memory encryption contexts, within the Realm physical address space, to be assigned to Realms, with policy controlled by Realm EL2 [1].                                                                                                                                                                                                                                                                                  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $G_{ZHPQC}$        | The GICv5 architecture ensures that an ITS can function correctly in systems with support for Memory Encryption Contexts (MEC).                                                                                                                                                                                                                                                                                                                                                                   |
| I <sub>YQGHF</sub> | In a system with support for MEC, the PEs write ITS translation structures to memory and these are read by the ITS.                                                                                                                                                                                                                                                                                                                                                                               |
|                    | In such a system, all ITS Realm translation structures are managed and configured by Realm EL2, and virtualized software running at EL1 is not expected to have direct access to the ITS configuration registers or translation structures. Therefore, the ITS only supports configuration of a single MECID used for all ITS memory accesses to the Realm PAS. This allows software running at Realm EL2 to write to the ITS translation structures and allows the ITS to read the translations. |
| I <sub>vrvqv</sub> | In the ITS, support for Memory Encryption Contexts (MEC) is indicated in ITS_IDR0.MEC for the Realm ITS Domain. If the MEC feature is supported, the supported MECID width is indicated in ITS_MEC_IDR.MECIDSIZE for the Realm ITS Domain.                                                                                                                                                                                                                                                        |
|                    | Arm strongly recommends that the MECID bit width supported by the ITS matches or exceeds the width supported by the PEs in the system.                                                                                                                                                                                                                                                                                                                                                            |
| R <sub>XKTWP</sub> | If the MEC feature is supported, ITS accesses to memory are associated with a MECID that identifies the Memory Encryption Context of the access.                                                                                                                                                                                                                                                                                                                                                  |
| R <sub>XTVVQ</sub> | Accesses made by the ITS for Secure, Non-secure, and Root PA spaces are issued with the default MECID of zero.                                                                                                                                                                                                                                                                                                                                                                                    |
| I <sub>FPSSV</sub> | Accesses made by the ITS to Realm PA space are associated with the global Realm PAS ITS MECID programmed in ITS_MEC_MECID_R.MECID.                                                                                                                                                                                                                                                                                                                                                                |
| R <sub>dgjxq</sub> | If an ITS without support for the Realm ITS Domain is integrated in a system that supports MEC, all ITS accesses for that ITS are treated as having the default MECID of zero.                                                                                                                                                                                                                                                                                                                    |

## 5.8 ITS support for software error reporting

| I <sub>fwkks</sub> | The ITS specifies a mechanism to report errors because of incorrect programming.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>fbvqn</sub> | The ITS detects software errors while processing ITS events. Otherwise, the ITS does not detect software errors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| R <sub>RLHPC</sub> | Software error codes that refer to incoming events apply to incoming events generated by all supported mechanisms. See Chapter 5 Interrupt translation service (ITS) for more information about the supported mechanisms for incoming events.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| R <sub>rljnx</sub> | ITS support for software error reporting is optional.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| I <sub>hkrkl</sub> | ITS_IDR0.SWE reports whether software error reporting is supported.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| R <sub>QRYDD</sub> | The value of ITS_IDR0.SWE is the same for all ITS Domains in an ITS in the system.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| I <sub>FCPZL</sub> | When ITS_IDR0.SWE is 1, the ITS uses the ITS_SWERR_STATUSR.IMP_EC to report any IMPLEMENTATION DEFINED errors detected by the ITS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| I <sub>ZGMTB</sub> | ITS_SWERR_STATUSR.EC is 0 when an IMPLEMENTATION DEFINED error is reported by the ITS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| I <sub>ZNSVM</sub> | When L2_DTE.DSWE is 0, the ITS does not report errors for the following error codes in ITS_SWERR_STATUSR.EC:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | <ul> <li>0x03: Failed lookup of L1_ITTE due to an external abort.</li> <li>0x04: Failed lookup of L2_ITTE due to an external abort.</li> <li>0x06: An incoming event could not be translated because L2_DTE.VALID is 0.</li> <li>0x07: An incoming event could not be translated because L1_ITTE.VALID is 0.</li> <li>0x08: An incoming event could not be translated because L2_ITTE.VALID is 0.</li> <li>0x0A: An incoming event could not be translated because the EventID &gt; (2 ^ L2_DTE.EVENTID_BITS) - 1.</li> <li>0x0C: An incoming event could not be translated because the EventID exceeds the L1_ITTE.SPAN.</li> <li>0x0D: An incoming event could not be translated because the event is associated with the Non-secure Interrupt Domain and L2_ITTE.DAC = 0.</li> </ul> |
| S <sub>fpvfm</sub> | When a device is assigned to a VM, the Hypervisor can set L2_DTE.DSWE to 0 in the L2 DTE of the device to mask reporting of software errors caused by misconfiguration of the device by VM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| I <sub>ZKJKN</sub> | Software error information can be read in an ITS Domain via the following ITS registers:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                    | <ul> <li>ITS_SWERR_STATUSR.</li> <li>ITS_SWERR_SYNDROMER0.</li> <li>ITS_SWERR_SYNDROMER1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| I <sub>YSSCL</sub> | When a software error is reported in the ITS Domain, the value of ITS_SWERR_STATUSR.V is 1. Otherwise, no software error is reported in the ITS Domain and fields in this register are UNKNOWN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| I <sub>pvqyf</sub> | When the value of ITS_SWERR_STATUSR.V is 1, all of the following are true in that ITS Domain:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                    | <ul> <li>ITS_SWERR_STATUSR.EC specifies the fault that caused the software error.</li> <li>ITS_SWERR_STATUSR.S0V indicates whether ITS_SWERR_SYNDROMER0 contains valid error syndrome information.</li> <li>ITS_SWERR_STATUSR.S1V indicates whether ITS_SWERR_SYNDROMER1 contains valid error syndrome information.</li> <li>ITS_SWERR_STATUSR.OF indicates whether multiple software errors were detected.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                  |
| I <sub>zbhqq</sub> | When ITS_SWERR_STATUSR.SOV is 1, ITS_SWERR_SYNDROMER0 reports the following information for the software error:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | <ul><li>The DeviceID and EventID of the incoming event that resulted in the software error.</li><li>The Interrupt Domain the incoming event is associated with.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| I <sub>BBZNG</sub> | When ITS_SWERR_STATUSR.S1V is 1, ITS_SWERR_SYNDROMER1 reports the address of the ITS translation structure associated with the software error.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# Chapter 5. Interrupt translation service (ITS) 5.8. ITS support for software error reporting

R<sub>LKLQG</sub> For each reported error, the values of ITS\_SWERR\_STATUSR.{S0V,S1V} are IMPLEMENTATION DEFINED and set independently.

S<sub>NZTWH</sub> Arm recommends that software performs the following sequence of operations to either clear the last error, or detect if new errors were reported:

- 1. Read ITS\_SWERR\_STATUSR and determine which fields need to be cleared to zero.
- 2. In a single-copy atomic write to ITS\_SWERR\_STATUSR:
  - 1. Write ones to all the W1C fields that are nonzero in the read value.
  - 2. Write zero to all the W1C fields that are zero in the read value.
  - 3. Write zero to all the RW fields.
- 3. Read back ITS\_SWERR\_STATUSR after the write. If the value read back is the same as the value that was written, all W1C fields that were non-zero are cleared, and no new errors were reported. Otherwise, one or more new errors were reported.

See also:

- 10.3.1.25 ITS\_SWERR\_STATUSR.
- 10.3.1.26 ITS\_SWERR\_SYNDROMER0.
- 10.3.1.27 ITS\_SWERR\_SYNDROMER1.

# Chapter 6 Interrupt Wire Bridge (IWB)

| A system is permitted to have zero, one, or many IWB instances.                                                                                                                                                                                                                                                              |       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|                                                                                                                                                                                                                                                                                                                              |       |
| Each IWB is associated with a single ITS in the system.                                                                                                                                                                                                                                                                      |       |
| Every input wire connected to the IWB is <i>asserted</i> or <i>de-asserted</i> .                                                                                                                                                                                                                                             |       |
| The mechanism for making an input wire asserted or de-asserted is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                    |       |
| For example, a wire connecting a device that signals <i>interrupt events</i> to the IWB may assert the input wire wh the device signals an event and de-assert the input wire at any time after signaling the event. Only the ass (and not the de-assertion) of the input wire matters for such a device.                    |       |
| As another example, a wire connecting a device signals <i>interrupt state</i> to the IWB may keep the input wire as to indicate a state in the device and keep the wire de-asserted to indicate a different state in the device. The wire would be asserted and de-asserted when the device transitions between such states. |       |
| The number of implemented wire control registers IWB_WTMR <n>, IWB_WDOMAINR<n> IWB_WENABLER<n> is reported in IWB_IDR0.IW_RANGE.</n></n></n>                                                                                                                                                                                 | , and |
| The maximum number of implemented wires for a single IWB instance is 65536.                                                                                                                                                                                                                                                  |       |
| The number of implemented wires by an IWB is less than or equal to (IWB_IDR0.IW_RANGE + 1) * 32.                                                                                                                                                                                                                             |       |
| Each input wire to an IWB can be uniquely identified by its <i>input wire index</i> which is a number from 0 th $(IWB\_IDR0.IW\_RANGE + 1) * 32 - 1.$                                                                                                                                                                        | rough |
| Accesses to wire control fields for wires that are not implemented in the wire control registers are RAZ/W                                                                                                                                                                                                                   | [.    |

### Chapter 6. Interrupt Wire Bridge (IWB)

| R <sub>VKMRC</sub>  | The IWB is identified with a DeviceID that is unique in the DeviceID namespace of the associated ITS.                                                                                                                              |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | All wire events signaled to the ITS from the same IWB are signaled using the same DeviceID.                                                                                                                                        |
| R <sub>RMRTF</sub>  | An input wire uses the input wire index as the EventID when signaling an event to the ITS.                                                                                                                                         |
| I <sub>mbfpr</sub>  | Each input wire is signaled with an EventID that is unique across all input wires implemented by the IWB.                                                                                                                          |
| I <sub>QHCJD</sub>  | Arm strongly recommends implementing wires contiguously to avoid the need to allocate a sparse ITT for the ITS.                                                                                                                    |
| $\rm S_{\rm HYHGF}$ | The relationship between wires and the connected interrupt source is available to system software in firmware tables.                                                                                                              |
| R <sub>RVNRP</sub>  | The mechanism used by the IWB to communicate events to the ITS is IMPLEMENTATION DEFINED.                                                                                                                                          |
| I <sub>tvrkt</sub>  | IWB_CR0.IWBEN controls whether the IWB is enabled or disabled.                                                                                                                                                                     |
| I <sub>rqjmn</sub>  | The Trigger mode of each wire connected to an IWB is configured to be either edge-triggered or level-sensitive.                                                                                                                    |
| $R_{WLHDQ}$         | When the IWB is enabled, events are generated according to the input wire settings:                                                                                                                                                |
|                     | • If an input wire is enabled and configured as edge-triggered, the IWB generates a SET_EDGE event when the input wire becomes asserted.                                                                                           |
|                     | • If an input wire is enabled and configured as level-sensitive, the IWB generates a SET_LEVEL event when the input wire becomes asserted and a CLEAR event when the level becomes de-asserted.                                    |
|                     | • If an input wire is disabled, the IWB does not generate any events as a result of the wire becoming asserted or de-asserted.                                                                                                     |
|                     | When the IWB is disabled, it generates no events to the ITS.                                                                                                                                                                       |
| R <sub>MXGNY</sub>  | When the IWB generates an event as a result of a wire being asserted or de-asserted, the event is generated in finite time.                                                                                                        |
| R <sub>PKSVB</sub>  | For an edge-triggered input wire, if the wire is asserted multiple times without the IWB having sent an event to the ITS, the IWB is permitted to only generate a single SET_EDGE event and send it to the ITS.                    |
|                     | Once an event is generated and sent to the ITS, when the wire is subsequently asserted, the IWB generates a new SET_EDGE event in finite time.                                                                                     |
| I <sub>htkht</sub>  | For example, when a wire that is configured as edge-triggered goes through the following transition, the IWB is permitted to generate only a single SET_EDGE event:                                                                |
|                     | <ol> <li>The wire is asserted</li> <li>The wire is de-asserted</li> <li>The wire is asserted</li> </ol>                                                                                                                            |
| $R_{\rm PHYZS}$     | If an input wire is configured as level-sensitive, the IWB is permitted to discard the SET_LEVEL and CLEAR events when the wire is asserted and de-asserted before the IWB sends any event to the ITS.                             |
| I <sub>htbrd</sub>  | For example, for a wire that is configured as level-sensitive and goes through the following transition, the IWB is permitted not to generate any events to the ITS:                                                               |
|                     | <ol> <li>The wire is asserted</li> <li>The wire is de-asserted</li> </ol>                                                                                                                                                          |
| $R_{GJJZH}$         | For an edge-triggered input wire, when the IWB or the input wire is disabled, the IWB is permitted to detect that the input wire is asserted and generate a SET_EDGE event later when the IWB and the input wire are enabled.      |
|                     | If the input wire's Trigger mode is updated from edge-triggered to level-sensitive when the IWB or input wire is disabled, the IWB does not generate any SET_EDGE events when the IWB and the input wire are subsequently enabled. |
| I <sub>bgsbg</sub>  | Changing the value of IWB_CR0.IWBEN does not affect the values in other IWB registers.                                                                                                                                             |

R<sub>VWTHK</sub> When a write to IWB\_CR0.IWBEN changes the value from 0 to 1, the IWB begins a transition from disabled to enabled.

The transition from disabled to enabled is complete when IWB\_CR0.IDLE is 1.

When the transition from disabled to enabled is complete, the IWB processes the following events:

For wires where IWB\_WTMR<n>.TM<x> is 1 (level-sensitive) and IWB\_WENABLER<n>.WEN<x> is 1:

- If the wire is asserted when the transition is complete, the IWB generates a SET\_LEVEL event.
- If the wire is de-asserted when the transition is complete, the IWB generates a CLEAR event.

For wires where IWB\_WTMR<n>.TM<x> is 0 (edge-triggered):

- The IWB does not generate any events for edge-triggered input wires when the IWB becomes enabled.
- If a level-sensitive input wire becomes asserted or de-asserted during the IWB transitions from disabled to enabled, the IWB either generates a single event corresponding to the final state of the input wire or generates multiple events for the input wire where the last event corresponds to the final state of the input wire.

R<sub>DRQYB</sub> When a write to IWB\_CR0.IWBEN changes the value from 1 to 0, the IWB begins a transition from enabled to disabled.

When the IWB is transitioning from enabled to disabled, the IWB is not guaranteed to detect when input wires are asserted or de-asserted.

The transition from enabled to disabled is complete when IWB\_CR0.IDLE is 1.

When the transition from enabled to disabled is complete, the IWB has generated a CLEAR event for every level-sensitive wire where it had sent a SET\_LEVEL event and no corresponding CLEAR. These events are Accepted by the ITS when the transition is complete.

#### Note

If the assignment of an input wire to an Interrupt Domain is changed when IWB\_CR0.IDLE is 0, and before a corresponding CLEAR event is Accepted by the ITS, the IWB does not guarantee that a CLEAR event is sent or Accepted by the ITS when IWB\_CR0.IDLE is 1.

See 6.2 *IWB support for multiple Interrupt Domains* for more information about assigning input wires to Interrupt Domains.

R<sub>XCTCW</sub> If the IWB is enabled or disabled when IWB\_WENABLE\_STATUSR.IDLE is 0 for any PAS, it is CONSTRAINED UNPREDICTABLE whether the IWB generates events for level-sensitive wires affected by the write to ongoing write to IWB\_WENABLER<n>.

See 6.1 *IWB wire control registers* for more information about individually enabling and disabling wires.

R<sub>XDGSG</sub> Following a write to IWB\_CR0.IWBEN, when IWB\_CR0.IDLE is 1, all events generated as a result of the write are Accepted by the ITS.

#### S<sub>XWPYQ</sub> When the IWB is reset, software is expected to configure wired interrupts using a sequence similar to the following:

- Software executing in a Security state that can access the MPPAS of the IWB performs the following steps:
  - 1. Individually disable all input wires to the IWB.
  - 2. Initialize the Interrupt Domain association for the input wires in the IWB.
  - 3. Enable the IWB.
- Software executing in any Security state performs the following steps to configure a wired interrupt in an Interrupt Domain that the input wire is assigned to:
  - 1. Enable and configure the IRS, including providing the necessary data structures in memory.
  - 2. Enable and configure the associated ITS, including providing the necessary data structures in memory.

- 3. Configure a valid translation in the ITS for the DeviceID and EventID associated with the IWB and input wire.
- 4. Configure the input wire in the IWB as edge-triggered or level-sensitive.
- 5. Individually enable the wire in the IWB.

See also:

- Chapter 4 Interrupt routing service (IRS)
- 4.8.2 Physical SPIs
- Chapter 5 Interrupt translation service (ITS)

# 6.1 IWB wire control registers

| D <sub>fkxgt</sub> | The IWB allows software to control the behavior of the IWB for each input wire through the following <i>wire control registers</i> :                                                                                                                                                                                                                                                                                     |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>IWB_WENABLER<n>: Enables and disables individual wires.</n></li> <li>IWB_WTMR<n>: Configures if individual wires are edge-triggered or level-sensitive.</n></li> <li>IWB_WDOMAINR<n>: Selects the Interrupt Domain that the individual wires are assigned to.</n></li> </ul>                                                                                                                                    |
| D <sub>wlwfz</sub> | The following terms are used to indicate programming of a single wire as opposed to a configuration setting which applies to all of the IWB:                                                                                                                                                                                                                                                                             |
|                    | • <i>Individually enabling</i> a wire refers to a write to IWB_WENABLER <n>.WEN<x> that updates the value from 0 to 1.</x></n>                                                                                                                                                                                                                                                                                           |
|                    | • <i>Individually disabling</i> a wire refers to a write to IWB_WENABLER <n>.WEN<x> that updates the value from 1 to 0.</x></n>                                                                                                                                                                                                                                                                                          |
| R <sub>SDJBH</sub> | When individually enabling one or more wires, the IWB behaves as follows:                                                                                                                                                                                                                                                                                                                                                |
|                    | <ul> <li>For wires where IWB_WTMR<n>.TM<x> is 1 (level-sensitive): <ul> <li>If the wire is asserted at the time of the write to IWB_WENABLER<n>, the IWB generates a SET_LEVEL event.</n></li> <li>If the wire is de-asserted at the time of the write to IWB_WENABLER<n>, the IWB generates a CLEAR event.</n></li> </ul> </x></n></li> <li>For wires where IWB_WTMR<n>.TM<x> is 0 (edge-triggered):</x></n></li> </ul> |
|                    | <ul> <li>The IWB does not generate any events for the wire.</li> </ul>                                                                                                                                                                                                                                                                                                                                                   |
|                    | When individually disabling one or more wires, the IWB behaves as follows:                                                                                                                                                                                                                                                                                                                                               |
|                    | <ul> <li>For wires where IWB_WTMR<n>.TM<x> is 1 (level-sensitive): <ul> <li>If a SET_LEVEL event was previously generated for that wire without a corresponding CLEAR event, the IWB generates a CLEAR event.</li> </ul> </x></n></li> <li>For wires where IWB_WTMR<n>.TM<x> is 0 (edge-triggered): <ul> <li>The IWB does not generate any events for the wire.</li> </ul> </x></n></li> </ul>                           |
|                    | Writing to IWB_WENABLER <n> when IWB_CR0.IWBEN is 0 has no effect other than changing the values stored in IWB_WENABLER<n>.</n></n>                                                                                                                                                                                                                                                                                      |
| I <sub>WLHND</sub> | The effects of a write to IWB_WENABLER <n> are complete when a read using the same PAS as the write of IWB_WENABLE_STATUSR.IDLE returns 1.</n>                                                                                                                                                                                                                                                                           |
| R <sub>HJXNH</sub> | When the effects of a write to IWB_WENABLER <n> are complete, all of the following are true:</n>                                                                                                                                                                                                                                                                                                                         |
|                    | <ul><li>Each input wire affected by the write becomes either disabled or enabled.</li><li>All CLEAR events generated as a result of individually disabling wires are Accepted by the ITS.</li></ul>                                                                                                                                                                                                                      |
|                    | Note                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | The IWB is required to generate a CLEAR event as a result of individually disabling a level-sensitive wire. The effects of the write to IWB_WENABLER <n> are not complete until the CLEAR events are accepted by the ITS.</n>                                                                                                                                                                                            |
|                    | The IWB is not required to generate any events and ensure that they are Accepted by the ITS before IWB_WENABLE_STATUSR.IDLE is 1 when individually enabling a wire.                                                                                                                                                                                                                                                      |
| S <sub>ddqds</sub> | The IWB is required to generate CLEAR events when individually disabling a wire to support the following use case:                                                                                                                                                                                                                                                                                                       |
|                    | • To re-sample the level of a level-sensitive interrupt, software can rely on a CLEAR being sent when the effects of individually disabling a wire are complete, and subsequent SET_EDGE or SET_LEVEL events                                                                                                                                                                                                             |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                          |

being sent in finite time.

• Software may remove a mapping for an event in the ITS and ensure that the ITS does not report failed translations for that wire due to events being sent by the IWB after the wire has been disabled.

#### Note

If the assignment of an input wire to an Interrupt Domain is changed when IWB\_WENABLE\_STATUSR.IDLE is 0 due to a write to IWB\_WENABLER<n> that disables that wire, and before a corresponding CLEAR event is Accepted by the ITS, the IWB does not guarantee that a CLEAR event is sent or Accepted by the ITS when IWB\_WENABLE\_STATUSR.IDLE is 1.

See 6.2 *IWB support for multiple Interrupt Domains* for more information about assigning input wires to Interrupt Domains.

S<sub>TFNWQ</sub> Software can poll IWB\_WENABLE\_STATUSR.IDLE until it is 1, using the same PAS as was used to individually disable the wire, to ensure that all events for a wire that has been disabled are Accepted by the ITS and that no further events will be generated for that wire.

Software can rely on this functionality combined with an ITS synchronization request to ensure that all events are translated by the ITS before unmapping the event to avoid spurious translation errors being logged by the ITS.

 $I_{VXFZX}$  Arm strongly recommends that a translation exists in the ITS for the wire before individually enabling the wire, and that the translation is not changed or made invalid in the ITS until the wire is individually disabled.

Further, Arm strongly recommends that a wire is individually disabled before changing the Interrupt Domain that the wire is assigned to. See 6.2 *IWB support for multiple Interrupt Domains* for more information.

R<sub>HWHSV</sub> It is IMPLEMENTATION DEFINED whether software is permitted to program the Trigger mode of individual wires.

If software is not permitted to program the Trigger mode, any access to the Trigger mode of individual wires is **RO**.

- I<sub>YQYHL</sub> The permission to program the Trigger mode is expressed by the pseudocode function IsWireConfigRO().
- R<sub>MQFZD</sub> Writing to IWB\_WTMR<n>.TM<x> when any of the following are true results in a CONSTRAINED UNPRE-DICTABLE behavior:
  - The wire is enabled.
  - IWB\_WENABLE\_STATUSR.IDLE is 0 due to a write to IWB\_WENABLER<n> affecting that wire.

The CONSTRAINED UNPREDICTABLE behavior is one of the following:

- The write is IGNORED and the configuration is not updated.
- The configuration is updated and no events are generated as a result of changing the configuration.
- The configuration is updated and the IWB generates a SET\_EDGE, SET\_LEVEL, or CLEAR event to the ITS.
- $S_{TQWXV}$  Software is expected to configure the wire to be edge-triggered or level-sensitive when the wire is individually disabled.
- I<sub>BNWSF</sub> Software may *resample* a wire by writing the input wire index to IWB\_WRESAMPLER.
- R<sub>QSYNQ</sub> A wire can only be resampled by writing the input wire index to IWB\_WRESAMPLER using one of the following PA spaces:
  - The MPPAS of the IWB.
  - The PAS associated with the Interrupt Domain that the wire is assigned to.

Writing the input wire index to IWB\_WRESAMPLER using any other PAS has no effects.

# Chapter 6. Interrupt Wire Bridge (IWB) 6.1. IWB wire control registers

 RHEPMEM
 Resampling an enabled wire has the following effects:

 • For wires where IWB\_WTMR<n>.TM<x> is 1 (level-sensitive), all of the following are true:

 • If the wire is asserted, the IWB generates a SET\_LEVEL event.

 • If the wire is de-asserted, the IWB generates a CLEAR event.

 • For wires where IWB\_WTMR<n>.TM<x> is 0 (edge-triggered), all of the following are true:

 • If the wire is asserted, the IWB generates a SET\_EDGE event.

 • If the wire is asserted, the IWB generates a SET\_EDGE event.

 • If the wire is de-asserted, the IWB generates no events.

 Resampling a disabled wire has no effects and generates no events.

 Resampling a disabled wire has no effects and generated in finite time.

 RMQVNP
 If a wire is being individually enabled or disabled at the same time that a wire is resampled, it is CONSTRAINED UNPREDICTABLE whether the resample has any effects.

 See also:
 See also:

#### see also.

- 4.5 IRS synchronization requests
- 5.2.4 ITS synchronization requests
- 10.4 *IWB register frames*

## 6.2 IWB support for multiple Interrupt Domains

R<sub>ZDJNJ</sub> An IWB only implements support for Interrupt Domains supported by PEs in the system.
 It is possible for an IWB to implement a subset of the Interrupt Domains that the PEs support.
 I<sub>WYBFB</sub> For a system with more than one IWB, it is possible for each IWB to implement a different set of Interrupt Domains.
 The Interrupt Domains implemented by an IWB are reported in IWB\_IDR0.INT\_DOMS.
 R<sub>ZLWKJ</sub> The MPPAS of an IWB is determined from the subset of Interrupt Domains implemented by the IWB as follows:

| Implemented Interrupt Domains  | IWB MPPAS  |  |  |
|--------------------------------|------------|--|--|
| Non-secure                     | Non-secure |  |  |
| Secure                         | Secure     |  |  |
| Non-secure, Secure, EL3        | Secure     |  |  |
| Non-secure, Realm, EL3         | Root       |  |  |
| Non-secure, Realm, Secure, EL3 | Root       |  |  |

- IVTYPKFor example, if an IWB implements the Non-secure, Secure, and EL3 Interrupt Domains, the MPPAS of the IWB<br/>is the Secure PAS. If the PEs in the system implement FEAT\_RME, the MPPAS of the PEs is the Root PAS.<br/>Software executing in either Root state or Secure state can access the MPPAS of the IWB.
- R<sub>ZGJQC</sub> The ITS associated with the IWB provides an ITS Domain for each Interrupt Domain implemented by the IWB.
- D<sub>TDVQF</sub> Each input wire connected to the IWB is *assigned* to an Interrupt Domain.
- $R_{QWBDZ}$  The assignment of a wire to an Interrupt Domain is configured in IWB\_WDOMAINR<n>.

For each wire, the assignment of a wire to an Interrupt Domain is either fixed or software programmable.

- S<sub>MMLFL</sub> The assignment of a wire to an Interrupt Domain is either fixed or software programmable. Software checks the configuration by attempting to assign a new Interrupt Domain for the wire in IWB\_WDOMAINR<n> using the IWB MPPAS and reading back the value once IWB\_WDOMAIN\_STATUSR.IDLE is 1. If the value returned has not been updated, the wire assignment to the Interrupt Domain is fixed. Otherwise, the wire assignment is software programmable.
- $I_{NZYYK}$  The Interrupt Domains supported by the IWB are reported in IWB\_IDR0.INT\_DOMS.
- R<sub>GFGYY</sub> When the IWB communicates an event related to a wire to the ITS, the Interrupt Domain of the event is the Interrupt Domain that the wire is assigned to.
- IVGSJNTo provide isolation between Interrupt Domains, the configuration of an input wire is restricted based on the PAS<br/>used to write to IWB wire registers.
- IVB\_WDOMAINR<n> is only accessible in the MPPAS of the IWB.
  - For any other PAS, the registers are RAZ/WI.
- IVFDHJ
   The fields in IWB\_WENABLER<n> and IWB\_WTMR<n> are modified only through one of the following PA spaces:
  - The MPPAS of the IWB.
  - The PAS associated with the Interrupt Domain that the wire is assigned to.
- I<sub>HTBXZ</sub> For example, in an implementation supporting all four Interrupt Domains, an input wire configured to be assigned to the Secure Interrupt Domain can only be configured and enabled when writing to the MMIO registers using either the Secure or Root PAS.

#### Chapter 6. Interrupt Wire Bridge (IWB) 6.2. IWB support for multiple Interrupt Domains

| I <sub>ftmvv</sub> | The effects of a write to IWB_WDOMAINR <n> are complete when IWB_WDOMAIN_STATUSR.IDLE is 1.</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>rxcqb</sub> | When a write to IWB_WDOMAINR <n> is complete, for each wire that was affected by the write, the wire is assigned to the new Interrupt Domain.</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | Events generated after the write to IWB_WDOMAINR <n>, but before the write completes, for wires affected by the write, are either signaled in the old Interrupt Domain or the new Interrupt Domain of the wires.</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| I <sub>YZCLL</sub> | The IWB does not generate any events as a result of a write to IWB_WDOMAINR <n>.</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| R <sub>bmzmz</sub> | If the IWB is being enabled or disabled at the same time that a wire is being assigned to a new Interrupt Domain, the IWB is not required to generate any events for that wire as a result of enabling or disabling the IWB.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | See Chapter 6 Interrupt Wire Bridge (IWB) for more information about enabling and disabling the IWB.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| R <sub>txfjs</sub> | If a wire is being individually enabled or disabled at the same time that a wire is being assigned to a new Interrupt Domain, the IWB is not required to generate any events for that wire as a result of individually enabling or disabling the wire.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                    | See 6.1 <i>IWB wire control registers</i> for more information about individually enabling and disabling wires.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| S <sub>XWKVY</sub> | Software can use the following sequence to change the assignment of a wire from an old Interrupt Domain to a new Interrupt Domain:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                    | <ol> <li>Software in the old Interrupt Domain performs the following actions:         <ol> <li>Disable the interrupt in the IRS where the wire is signaled.</li> <li>Individually disable the wire in the IWB.</li> <li>Wait until IWB_WENABLE_STATUSR.IDLE is 1 to ensure that no further events will be generated for the wire.</li> <li>Perform a synchronization request in the ITS and wait until it has completed.</li> <li>Unmap the event from the ITS and invalidate the required ITS caches.</li> <li>Request that software running in a Security state that can access the MPPAS of the IWB, assigns the input wire to the new Interrupt Domain.</li> </ol> </li> </ol> |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

- 2. Software in the Security state that can access the MPPAS of the IWB performs the following actions:
  - Writes to IWB\_WDOMAINR<n>.WDDOM<x> to assign the wire to the new Interrupt Domain.
     Waits until IWB\_WDOMAIN\_STATUSR.IDLE is 1.
- 3. Software in the Security state that can access the MPPAS of the IWB notifies software in the new Interrupt Domain that the wire has been re-assigned.
- 4. Software in the new Interrupt Domain performs the following actions:
  - 1. Allocate and configure an interrupt in the IRS.
  - 2. Map the wire event in the ITS for the new Interrupt Domain.
  - 3. Individually enable the wire in the IWB.

See also:

- 10.2 IRS register frames
- 10.4 IWB register frames

# Chapter 7 GIC Performance Monitoring Unit (PMU)

| $D_{WQRHY}$        | A GICv5 system may implement one or more <i>GIC Performance Monitoring Units (PMU)</i> that counts events for one or more GICv5 system components.                                                                                                                                          |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>gsjjj</sub> | A GIC PMU is an implementation of the Arm <sup>®</sup> CoreSight <sup>TM</sup> Architecture Performance Monitoring Unit Architecture[11].                                                                                                                                                   |
| I <sub>CXHZH</sub> | The GIC PMU registers for each GIC PMU are accessible in a separate 64KB aligned GIC_PMU_FRAME.                                                                                                                                                                                             |
| R <sub>QZHLT</sub> | The base address of the GIC_PMU_FRAME is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                            |
| $S_{\text{BPXJG}}$ | Arm expects that firmware describes the base address of ITS PMU register frames to system software using firmware data structures.                                                                                                                                                          |
| R <sub>VGHTV</sub> | For a GIC PMU, monitor 0 is 64 bits. The sizes of all other monitors are IMPLEMENTATION DEFINED. This means that PMCFGR.SIZE is <code>0b111111</code> .                                                                                                                                     |
| S <sub>HTCFV</sub> | Arm expects that monitor 0 is used to count GIC cycles.                                                                                                                                                                                                                                     |
| $\rm D_{LTMWH}$    | A GIC PMU counts events from GIC components. This is referred to as the <i>agent being monitored</i> in the $Arm^{\textcircled{B}}$<br><i>CoreSight</i> <sup>TM</sup> <i>Architecture Performance Monitoring Unit Architecture</i> [11]. The agent being monitored is one of the following: |
|                    | <ul> <li>The GIC PMU counts events for a single ITS.</li> <li>The GIC PMU counts events for a single IRS.</li> <li>The GIC PMU counts events for a single IRS and all of its associated ITSs.</li> </ul>                                                                                    |
|                    | Figure 7.1 shows different implementation options for GIC PMUs in a GICv5 system.                                                                                                                                                                                                           |
| R <sub>FKJCW</sub> | When a GIC PMU counts events for a system component that supports multiple Interrupt Domains, the GIC PMU counts events for all the supported Interrupt Domains.                                                                                                                            |



Figure 7.1: GIC PMU implementation options

#### Note

The GIC PMU implementation options are shown using only the Non-secure and Realm Interrupt Domains for illustrative purposes. The GIC PMU is also supported for the Secure and EL3 Interrupt Domains.

 $\label{eq:linear} I_{\text{HLZWW}} \qquad \mbox{GIC_PMIDR0.IRS_PMU} \ reports \ whether \ the \ GIC \ PMU \ counts \ events \ for \ an \ IRS.$ 

GIC\_PMIDR0.ITS\_PMU reports whether the GIC PMU counts events for one or more ITSs.

GIC\_PMIDR0.{IRS\_PMU, ITS\_PMU} is not permitted to be {0, 0}.

See also:

• 10.5.1 GIC\_PMU\_FRAME, GIC PMU register frame

 $R_{\text{BMCHW}}$ 

# 7.1 CoreSight PMU extensions

| R <sub>fvchk</sub> | A GIC PMU implements the 64-bit programmers' model extension defined in [11].                                                                                                                                                      |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>schgw</sub> | A GIC PMU implements the direct access to enables and overflows extension because it is always implemented when the 64-bit programmers' model extension is implemented.                                                            |
| R <sub>tgdsp</sub> | A GIC PMU implements the observability and access control extension defined in [11] if, for any of the components in the agent being monitored, all of the following are true:                                                     |
|                    | <ul> <li>Multiple Interrupt Domains are supported.</li> <li>Any of the following are true: <ul> <li>The agent supports the Secure Interrupt Domain.</li> <li>The agent supports the EL3 Interrupt Domain.</li> </ul> </li> </ul>   |
|                    | Otherwise, it is IMPLEMENTATION DEFINED whether the GIC PMU implements the observability and access control extension.                                                                                                             |
| R <sub>sksty</sub> | If a GIC PMU does not implement the observability and access control extension, it is IMPLEMENTATION DEFINED which physical address space is used to access the GIC PMU registers.                                                 |
| I <sub>JMZMR</sub> | GIC_PMIDR0.OACE reports whether the observability and access control extension is implemented.                                                                                                                                     |
| R <sub>qzccm</sub> | When the Observability and access control extension is implemented, all of the following are true:                                                                                                                                 |
|                    | <ul> <li>It is IMPLEMENTATION DEFINED whether PMSCR and PMROOTCR are implemented in the GIC PMU register frame or at an IMPLEMENTATION DEFINED location.</li> <li>PMSCR is only accessible in the MPPAS for the system.</li> </ul> |
| R <sub>PMHYN</sub> | When the Observability and access control extension is implemented, and the agent being monitored supports the Realm interrupt domain, all of the following are true:                                                              |
|                    | • The configuration of PMSCR.NSRA has no impact on the access controls to the GIC PMU configuration registers.                                                                                                                     |
|                    | • The configuration of PMSCR.NSMSI has no impact on physical address space used for message-signaled interrupts from the GIC PMU.                                                                                                  |
|                    | • The following fields are added to PMROOTCR, Root and Realm Control Register:                                                                                                                                                     |
|                    | RA, bits [6:4] Register Access.                                                                                                                                                                                                    |
|                    | This field determines physical address space for which register access is enabled for the PMU.                                                                                                                                     |

| RA    | Description                                                                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 0b000 | Root register access is enabled. Access from other address spaces is disabled, meaning accesses to all PMU registers are RAZ/WI.            |
| 0b001 | Root and Realm register access is enabled. Access from other address spaces is disabled, meaning accesses to all PMU registers are RAZ/WI.  |
| 0b010 | Root and Secure register access is enabled. Access from other address spaces is disabled, meaning accesses to all PMU registers are RAZ/WI. |
| 0b011 | All access is enabled.                                                                                                                      |

Other values are reserved.

For the CoreSight management registers, 0xFA8 to 0xFFC, it is IMPLEMENTATION DEFINED whether these registers are RO or RAZ/WI when register access is disabled by this field.

The reset value of this field is IMPLEMENTATION DEFINED, and depends on the security policy of the component implementing this register.

RMSI, bits [11:10] Root control for MSI PA space

When PMCFGR.MSI is 1, this field determines the physical address space used for MSIs.

| RA    | Description                                                                                                                       |
|-------|-----------------------------------------------------------------------------------------------------------------------------------|
| 06000 | MSIs are generated using the Root PAS. If PMROOTCR.RA is not 0b000, this value results in the Non-secure PAS being used for MSIs. |
| 0b001 | MSIs are generated using the Realm PAS. If PMROOTCR.RA is 0b010, this value results in the Non-secure PAS being used for MSIs.    |
| 0b010 | MSIs are generated using the Secure PAS. If PMROOTCR.RA is 0b0x1, this value results in the Non-secure PAS being used for MSIs.   |
| 0b011 | MSIs are generated using the Non-secure PAS.                                                                                      |

Other values are reserved.

The reset value of this field is IMPLEMENTATION DEFINED, and depends on the security policy of the component implementing this register.

- R<sub>TSZTF</sub> It is IMPLEMENTATION DEFINED whether GIC PMU implements the Freeze on overflow extension defined in [11].
- R<sub>KLJSW</sub> A GIC PMU does not implement the Halt-on-debug extension defined in [11]. For GIC PMU, PMCFGR.HDBG is 0.
- R<sub>XHQVD</sub> A GIC PMU does not implement the Fixed-function cycle counter extension defined in [11].
- R<sub>VQYFY</sub> A GIC PMU does not implement the monitor group extension defined in [11]. For GIC PMU, PMCFGR.NCG is 0.
- R<sub>CZMLC</sub> A GIC PMU does not implement the Counter chaining extension defined in [11].
- R<sub>DSXHC</sub> A GIC PMU does not implement the event counter threshold and edge detection extensions defined in [11].
- $I_{SKNKR}$  The Arm<sup>®</sup> CoreSight<sup>TM</sup> Architecture Performance Monitoring Unit Architecture[11] defines Reusable event filter definitions.

When a GIC PMU implements the observability and access control extension, the GIC PMU implements the Security operating state filtering. Otherwise, the GIC PMU does not use the Security operating state filtering. See 7.4 *Event filtering* for more information.

No other Reusable event filter definitions are used.

- R<sub>JZTKK</sub> It is IMPLEMENTATION DEFINED whether GIC PMU implements support for the Snapshot extension defined in [11].
- $I_{ZRJLK}$  If the Snapshot extension is implemented, PMCFGR.SS is 1.
- R<sub>XTRZB</sub> It is IMPLEMENTATION DEFINED whether the GIC PMU does implements the Trace generation extension defined in [11].
- R<sub>RRYKG</sub> A GIC PMU does not implement the Export extension defined in [11]. For GIC PMU, PMCFG.EX is 0.
- $R_{GYDWV}$  A GIC PMU does not implement the Dual-page extension defined in [11].

## 7.2 GIC PMU Overflow interrupt

| R <sub>hvtmv</sub> | A GIC PMU implements an overflow interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | The permitted overflow interrupt types depend on which type of agent is being monitored as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>If the GIC PMU counts events for an IRS, or for an IRS and its associated ITSs, the overflow interrupt is an SPI connected to that IRS.</li> <li>If the GIC PMU counts events for a single ITS, the overflow interrupt is one of the following: <ul> <li>An interrupt signal connected to an SPI on the associated IRS.</li> <li>An interrupt wire signal connected to an IWB.</li> <li>An ITS event generated from the ITS PMU as a system peripheral and translated by the ITS.</li> </ul> </li> </ul>                                                        |
| R <sub>drwtl</sub> | If the overflow interrupt is an ITS event generated from the GIC PMU as a system peripheral and translated by the ITS, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                    | <ul> <li>The GIC PMU uses the message-signaled interrupt functionality to configure the overflow interrupt as defined in [11].</li> <li>PMCFGR.MSI is 1.</li> <li>PMIRQCR0 is IGNORED and access to the register is permitted to be RES0 or RAZ/WI.</li> <li>The DeviceID for the ITS event is IMPLEMENTATION DEFINED.</li> <li>The EventID for the ITS event is programmed using PMIRQCR1.DATA.</li> <li>The originating Interrupt Domain is the Interrupt Domain corresponding to the physical address space configured for the message-signaled interrupt.</li> </ul> |
| I <sub>llfnw</sub> | The Arm <sup>®</sup> CoreSight <sup>™</sup> Architecture Performance Monitoring Unit Architecture[11] defines rules and controls that specify the physical address space used for message-signaled interrupts.                                                                                                                                                                                                                                                                                                                                                           |
|                    | These rules are extended to also support the Root and Realm physical address space for message-signaled interrupts. See 7.1 <i>CoreSight PMU extensions</i> for more information.                                                                                                                                                                                                                                                                                                                                                                                        |
| R <sub>ptfkg</sub> | When Non-secure register access is enabled, message-signaled interrupts are always Non-secure.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                    | Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

This replaces an incorrect statement in [11] that states the opposite rule for Non-secure register access and the MSI physical address space.

Chapter 7. GIC Performance Monitoring Unit (PMU) 7.3. GIC PMU event types

## 7.3 GIC PMU event types

D<sub>QTVKY</sub> GIC PMU events are identified by a 4-bit PMEVTYPE value specifying an *event type*, and a 12-bit PMEVTID value specifying the *event* for the event type.

The PMEVTYPE space is interpreted as follows:

- 0b0000: Architected IRS event.
- 0b0001: IMPLEMENTATION DEFINED IRS event.
- 0b0010: Architected ITS event.
- 0b0011: IMPLEMENTATION DEFINED ITS event.

All PMEVTYPE values not defined above are reserved.

See 7.5 IRS PMU events and 7.6 ITS PMU events for information about the architected events.

- $I_{RWFQW}$  An implementation may implement support for fewer than 16 bits of PMEVTID. In this case, unimplemented upper bits are RES0.
- IVSWDJ
   When an event is selected using GIC\_PMEVTYPER<n>.{PMEVTYPE, PMEVTID}, GIC\_PMEVTYPER<n>.V

   reports whether an implemented event is selected.
   PMEVTYPE, PMEVTID}

Chapter 7. GIC Performance Monitoring Unit (PMU) 7.4. Event filtering

## 7.4 Event filtering

| I <sub>JLHGK</sub> | The GIC PMU supports filtering of events using various filters. The available filters depend on the event type and the event. See 7.5 <i>IRS PMU events</i> and 7.6 <i>ITS PMU events</i> for information about which filters are supported for the event types and architected events.                                                                                                                                          |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>NYZYT</sub> | When an event is selected using GIC_PMEVTYPER <n>.{PMEVTYPE, PMEVTID}, GIC_PMEVTYPER<n>.FS reports whether filtering is supported for the selected event.</n></n>                                                                                                                                                                                                                                                                |
| $R_{MZLWX}$        | When more than one filter for an event is enabled, the event is counted if and only if it matches on all enabled filters.                                                                                                                                                                                                                                                                                                        |
| I <sub>rfzhb</sub> | When a GIC PMU implements the observability and access control extension, the GIC PMU supports filtering of events based on their association with the Security state using the Security operating state filtering defined as part of the Reusable event filter definitions defined in <i>Arm</i> <sup>®</sup> <i>CoreSight</i> <sup>TM</sup> <i>Architecture Performance Monitoring Unit Architecture</i> [11].                 |
|                    | The Security operating state filtering State match controls are implemented using GIC_PMEVTYPER <n>. {RL,EL3,NS,S}</n>                                                                                                                                                                                                                                                                                                           |
|                    | By filtering events using the Security state, the GIC PMU filters events matching the corresponding Interrupt Domains.                                                                                                                                                                                                                                                                                                           |
| D <sub>dgskd</sub> | On some filters, the GIC PMU supports <i>filtering on a range</i> of values instead of matching on an exact value.                                                                                                                                                                                                                                                                                                               |
|                    | When filtering on a range, the range is specified by splitting the value into X most significant bits that must match, and Y least significant bits that are allowed to differ as follows:                                                                                                                                                                                                                                       |
|                    | <ul> <li>Bit[Y-1] is 0. That is, the most significant bit in the group of bits that do not need to match is zero.</li> <li>Bits[(Y-2:0] are 1. That is, the remaining bits that are allowed to differ are all programmed to 1.</li> <li>The remainder of bits (the X most-significant bits, from bit Y upwards) contain a value that must match the corresponding bits for the value associated with monitored event.</li> </ul> |
| I <sub>GSLNM</sub> | GIC_PMEVTYPER <n>.FSPAN reports whether filtering by a range of values is supported for the selected event.</n>                                                                                                                                                                                                                                                                                                                  |
| R <sub>MZTYJ</sub> | For each event that may support filtering on a range of values, it is IMPLEMENTATION DEFINED whether filtering on a range of values is supported or filtering is only supported on an exact value.                                                                                                                                                                                                                               |
| $S_{LKPXH}$        | Arm expects that when a virtual GIC PMU is presented to a VM, the virtual GIC PMU does not support filtering on a range of values for identifiers where ranges in the host system do not correspond to similar ranges in the guest system.                                                                                                                                                                                       |
| I <sub>VMFDS</sub> | The following are examples (in binary) of specifying ranges for GIC PMU filtering:                                                                                                                                                                                                                                                                                                                                               |
|                    | • 0000:0000:0001:1011:1111:0111:0111 matches<br>0000:0000:1001:1011:1111:0111:1111:xxxx                                                                                                                                                                                                                                                                                                                                          |
|                    | • 0000:0000:0001:1011:1111:0111:0110 matches<br>0000:0000:0001:1011:1111:0111:011x                                                                                                                                                                                                                                                                                                                                               |
|                    | • 0000:0000:0001:1011:1111:0101:1111:111                                                                                                                                                                                                                                                                                                                                                                                         |

Chapter 7. GIC Performance Monitoring Unit (PMU) 7.5. IRS PMU events

## 7.5 IRS PMU events

R<sub>JPYSX</sub> The architected IRS PMU events are listed in Table 7.3.

#### Table 7.3: Architected IRS PMU events

| PMEVTYPE | PMEVTID | Name             | Description                                                                                                                                    |  |
|----------|---------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0        | 0       | PMIRSCC          | Counts IRS cycles.                                                                                                                             |  |
| 0        | 1       | PMIRSPENDSETIN   | Counts incoming interrupt events to make an interrupt Pending.<br>The events are counted when received from an SPI, an ITS, or<br>another IRS. |  |
| 0        | 2       | PMIRSPENDCLEARIN | Counts incoming interrupt events to make an interrupt Idle. The<br>events are counted when received from an SPI, an ITS, or anothe<br>IRS.     |  |
| 0        | 3       | PMIRSPENDSETOUT  | Counts incoming interrupt events to make an interrupt Pending that are forwarded to another IRS.                                               |  |
| 0        | 4       | PMIRSPENDCLROUT  | Counts incoming interrupt events to make an interrupt Idle that are forwarded to another IRS.                                                  |  |
| 0        | 5       | PMIRSPENDSETPRO  | Counts interrupt events to make an interrupt Pending that are processed at this IRS.                                                           |  |
| 0        | 6       | PMIRSPENDCLRPRO  | Counts interrupt events to make an interrupt Idle that are processed at this IRS.                                                              |  |
| 0        | 7       | PMIRSPECMDPEND   | Counts commands received from a PE to update an interrupt Pending state.                                                                       |  |
| 0        | 8       | PMIRSPECMDHANDLE | Counts commands received from a PE related to handling of an interrupt. Includes only Activate and Deactivate commands.                        |  |
| 0        | 9       | PMIRSPECMDCFG    | Counts commands received from a PE to update or request the configuration and state of an interrupt.                                           |  |
| 0        | 10      | PMIRSVPEMIGR     | Counts when a VPE is made resident on an IRS and was not previously resident on that IRS.                                                      |  |
| 0        | 11      | PMIRSISTMISS     | IST cache miss. Counts for each interrupt effect requiring an access to the IST.                                                               |  |
| 0        | 12      | PMIRSVMTMISS     | VM table cache miss. Counts for each interrupt effect to a virtual interrupt requiring an access to the VM table.                              |  |
| 0        | 13      | PMIRSVPETMISS    | VPE table cache miss. Counts for each interrupt effect to a virtual interrupt requiring an access to the VPE table.                            |  |
| 0        | 14      | PMIRSVMDMISS     | VM descriptor miss. Counts for each interrupt effect to a virtual interrupt requiring an access to the VM descriptor.                          |  |
| 0        | 15      | PMIRSVPEDMISS    | VPE descriptor miss. Counts for each interrupt effect to a virtual interrupt requiring an access to the VPE descriptor.                        |  |
| 0        | 16      | PMIRSL1ISTLU     | Level 1 IST table access. Counts for each memory access to a level 1 IST.                                                                      |  |
| 0        | 17      | PMIRSL2ISTLU     | Level 2 IST table access. Counts for each memory access to a level 2 IST.                                                                      |  |

Chapter 7. GIC Performance Monitoring Unit (PMU) 7.5. IRS PMU events

| PMEVTYPE | PMEVTID | Name         | Description                                                                                 |
|----------|---------|--------------|---------------------------------------------------------------------------------------------|
| 0        | 18      | PMIRSL1VMTLU | Level 1 VM table access. Counts for each memory access to a level 1 VM table.               |
| 0        | 19      | PMIRSL2VMTLU | Level 2 VM table access. Counts for each memory access to a level 2 VM table.               |
| 0        | 20      | PMIRSVPETLU  | VPE table access. Counts for each memory access to a VPE table.                             |
| 0        | 21      | PMIRSVMDLU   | VM descriptor access. Counts for each memory access to a VM descriptor.                     |
| 0        | 22      | PMIRSVPEDLU  | VPE descriptor access. Counts for each memory access to a VPE descriptor.                   |
| 0        | 23      | PMIRSVPEDB   | Counts when a VPE doorbell event is generated.                                              |
| 0        | 24      | PMIRS1NPESEL | Counts when a new PE or VPE selected for a 1ofN interrupt.                                  |
| 0        | 25      | PMIRS1NDB    | Counts when the 1ofN doorbell configuration for a VM causes a VPE doorbell to be generated. |

All other PMEVTID values for the architected IRS event type are reserved.

- R<sub>GFFRF</sub> In a multi-IRS system, the events are counted only for the IRS being being monitored by the GIC PMU.
- S<sub>ZKMFB</sub> Software is expected to combine events from multiple GIC PMUs to gather counts of events globally for the system.
- R<sub>CTPKW</sub> When the IRS cycle counter event PMIRSCC is monitored, the event always counts IRS cycles, unless the IRS is in a low power state.
- R<sub>HBFMK</sub> When an incoming interrupt event is received at the same IRS that processed the event, the event is counted both as incoming and as processing for the same interrupt event.
- R<sub>KKJVF</sub> Table 7.4 lists the GIC System instructions that are processed by the IRS and recorded by IRS PMU events when the PE indicates to the IRS that the instruction is being executed. See 2.6 *GIC System instructions* for more information.

#### Table 7.4: IRS PMU events counting processing of GIC System instructions

| PMIRSPECMDPEND | PMIRSPECMDHANDLE | PMIRSPECMDCFG |
|----------------|------------------|---------------|
| GIC xDPEND     | GICR CDIA        | GIC xDDIS     |
|                | GICR CDNMIA      | GIC xDEN      |
|                | GIC xDDI         | GIC xDRCFG    |
|                |                  | GIC xDPRI     |
|                |                  | GIC xDAFF     |
|                |                  | GIC xDHM      |

 $R_{\rm XJKZC}$ 

- When monitoring any of the following events, the event is counted when the IRS performs any access to IRS data structures in memory as part of processing an Interrupt Effect or when making a VPE resident:
  - 11: PMIRSISTMISS.
  - 12: PMIRSVMTMISS.

- 13: PMIRSVPETMISS.
- 14: PMIRSVMDMISS.
- 15: PMIRSVPEDMISS.

 $R_{\rm JJNGJ}$ 

- The IRS data structure access events are counted for an access to the corresponding IRS data structure in memory for any of the following reasons:
  - There was an access to the data structure related to an Interrupt Effect.
  - There was an access to the data structure related to making a VPE resident.
  - There was a speculative access performed by the IRS.

#### 7.5.1 IRS PMU events filtering

R<sub>CSDPD</sub> The GIC PMU supports the following filter types for the IRS events:

- Filtering on INTID.
- Filtering on physical or virtual interrupts, and a specific VM ID for virtual interrupts (VM and VM ID).
- Filtering on whether an access to an IRS data structure was a read or a write (RW).
- Filtering on the which PE sent a PE command to the IRS (Source PE).

Table 7.5 shows which filters are supported for the architected IRS events.

#### Table 7.5: Supported filters for IRS PMU events

| PMEVTID | Name             | INTID filter | VM and VM ID filter | RW filter | Source PE filter |  |
|---------|------------------|--------------|---------------------|-----------|------------------|--|
| 0       | PMIRSCC          | No           | No                  | No        | No               |  |
| 1       | PMIRSPENDSETIN   | Yes          | Yes                 | No        | No               |  |
| 2       | PMIRSPENDCLEARIN | Yes          | Yes                 | No        | No               |  |
| 3       | PMIRSPENDSETOUT  | Yes          | Yes                 | No        | No               |  |
| 4       | PMIRSPENDCLROUT  | Yes          | Yes                 | No        | No               |  |
| 5       | PMIRSPENDSETPRO  | Yes          | Yes                 | No        | No               |  |
| 6       | PMIRSPENDCLRPRO  | Yes          | Yes                 | No        | No               |  |
| 7       | PMIRSPECMDPEND   | Yes          | Yes                 | No        | Yes              |  |
| 8       | PMIRSPECMDHANDLE | Yes          | Yes                 | No        | Yes              |  |
| 9       | PMIRSPECMDCFG    | Yes          | Yes                 | No        | Yes              |  |
| 10      | PMIRSVPEMIGR     | No           | Yes <sup>a</sup>    | No        | Yes              |  |
| 11      | PMIRSISTMISS     | Yes          | Yes                 | Yes       | No               |  |
| 12      | PMIRSVMTMISS     | No           | Yes                 | Yes       | No               |  |
| 13      | PMIRSVPETMISS    | No           | Yes                 | Yes       | No               |  |
| 14      | PMIRSVMDMISS     | No           | Yes                 | Yes       | No               |  |
| 15      | PMIRSVPEDMISS    | No           | Yes                 | Yes       | No               |  |
| 16      | PMIRSL1ISTLU     | Yes          | Yes                 | Yes       | No               |  |
| 17      | PMIRSL2ISTLU     | Yes          | Yes                 | Yes       | No               |  |
| 18      | PMIRSL1VMTLU     | No           | Yes                 | Yes       | No               |  |
| 19      | PMIRSL2VMTLU     | No           | Yes                 | Yes       | No               |  |

| PMEVTID | Name         | INTID filter | VM and VM ID filter | RW filter | Source PE filter |
|---------|--------------|--------------|---------------------|-----------|------------------|
| 20      | PMIRSVPETLU  | No           | Yes                 | Yes       | No               |
| 21      | PMIRSVMDLU   | No           | Yes                 | Yes       | No               |
| 22      | PMIRSVPEDLU  | No           | Yes                 | Yes       | No               |
| 23      | PMIRSVPEDB   | No           | Yes                 | No        | No               |
| 24      | PMIRS1NPESEL | Yes          | Yes                 | No        | No               |
| 25      | PMIRS1NDB    | No           | Yes                 | No        | No               |
|         |              |              |                     |           |                  |

Chapter 7. GIC Performance Monitoring Unit (PMU) 7.5. IRS PMU events

a. The event is not counted when filtering on physical events only.

All other PMEVTID values for the architected IRS event type are reserved.

Chapter 7. GIC Performance Monitoring Unit (PMU) 7.6. ITS PMU events

## 7.6 ITS PMU events

R<sub>GCNFY</sub> The architected ITS PMU events are listed in Table 7.6.

#### Table 7.6: Architected ITS PMU events

| PMEVTYPE | PMEVTID | Name         | Description                                                                                                                                       |
|----------|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 2        | 0       | PMITSCC      | Counts ITS cycles.                                                                                                                                |
| 2        | 1       | PMITSTRQ     | Counts for each translation request performed by the ITS.                                                                                         |
| 2        | 2       | PMITSDIDMISS | DeviceID cache miss. Counts for each translation of a DeviceID that could not be satisfied from cache.                                            |
| 2        | 3       | PMITSEIDMISS | EventID cache miss. Counts for each translation of an EventID that could not be satisfied from cache.                                             |
| 2        | 4       | PMITSL1DTLU  | L1 device table lookup. Counts every time a level 1 DTE is looked up in memory. Does not count when the entry is read from cache.                 |
| 2        | 5       | PMITSL2DTLU  | L2 device table lookup. Counts every time a level 2 DTE is looked up in memory. Does not count when the entry is read from cache.                 |
| 2        | 6       | PMITSL1ITTLU | L1 interrupt translation table lookup. Counts every time a level 1 ITTE is looked up in memory. Does not count when the entry is read from cache. |
| 2        | 7       | PMITSL2ITTLU | L2 interrupt translation table lookup. Counts every time a level 2 ITTE is looked up in memory. Does not count when the entry is read from cache. |

All other PMEVTID values for the architected ITS event type are reserved.

R<sub>MSFLT</sub> When the ITS cycle counter event PMITSCC is monitored, it counts regardless of the event being translated by the ITS, unless the ITS is in a low power state.

R<sub>YFQCW</sub> The ITS DeviceID and EventID cache miss events, PMITSDIDMISS and PMITSEIDMISS, are counted when the translation causes any access to the ITS translation structures in memory to perform the translation.

- R<sub>ZJTPS</sub> The ITS table lookup events are counted for each access to an ITS translation structure in memory caused by performing a translation or by speculative accesses.
- R<sub>GKBVK</sub> ITS events are counted regardless of whether the translation was successful or not.

### 7.6.1 ITS PMU events filtering

R<sub>HXGVO</sub> A GIC PMU supports filtering of ITS events by any of the following combinations of DeviceID and EventID:

- No filtering on DeviceID or EventID.
- DeviceID.
- DeviceID and EventID.
- R<sub>LNVGM</sub> Filtering on DeviceID and EventID is supported for all other ITS events than ITS event 0 PMITSCC.
- IWhen a GIC PMU counts events for an IRS and multiple associated ITSs, a monitor always counts ITS events for<br/>a single ITS specified by GIC\_PMEVFILT2R<n>.ITSID.

#### Chapter 7. GIC Performance Monitoring Unit (PMU) 7.6. ITS PMU events

I<sub>XGBDQ</sub> When GIC\_PMEVFILT2R<n>.FILTER\_DID is 0, the monitor counts the selected PMU event for all translation requests.

When GIC\_PMEVFILT2R<n>.FILTER\_DID is 1 and GIC\_PMEVFILT2R<n>.FILTER\_DID\_SPAN is 0, the monitor counts the selected PMU event for translation requests where the DeviceID matches the DeviceID specified in GIC\_PMEVFILTR<n>.DEVICE\_ID.

When GIC\_PMEVFILT2R<n>.FILTER\_DID is 1 and GIC\_PMEVFILT2R<n>.FILTER\_DID\_SPAN is 1, the monitor counts the selected PMU event for translation requests where the DeviceID matches a range of DeviceIDs specified in GIC\_PMEVFILTR<n>.DEVICE\_ID.

If the ITS being monitored supports less than 2 bits of DeviceID, GIC\_PMEVFILT2R<n>.FILTER\_DID\_SPAN is RES0 and matching a range of DeviceIDs is not supported.

INTCKY When GIC\_PMEVFILT2R<n>.FILTER\_DID is 0, the monitor counts the selected PMU event for all translation requests, and filtering on EventID is not supported.

When GIC\_PMEVFILT2R<n>.FILTER\_DID is 1 and GIC\_PMEVFILT2R<n>.FILTER\_EID is 0, the monitor counts the selected PMU event for translation requests where the DeviceID matches the DeviceID filter value, for all EventIDs.

When GIC\_PMEVFILT2R<n>.FILTER\_DID is 1, GIC\_PMEVFILT2R<n>.FILTER\_EID is 1, and GIC\_PMEVFILT2R<n>.FILTER\_EID\_SPAN is 0, the monitor counts the selected PMU event for translation requests where the DeviceID matches the DeviceID filter value, and the EventID matches the EventID specified in GIC\_PMEVTILFTR<n>.EVENT\_ID.

When GIC\_PMEVFILT2R<n>.FILTER\_DID is 1, GIC\_PMEVFILT2R<n>.FILTER\_EID is 1, and GIC\_PMEVFILT2R<n>.FILTER\_EID\_SPAN is 1, the monitor counts the selected PMU event for translation requests where the DeviceID matches the DeviceID filter value, and the EventID matches the EventID matches a range of EventIDs specified in GIC\_PMEVTILFTR<n>.EVENT\_ID.

If the ITS supports less than 2 bits of EventID, GIC\_PMEVFILT2R<n>.FILTER\_EID\_SPAN is RES0 and matching a range of EventIDs is not supported.

# Chapter 8 System instructions

This chapter describes the GICv5 system intructions.

Chapter 8. System instructions 8.1. System instructions for the Current Interrupt Domain

## 8.1 System instructions for the Current Interrupt Domain

## 8.1.1 GIC CDAFF, Interrupt Set Target in the Current Interrupt Domain

The GIC CDAFF characteristics are:

#### Purpose

Sets the routing mode and target PE for the specified INTID in the Current Interrupt Domain.

If the Current Interrupt Domain is the Virtual Interrupt Domain, this operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GIC CDAFF are UNDEFINED.

#### Attributes

GIC CDAFF is a 64-bit System instruction.

## **Field descriptions**

The GIC CDAFF bit assignments are:



#### Bits [63:48]

Reserved, RESO.

#### IAFFID, bits [47:32]

The interrupt Affinity value.

The IRS may support fewer than 16 bits of IAFFID. Unimplemented upper bits are treated as RESO by the IRS.

When IRM is 1, this field provides an IMPLEMENTATION DEFINED hint to 1ofN selection algorithm. A value of 0 means that no hint is provided.

#### TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### IRM, bit [28]

Controls how the interrupt is routed.

If the GIC IRS does not support 1ofN distribution of the specified interrupt Type, this configuration is treated as RES0.

| IRM | Meaning                                |
|-----|----------------------------------------|
| 0d0 | The interrupt Routing mode is Targeted |
| 0b1 | The interrupt Routing mode is 1ofN     |

#### Bits [27:24]

Reserved, RESO.

#### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

## Accessing GIC CDAFF

This instruction has no effect if the INTID is unreachable.

This instruction is treated as a NOP if the operation applies to the Virtual Interrupt Domain and there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

#### GIC CDAFF, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b000 | 0b1100 | 0b0001 | 0b011 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGITR_EL2.GICCDAFF == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        GIC(X[t, 64], GICInstrDomain_VD, GICInstr_AFF);
    else
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_AFF);
elsif PSTATE.EL == EL2 then
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_AFF);
elsif PSTATE.EL == EL3 then
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_AFF);
```

## 8.1.2 GIC CDDI, Interrupt Deactivate in the Current Interrupt Domain

The GIC CDDI characteristics are:

#### Purpose

Clears the Active state of the specified INTID at the CPU interface in the Current Interrupt Domain.

This instruction applies to all interrupt types, including PPIs.

If the Current Interrupt Domain is the Virtual Interrupt Domain and the interrupt type is a PPI, this operation applies to the virtual PPI identified by the specified INTID.

If the Current Interrupt Domain is the Virtual Interrupt Domain and the interrupt type is not a PPI, this operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GIC CDDI are UNDEFINED.

#### Attributes

GIC CDDI is a 64-bit System instruction.

### **Field descriptions**

The GIC CDDI bit assignments are:

| L   | 63    |    |      |      |    | 33   | 32 |
|-----|-------|----|------|------|----|------|----|
|     |       |    |      |      |    | RES0 | WI |
| . L | 31 29 | 28 |      | 24 I | 23 |      | 0  |
|     | TYPE  |    | RES0 |      |    | ID   |    |

#### Bits [63:33]

Reserved, RESO.

#### Bit [32]

Reserved, WI.

### TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b001 | PPI     |  |
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

Bits [28:24]

Reserved, RESO.

#### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

## Accessing GIC CDDI

This instruction has no effect if the INTID is unreachable

This instruction is treated as a NOP if the operation applies to the Virtual Interrupt Domain, the interrupt type is not a PPI and there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

## GIC CDDI, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b000 | 0b1100 | 0b0010 | 06000 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGITR_EL2.GICCDDI == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        GIC(X[t, 64], GICInstrDomain_VD, GICInstr_DI);
    else
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_DI);
    elsif PSTATE.EL == EL2 then
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_DI);
elsif PSTATE.EL == EL3 then
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_DI);
```

## 8.1.3 GIC CDDIS, Interrupt Disable in the Current Interrupt Domain

The GIC CDDIS characteristics are:

#### Purpose

Disables the specified INTID in the Current Interrupt Domain.

If the Current Interrupt Domain is the Virtual Interrupt Domain this operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GIC CDDIS are UNDEFINED.

#### Attributes

GIC CDDIS is a 64-bit System instruction.

## **Field descriptions**

The GIC CDDIS bit assignments are:

| 63     |       |      | 32 |
|--------|-------|------|----|
|        |       | RES0 |    |
| 31 29  | 28 24 | 23   | 0  |
| IYPE I | RES0  | ID   |    |

#### Bits [63:32]

Reserved, RESO.

TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Valued not defined above are reserved

#### Bits [28:24]

Reserved, RESO.

#### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

## Accessing GIC CDDIS

This instruction has no effect if the INTID is unreachable

This instruction is treated as a NOP if the operation applies to the Virtual Interrupt Domain and there is no resident VPE.

#### Chapter 8. System instructions

8.1. System instructions for the Current Interrupt Domain

Accesses to this instruction use the following encodings in the System instruction encoding space:

GIC CDDIS, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 06000 | 0b1100 | 0b0001 | 0b000 |

| if PSTATE.EL == ELO then                                              |
|-----------------------------------------------------------------------|
| UNDEFINED;                                                            |
| elsif PSTATE.EL == EL1 then                                           |
| if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then |
| UNDEFINED;                                                            |
| elsif EL2Enabled() && ICH_HFGITR_EL2.GICCDDIS == '0' then             |
| AArch64.SystemAccessTrap(EL2, 0x18);                                  |
| elsif EL2Enabled() && HCR_EL2.IMO == '1' then                         |
| <pre>GIC(X[t, 64], GICInstrDomain_VD, GICInstr_DIS);</pre>            |
| else                                                                  |
| GIC(X[t, 64], GICInstrDomain_CD, GICInstr_DIS);                       |
| elsif PSTATE.EL == EL2 then                                           |
| GIC(X[t, 64], GICInstrDomain_CD, GICInstr_DIS);                       |
| elsif PSTATE.EL == EL3 then                                           |
| GIC(X[t, 64], GICInstrDomain_CD, GICInstr_DIS);                       |

## 8.1.4 GIC CDEN, Interrupt Enable in the Current Interrupt Domain

The GIC CDEN characteristics are:

#### Purpose

Enables the specified INTID in the Current Interrupt Domain.

If the Current Interrupt Domain is the Virtual Interrupt Domain, this operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GIC CDEN are UNDEFINED.

#### Attributes

GIC CDEN is a 64-bit System instruction.

## **Field descriptions**

The GIC CDEN bit assignments are:

| 1 | 63    |       | 3.   | 2 |
|---|-------|-------|------|---|
|   |       |       | RES0 |   |
| 1 | 31 29 | 28 24 | 23 6 |   |
|   | TYPE  | RES0  | ID   |   |

#### Bits [63:32]

Reserved, RESO.

TYPE, bits [31:29]

Type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Bits [28:24]

Reserved, RESO.

#### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

## Accessing GIC CDEN

This instruction has no effect if the INTID is unreachable

This instruction is treated as a NOP if the operation applies to the Virtual Interrupt Domain, the interrupt type is not a PPI and there is no resident VPE.

#### Chapter 8. System instructions

8.1. System instructions for the Current Interrupt Domain

Accesses to this instruction use the following encodings in the System instruction encoding space:

GIC CDEN, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b000 | 0b1100 | 0b0001 | 0b001 |

| if PSTATE.EL == ELO then                                              |
|-----------------------------------------------------------------------|
| UNDEFINED;                                                            |
| elsif PSTATE.EL == EL1 then                                           |
| if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then |
| UNDEFINED;                                                            |
| elsif EL2Enabled() && ICH_HFGITR_EL2.GICCDEN == '0' then              |
| AArch64.SystemAccessTrap(EL2, 0x18);                                  |
| elsif EL2Enabled() && HCR_EL2.IMO == '1' then                         |
| <pre>GIC(X[t, 64], GICInstrDomain_VD, GICInstr_EN);</pre>             |
| else                                                                  |
| GIC(X[t, 64], GICInstrDomain_CD, GICInstr_EN);                        |
| elsif PSTATE.EL == EL2 then                                           |
| GIC(X[t, 64], GICInstrDomain_CD, GICInstr_EN);                        |
| elsif PSTATE.EL == EL3 then                                           |
| GIC(X[t, 64], GICInstrDomain_CD, GICInstr_EN);                        |

## 8.1.5 GIC CDEOI, Priority Drop in the Current Interrupt Domain

The GIC CDEOI characteristics are:

#### Purpose

Performs a Priority Drop of the running priority at the CPU interface in the Current Interrupt Domain.

If the Current Interrupt Domain is the Virtual Interrupt Domain, the Priority Drop applies to the virtual running priority.

Otherwise, it applies to the physical running priority in the Current Physical Interrupt Domain.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GIC CDEOI are UNDEFINED.

#### Attributes

GIC CDEOI is a 64-bit System instruction.

## **Field descriptions**

The GIC CDEOI bit assignments are:

| 63 |      | 32 |
|----|------|----|
|    | RES0 |    |
| 31 |      | θι |
|    | RES0 |    |

#### Bits [63:0]

Reserved, RESO.

## Accessing GIC CDEOI

The Rt field should be set to 0b11111. If the Rt field is not set to 0b11111, it is CONSTRAINED UNPREDICTABLE whether:

- The instruction is UNDEFINED.
- The instruction behaves as if the Rt field is set to 0b11111.

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC CDEOI, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0Ь000 | 0b1100 | 0b0001 | 0b111 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGITR_EL2.GICCDEOI == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        GIC(X[t, 64], GICInstrDomain_VD, GICInstr_EOI);
    else
```

#### Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

#### Chapter 8. System instructions 8.1. System instructions for the Current Interrupt Domain

GIC(X[t, 64], GICInstrDomain\_CD, GICInstr\_EOI); elsif PSTATE.EL == EL2 then GIC(X[t, 64], GICInstrDomain\_CD, GICInstr\_EOI); elsif PSTATE.EL == EL3 then GIC(X[t, 64], GICInstrDomain\_CD, GICInstr\_EOI);

## 8.1.6 GIC CDHM, Interrupt Handling mode state in the Current Interrupt Domain

The GIC CDHM characteristics are:

#### Purpose

Sets the Handling mode of the specified INTID in the Current Interrupt Domain.

If the Current Interrupt Domain is the Virtual Interrupt Domain this operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GIC CDHM are UNDEFINED.

#### Attributes

GIC CDHM is a 64-bit System instruction.

#### **Field descriptions**

The GIC CDHM bit assignments are:

| 63    |       |      | 33 | 32 |
|-------|-------|------|----|----|
|       |       | RES0 | 1  | нм |
| 31 29 | 28 24 | 23   |    | 0  |
| TYPE  | RES0  | ID   |    |    |

#### Bits [63:33]

Reserved, RESO.

#### HM, bit [32]

Handling mode

| НМ  | Meaning |  |
|-----|---------|--|
| 0b0 | Edge    |  |
| 0b1 | Level   |  |

#### TYPE, bits [31:29]

Type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Bits [28:24]

Reserved, RESO.

#### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

## Accessing GIC CDHM

This instruction has no effect if the INTID is unreachable

This instruction is treated as a NOP if the operation applies to the Virtual Interrupt Domain and there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

#### GIC CDHM, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |  |
|------|-------|--------|--------|-------|--|
| 0b01 | 0b000 | 0b1100 | 0b0010 | 0b001 |  |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGITR_EL2.GICCDHM == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        GIC(X[t, 64], GICInstrDomain_VD, GICInstr_HM);
    else
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_HM);
elsif PSTATE.EL == EL2 then
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_HM);
elsif PSTATE.EL == EL3 then
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_HM);
```

## 8.1.7 GIC CDPEND, Interrupt Set/Clear Pending state in the Current Interrupt Domain

The GIC CDPEND characteristics are:

#### Purpose

Generates a SET or CLEAR event for the specified INTID in the Current Interrupt Domain.

If the Current Interrupt Domain is the Virtual Interrupt Domain this operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GIC CDPEND are UNDEFINED.

#### Attributes

GIC CDPEND is a 64-bit System instruction.

## **Field descriptions**

The GIC CDPEND bit assignments are:



#### Bits [63:33]

Reserved, RESO.

#### PENDING, bit [32]

Pending status

| PENDING | Meaning                          |
|---------|----------------------------------|
| 0b0     | Generate CLEAR event to the IRS. |
| 0b1     | Generate SET event to the IRS.   |

### TYPE, bits [31:29]

Type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Bits [28:24]

Reserved, RESO.

#### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

## Accessing GIC CDPEND

This instruction has no effect if the INTID is unreachable

This instruction is treated as a NOP if the operation applies to the Virtual Interrupt Domain and there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

#### GIC CDPEND, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |  |
|------|-------|--------|--------|-------|--|
| 0b01 | 0b000 | 0b1100 | 0b0001 | 0b100 |  |

if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if EL2Enabled() && HCR\_EL2.IMO == '1' && ICH\_VCTLR\_EL2.V3 == '1' then UNDEFINED; elsif EL2Enabled() && ICH\_HFGITR\_EL2.GICCDPEND == '0' then AArch64.SystemAccessTrap(EL2, 0x18); elsif EL2Enabled() && HCR\_EL2.IMO == '1' then GIC(X[t, 64], GICInstrDomain\_VD, GICInstr\_PEND); else GIC(X[t, 64], GICInstrDomain\_CD, GICInstr\_PEND); elsif PSTATE.EL == EL2 then GIC(X[t, 64], GICInstrDomain\_CD, GICInstr\_PEND); elsif PSTATE.EL == EL3 then GIC(X[t, 64], GICInstrDomain\_CD, GICInstr\_PEND);

## 8.1.8 GIC CDPRI, Interrupt Set priority in the Current Interrupt Domain

The GIC CDPRI characteristics are:

#### Purpose

Sets the priority for the specified INTID in the Current Interrupt Domain.

If the Current Interrupt Domain is the Virtual Interrupt Domain this operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GIC CDPRI are UNDEFINED.

#### Attributes

GIC CDPRI is a 64-bit System instruction.

## **Field descriptions**

The GIC CDPRI bit assignments are:

| L 63     |      |      | 40 | 39 35    | 34 32 |
|----------|------|------|----|----------|-------|
|          |      | RES0 |    | PRIORITY | RES0  |
| 31 29 28 | 24   | 23   |    |          | Θ     |
| TYPE     | RES0 | ID   |    |          |       |

#### Bits [63:40]

Reserved, RESO.

#### PRIORITY, bits [39:35]

The priority of the specified INTID

Only the upper N bits of the Priority field are implemented where  $N = (ICC_IDR0_EL1.PRI_BITS + 1)$ . Unimplemented bits are RES0.

#### Bits [34:32]

Reserved, RESO.

#### TYPE, bits [31:29]

Type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Bits [28:24]

Reserved, RESO.

#### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

## Accessing GIC CDPRI

This instruction has no effect if the INTID is unreachable

This instruction is treated as a NOP if the operation applies to the Virtual Interrupt Domain and there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

#### GIC CDPRI, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |  |
|------|-------|--------|--------|-------|--|
| 0b01 | 0b000 | 0b1100 | 0b0001 | 0b010 |  |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGITR_EL2.GICCDPRI == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        GIC(X[t, 64], GICInstrDomain_VD, GICInstr_PRI);
    else
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_PRI);
elsif PSTATE.EL == EL2 then
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_PRI);
elsif PSTATE.EL == EL3 then
        GIC(X[t, 64], GICInstrDomain_CD, GICInstr_PRI);
```

## 8.1.9 GIC CDRCFG, Request Interrupt Configuration in the Current Interrupt Domain

The GIC CDRCFG characteristics are:

#### Purpose

Request to read configuration of the specified INTID in the Current Interrupt Domain into ICC\_ICSR\_EL1.

If the Current Interrupt Domain is the Virtual Interrupt Domain, this operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GIC CDRCFG are UNDEFINED.

#### Attributes

GIC CDRCFG is a 64-bit System instruction.

### **Field descriptions**

The GIC CDRCFG bit assignments are:

| L 63  |       |      | 32 |
|-------|-------|------|----|
|       |       | RES0 |    |
| 31 29 | 28 24 | 23   | θι |
| TYPE  | RES0  | ID   |    |

#### Bits [63:32]

Reserved, RESO.

#### TYPE, bits [31:29]

Type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Bits [28:24]

Reserved, RESO.

#### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

## Accessing GIC CDRCFG

This instruction is treated as a NOP if the operation applies to the Virtual Interrupt Domain and there is no resident VPE.

#### Chapter 8. System instructions

8.1. System instructions for the Current Interrupt Domain

Accesses to this instruction use the following encodings in the System instruction encoding space:

| GIC | CD | RCF | G. | <xt></xt> |
|-----|----|-----|----|-----------|
|     | 00 |     | ч, | ~~~~~     |

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b000 | 0b1100 | 0b0001 | 0b101 |

| if PSTATE.EL == ELO then                                              |
|-----------------------------------------------------------------------|
| UNDEFINED;                                                            |
| elsif PSTATE.EL == EL1 then                                           |
| if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then |
| UNDEFINED;                                                            |
| elsif EL2Enabled() && ICH_HFGITR_EL2.GICCDRCFG == '0' then            |
| AArch64.SystemAccessTrap(EL2, 0x18);                                  |
| elsif EL2Enabled() && HCR_EL2.IMO == '1' then                         |
| <pre>GIC(X[t, 64], GICInstrDomain_VD, GICInstr_RCFG);</pre>           |
| else                                                                  |
| GIC(X[t, 64], GICInstrDomain_CD, GICInstr_RCFG);                      |
| elsif PSTATE.EL == EL2 then                                           |
| GIC(X[t, 64], GICInstrDomain_CD, GICInstr_RCFG);                      |
| elsif PSTATE.EL == EL3 then                                           |
| GIC(X[t, 64], GICInstrDomain_CD, GICInstr_RCFG);                      |

# 8.1.10 GICR CDIA, Interrupt Acknowledge in the Current Interrupt Domain

The GICR CDIA characteristics are:

#### Purpose

Acknowledges the HPPI in the Current Interrupt Domain.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GICR CDIA are UNDEFINED.

### Attributes

GICR CDIA is a 64-bit System instruction.

# **Field descriptions**

The GICR CDIA bit assignments are:



### Bits [63:33]

Reserved, RESO.

### VALID, bit [32]

Indicates whether the instruction successfully acknowledged an interrupt.

| VALID | Meaning                        |
|-------|--------------------------------|
| 000   | No interrupt was acknowledged. |
| 0b1   | The HPPI was acknowledged.     |

When this field is 1, the instruction acknowledges an HPPI of Sufficient priority that is not an NMI.

# TYPE, bits [31:29]

The type of the acknowledged interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b001 | PPI     |  |
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

If VALID is 0, this field is RES0.

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the acknowledged interrupt.

If VALID is 0, this field is RES0.

# Accessing GICR CDIA

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GICR <Xt>, CDIA

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b000 | 0b1100 | 0b0011 | 0b000 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGITR_EL2.GICRCDIA == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = GICR(GICInstrDomain_VD, GICInstr_IA);
    else
        X[t, 64] = GICR(GICInstrDomain_CD, GICInstr_IA);
elsif PSTATE.EL == EL2 then
        X[t, 64] = GICR(GICInstrDomain_CD, GICInstr_IA);
elsif PSTATE.EL == EL3 then
        X[t, 64] = GICR(GICInstrDomain_CD, GICInstr_IA);
```

# 8.1.11 GICR CDNMIA, Non-maskable Interrupt Acknowledge in the Current Interrupt Domain

The GICR CDNMIA characteristics are:

#### Purpose

Acknowledges the HPPI, if it is an NMI, in the Current Interrupt Domain.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GICR CDNMIA are UNDEFINED.

### Attributes

GICR CDNMIA is a 64-bit System instruction.

# **Field descriptions**

The GICR CDNMIA bit assignments are:



### Bits [63:33]

Reserved, RESO.

### VALID, bit [32]

Indicates whether the instruction successfully acknowledged an NMI.

| VALID | Meaning                        |
|-------|--------------------------------|
| 0b0   | No interrupt was acknowledged. |
| 0b1   | The HPPI was acknowledged.     |

When this field is 1, the instruction acknowledges an HPPI of Sufficient priority that is an NMI.

# TYPE, bits [31:29]

The type of the acknowledged interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b001 | PPI     |  |
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

If VALID is 0, this field is RES0.

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the acknowledged interrupt.

If VALID is 0, this field is RES0.

# Accessing GICR CDNMIA

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GICR <Xt>, CDNMIA

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b000 | 0b1100 | 0b0011 | 0b001 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGITR_EL2.GICRCDNMIA == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = GICR(GICInstrDomain_VD, GICInstr_NMIA);
    else
        X[t, 64] = GICR(GICInstrDomain_CD, GICInstr_NMIA);
    elsif PSTATE.EL == EL2 then
        X[t, 64] = GICR(GICInstrDomain_CD, GICInstr_NMIA);
elsif PSTATE.EL == EL3 then
        X[t, 64] = GICR(GICInstrDomain_CD, GICInstr_NMIA);
```

Chapter 8. System instructions 8.2. System instructions for the Virtual Interrupt Domain

# 8.2 System instructions for the Virtual Interrupt Domain

# 8.2.1 GIC VDAFF, Interrupt Set Target in the Virtual Interrupt Domain

The GIC VDAFF characteristics are:

### Purpose

Sets the routing mode and target VPE for the specified INTID in the Virtual Interrupt Domain.

This operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to GIC VDAFF are UNDEFINED.

### Attributes

GIC VDAFF is a 64-bit System instruction.

# **Field descriptions**

The GIC VDAFF bit assignments are:



### Bits [63:48]

Reserved, RESO.

### IAFFID, bits [47:32]

The interrupt Affinity value.

The IRS may support fewer than 16 bits of IAFFID. Unimplemented upper bits are treated as RESO by the IRS.

When IRM is 1, this field provides an IMPLEMENTATION DEFINED hint to 1ofN selection algorithm. A value of 0 means that no hint is provided.

# TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### IRM, bit [28]

Controls how the interrupt is routed.

If the GIC IRS does not support 1ofN distribution of the specified interrupt Type, this configuration is treated as RES0.

| IRM | Meaning                                |
|-----|----------------------------------------|
| 0d0 | The interrupt Routing mode is Targeted |
| 0b1 | The interrupt Routing mode is 1ofN     |

### Bits [27:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC VDAFF

This instruction has no effect if the INTID is unreachable.

This instruction is treated as a NOP if there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC VDAFF, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b100 | 0b1100 | 0b0001 | 0b011 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    GIC(X[t, 64], GICInstrDomain_VD, GICInstr_AFF);
elsif PSTATE.EL == EL3 then
    if !EL2Enabled() then
        UNDEFINED;
else
    GIC(X[t, 64], GICInstrDomain_VD, GICInstr_AFF);
```

# 8.2.2 GIC VDDI, Interrupt Deactivate in the Virtual Interrupt Domain

The GIC VDDI characteristics are:

### Purpose

Clears the Active state of the specified INTID in the Virtual Interrupt Domain.

This instruction applies to all interrupt types, including PPIs.

If the interrupt type is a PPI, this operation applies to the virtual PPI identified by the specified INTID.

If the interrupt type is not a PPI, this operation applies to the virtual INTID in the VM identified by the resident VPE.

### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to GIC VDDI are UNDEFINED.

### Attributes

GIC VDDI is a 64-bit System instruction.

# **Field descriptions**

The GIC VDDI bit assignments are:

| 63    |       |    |      | 33 | 3   32 |
|-------|-------|----|------|----|--------|
|       |       |    | RES0 |    | WI     |
| 31 29 | 28 24 | 23 |      |    | 0      |
| TYPE  | RES0  |    |      | ID |        |

# Bits [63:33]

Reserved, RESO.

Bit [32]

Reserved, WI.

### TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b001 | PPI     |  |
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC VDDI

This instruction has no effect if the INTID is unreachable

This instruction is treated as a NOP if the operation applies to the Virtual Interrupt Domain, the interrupt type is not a PPI and there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC VDDI, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b100 | 0b1100 | 0b0010 | 0b000 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    GIC(X[t, 64], GICInstrDomain_VD, GICInstr_DI);
elsif PSTATE.EL == EL3 then
    GIC(X[t, 64], GICInstrDomain_VD, GICInstr_DI);
```

# 8.2.3 GIC VDDIS, Interrupt Disable in the Virtual Interrupt Domain

The GIC VDDIS characteristics are:

### Purpose

Disables the specified INTID in the Virtual Interrupt Domain.

This operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to GIC VDDIS are UNDEFINED.

### Attributes

GIC VDDIS is a 64-bit System instruction.

# **Field descriptions**

The GIC VDDIS bit assignments are:

| 63    |       |      | 32 |
|-------|-------|------|----|
|       |       | RES0 |    |
| 31 29 | 28 24 | 23   | 0  |
| TYPE  | RES0  | ID   |    |

### Bits [63:32]

Reserved, RESO.

### TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Valued not defined above are reserved

### Bits [28:24]

Reserved, RESO.

ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC VDDIS

This instruction has no effect if the INTID is unreachable.

This instruction is treated as a NOP if there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC VDDIS, <Xt>

### Chapter 8. System instructions 8.2. System instructions for the Virtual Interrupt Domain

| ор0                              | op1               | CRn             | CRm             | op2     |
|----------------------------------|-------------------|-----------------|-----------------|---------|
| 0b01                             | 0b100             | 0b1100          | 0b0001          | 0Ь000   |
|                                  |                   |                 |                 |         |
| if PSTATE.EL == EL(              | ) then            |                 |                 |         |
| UNDEFINED;<br>elsif PSTATE.EL == | EL1 then          |                 |                 |         |
|                                  | && HCR_EL2.NV =   | = '1' && ICH VC | TLR EL2.V3 == ' | 0' then |
|                                  | stemAccessTrap(EL | _               |                 |         |
| else                             | -                 |                 |                 |         |
| UNDEFINED;                       |                   |                 |                 |         |
| elsif PSTATE.EL ==               | EL2 then          |                 |                 |         |
| GIC(X[t, 64], 0                  | GICInstrDomain_VD | , GICInstr_DIS) | ;               |         |
| elsif PSTATE.EL ==               | EL3 then          |                 |                 |         |
| if !EL2Enabled                   | () then           |                 |                 |         |
| UNDEFINED;                       |                   |                 |                 |         |
| else                             |                   |                 |                 |         |
| GIC(X[t, 64                      | ], GICInstrDomai  | n_VD, GICInstr_ | DIS);           |         |

# 8.2.4 GIC VDEN, Interrupt Enable in the Virtual Interrupt Domain

The GIC VDEN characteristics are:

### Purpose

Enables the specified INTID in the Virtual Interrupt Domain.

This operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to GIC VDEN are UNDEFINED.

### Attributes

GIC VDEN is a 64-bit System instruction.

# **Field descriptions**

The GIC VDEN bit assignments are:

| 63    |       |      | 32 |
|-------|-------|------|----|
|       |       | RES0 |    |
| 31 29 | 28 24 | 23   | Θ  |
| TYPE  | RES0  | ID   |    |

### Bits [63:32]

Reserved, RESO.

### TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# **Accessing GIC VDEN**

This instruction has no effect if the INTID is unreachable.

This instruction is treated as a NOP if there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC VDEN, <Xt>

### Chapter 8. System instructions 8.2. System instructions for the Virtual Interrupt Domain

| ор0                 | op1               | CRn CRm         |                 | op2     |
|---------------------|-------------------|-----------------|-----------------|---------|
| 0b01                | 0b100             | 0b1100          | 0b0001          | 0b001   |
|                     |                   |                 |                 |         |
| if PSTATE.EL == EL( | ) then            |                 |                 |         |
| UNDEFINED;          |                   |                 |                 |         |
| elsif PSTATE.EL ==  | EL1 then          |                 |                 |         |
| if EL2Enabled()     | && HCR_EL2.NV =   | = '1' && ICH_VC | TLR_EL2.V3 == ' | 0' then |
| AArch64.Sys         | stemAccessTrap(EL | 2, 0x18);       |                 |         |
| else                |                   |                 |                 |         |
| UNDEFINED;          |                   |                 |                 |         |
| elsif PSTATE.EL ==  | EL2 then          |                 |                 |         |
| GIC(X[t, 64], (     | GICInstrDomain_VD | , GICInstr_EN); |                 |         |
| elsif PSTATE.EL ==  | EL3 then          |                 |                 |         |
| if !EL2Enabled      | () then           |                 |                 |         |
| UNDEFINED;          |                   |                 |                 |         |
| else                |                   |                 |                 |         |
| GIC(X[t, 64         | ], GICInstrDomai  | n_VD, GICInstr_ | EN);            |         |

# 8.2.5 GIC VDHM, Interrupt Handling mode in the Virtual Interrupt Domain

The GIC VDHM characteristics are:

### Purpose

Sets the Handling mode of the specified INTID in the Virtual Interrupt Domain.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to GIC VDHM are UNDEFINED.

### Attributes

GIC VDHM is a 64-bit System instruction.

# **Field descriptions**

The GIC VDHM bit assignments are:

| 63    |       | 33 <sub>1</sub> 3 | 32 |
|-------|-------|-------------------|----|
|       |       | RES0 H            | ΗM |
| 31 29 | 28 24 | 23                | 0  |
| TYPE  | RES0  | ID                |    |

# Bits [63:33]

Reserved, RESO.

### HM, bit [32]

Handling mode

| HM  | Meaning |  |
|-----|---------|--|
| 0b0 | Edge    |  |
| 0b1 | Level   |  |

# TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC VDHM

This instruction has no effect if the INTID is unreachable.

This instruction is treated as a NOP if there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC VDHM, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b100 | 0b1100 | 0b0010 | 0b001 |

| <pre>if PSTATE.EL == EL0 then     UNDEFINED;</pre>                   |
|----------------------------------------------------------------------|
| elsif PSTATE.EL == EL1 then                                          |
| if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then |
| AArch64.SystemAccessTrap(EL2, 0x18);                                 |
| else                                                                 |
| UNDEFINED;                                                           |
| elsif PSTATE.EL == EL2 then                                          |
| GIC(X[t, 64], GICInstrDomain_VD, GICInstr_HM);                       |
| elsif PSTATE.EL == EL3 then                                          |
| GIC(X[t, 64], GICInstrDomain_VD, GICInstr_HM);                       |

# 8.2.6 GIC VDPEND, Interrupt Set/Clear Pending state in the Virtual Interrupt Domain

The GIC VDPEND characteristics are:

#### Purpose

Generates a SET or CLEAR event for the specified INTID in the Virtual Interrupt Domain.

This operation applies to the virtual INTID in the VM identified by the specified VM identifier.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to GIC VDPEND are UNDEFINED.

### Attributes

GIC VDPEND is a 64-bit System instruction.

### **Field descriptions**

The GIC VDPEND bit assignments are:



### Bits [63:48]

Reserved, RESO.

#### VM, bits [47:33]

The Virtual Machine identifier.

### PENDING, bit [32]

Pending status

| PENDING | Meaning                          |
|---------|----------------------------------|
| 0b0     | Generate CLEAR event to the IRS. |
| 0b1     | Generate SET event to the IRS.   |

### TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC VDPEND

This instruction has no effect if the INTID is unreachable.

This instruction has no effect if the VM is invalid.

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC VDPEND, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b100 | 0b1100 | 0b0001 | 0b100 |

| if PSTATE.EL == ELO then                                             |
|----------------------------------------------------------------------|
| UNDEFINED;                                                           |
| elsif PSTATE.EL == EL1 then                                          |
| if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then |
| AArch64.SystemAccessTrap(EL2, 0x18);                                 |
| else                                                                 |
| UNDEFINED;                                                           |
| elsif PSTATE.EL == EL2 then                                          |
| GIC(X[t, 64], GICInstrDomain_VD, GICInstr_PEND);                     |
| elsif PSTATE.EL == EL3 then                                          |
| if !EL2Enabled() then                                                |
| UNDEFINED;                                                           |
| else                                                                 |
| GIC(X[t, 64], GICInstrDomain_VD, GICInstr_PEND);                     |
|                                                                      |

# 8.2.7 GIC VDPRI, Interrupt Set priority in the Virtual Interrupt Domain

The GIC VDPRI characteristics are:

### Purpose

Sets the priority for the specified INTID in the Virtual Interrupt Domain.

This operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to GIC VDPRI are UNDEFINED.

### Attributes

GIC VDPRI is a 64-bit System instruction.

# **Field descriptions**

The GIC VDPRI bit assignments are:

| L 63  |       |     |   |    | 40 | 39       | 35 | 34  | 32 |
|-------|-------|-----|---|----|----|----------|----|-----|----|
|       |       | RES | 0 |    |    | PRIORITY | (  | RES | 0  |
| 31 29 | 28 24 | 23  |   |    |    |          |    |     | 0  |
| TYPE  | RES0  |     |   | ID |    |          |    |     |    |

### Bits [63:40]

Reserved, RESO.

### PRIORITY, bits [39:35]

The priority of the specified INTID

Only the upper N bits of the Priority field are implemented where  $N = (ICC_IDR0_EL1.PRI_BITS + 1)$ . Unimplemented bits are RES0.

# Bits [34:32]

Reserved, RESO.

### TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented lower bits are RES0.

# Accessing GIC VDPRI

This instruction has no effect if the INTID is unreachable.

This instruction is treated as a NOP if there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC VDPRI, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b100 | 0b1100 | 0b0001 | 0b010 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    GIC(X[t, 64], GICInstrDomain_VD, GICInstr_PRI);
elsif PSTATE.EL == EL3 then
    if !EL2Enabled() then
        UNDEFINED;
else
    GIC(X[t, 64], GICInstrDomain_VD, GICInstr_PRI);
```

# 8.2.8 GIC VDRCFG, Request Interrupt Configuration in the Virtual Interrupt Domain

The GIC VDRCFG characteristics are:

#### Purpose

Request to read configuration of the specified INTID in the Virtual Interrupt Domain into ICC\_ICSR\_EL1.

This operation applies to the virtual INTID in the VM identified by the resident VPE.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to GIC VDRCFG are UNDEFINED.

#### Attributes

GIC VDRCFG is a 64-bit System instruction.

### Field descriptions

The GIC VDRCFG bit assignments are:

| 63 |     |     |    |      |      | 32 |
|----|-----|-----|----|------|------|----|
|    |     |     |    |      | RES0 |    |
| 31 | 29  | 28  | 24 | l 23 |      | Θ  |
| TY | ′PE | RES | )  |      | ID   |    |

### Bits [63:32]

Reserved, RESO.

TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC VDRCFG

This instruction is treated as a NOP if there is no resident VPE.

Accesses to this instruction use the following encodings in the System instruction encoding space:

#### GIC VDRCFG, <Xt>

### Chapter 8. System instructions 8.2. System instructions for the Virtual Interrupt Domain

|           | op0                  | op1               | CRn             | CRm             | op2    |
|-----------|----------------------|-------------------|-----------------|-----------------|--------|
|           | 0b01                 | 0b100             | 0b1100          | 0b0001          | 0b101  |
|           |                      |                   |                 |                 |        |
| -         | E.EL == EL(          | ) then            |                 |                 |        |
|           | TINED;<br>TATE.EL == | FI1 then          |                 |                 |        |
|           |                      | ) && HCR_EL2.NV = | = '1' && TCH VC | TLR EL2.V3 == ' | 0'then |
|           |                      | stemAccessTrap(EL |                 |                 |        |
| else      | -                    | <b>1</b>          |                 |                 |        |
| τ         | JNDEFINED;           |                   |                 |                 |        |
| elsif PST | CATE.EL ==           | EL2 then          |                 |                 |        |
| GIC()     | K[t, 64], (          | GICInstrDomain_VD | , GICInstr_RCFG | );              |        |
| elsif PST | CATE.EL ==           | EL3 then          |                 |                 |        |
| if !E     | L2Enabled            | () then           |                 |                 |        |
| Ţ         | JNDEFINED;           |                   |                 |                 |        |
| else      |                      |                   |                 |                 |        |
| (         | GIC(X[t, 64          | 4], GICInstrDomai | n_VD, GICInstr_ | RCFG);          |        |

Chapter 8. System instructions 8.3. System instructions for the Logical Interrupt Domain

# 8.3 System instructions for the Logical Interrupt Domain

# 8.3.1 GIC LDAFF, Interrupt Set Target in the Logical Interrupt Domain

The GIC LDAFF characteristics are:

### Purpose

Sets the routing mode and target PE for the specified INTID in the Logical Interrupt Domain associated with the Security state selected by the SCR\_EL3.{NS, NSE} bits.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to GIC LDAFF are UNDEFINED.

### Attributes

GIC LDAFF is a 64-bit System instruction.

# **Field descriptions**

The GIC LDAFF bit assignments are:



### Bits [63:48]

Reserved, RESO.

### IAFFID, bits [47:32]

The interrupt Affinity value.

The IRS may support fewer than 16 bits of IAFFID. Unimplemented upper bits are treated as RESO by the IRS.

When IRM is 1, this field provides an IMPLEMENTATION DEFINED hint to 1ofN selection algorithm. A value of 0 means that no hint is provided.

# TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### IRM, bit [28]

Controls how the interrupt is routed.

If the GIC IRS does not support 1ofN distribution of the specified interrupt Type, this configuration is treated as RES0.

| IRM | Meaning                                |
|-----|----------------------------------------|
| 0d0 | The interrupt Routing mode is Targeted |
| 0b1 | The interrupt Routing mode is 1ofN     |

### Bits [27:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC LDAFF

When executed at EL3, if SCR\_EL3.{NS, NSE} select a reserved value, the behavior is CONSTRAINED UNPRE-DICTABLE with the permitted options:

- SCR\_EL3.{NS, NSE} is treated as having an UNKNOWN value.
- The instruction is treated as a NOP.

This instruction has no effect if the INTID is unreachable

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC LDAFF, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b110 | 0b1100 | 0b0001 | 0b011 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    UNDEFINED;
elsif PSTATE.EL == EL2 then
    UNDEFINED;
elsif PSTATE.EL == EL3 then
    GIC(X[t, 64], GICInstrDomain_LD, GICInstr_AFF);
```

# 8.3.2 GIC LDDI, Interrupt Deactivate in the Logical Interrupt Domain

The GIC LDDI characteristics are:

### Purpose

Enables the specified INTID in the Logical Interrupt Domain associated with the Security state selected by the SCR\_EL3.{NS, NSE} bits.

This instruction applies to all interrupt types, including PPIs.

### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to GIC LDDI are UNDEFINED.

### Attributes

GIC LDDI is a 64-bit System instruction.

# **Field descriptions**

The GIC LDDI bit assignments are:

| L | 63    |       | 33 <sub> </sub> 3 | 2 |
|---|-------|-------|-------------------|---|
|   |       |       | RES0 W            | Ι |
|   | 31 29 | 28 24 | 23                | 9 |
|   | TYPE  | RES0  | ID                |   |

### Bits [63:33]

Reserved, RESO.

### Bit [32]

Reserved, WI.

TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b001 | PPI     |  |
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC LDDI

When executed at EL3, if SCR\_EL3.{NS, NSE} select a reserved value, the behavior is CONSTRAINED UNPRE-DICTABLE with the permitted options:

- SCR\_EL3.{NS, NSE} is treated as having an UNKNOWN value.
- The instruction is treated as a NOP.

This instruction has no effect if the INTID is unreachable.

Accesses to this instruction use the following encodings in the System instruction encoding space:

### GIC LDDI, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b110 | 0b1100 | 0b0010 | 0b000 |

| if PSTATE.EL == ELO then                       |  |
|------------------------------------------------|--|
| UNDEFINED;                                     |  |
| elsif PSTATE.EL == EL1 then                    |  |
| UNDEFINED;                                     |  |
| elsif PSTATE.EL == EL2 then                    |  |
| UNDEFINED;                                     |  |
| elsif PSTATE.EL == EL3 then                    |  |
| GIC(X[t, 64], GICInstrDomain_LD, GICInstr_DI); |  |

# 8.3.3 GIC LDDIS, Interrupt Disable in the Logical Interrupt Domain

The GIC LDDIS characteristics are:

### Purpose

Disables the specified INTID in the Logical Interrupt Domain associated with the Security state selected by the SCR\_EL3.{NS, NSE} bits.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to GIC LDDIS are UNDEFINED.

### Attributes

GIC LDDIS is a 64-bit System instruction.

# **Field descriptions**

The GIC LDDIS bit assignments are:

| 63    |      |    |                 |      | 32 |
|-------|------|----|-----------------|------|----|
|       |      |    |                 | RES0 |    |
| 31 29 | 28   | 24 | <sub>1</sub> 23 |      | Θι |
| TYPE  | RES0 |    |                 | ID   |    |

### Bits [63:32]

Reserved, RESO.

### TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Valued not defined above are reserved

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC LDDIS

When executed at EL3, if SCR\_EL3.{NS, NSE} select a reserved value, the behavior is CONSTRAINED UNPRE-DICTABLE with the permitted options:

- SCR\_EL3.{NS, NSE} is treated as having an UNKNOWN value.
- The instruction is treated as a NOP.

#### Chapter 8. System instructions 8.3. System instructions for the Logical Interrupt Domain

This instruction has no effect if the INTID is unreachable.

Accesses to this instruction use the following encodings in the System instruction encoding space:

GIC LDDIS, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b110 | 0b1100 | 0b0001 | 0b000 |

| if PSTATE.EL == ELO  | then                            |
|----------------------|---------------------------------|
| UNDEFINED;           |                                 |
| elsif PSTATE.EL == E | L1 then                         |
| UNDEFINED;           |                                 |
| elsif PSTATE.EL == E | L2 then                         |
| UNDEFINED;           |                                 |
| elsif PSTATE.EL == E | L3 then                         |
| GIC(X[t, 64], GI     | CInstrDomain_LD, GICInstr_DIS); |

# 8.3.4 GIC LDEN, Interrupt Enable in the Logical Interrupt Domain

The GIC LDEN characteristics are:

### Purpose

Enables the specified INTID in the Logical Interrupt Domain associated with the Security state selected by the SCR\_EL3.{NS, NSE} bits.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to GIC LDEN are UNDEFINED.

### Attributes

GIC LDEN is a 64-bit System instruction.

# **Field descriptions**

The GIC LDEN bit assignments are:

| 63                 |       |    |      | 32  |
|--------------------|-------|----|------|-----|
|                    |       |    | RES0 |     |
|                    |       |    |      |     |
| 1 <sup>31</sup> 29 | 28 24 | 23 |      | Θ ι |
| TYPE               | RES0  |    | ID   |     |

### Bits [63:32]

Reserved, RESO.

### TYPE, bits [31:29]

Type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC LDEN

When executed at EL3, if SCR\_EL3.{NS, NSE} select a reserved value, the behavior is CONSTRAINED UNPRE-DICTABLE with the permitted options:

- SCR\_EL3.{NS, NSE} is treated as having an UNKNOWN value.
- The instruction is treated as a NOP.

#### Chapter 8. System instructions 8.3. System instructions for the Logical Interrupt Domain

This instruction has no effect if the INTID is unreachable.

Accesses to this instruction use the following encodings in the System instruction encoding space:

GIC LDEN, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b110 | 0b1100 | 0b0001 | 0b001 |

| if PSTATE.EL == ELO then                       |
|------------------------------------------------|
| UNDEFINED;                                     |
| elsif PSTATE.EL == EL1 then                    |
| UNDEFINED;                                     |
| elsif PSTATE.EL == EL2 then                    |
| UNDEFINED;                                     |
| elsif PSTATE.EL == EL3 then                    |
| GIC(X[t, 64], GICInstrDomain_LD, GICInstr_EN); |

# 8.3.5 GIC LDHM, Interrupt Handling mode in the Logical Interrupt Domain

The GIC LDHM characteristics are:

### Purpose

Sets the Handling mode of the specified INTID in the Logical Interrupt Domain associated with the Security state selected by the SCR\_EL3.{NS, NSE} bits.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to GIC LDHM are UNDEFINED.

### Attributes

GIC LDHM is a 64-bit System instruction.

# **Field descriptions**

The GIC LDHM bit assignments are:

| 63   |        |      |    |    |      | 33 | 32 |
|------|--------|------|----|----|------|----|----|
|      |        |      |    |    | RES0 |    | ΗМ |
| 31   | 9   28 |      | 24 | 23 |      |    |    |
| TYPE |        | RES0 |    |    | ID   |    |    |

### Bits [63:33]

Reserved, RESO.

### HM, bit [32]

Handling mode

| HM  | Meaning |  |
|-----|---------|--|
| 0b0 | Edge    |  |
| 0b1 | Level   |  |

# TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

# ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC LDHM

When executed at EL3, if SCR\_EL3.{NS, NSE} select a reserved value, the behavior is CONSTRAINED UNPRE-DICTABLE with the permitted options:

- SCR\_EL3.{NS, NSE} is treated as having an UNKNOWN value.
- The instruction is treated as a NOP.

This instruction has no effect if the INTID is unreachable.

Accesses to this instruction use the following encodings in the System instruction encoding space:

# GIC LDHM, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b110 | 0b1100 | 0b0010 | 0b001 |

| if PSTATE.EL == EL0 then                       |
|------------------------------------------------|
| UNDEFINED;                                     |
| elsif PSTATE.EL == EL1 then                    |
| UNDEFINED;                                     |
| elsif PSTATE.EL == EL2 then                    |
| UNDEFINED;                                     |
| elsif PSTATE.EL == EL3 then                    |
| GIC(X[t, 64], GICInstrDomain_LD, GICInstr_HM); |

# 8.3.6 GIC LDPEND, Interrupt Set/Clear Pending state in the Logical Interrupt Domain

The GIC LDPEND characteristics are:

### Purpose

Generates a SET or CLEAR event for the specified INTID in the Logical Interrupt Domain associated with the Security state selected by the SCR\_EL3.{NS, NSE} bits.

### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to GIC LDPEND are UNDEFINED.

### Attributes

GIC LDPEND is a 64-bit System instruction.

# **Field descriptions**

The GIC LDPEND bit assignments are:



# Bits [63:33]

Reserved, RESO.

### PENDING, bit [32]

Pending status

| PENDING | Meaning                          |
|---------|----------------------------------|
| 0b0     | Generate CLEAR event to the IRS. |
| 0b1     | Generate SET event to the IRS.   |

# TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

# ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC LDPEND

When executed at EL3, if SCR\_EL3.{NS, NSE} select a reserved value, the behavior is CONSTRAINED UNPRE-DICTABLE with the permitted options:

- SCR\_EL3.{NS, NSE} is treated as having an UNKNOWN value.
- The instruction is treated as a NOP.

This instruction has no effect if the INTID is unreachable.

Accesses to this instruction use the following encodings in the System instruction encoding space:

# GIC LDPEND, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b110 | 0b1100 | 0b0001 | 0b100 |

| if PSTATE.EL == ELO then                         |
|--------------------------------------------------|
| UNDEFINED;                                       |
| elsif PSTATE.EL == EL1 then                      |
| UNDEFINED;                                       |
| elsif PSTATE.EL == EL2 then                      |
| UNDEFINED;                                       |
| elsif PSTATE.EL == EL3 then                      |
| GIC(X[t, 64], GICInstrDomain_LD, GICInstr_PEND); |

# 8.3.7 GIC LDPRI, Interrupt Set priority in the Logical Interrupt Domain

The GIC LDPRI characteristics are:

### Purpose

Sets the priority for the specified INTID in the Logical Interrupt Domain associated with the Security state selected by the SCR\_EL3.{NS, NSE} bits.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to GIC LDPRI are UNDEFINED.

### Attributes

GIC LDPRI is a 64-bit System instruction.

# **Field descriptions**

The GIC LDPRI bit assignments are:

| 63    |      |         |      | 40 | ) <sub>1</sub> 39 | 35 | 34  | 32 |
|-------|------|---------|------|----|-------------------|----|-----|----|
|       |      |         | RES0 |    | PRIORIT           | Y  | RES | 0  |
| 31 29 | 28   | 24   23 |      |    |                   |    |     | 0  |
| TYPE  | RES0 |         |      | ID |                   |    |     |    |

### Bits [63:40]

Reserved, RESO.

### PRIORITY, bits [39:35]

The priority of the specified INTID

Only the upper N bits of the Priority field are implemented where  $N = (ICC_IDR0_EL1.PRI_BITS + 1)$ . Unimplemented bits are RES0.

### Bits [34:32]

Reserved, RESO.

# TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

### Bits [28:24]

Reserved, RESO.

### ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC LDPRI

When executed at EL3, if SCR\_EL3.{NS, NSE} select a reserved value, the behavior is CONSTRAINED UNPRE-DICTABLE with the permitted options:

- SCR\_EL3.{NS, NSE} is treated as having an UNKNOWN value.
- The instruction is treated as a NOP.

This instruction has no effect if the INTID is unreachable.

Accesses to this instruction use the following encodings in the System instruction encoding space:

# GIC LDPRI, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b110 | 0b1100 | 0b0001 | 0b010 |

| if PSTATE.EL == ELO then           |               |
|------------------------------------|---------------|
| UNDEFINED;                         |               |
| elsif PSTATE.EL == EL1 then        |               |
| UNDEFINED;                         |               |
| elsif PSTATE.EL == EL2 then        |               |
| UNDEFINED;                         |               |
| elsif PSTATE.EL == EL3 then        |               |
| GIC(X[t, 64], GICInstrDomain_LD, G | ICInstr_PRI); |

# 8.3.8 GIC LDRCFG, Request Interrupt Configuration in the Logical Interrupt Domain

The GIC LDRCFG characteristics are:

# Purpose

Request to read configuration of the specified INTID in the Logical Interrupt Domain associated with the Security state selected by the SCR\_EL3.{NS, NSE} bits into ICC\_ICSR\_EL1.

#### Configuration

This instruction is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to GIC LDRCFG are UNDEFINED.

# Attributes

GIC LDRCFG is a 64-bit System instruction.

# **Field descriptions**

The GIC LDRCFG bit assignments are:

| 63    |      |    |    |      | 32 |
|-------|------|----|----|------|----|
|       |      |    |    | RES0 |    |
| 31 29 | 1 28 | 24 | 23 |      | 0  |
| TYPE  | RES0 |    |    | ID   |    |

# Bits [63:32]

Reserved, RESO.

# TYPE, bits [31:29]

Type of the interrupt

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

# Bits [28:24]

Reserved, RESO.

# ID, bits [23:0]

The ID of the interrupt.

ID and TYPE together form an INTID.

The number of ID bits implemented is reported in ICC\_IDR0\_EL1.ID\_BITS. Unimplemented upper bits are RES0.

# Accessing GIC LDRCFG

When executed at EL3, if SCR\_EL3.{NS, NSE} select a reserved value, the behavior is CONSTRAINED UNPRE-DICTABLE with the permitted options:

- SCR\_EL3.{NS, NSE} is treated as having an UNKNOWN value.
- The instruction is treated as a NOP.

#### Chapter 8. System instructions 8.3. System instructions for the Logical Interrupt Domain

ICC\_ICSR\_EL1.F is set to 1 and other fields become UNKNOWN after execution of this instruction if the INTID is unreachable.

Accesses to this instruction use the following encodings in the System instruction encoding space:

# GIC LDRCFG, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b110 | 0b1100 | 0b0001 | 0b101 |

if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then UNDEFINED; elsif PSTATE.EL == EL2 then UNDEFINED; elsif PSTATE.EL == EL3 then GIC(X[t, 64], GICInstrDomain\_LD, GICInstr\_RCFG);

# 8.4 GIC synchronization barrier instructions

# 8.4.1 GSB SYS, GIC Synchronization Barrier System

The GSB SYS characteristics are:

# Purpose

GIC Synchronization Barrier System ensures completion of the effects of GIC instructions and prevents loads, stores, and GIC instructions from executing part of their functionality before the GSB SYS.

See 2.12 Interrupt ordering model and synchronization requirements for more information.

# Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GSB SYS are UNDEFINED.

# Accessing GSB SYS

Accesses to this instruction use the following encodings in the System instruction encoding space:

# GSB SYS

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b000 | 0b1100 | 0b0000 | 0b000 |

if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then GSB(GICInstr\_SYS); elsif PSTATE.EL == EL2 then GSB(GICInstr\_SYS); elsif PSTATE.EL == EL3 then GSB(GICInstr\_SYS);

# 8.4.2 GSB ACK, GIC Synchronization Barrier Interrupt Acknowledge

The GSB ACK characteristics are:

# Purpose

GIC Synchronization Barrier Interrupt Acknowledge ensures completion of the effects of the GICR  $\hookrightarrow$  CDIA and GICR CDNMIA instructions and prevents loads, stores, and GIC instructions from executing part of their functionality before the GSB ACK.

See 2.12 Interrupt ordering model and synchronization requirements for more information.

# Configuration

This instruction is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to GSB ACK are UNDEFINED.

# Accessing GSB ACK

Accesses to this instruction use the following encodings in the System instruction encoding space:

# GSB ACK

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b01 | 0b000 | 0b1100 | 0b0000 | 0b001 |

if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then GSB(GICInstr\_ACK); elsif PSTATE.EL == EL2 then GSB(GICInstr\_ACK); elsif PSTATE.EL == EL3 then GSB(GICInstr\_ACK);

# Chapter 9 System registers

This chapter describes the GICv5 system registers.

# 9.1 Synchronization requirements for GICv5 System registers

- I<sub>CWKLD</sub> The GICv5 System registers follow the requirements for System registers in the *Arm<sup>®</sup>* Architecture Reference Manual, for A-profile architecture[1].
- R<sub>NWMPV</sub> Access to the following System registers are self-synchronizing:
  - ICC\_PCR\_EL3
  - ICC\_PCR\_EL1
  - ICV\_PCR\_EL1

This means that the architectural side effects of direct writes to any of the above System registers are visibile to instructions in program order after the direct write. The effects of a direct write include updates to the pending state of the IRQ, FIQ, vIRQ, and vFIQ asynchronous exceptions.

Chapter 9. System registers 9.2. CPU interface registers

# 9.2 CPU interface registers

Configuration and state of the CPU interface.

# 9.2.1 ICC\_APR\_EL1, Interrupt Controller Physical Active Priorities Register

The ICC\_APR\_EL1 characteristics are:

#### Purpose

Records physical active priorities for the Non-secure, Realm, and Secure Interrupt Domains.

#### Configuration

There are separate banked copies of this register for Non-secure, Realm and Secure state.

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_APR\_EL1 are UNDEFINED.

# Attributes

ICC\_APR\_EL1 is a 64-bit register.

This register has the following instances:

- ICC\_APR\_EL1, when EL3 is not implemented
- ICC\_APR\_EL1\_NS, when EL3 is implemented
- ICC\_APR\_EL1\_RL, when FEAT\_RME is implemented
- ICC\_APR\_EL1\_S, when (EL3 is implemented and FEAT\_RME is not implemented) or (FEAT\_RME is implemented and FEAT\_SEL2 is implemented)

# **Field descriptions**

The ICC\_APR\_EL1 bit assignments are:



# Bits [63:32]

Reserved, RESO.

# P<x>, bits [x], for x = 31 to 0

Provides access to the active priorities.

| P <x></x> | Meaning             |  |
|-----------|---------------------|--|
| 0b0       | Priority not active |  |
| 0b1       | Priority active     |  |

Fields in this register are indexed using the 5-bit priority as an unsigned integer, P[Priority].

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- Access is **RES0** if all of the following are true:
  - x MOD 2 == 1
  - ICC\_IDR0\_EL1.PRI\_BITS == 0b011
- Otherwise, access to this field is **RW**

# Accessing ICC\_APR\_EL1

Accesses to this register use the following encodings in the System register encoding space:

```
MRS <Xt>, ICC_APR_EL1
```

| орО  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b000 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_APR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV\_APR\_EL1;
    elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            X[t, 64] = ICC\_APR\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            X[t, 64] = ICC\_APR\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            X[t, 64] = ICC\_APR\_EL1\_NS;
        else
            UNDEFINED;
    else
        X[t, 64] = ICC\_APR\_EL1;
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            X[t, 64] = ICC\_APR\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            X[t, 64] = ICC\_APR\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            X[t, 64] = ICC\_APR\_EL1\_NS;
        else
            UNDEFINED;
    else
        X[t, 64] = ICC\_APR\_EL1;
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        X[t, 64] = ICC\_APR\_EL1\_S;
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \hookrightarrow then
        X[t, 64] = ICC\_APR\_EL1\_RL;
```

#### Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

# Chapter 9. System registers 9.2. CPU interface registers

```
elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        X[t, 64] = ICC_APR_EL1_NS;
else
        UNDEFINED;
```

# MSR ICC\_APR\_EL1, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b000 |

```
if PSTATE_EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_APR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV\_APR\_EL1 = X[t, 64];
    elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            ICC\_APR\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            ICC\_APR\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            ICC\_APR\_EL1\_NS = X[t, 64];
        else
            UNDEFINED;
    else
        ICC\_APR\_EL1 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR EL3.NS == '0' then
            ICC\_APR\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            ICC\_APR\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
             ICC\_APR\_EL1\_NS = X[t, 64];
        else
            UNDEFINED;
    else
        ICC\_APR\_EL1 = X[t, 64];
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        ICC\_APR\_EL1\_S = X[t, 64];
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \hookrightarrow then
        ICC\_APR\_EL1\_RL = X[t, 64];
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        ICC\_APR\_EL1\_NS = X[t, 64];
    else
        UNDEFINED:
```

# 9.2.2 ICC\_APR\_EL3, Interrupt Controller Physical Active Priorities Register for EL3

The ICC\_APR\_EL3 characteristics are:

#### Purpose

Records active priorities for the EL3 Interrupt Domain.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to ICC\_APR\_EL3 are UNDEFINED.

# Attributes

ICC\_APR\_EL3 is a 64-bit register.

# **Field descriptions**

The ICC\_APR\_EL3 bit assignments are:



# Bits [63:32]

Reserved, RESO.

# *P*<*x*>, bits [*x*], for *x* = 31 to 0

Provides access to the active priorities.

| P <x></x> | Meaning             |
|-----------|---------------------|
| 0b0       | Priority not active |
| 0b1       | Priority active     |

Fields in this register are indexed using the 5-bit priority as an unsigned integer, P[Priority].

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- Access is RES0 if all of the following are true:
  x MOD 2 == 1
  - ICC\_IDR0\_EL1.PRI\_BITS == 0b011
- Otherwise, access to this field is **RW**

# Accessing ICC\_APR\_EL3

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, ICC\_APR\_EL3

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b1100 | 0b1000 | 0b000 |

| if PST  | ATE.EL = | == ELO | the  | n    |
|---------|----------|--------|------|------|
| UNI     | DEFINED  | ;      |      |      |
| elsif I | PSTATE.  | EL ==  | EL1  | then |
| UNI     | DEFINED  | ;      |      |      |
| elsif H | PSTATE.  | EL ==  | EL2  | then |
| UNI     | DEFINED  | ;      |      |      |
| elsif H | PSTATE.  | EL ==  | EL3  | then |
| X [ 1   | c, 64] = | = ICC_ | APR_ | EL3; |

# MSR ICC\_APR\_EL3, <Xt>

| орО  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b1100 | 0b1000 | 0b000 |

| if PSTATE.EL == ELO then |           |     |      |      |  |
|--------------------------|-----------|-----|------|------|--|
| UN                       | IDEFINED; |     |      |      |  |
| elsif                    | PSTATE.EL | ==  | EL1  | then |  |
| UN                       | IDEFINED; |     |      |      |  |
| elsif                    | PSTATE.EL | ==  | EL2  | then |  |
| UNDEFINED;               |           |     |      |      |  |
| elsif                    | PSTATE.EL | ==  | EL3  | then |  |
| IC                       | C_APR_EL3 | = > | <[t, | 64]; |  |

# 9.2.3 ICC\_CR0\_EL1, Interrupt Controller EL1 Physical Control Register

The ICC\_CR0\_EL1 characteristics are:

#### Purpose

Controls behavior of the physical CPU interface for the Non-secure, Realm, and Secure Interrupt Domains.

#### Configuration

There are separate banked copies of this register for Non-secure, Realm and Secure state.

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_CR0\_EL1 are UNDEFINED.

# Attributes

ICC\_CR0\_EL1 is a 64-bit register.

This register has the following instances:

- ICC\_CR0\_EL1, when EL3 is not implemented
- ICC\_CR0\_EL1\_NS, when EL3 is implemented
- ICC\_CR0\_EL1\_RL, when FEAT\_RME is implemented
- ICC\_CR0\_EL1\_S, when (EL3 is implemented and FEAT\_RME is not implemented) or (FEAT\_RME is implemented and FEAT\_SEL2 is implemented)

# Field descriptions

The ICC\_CR0\_EL1 bit assignments are:



# Bits [63:39]

Reserved, RESO.

# PID, bit [38]

#### When EL3 is implemented:

Preemptive Interrupt Domain. Indicates whether the Interrupt Domain associated with the Security state selected by SCR\_EL3.{NSE,NS} is the Preemptive Interrupt Domain.

Access to this field is **RO**.

Otherwise:

RAZ/WI

IPPT, bits [37:32]

When ICC\_CR0\_EL1.PID == 1:

Interrupt Preemptive Priority Threshold value for the Preemptive Interrupt Domain.

When fewer than 5 bits of priority is implemented, only bits [5:N] are implemented where  $N = (4 - ICC_IDR0_EL1.PRI_BITS)$ . Unimplemented bits are RES0.

Note: ICC\_CR0\_EL1.IPPT is a 6 bits field to ensure it can be strictly higher than the interrupt priority, which is a 5-bit unsigned value.

See 2.9.3 Preemptive interrupts for more information.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

#### Bits [31:1]

Reserved, RESO.

# EN, bit [0]

Enable interrupts for the Interrupt Domain.

When this field is 0, there is no HPPI of Sufficient priority for the Interrupt Domain.

| EN  | Meaning   |  |
|-----|-----------|--|
| 000 | Disabled. |  |
| 0b1 | Enabled.  |  |

The reset behavior of this field is:

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

# Accessing ICC\_CR0\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_CR0\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b001 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_CR0_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_CR0_EL1;
    elsif HaveEL(EL3) then
        if SCR EL3.NS == '0' then
            X[t, 64] = ICC\_CR0\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            X[t, 64] = ICC\_CR0\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            X[t, 64] = ICC\_CR0\_EL1\_NS;
        else
            UNDEFINED;
    else
```

# Chapter 9. System registers 9.2. CPU interface registers

```
X[t, 64] = ICC\_CR0\_EL1;
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
             X[t, 64] = ICC\_CR0\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            X[t, 64] = ICC\_CR0\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            X[t, 64] = ICC\_CR0\_EL1\_NS;
        else
            UNDEFINED;
    else
        X[t, 64] = ICC\_CR0\_EL1;
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        X[t, 64] = ICC\_CR0\_EL1\_S;
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \rightarrow then
        X[t, 64] = ICC\_CR0\_EL1\_RL;
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        X[t, 64] = ICC\_CR0\_EL1\_NS;
    else
        UNDEFINED;
```

```
MSR ICC_CR0_EL1, <Xt>
```

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b001 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_CR0_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV\_CR0\_EL1 = X[t, 64];
    elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            ICC\_CR0\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            ICC\_CR0\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            ICC\_CR0\_EL1\_NS = X[t, 64];
        else
            UNDEFINED;
    else
        ICC\_CR0\_EL1 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
             ICC\_CR0\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
```

# Chapter 9. System registers 9.2. CPU interface registers

```
ICC\_CR0\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            ICC\_CR0\_EL1\_NS = X[t, 64];
        else
            UNDEFINED;
    else
        ICC\_CR0\_EL1 = X[t, 64];
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        ICC\_CR0\_EL1\_S = X[t, 64];
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \hookrightarrow then
        ICC\_CR0\_EL1\_RL = X[t, 64];
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        ICC\_CR0\_EL1\_NS = X[t, 64];
    else
        UNDEFINED;
```

# 9.2.4 ICC\_CR0\_EL3, Interrupt Controller EL3 Physical Control Register

The ICC\_CR0\_EL3 characteristics are:

# Purpose

Controls behavior of the CPU interface in the EL3 Interrupt Domain.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to ICC\_CR0\_EL3 are UNDEFINED.

# Attributes

ICC\_CR0\_EL3 is a 64-bit register.

# **Field descriptions**

The ICC\_CR0\_EL3 bit assignments are:

| 63 |      | 34   33 | 32    |
|----|------|---------|-------|
|    | RES0 | P]      | [D    |
| 31 |      | 1       | . 0 . |
|    | RES0 |         | EN    |

# Bits [63:34]

Reserved, RESO.

# PID, bits [33:32]

Preemptive Interrupt Domain.

The PE behaves as if there is no Preemptive Interrupt Domain when any of the following are true:

- This field is set to 0b10.
- This field is set to an Interrupt Domain that is not implemented.

| PID  | Meaning                     |
|------|-----------------------------|
| 0b00 | Secure Interrupt Domain     |
| 0b01 | Non-secure Interrupt Domain |
| 0b10 | None                        |
| 0b11 | Realm Interrupt Domain      |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Bits [31:1]

Reserved, RESO.

# EN, bit [0]

Enable interrupts for the EL3 Interrupt Domain.

When this field is set to 0, the PE behaves as if there is no HPPI of Sufficient priority in the EL3 Interrupt Domain.

| EN  | Meaning   |  |
|-----|-----------|--|
| 0b0 | Disabled. |  |
| 0b1 | Enabled.  |  |

The reset behavior of this field is:

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

# Accessing ICC\_CR0\_EL3

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_CR0\_EL3

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b1100 | 0b1001 | 0b000 |

| if PSTATE.EL == ELO then    |  |  |  |  |
|-----------------------------|--|--|--|--|
| UNDEFINED;                  |  |  |  |  |
| elsif PSTATE.EL == EL1 then |  |  |  |  |
| UNDEFINED;                  |  |  |  |  |
| elsif PSTATE.EL == EL2 then |  |  |  |  |
| UNDEFINED;                  |  |  |  |  |
| elsif PSTATE.EL == EL3 then |  |  |  |  |
| $X[t, 64] = ICC\_CR0\_EL3;$ |  |  |  |  |

#### MSR ICC\_CR0\_EL3, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b1100 | 0b1001 | 0b000 |

| ELO then    |
|-------------|
|             |
| == EL1 then |
|             |
| == EL2 then |
|             |
| == EL3 then |
| = X[t, 64]; |
|             |

# 9.2.5 ICC\_DOMHPPIR\_EL3, Interrupt Controller Domain Highest Priority Pending Interrupt Register

The ICC\_DOMHPPIR\_EL3 characteristics are:

#### Purpose

Reports the HPPI for a Non-EL3 Interrupt Domain.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to ICC\_DOMHPPIR\_EL3 are UNDEFINED.

#### Attributes

ICC\_DOMHPPIR\_EL3 is a 64-bit register.

# **Field descriptions**

The ICC\_DOMHPPIR\_EL3 bit assignments are:



#### Bits [63:4]

Reserved, RESO.

# P\_HPPI, bit [3]

Preemptive HPPI for the Preemptive Interrupt Domain valid bit.

| P_HPPI | Meaning                                                                                 |
|--------|-----------------------------------------------------------------------------------------|
| 000    | There is no Preemptive HPPI of Sufficient priority for the Preemptive Interrupt Domain. |
| 0b1    | There is an Preemptive HPPI of Sufficient priority for the Preemptive Interrupt Domain. |

Accessing this field has the following behavior:

- **RO** if HavePreemptiveDomain()
- Otherwise, access to this field is **RES0**

# RL\_HPPI, bit [2]

HPPI for Realm Interrupt Domain valid bit.

| RL_HPPI | Meaning                                                             |
|---------|---------------------------------------------------------------------|
| 0b0     | There is no HPPI of Sufficient priority for Realm Interrupt Domain. |
| 0b1     | There is an HPPI of Sufficient priority for Realm Interrupt Domain. |

Accessing this field has the following behavior:

- **RO** if HaveDomain(GICDomain\_RL)
- Otherwise, access to this field is **RES0**

# S\_HPPI, bit [1]

HPPI for Secure Interrupt Domain valid bit.

| S_HPPI | Meaning                                                              |
|--------|----------------------------------------------------------------------|
| 060    | There is no HPPI of Sufficient priority for Secure Interrupt Domain. |
| 0b1    | There is an HPPI of Sufficient priority for Secure Interrupt Domain. |

Accessing this field has the following behavior:

- **RO** if HaveDomain(GICDomain\_S)
- Otherwise, access to this field is **RES0**

# NS\_HPPI, bit [0]

HPPI for Non-secure Interrupt Domain valid bit.

| NS_HPPI | Meaning                                                                  |
|---------|--------------------------------------------------------------------------|
| 0b0     | There is no HPPI of Sufficient priority for Non-secure Interrupt Domain. |
| 0b1     | There is an HPPI of Sufficient priority for Non-secure Interrupt Domain. |

Accessing this field has the following behavior:

- **RO** if HaveDomain(GICDomain\_NS)
- Otherwise, access to this field is **RES0**

# Accessing ICC\_DOMHPPIR\_EL3

#### Read-only

if

els

els

els

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, ICC\_DOMHPPIR\_EL3

| op0                                                                                                                    | op1                  | CRn    | CRm    | op2   |
|------------------------------------------------------------------------------------------------------------------------|----------------------|--------|--------|-------|
| 0b11                                                                                                                   | 0b110                | 0b1100 | 0b1000 | 0b010 |
| PSTATE.EL == ELO<br>UNDEFINED;<br>sif PSTATE.EL ==<br>UNDEFINED;<br>sif PSTATE.EL ==<br>UNDEFINED;<br>sif PSTATE.EL == | EL1 then<br>EL2 then |        |        |       |

# 9.2.6 ICC\_HAPR\_EL1, Interrupt Controller Physical Highest Active Priority Register

The ICC\_HAPR\_EL1 characteristics are:

#### Purpose

Reports the running priority of the Current Physical Interrupt Domain.

#### Configuration

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_HAPR\_EL1 are UNDEFINED.

#### Attributes

ICC\_HAPR\_EL1 is a 64-bit register.

# **Field descriptions**

The ICC\_HAPR\_EL1 bit assignments are:

|      | 32       |            |
|------|----------|------------|
| RES0 |          |            |
| 8    | l 7 0    | _          |
| RES0 | PRIORITY |            |
|      | 8        | RES0 8 7 0 |

# Bits [63:8]

Reserved, RESO.

#### PRIORITY, bits [7:0]

The running priority for the Current Physical Interrupt Domain.

If there are no active priorities on the CPU interface in the applicable Interrupt Domain, or all active priorities have undergone a priority drop, the value returned is the Idle priority.

# Accessing ICC\_HAPR\_EL1

Read-only

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_HAPR\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b011 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_HAPR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_HAPR_EL1;
    else
        X[t, 64] = ICC_HAPR_EL1;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_HAPR_EL1;
```

#### Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

# Chapter 9. System registers 9.2. CPU interface registers

elsif PSTATE.EL == EL3 then
 X[t, 64] = ICC\_HAPR\_EL1;

# 9.2.7 ICC\_HPPIR\_EL1, Interrupt Controller Physical Highest Priority Pending Interrupt Register

The ICC\_HPPIR\_EL1 characteristics are:

#### Purpose

Reports the HPPI for the Physical Interrupt Domain associated with the Security state selected by SCR\_EL3.{NS, NSE}.

# Configuration

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_HPPIR\_EL1 are UNDEFINED.

# Attributes

ICC\_HPPIR\_EL1 is a 64-bit register.

# **Field descriptions**

The ICC\_HPPIR\_EL1 bit assignments are:



# Bits [63:33]

Reserved, RESO.

# HPPIV, bit [32]

HPPI valid.

There is an HPPI with Sufficient priority for the Interrupt Domain.

| HPPIV | Meaning                                                                      |
|-------|------------------------------------------------------------------------------|
| 060   | Invalid: There is no HPPI with Sufficient priority for the Interrupt Domain. |
| 0b1   | VALID: There is an HPPI with Sufficient priority for the Interrupt Domain.   |

If ICC\_HPPIR\_EL1.HPPIV is 1, ID and TYPE together form the INTID of the HPPI for the Interrupt Domain.

# TYPE, bits [31:29]

The encoding of this field depends on the value of HPPIV as described below:

- If ICC\_HPPIR\_EL1.HPPIV is 0, TYPE is RES0.
- If ICC\_HPPIR\_EL1.HPPIV is 1, TYPE specifies the Type of the interrupt.

| ТҮРЕ  | Meaning |
|-------|---------|
| 0b001 | PPI     |
| 0b010 | LPI     |

| ТҮРЕ  | Meaning |
|-------|---------|
| 0b011 | SPI     |

Values not defined above are reserved.

# Bits [28:24]

Reserved, RESO.

# ID, bits [23:0]

The encoding of this field depends on the value of HPPIV as described below:

- If ICC\_HPPIR\_EL1.HPPIV is 0, ID is RES0.
- If ICC\_HPPIR\_EL1.HPPIV is 1, ID specifies the interrupt ID.

# Accessing ICC\_HPPIR\_EL1

#### Read-only

When accessed at EL3, if SCR\_EL3.{NS, NSE} select a reserved value, the behavior is CONSTRAINED UNPRE-DICTABLE with the permitted options:

- SCR\_EL3.{NS, NSE} is treated as having an UNKNOWN value.
- The access is treated as a NOP.

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, ICC\_HPPIR\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b011 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_HPPIR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_HPPIR_EL1;
    else
        X[t, 64] = ICC_HPPIR_EL1;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_HPPIR_EL1;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_HPPIR_EL1;
```

# 9.2.8 ICC\_HPPIR\_EL3, Interrupt Controller Physical Highest Priority Pending Interrupt Register

The ICC\_HPPIR\_EL3 characteristics are:

#### Purpose

Reports the HPPI for the EL3 Interrupt Domain.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to ICC\_HPPIR\_EL3 are UNDEFINED.

#### Attributes

ICC\_HPPIR\_EL3 is a 64-bit register.

# **Field descriptions**

The ICC\_HPPIR\_EL3 bit assignments are:

| 63    |       | 33   32 | I.    |
|-------|-------|---------|-------|
|       |       | RES0    |       |
|       |       |         | HPPIV |
| 31 29 | 28 24 | 23 0    | I     |
| TYPE  | RES0  | ID      |       |
| TYPE  | RES0  | ID      |       |

# Bits [63:33]

Reserved, RESO.

#### HPPIV, bit [32]

HPPI valid.

There is an HPPI with Sufficient priority for the Interrupt Domain.

| HPPIV | Meaning                                                                      |
|-------|------------------------------------------------------------------------------|
| 060   | Invalid: There is no HPPI with Sufficient priority for the Interrupt Domain. |
| 0b1   | VALID: There is an HPPI with Sufficient priority for the Interrupt Domain.   |

If ICC\_HPPIR\_EL3.HPPIV is 1, ID and TYPE together form the INTID of the HPPI for the Interrupt Domain.

# TYPE, bits [31:29]

The encoding of this field depends on the value of HPPIV as described below:

- If ICC\_HPPIR\_EL3.HPPIV is 0, TYPE is RES0.
- If ICC\_HPPIR\_EL3.HPPIV is 1, TYPE specifies the Type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b001 | PPI     |  |
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

# Bits [28:24]

Reserved, RESO.

# ID, bits [23:0]

The encoding of this field depends on the value of HPPIV as described below:

- If ICC\_HPPIR\_EL3.HPPIV is 0, ID is RES0.
- If ICC\_HPPIR\_EL3.HPPIV is 1, ID specifies the interrupt ID.

# Accessing ICC\_HPPIR\_EL3

Read-only

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, ICC\_HPPIR\_EL3

| ор0                               | op1      | CRn    | CRm    | op2   |
|-----------------------------------|----------|--------|--------|-------|
| 0b11                              | 0b110    | 0b1100 | 0b1001 | 0b001 |
|                                   |          |        |        |       |
| if PSTATE.EL == ELO<br>UNDEFINED; | then     |        |        |       |
| elsif PSTATE.EL ==                | EL1 then |        |        |       |
| UNDEFINED;                        |          |        |        |       |
| elsif PSTATE EL ==                | EL2 then |        |        |       |

| elsii | PSI  | L'ATE . | · ĔĹ | ==   | ELZ  | then   |   |
|-------|------|---------|------|------|------|--------|---|
| UI    | NDEE | FINE    | );   |      |      |        |   |
| elsif | PSI  | CATE.   | .EL  | ==   | EL3  | then   |   |
| Х     | [t,  | 64]     | =    | ICC_ | HPPI | IR_EL3 | ; |

# 9.2.9 ICC\_IAFFIDR\_EL1, Interrupt Controller PE Interrupt Affinity ID Register

The ICC\_IAFFIDR\_EL1 characteristics are:

#### Purpose

Reports the PE interrupt Affinity ID for the PE.

#### Configuration

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_IAFFIDR\_EL1 are UNDEFINED.

#### Attributes

ICC\_IAFFIDR\_EL1 is a 64-bit register.

# **Field descriptions**

The ICC\_IAFFIDR\_EL1 bit assignments are:



# Bits [63:16]

Reserved, RESO.

IAFFID, bits [15:0]

PE interrupt Affinity ID.

# Accessing ICC\_IAFFIDR\_EL1

#### Read-only

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_IAFFIDR\_EL1

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b101 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_IAFFIDR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = ICC_IAFFIDR_EL1;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_IAFFIDR_EL1;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_IAFFIDR_EL1;
```

# 9.2.10 ICC\_ICSR\_EL1, Interrupt Controller Interrupt Configuration and State Register

The ICC\_ICSR\_EL1 characteristics are:

#### Purpose

Reports the configuration and state of the INTID specified to a previous GIC request interrupt configuration instruction.

#### Configuration

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_ICSR\_EL1 are UNDEFINED.

#### Attributes

ICC\_ICSR\_EL1 is a 64-bit register.

# **Field descriptions**

The ICC\_ICSR\_EL1 bit assignments are:



#### Bits [63:48]

Reserved, RESO.

#### IAFFID, bits [47:32]

The interrupt Affinity value.

The IRS may support fewer than 16 bits of IAFFID. Upper bits not implemented by the IRS are returned as zero. When IRM is 1, this field is IMPLEMENTATION SPECIFIC.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### Bits [31:16]

Reserved, RESO.

#### Priority, bits [15:11]

The interrupt's Priority.

Bits [4:N] of the priority value are implemented where  $N = (4 - ICC_IDR0_EL1.PRI_BITS)$ . Unimplemented bits are RES0.

This means that when fewer than 5 bits of priority is implemented, Priority[14 - ICC\_IDR0\_EL1.PRI\_BITS:11] are RES0.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Bits [10:6]

Reserved, RESO.

# HM, bit [5]

The interrupt's Handling mode.

| HM  | Meaning         |  |
|-----|-----------------|--|
| 0b0 | Edge-triggered  |  |
| 0b1 | Level-sensitive |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Active, bit [4]

The interrupt's Active state.

| Active | Meaning  |  |
|--------|----------|--|
| 0b0    | Inactive |  |
| 0b1    | Active   |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# IRM, bit [3]

Interrupt Routing mode.

| IRM | Meaning                                 |
|-----|-----------------------------------------|
| 0b0 | The interrupt Routing mode is Targeted. |
| 0b1 | The interrupt Routing mode is 1ofN.     |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Pending, bit [2]

The interrupt's Pending state.

| Pending | Meaning     |  |
|---------|-------------|--|
| 0b0     | Not pending |  |
| 0b1     | Pending     |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Enabled, bit [1]

The interrupt's individual enable.

| Enabled | Meaning  |
|---------|----------|
| 0b0     | Disabled |
| 0b1     | Enabled  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# F, bit [0]

Indicates whether the IRS returned valid data.

| F   | Meaning                                |
|-----|----------------------------------------|
| 0d0 | Request completed successfully.        |
| 0b1 | Request did not complete successfully. |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Accessing ICC\_ICSR\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_ICSR\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b100 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_ICSR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = ICC_ICSR_EL1;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_ICSR_EL1;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_ICSR_EL1;
```

#### MSR ICC\_ICSR\_EL1, <Xt>

# Chapter 9. System registers 9.2. CPU interface registers

| op           | 0                    | op1           | CRn              | CRm             | op2      |
|--------------|----------------------|---------------|------------------|-----------------|----------|
| 0b           | 11                   | 0b000         | 0b1100           | 0b1010          | 0b100    |
|              |                      |               |                  |                 |          |
| if PSTATE.EI | == ELO the           | en            |                  |                 |          |
| UNDEFINE     | D;                   |               |                  |                 |          |
| elsif PSTATE | C.EL == EL1          | then          |                  |                 |          |
|              | abled() &&<br>FINED; | HCR_EL2.IMO   | == '1' && ICH_VC | CTLR_EL2.V3 ==  | '1' then |
| elsif EI     | 2Enabled()           | && ICH_HFGW1  | R_EL2.ICC_ICSR_E | EL1 == '0' then |          |
| AArc         | h64.System           | AccessTrap(EI | L2, 0x18);       |                 |          |
| else         |                      |               |                  |                 |          |
| ICC_         | ICSR_EL1 =           | X[t, 64];     |                  |                 |          |
| elsif PSTATE | C.EL == EL2          | then          |                  |                 |          |
| ICC_ICSF     | $x_{EL1} = X[t]$     | 64];          |                  |                 |          |
| elsif PSTATE | C.EL == EL3          | then          |                  |                 |          |
| ICC_ICSF     | $x_EL1 = X[t]$       | 64] <b>;</b>  |                  |                 |          |

# 9.2.11 ICC\_IDR0\_EL1, Interrupt Controller ID Register 0

The ICC\_IDR0\_EL1 characteristics are:

#### Purpose

Contains read-only fields with information about the CPU interface.

#### Configuration

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_IDR0\_EL1 are UNDEFINED.

# Attributes

ICC\_IDR0\_EL1 is a 64-bit register.

# **Field descriptions**

The ICC\_IDR0\_EL1 bit assignments are:



# Bits [63:12]

Reserved, RESO.

# GCIE\_LEGACY, bits [11:8]

Indicates support for legacy GICv3.3 virtual CPU interface.

| GCIE_LEGACY | Meaning                                                 |
|-------------|---------------------------------------------------------|
| 000000      | Legacy GICv3.3 virtual CPU interface is not implemented |
| 0b0001      | Legacy GICv3.3 virtual CPU interface is implemented     |

FEAT\_GCIE\_LEGACY extension implements the functionality identified by the value 1.

# PRI\_BITS, bits [7:4]

The number of priority bits implemented, minus one.

| PRI_BITS | Meaning            |  |
|----------|--------------------|--|
| 0b0011   | 4 bits of priority |  |
| 0b0100   | 5 bits of priority |  |

Values not defined above are reserved.

When FEAT\_GCIE\_LEGACY is implemented, the only permitted value of this field is 0b100.

# ID\_BITS, bits [3:0]

Identifier bits.

Read-only and writes are ignored.

The number of interrupt identifier bits supported.

| ID_BITS | Meaning |  |
|---------|---------|--|
| 000000  | 16 bits |  |
| 0b0001  | 24 bits |  |

# Accessing ICC\_IDR0\_EL1

#### Read-only

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, ICC\_IDR0\_EL1

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b010 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_IDRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = ICC_IDR0_EL1;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_IDR0_EL1;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_IDR0_EL1;
```

# 9.2.12 ICC\_PCR\_EL1, Interrupt Controller Physical Interrupt Priority Control Register

The ICC\_PCR\_EL1 characteristics are:

#### Purpose

Reports the Physical priority mask for the Non-secure, Realm, and Secure Interrupt Domains.

#### Configuration

There are separate banked copies of this register for Non-secure, Realm and Secure state.

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_PCR\_EL1 are UNDEFINED.

# Attributes

ICC\_PCR\_EL1 is a 64-bit register.

This register has the following instances:

- ICC\_PCR\_EL1, when EL3 is not implemented
- ICC\_PCR\_EL1\_NS, when EL3 is implemented
- ICC\_PCR\_EL1\_RL, when FEAT\_RME is implemented
- ICC\_PCR\_EL1\_S, when (EL3 is implemented and FEAT\_RME is not implemented) or (FEAT\_RME is implemented and FEAT\_SEL2 is implemented)

# **Field descriptions**

The ICC\_PCR\_EL1 bit assignments are:

| 1 | 63   | 32       | 2 |
|---|------|----------|---|
|   | RESO |          |   |
| 1 | 31 5 | 4 0      | _ |
|   | RES0 | PRIORITY |   |

# Bits [63:5]

Reserved, RESO.

# PRIORITY, bits [4:0]

The priority mask for the Interrupt Domain.

When fewer than 5 bits of priority is implemented, only bits [4:N] are implemented where  $N = (4 - ICC_IDR0_EL1.PRI_BITS)$ . Unimplemented bits are RES0.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Accessing ICC\_PCR\_EL1

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, ICC\_PCR\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b010 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PCR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR EL2.IMO == '1' then
        X[t, 64] = ICV_PCR_EL1;
    elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            X[t, 64] = ICC\_PCR\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            X[t, 64] = ICC\_PCR\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            X[t, 64] = ICC\_PCR\_EL1\_NS;
        else
            UNDEFINED;
    else
        X[t, 64] = ICC\_PCR\_EL1;
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            X[t, 64] = ICC\_PCR\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            X[t, 64] = ICC\_PCR\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            X[t, 64] = ICC\_PCR\_EL1\_NS;
        else
            UNDEFINED;
    else
        X[t, 64] = ICC\_PCR\_EL1;
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        X[t, 64] = ICC\_PCR\_EL1\_S;
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \rightarrow then
        X[t, 64] = ICC_PCR_EL1_RL;
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        X[t, 64] = ICC\_PCR\_EL1\_NS;
    else
        UNDEFINED;
```

#### MSR ICC\_PCR\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b010 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
```

```
elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PCR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV\_PCR\_EL1 = X[t, 64];
    elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
             ICC\_PCR\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
             ICC\_PCR\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
             ICC\_PCR\_EL1\_NS = X[t, 64];
        else
             UNDEFINED;
    else
        ICC\_PCR\_EL1 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
             ICC\_PCR\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            ICC\_PCR\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            ICC\_PCR\_EL1\_NS = X[t, 64];
        else
            UNDEFINED;
    else
        ICC\_PCR\_EL1 = X[t, 64];
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        ICC\_PCR\_EL1\_S = X[t, 64];
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \hookrightarrow then
        ICC\_PCR\_EL1\_RL = X[t, 64];
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        ICC\_PCR\_EL1\_NS = X[t, 64];
    else
        UNDEFINED;
```

# 9.2.13 ICC\_PCR\_EL3, Interrupt Controller Interrupt Priority Control Register for EL3

The ICC\_PCR\_EL3 characteristics are:

#### Purpose

Reports the Physical priority mask for the physical CPU interface for the EL3 Interrupt Domain.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to ICC\_PCR\_EL3 are UNDEFINED.

#### Attributes

ICC\_PCR\_EL3 is a 64-bit register.

#### **Field descriptions**

The ICC\_PCR\_EL3 bit assignments are:

| l | 63   | 32       |
|---|------|----------|
|   | RES0 |          |
|   | 31 5 | 4 0      |
|   | RES0 | PRIORITY |

#### Bits [63:5]

Reserved, RESO.

#### PRIORITY, bits [4:0]

The priority mask for the EL3 Interrupt Domain.

When fewer than 5 bits of priority is implemented, only bits [4:N] are implemented where  $N = (4 - ICC_IDR0_EL1.PRI_BITS)$ . Unimplemented bits are RES0.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Accessing ICC\_PCR\_EL3

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PCR\_EL3

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b1100 | 0b1000 | 0b001 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    UNDEFINED;
elsif PSTATE.EL == EL2 then
    UNDEFINED;
elsif PSTATE.EL == EL3 then
    X[t, 64] = ICC_PCR_EL3;
```

# MSR ICC\_PCR\_EL3, <Xt>

| op0                | op1      | CRn    | CRm op2 |       |
|--------------------|----------|--------|---------|-------|
| 0b11               | 0b110    | 0b1100 | 0b1000  | 0b001 |
|                    |          |        |         |       |
| if PSTATE.EL == EL | 0 then   |        |         |       |
| UNDEFINED;         |          |        |         |       |
| elsif PSTATE.EL == | EL1 then |        |         |       |
| UNDEFINED;         |          |        |         |       |
| elsif PSTATE.EL == | EL2 then |        |         |       |
| UNDEFINED;         |          |        |         |       |
| elsif PSTATE.EL == | EL3 then |        |         |       |
| ICC_PCR_EL3 =      | X[+ 6/1. |        |         |       |

# 9.2.14 ID\_AA64PFR2\_EL1, AArch64 Processor Feature Register 2

The ID\_AA64PFR2\_EL1 characteristics are:

#### Purpose

Provides additional information about implemented PE features in AArch64 state.

#### Configuration

Prior to the introduction of the features described by this register, this register was unnamed and reserved, RES0 from EL1, EL2, and EL3.

#### Attributes

ID\_AA64PFR2\_EL1 is a 64-bit register.

# **Field descriptions**

The ID\_AA64PFR2\_EL1 bit assignments are:



#### Bits [63:36]

Reserved, RESO.

FPMR, bits [35:32]

Bits [31:20]

Reserved, RESO.

UINJ, bits [19:16]

#### GCIE, bits [15:12]

Support for the GICv5 CPU interface extension.

| GCIE   | Meaning                                      |
|--------|----------------------------------------------|
| 0b0000 | GICv5 CPU interface registers not supported. |
| 0b0001 | GICv5 CPU interface registers supported.     |

All other values are reserved.

FEAT\_GCIE implements the functionality identified by the value 0b0001.

# MTEFAR, bits [11:8]

MTESTOREONLY, bits [7:4]

MTEPERM, bits [3:0]

# Accessing ID\_AA64PFR2\_EL1

Accesses to this register use the following encodings in the System register encoding space:

MRS <Xt>, ID\_AA64PFR2\_EL1

| opu opi CRn CR        | m op2     | CRn CRm      | op1   | op0  |
|-----------------------|-----------|--------------|-------|------|
| 0b11 0b000 0b0000 0b0 | 100 0ь010 | 060000 06010 | 0b000 | )b11 |

```
if PSTATE.EL == ELO then
    if IsFeatureImplemented(FEAT_IDST) then
        if EL2Enabled() && HCR_EL2.TGE == '1' then
            AArch64.SystemAccessTrap(EL2, 0x18);
        else
            AArch64.SystemAccessTrap(EL1, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && !FALSE && (IsFeatureImplemented(FEAT_FGT) || !IsZero(
       ← ID_AA64PFR2_EL1) || boolean IMPLEMENTATION_DEFINED "ID_AA64PFR2_EL1
        →trapped by HCR_EL2.TID3") && HCR_EL2.TID3 == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = ID_AA64PFR2_EL1;
elsif PSTATE.EL == EL2 then
    X[t, 64] = ID_AA64PFR2_EL1;
elsif PSTATE.EL == EL3 then
    X[t, 64] = ID_AA64PFR2_EL1;
```

# 9.3 Virtual CPU interface registers

- I\_TRMKL
   Each ICC\_ system register that is accessible at EL1 and higher and whose state is specific to the Virtual Interrupt

   Domain, has a corresponding virtual ICV\_ register. The ICV\_ registers are accessed using the same system register encodings as their ICC\_ counterparts.
- ITBPCJ ICC\_IDR0 does not have an ICV\_ equivalent register.
- ILBWLV
   When Legacy operation is disabled, the field layouts and interpretations of the ICV\_registers are identical to the ICC\_registers. This enables binary compatibility for software between the physical and virtual CPU interfaces.
- I<sub>MCZFN</sub> ICC\_ICSR\_EL1 does not have an ICV\_ equivalent register.
- INMXVC ICC\_IAFFIDR\_EL1 does not have an ICV\_ equivalent register. When virtualization is being used, Arm expects EL2 software to trap EL1 accesses to ICC\_IAFFIDR\_EL1.

# 9.3.1 ICV\_APR\_EL1, Interrupt Controller Virtual Active Priorities Register

The ICV\_APR\_EL1 characteristics are:

#### Purpose

Records active priorities for the Virtual CPU interface.

#### Configuration

AArch64 system register ICV\_APR\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICH\_APR\_EL2[63:0].

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_APR\_EL1 are UNDEFINED.

#### Attributes

ICV\_APR\_EL1 is a 64-bit register.

# **Field descriptions**

The ICV\_APR\_EL1 bit assignments are:



# Bits [63:32]

Reserved, RESO.

#### *P*<*x*>, bits [*x*], for *x* = 31 to 0

Provides access to the active priorities.

| P <x></x> | Meaning             |  |
|-----------|---------------------|--|
| 0b0       | Priority not active |  |
| 0b1       | Priority active     |  |

Fields in this register are indexed using the 5-bit priority as an unsigned integer, P[Priority].

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

• Access is **RES0** if all of the following are true:

- x MOD 2 == 1

- ICC\_IDR0\_EL1.PRI\_BITS == 0b011

• Otherwise, access to this field is **RW** 

# Accessing ICV\_APR\_EL1

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, ICC\_APR\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| )b11 | 0b001 | 0b1100 | 0b0000 | 0b000 |

| if PSTATE.EL == ELO then<br>UNDEFINED;                                          |
|---------------------------------------------------------------------------------|
| elsif PSTATE.EL == EL1 then                                                     |
| if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then           |
| UNDEFINED;                                                                      |
| elsif EL2Enabled() && ICH HFGRTR EL2.ICC APR EL1 == '0' then                    |
| AArch64.SystemAccessTrap(EL2, 0x18);                                            |
| elsif EL2Enabled() && HCR_EL2.IMO == '1' then                                   |
| X[t, 64] = ICV_APR_EL1;                                                         |
| elsif HaveEL(EL3) then                                                          |
| if SCR_EL3.NS == '0' then                                                       |
| $X[t, 64] = ICC_APR_EL1_S;$                                                     |
| elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==     |
| $\rightarrow$ '1' then                                                          |
| X[t, 64] = ICC_APR_EL1_RL;                                                      |
| elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then                              |
| X[t, 64] = ICC_APR_EL1_NS;                                                      |
| else                                                                            |
| UNDEFINED;                                                                      |
| else                                                                            |
| $X[t, 64] = ICC_APR_EL1;$                                                       |
| elsif PSTATE.EL == EL2 then                                                     |
| if HaveEL(EL3) then                                                             |
| if SCR_EL3.NS == '0' then                                                       |
| $X[t, 64] = ICC APR EL1_S;$                                                     |
| elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==     |
| <pre></pre>                                                                     |
| $X[t, 64] = ICC\_APR\_EL1\_RL;$                                                 |
| elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then                              |
| $X[t, 64] = ICC_{APR} EL1_{NS};$                                                |
| else                                                                            |
| UNDEFINED;                                                                      |
| else                                                                            |
| $X[t, 64] = ICC_APR_EL1;$                                                       |
| elsif PSTATE.EL == EL3 then                                                     |
| if SCR_EL3.NS == '0' then                                                       |
|                                                                                 |
| elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1' |
| ↔ then                                                                          |
| $X[t, 64] = ICC_APR_EL1_RL;$                                                    |
| elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then                              |
| X[t, 64] = ICC_APR_EL1_NS;                                                      |
| else                                                                            |
| UNDEFINED;                                                                      |

MSR ICC\_APR\_EL1, <Xt>

| орО  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b000 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_APR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV\_APR\_EL1 = X[t, 64];
    elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            ICC_APR_EL1_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            ICC\_APR\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            ICC\_APR\_EL1\_NS = X[t, 64];
        else
            UNDEFINED;
    else
        ICC\_APR\_EL1 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
             ICC\_APR\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            ICC\_APR\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            ICC\_APR\_EL1\_NS = X[t, 64];
        else
            UNDEFINED;
    else
        ICC\_APR\_EL1 = X[t, 64];
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        ICC\_APR\_EL1\_S = X[t, 64];
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \hookrightarrow then
        ICC\_APR\_EL1\_RL = X[t, 64];
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        ICC\_APR\_EL1\_NS = X[t, 64];
    else
        UNDEFINED;
```

# 9.3.2 ICV\_CR0\_EL1, Interrupt Controller EL1 Virtual Control Register

The ICV\_CR0\_EL1 characteristics are:

#### Purpose

Controls behavior of the CPU interface in the Virtual Interrupt Domain.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_CR0\_EL1 are UNDEFINED.

#### Attributes

ICV\_CR0\_EL1 is a 64-bit register.

# **Field descriptions**

The ICV\_CR0\_EL1 bit assignments are:



#### Bits [63:39]

Reserved, RESO.

#### Bit [38]

Reserved, RESO.

#### Bits [37:32]

Reserved, RESO.

#### Bits [31:1]

Reserved, RESO.

# EN, bit [0]

Enable interrupts for the Interrupt Domain.

When this field is 0, there is no HPPI of Sufficient priority for the Interrupt Domain.

| EN  | Meaning   |  |
|-----|-----------|--|
| 0b0 | Disabled. |  |
| 0b1 | Enabled.  |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Accessing ICV\_CR0\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_CR0\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b001 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED:
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_CR0_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV\_CR0\_EL1;
    elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            X[t, 64] = ICC\_CR0\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            X[t, 64] = ICC\_CR0\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            X[t, 64] = ICC\_CR0\_EL1\_NS;
        else
            UNDEFINED;
    else
        X[t, 64] = ICC\_CR0\_EL1;
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            X[t, 64] = ICC\_CR0\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            X[t, 64] = ICC\_CR0\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            X[t, 64] = ICC\_CR0\_EL1\_NS;
        else
            UNDEFINED;
    else
        X[t, 64] = ICC\_CR0\_EL1;
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        X[t, 64] = ICC\_CR0\_EL1\_S;
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \hookrightarrow then
        X[t, 64] = ICC\_CR0\_EL1\_RL;
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        X[t, 64] = ICC\_CR0\_EL1\_NS;
    else
        UNDEFINED;
```

MSR ICC\_CR0\_EL1, <Xt>

#### Chapter 9. System registers 9.3. Virtual CPU interface registers

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b001 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_CR0_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV\_CR0\_EL1 = X[t, 64];
    elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            ICC\_CR0\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
             ICC\_CR0\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
             ICC\_CR0\_EL1\_NS = X[t, 64];
        else
            UNDEFINED;
    else
        ICC\_CR0\_EL1 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            ICC\_CR0\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            ICC\_CR0\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            ICC\_CR0\_EL1\_NS = X[t, 64];
        else
            UNDEFINED;
    else
        ICC\_CR0\_EL1 = X[t, 64];
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        ICC\_CR0\_EL1\_S = X[t, 64];
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \hookrightarrow then
        ICC\_CR0\_EL1\_RL = X[t, 64];
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        ICC\_CR0\_EL1\_NS = X[t, 64];
    else
        UNDEFINED;
```

# 9.3.3 ICV\_HAPR\_EL1, Interrupt Controller Virtual Highest Active Priority Register

The ICV\_HAPR\_EL1 characteristics are:

#### Purpose

Reports the running priority of the Virtual Interrupt Domain.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_HAPR\_EL1 are UNDEFINED.

#### Attributes

ICV\_HAPR\_EL1 is a 64-bit register.

#### **Field descriptions**

The ICV\_HAPR\_EL1 bit assignments are:

| 63 |      | 3                | 32 |
|----|------|------------------|----|
|    | RES0 |                  |    |
| 31 | 8    | <sub>1</sub> 7 ( |    |
|    | RES0 | PRIORITY         | -  |

#### Bits [63:8]

Reserved, RESO.

#### PRIORITY, bits [7:0]

The running priority for the Virtual Interrupt Domain.

If there are no active priorities on the CPU interface in the applicable Interrupt Domain, or all active priorities have undergone a priority drop, the value returned is the Idle priority.

# Accessing ICV\_HAPR\_EL1

Read-only

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_HAPR\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b011 |

```
if PSTATE.EL == EL0 then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
   if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
   elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_HAPR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
   elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_HAPR_EL1;
   else
        X[t, 64] = ICC_HAPR_EL1;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_HAPR_EL1;
```

#### Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

## Chapter 9. System registers 9.3. Virtual CPU interface registers

elsif PSTATE.EL == EL3 then
 X[t, 64] = ICC\_HAPR\_EL1;

# 9.3.4 ICV\_HPPIR\_EL1, Interrupt Controller Virtual Highest Priority Pending Interrupt Register

The ICV\_HPPIR\_EL1 characteristics are:

#### Purpose

Reports the HPPI for the Virtual Interrupt Domain.

#### Configuration

AArch64 system register ICV\_HPPIR\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICH\_HPPIR\_EL2[63:0].

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_HPPIR\_EL1 are UNDEFINED.

#### Attributes

ICV\_HPPIR\_EL1 is a 64-bit register.

# **Field descriptions**

The ICV\_HPPIR\_EL1 bit assignments are:



## Bits [63:33]

Reserved, RESO.

#### HPPIV, bit [32]

HPPI valid.

There is an HPPI with Sufficient priority for the Interrupt Domain.

| HPPIV | Meaning                                                                      |
|-------|------------------------------------------------------------------------------|
| 0b0   | Invalid: There is no HPPI with Sufficient priority for the Interrupt Domain. |
| 0b1   | VALID: There is an HPPI with Sufficient priority for the Interrupt Domain.   |

If ICV\_HPPIR\_EL1.HPPIV is 1, ID and TYPE together form the INTID of the HPPI for the Interrupt Domain. *TYPE, bits [31:29]* 

#### The encoding of this field depends on the value of HPPIV as described below:

- If ICV\_HPPIR\_EL1.HPPIV is 0, TYPE is RES0.
- If ICV\_HPPIR\_EL1.HPPIV is 1, TYPE specifies the Type of the interrupt.

| ТҮРЕ  | Meaning |
|-------|---------|
| 0b001 | PPI     |

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Bits [28:24]

Reserved, RESO.

## ID, bits [23:0]

The encoding of this field depends on the value of HPPIV as described below:

- If ICV\_HPPIR\_EL1.HPPIV is 0, ID is RES0.
- If ICV\_HPPIR\_EL1.HPPIV is 1, ID specifies the interrupt ID.

# Accessing ICV\_HPPIR\_EL1

#### Read-only

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_HPPIR\_EL1

| орО  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b011 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_HPPIR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_HPPIR_EL1;
else
        X[t, 64] = ICC_HPPIR_EL1;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_HPPIR_EL1;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_HPPIR_EL1;
```

# 9.3.5 ICV\_PCR\_EL1, Interrupt Controller Virtual Interrupt Priority Control Register

The ICV\_PCR\_EL1 characteristics are:

#### Purpose

Reports the Virtual priority mask for the Virtual Interrupt Domain.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_PCR\_EL1 are UNDEFINED.

#### Attributes

ICV\_PCR\_EL1 is a 64-bit register.

#### Field descriptions

The ICV\_PCR\_EL1 bit assignments are:

|      | 32       |            |
|------|----------|------------|
| RESO |          |            |
| 5    | 4 0      | _          |
| RES0 | PRIORITY |            |
|      | 5        | RES0 5 4 0 |

#### Bits [63:5]

Reserved, RESO.

#### PRIORITY, bits [4:0]

The priority mask for the Interrupt Domain.

When fewer than 5 bits of priority is implemented, only bits [4:N] are implemented where  $N = (4 - ICC_IDR0_EL1.PRI_BITS)$ . Unimplemented bits are RES0.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## Accessing ICV\_PCR\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PCR\_EL1

| ор0  | op1   | CRn    | CRm    | op2   |  |
|------|-------|--------|--------|-------|--|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b010 |  |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PCR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PCR_EL1;
elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
```

#### Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

```
X[t, 64] = ICC\_PCR\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            X[t, 64] = ICC\_PCR\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
             X[t, 64] = ICC\_PCR\_EL1\_NS;
        else
             UNDEFINED;
    else
        X[t, 64] = ICC\_PCR\_EL1;
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
             X[t, 64] = ICC\_PCR\_EL1\_S;
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
             X[t, 64] = ICC\_PCR\_EL1\_RL;
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
             X[t, 64] = ICC\_PCR\_EL1\_NS;
        else
             UNDEFINED;
    else
        X[t, 64] = ICC\_PCR\_EL1;
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        X[t, 64] = ICC\_PCR\_EL1\_S;
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \hookrightarrow then
        X[t, 64] = ICC\_PCR\_EL1\_RL;
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        X[t, 64] = ICC\_PCR\_EL1\_NS;
    else
        UNDEFINED;
```

#### MSR ICC\_PCR\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b001 | 0b1100 | 0b0000 | 0b010 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PCR_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV\_PCR\_EL1 = X[t, 64];
    elsif HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            ICC\_PCR\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
            ICC\_PCR\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
            ICC\_PCR\_EL1\_NS = X[t, 64];
```

```
else
            UNDEFINED;
    else
        ICC\_PCR\_EL1 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if HaveEL(EL3) then
        if SCR_EL3.NS == '0' then
            ICC\_PCR\_EL1\_S = X[t, 64];
        elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS ==
            \hookrightarrow '1' then
             ICC\_PCR\_EL1\_RL = X[t, 64];
        elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
             ICC\_PCR\_EL1\_NS = X[t, 64];
        else
             UNDEFINED;
    else
        ICC\_PCR\_EL1 = X[t, 64];
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        ICC\_PCR\_EL1\_S = X[t, 64];
    elsif IsFeatureImplemented(FEAT_RME) && SCR_EL3.NSE == '1' && SCR_EL3.NS == '1'
        \hookrightarrow then
        ICC\_PCR\_EL1\_RL = X[t, 64];
    elsif SCR_EL3.NSE == '0' && SCR_EL3.NS == '1' then
        ICC\_PCR\_EL1\_NS = X[t, 64];
    else
        UNDEFINED;
```

Chapter 9. System registers 9.4. PPI registers

# 9.4 PPI registers

Configuration and state of PPIs.

# 9.4.1 ICC\_PPI\_CACTIVER<n>\_EL1, Interrupt Controller Physical PPI Clear Active Registers, n = 0 - 1

The ICC\_PPI\_CACTIVER<n>\_EL1 characteristics are:

#### Purpose

Clear Active state for physical PPIs.

#### Configuration

AArch64 system register ICC\_PPI\_CACTIVER<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICC\_PPI\_SACTIVER<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_PPI\_CACTIVER<n>\_EL1 are UNDEFINED.

#### Attributes

ICC\_PPI\_CACTIVER<n>\_EL1 is a 64-bit register.

# **Field descriptions**

The ICC\_PPI\_CACTIVER<n>\_EL1 bit assignments are:



# ACTIVE<x>, bits [x], for x = 63 to 0

Configures whether PPIs are Active.

Reads return the Active state of the INTID.

Writing 1 clears the Active state of the INTID. Writing 0 has no effect.

| ACTIVE <x></x> | Meaning  |
|----------------|----------|
| 0b0            | Inactive |
| 0b1            | Active   |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Access is RAZ/WI if all of the following are true:
   !IsPPIAssignedToCurrentDomain((n \* 64) + x)
  - PSTATE.EL IN {EL2, EL1}
- Otherwise, access to this field is W1C

#### Accessing ICC\_PPI\_CACTIVER<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_CACTIVER<n>\_EL1

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b00:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_ACTIVERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_CACTIVER_EL1[n];
    else
        X[t, 64] = ICC_PPI_CACTIVER_EL1[n];
    elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_CACTIVER_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_CACTIVER_EL1[n];
```

MSR ICC\_PPI\_CACTIVER<n>\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b00:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
    UNDEFINED;
```

# Chapter 9. System registers 9.4. PPI registers

```
elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_ACTIVERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV_PPI_CACTIVER_EL1[n] = X[t, 64];
    else
        ICC_PPI_CACTIVER_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL2 then
        ICC_PPI_CACTIVER_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICC_PPI_CACTIVER_EL1[n] = X[t, 64];
```

# 9.4.2 ICC\_PPI\_CPENDR<n>\_EL1, Interrupt Controller Physical PPI Clear Pending State Registers, n = 0 - 1

The ICC\_PPI\_CPENDR<n>\_EL1 characteristics are:

#### Purpose

Clear pending state for physical PPIs.

#### Configuration

AArch64 system register ICC\_PPI\_CPENDR<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICC\_PPI\_SPENDR<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_PPI\_CPENDR<n>\_EL1 are UNDEFINED.

#### Attributes

ICC\_PPI\_CPENDR<n>\_EL1 is a 64-bit register.

# **Field descriptions**

The ICC\_PPI\_CPENDR<n>\_EL1 bit assignments are:



# *PEND<x>, bits [x], for x = 63 to 0*

Controls the Pending state of PPIs.

Reads return the current state of the INTIDs.

Writing 1 to a field clears the Pending state of the corresponding INTID. Writing 0 has no effect.

| PEND <x></x> | Meaning     |
|--------------|-------------|
| 0d0          | Not pending |
| 0b1          | Pending     |

The reset behavior of this field is:

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

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Access is RAZ/WI if all of the following are true:
   IsPPIAssignedToCurrentDomain((n \* 64) + x)
  - PSTATE.EL IN {EL2, EL1}
- When ICC\_PPI\_HMR<n>\_EL1.HM<x> == 1, access to this field is **RO**
- Otherwise, access to this field is W1C

#### Accessing ICC\_PPI\_CPENDR<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_CPENDR<n>\_EL1

| орО  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b10:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_PENDRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_CPENDR_EL1[n];
    else
        X[t, 64] = ICC_PPI_CPENDR_EL1[n];
    elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_CPENDR_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_CPENDR_EL1[n];
```

MSR ICC\_PPI\_CPENDR<n>\_EL1, <Xt>

| ор0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b10:n[0] |

```
if PSTATE.EL == ELO then
```

```
UNDEFINED;
```

```
elsif PSTATE.EL == EL1 then
```

```
if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
```

# Chapter 9. System registers 9.4. PPI registers

```
UNDEFINED;
elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_PENDRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV_PPI_CPENDR_EL1[n] = X[t, 64];
else
        ICC_PPI_CPENDR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL2 then
        ICC_PPI_CPENDR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICC_PPI_CPENDR_EL1[n] = X[t, 64];
```

# 9.4.3 ICC\_PPI\_DOMAINR<n>\_EL3, Interrupt Controller PPI Domain Registers, n = 0 - 3

The ICC\_PPI\_DOMAINR<n>\_EL3 characteristics are:

#### Purpose

Controls which Interrupt Domain PPI sources are assigned to.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL3 is implemented. Otherwise, direct accesses to ICC\_PPI\_DOMAINR<n>\_EL3 are UNDEFINED.

#### Attributes

ICC\_PPI\_DOMAINR<n>\_EL3 is a 64-bit register.

#### **Field descriptions**

The ICC\_PPI\_DOMAINR<n>\_EL3 bit assignments are:



#### DOM < x >, bits [2x+1:2x], for x = 31 to 0

Controls the Physical Interrupt Domain that a PPI is assigned to.

Encodings for unimplemented Interrupt Domains are reserved.

| DOM <x></x> | Meaning    |
|-------------|------------|
| 0000        | Secure     |
| 0b01        | Non-secure |
| 0b10        | EL3        |
| 0b11        | Realm      |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 32) + x)
- Otherwise, access to this field is **RW**

# Accessing ICC\_PPI\_DOMAINR<n>\_EL3

Accesses to this register use the following encodings in the System register encoding space:

MRS <Xt>, ICC\_PPI\_DOMAINR<n>\_EL3

| op0  | op1   | CRn    | CRm    | op2        |
|------|-------|--------|--------|------------|
| 0b11 | 0b110 | 0b1100 | 0b1000 | 0b1:n[1:0] |

| if PSTATE.EL == ELO then                      |
|-----------------------------------------------|
| UNDEFINED;                                    |
| elsif PSTATE.EL == EL1 then                   |
| UNDEFINED;                                    |
| elsif PSTATE.EL == EL2 then                   |
| UNDEFINED;                                    |
| elsif PSTATE.EL == EL3 then                   |
| <pre>X[t, 64] = ICC_PPI_DOMAINR_EL3[n];</pre> |

## MSR ICC\_PPI\_DOMAINR<n>\_EL3, <Xt>

| орО  | op1   | CRn    | CRm    | op2        |
|------|-------|--------|--------|------------|
| 0b11 | 0b110 | 0b1100 | 0b1000 | 0b1:n[1:0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    UNDEFINED;
elsif PSTATE.EL == EL2 then
    UNDEFINED;
elsif PSTATE.EL == EL3 then
    ICC_PPI_DOMAINR_EL3[n] = X[t, 64];
```

# 9.4.4 ICC\_PPI\_ENABLER<n>\_EL1, Interrupt Controller Physical PPI Enable Registers, n = 0 - 1

The ICC\_PPI\_ENABLER<n>\_EL1 characteristics are:

#### Purpose

Access to Enable state for physical PPIs.

#### Configuration

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_PPI\_ENABLER<n>\_EL1 are UNDEFINED.

#### Attributes

ICC\_PPI\_ENABLER<n>\_EL1 is a 64-bit register.

## **Field descriptions**

The ICC\_PPI\_ENABLER<n>\_EL1 bit assignments are:



#### EN<x>, bits [x], for x = 63 to 0

Configures whether PPIs are enabled.

Reads return the current state of the INTID.

| EN <x></x> | Meaning  |  |
|------------|----------|--|
| 0b0        | Disabled |  |
| 0b1        | Enabled  |  |

Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Access is **RAZ/WI** if all of the following are true:
  - !IsPPIAssignedToCurrentDomain((n \* 64) + x)
     PSTATE.EL IN {EL2, EL1}
- Otherwise, access to this field is **RW**

# Accessing ICC\_PPI\_ENABLER<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_ENABLER<n>\_EL1

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b11:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_ENABLERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_ENABLER_EL1[n];
    else
        X[t, 64] = ICC_PPI_ENABLER_EL1[n];
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_ENABLER_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_ENABLER_EL1[n];
```

#### MSR ICC\_PPI\_ENABLER<n>\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b11:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_ENABLERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV_PPI_ENABLER_EL1[n] = X[t, 64];
    else
        ICC_PPI_ENABLER_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL2 then
```

#### Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

Chapter 9. System registers 9.4. PPI registers

# 9.4.5 ICC\_PPI\_HMR<n>\_EL1, Interrupt Controller Physical PPI Handling mode Registers, n = 0 - 1

The ICC\_PPI\_HMR<n>\_EL1 characteristics are:

#### Purpose

Report whether physical PPIs are Edge or Level.

#### Configuration

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_PPI\_HMR<n>\_EL1 are UNDEFINED.

#### Attributes

ICC\_PPI\_HMR<n>\_EL1 is a 64-bit register.

## **Field descriptions**

The ICC\_PPI\_HMR<n>\_EL1 bit assignments are:



#### HM<x>, bits [x], for x = 63 to 0

The PPI Handling mode.

| HM <x></x> | Meaning |  |
|------------|---------|--|
| 0b0        | Edge    |  |
| 0b1        | Level   |  |

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Otherwise, access to this field is **RO**

# Accessing ICC\_PPI\_HMR<n>\_EL1

Read-only

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_HMR<n>\_EL1

| ор0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b00:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_HMRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_HMR_EL1[n];
    else
        X[t, 64] = ICC_PPI_HMR_EL1[n];
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_HMR_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_HMR_EL1[n];
```

# 9.4.6 ICC\_PPI\_PRIORITYR<n>\_EL1, Interrupt Controller Physical PPI Priority Registers, n = 0 - 15

The ICC\_PPI\_PRIORITYR<n>\_EL1 characteristics are:

#### Purpose

Configures the priority of physical PPIs.

#### Configuration

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_PPI\_PRIORITYR<n>\_EL1 are UNDEFINED.

#### Attributes

ICC\_PPI\_PRIORITYR<n>\_EL1 is a 64-bit register.

#### **Field descriptions**

The ICC\_PPI\_PRIORITYR<n>\_EL1 bit assignments are:

| 63 6 | 1   60 | 56    | 55 5 | 3   52 | 48 47 | 45   | 44      | 40 | 39   | 37 <sub>I</sub> | 36        | 32 |
|------|--------|-------|------|--------|-------|------|---------|----|------|-----------------|-----------|----|
| RES0 | PRIO   | RITY7 | RES0 | PRIORI | TY6 F | RES0 | PRIORIT | Y5 | RESO | )               | PRIORITY4 |    |
| 31 2 | 9 28   | 24    | 23 2 | 21 20  | 16 15 | 13   | 12      | 8  | 7    | 5               | 4         | 0  |
|      |        |       |      |        |       |      |         |    |      |                 |           |    |

#### Bits [63:61, 55:53, 47:45, 39:37, 31:29, 23:21, 15:13, 7:5]

Reserved, RESO.

# *PRIORITY*<*x*>, bits [60:56, 52:48, 44:40, 36:32, 28:24, 20:16, 12:8, 4:0], for *x* = 7 to 0, where each field is 5 bits wide

Configures the priority of the corresponding PPI.

Only the upper N bits of each 5-bit Priority field are implemented where  $N = (ICC_IDR0_EL1.PRI_BITS + 1)$ . Unimplemented bits are RES0.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 8) + x)
- Access is **RAZ/WI** if all of the following are true:
  - !IsPPIAssignedToCurrentDomain((n \* 8) + x)
  - PSTATE.EL IN {EL2, EL1}
- Otherwise, access to this field is **RW**

# Accessing ICC\_PPI\_PRIORITYR<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_PRIORITYR<n>\_EL1

| ор0  | op1   | CRn    | CRm        | op2    |
|------|-------|--------|------------|--------|
| 0b11 | 0b000 | 0b1100 | 0b111:n[3] | n[2:0] |

# Chapter 9. System registers 9.4. PPI registers

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_PRIORITYRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_PRIORITYR_EL1[n];
    else
        X[t, 64] = ICC_PPI_PRIORITYR_EL1[n];
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_PRIORITYR_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_PRIORITYR_EL1[n];
```

MSR ICC\_PPI\_PRIORITYR<n>\_EL1, <Xt>

| op0  | op1   | CRn    | CRm        | op2    |
|------|-------|--------|------------|--------|
| 0b11 | 0b000 | 0b1100 | 0b111:n[3] | n[2:0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_PRIORITYRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV_PPI_PRIORITYR_EL1[n] = X[t, 64];
    else
        ICC_PPI_PRIORITYR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL2 then
        ICC_PPI_PRIORITYR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICC_PPI_PRIORITYR_EL1[n] = X[t, 64];
```

# 9.4.7 ICC\_PPI\_SACTIVER<n>\_EL1, Interrupt Controller Physical PPI Set Active Registers, n = 0 - 1

The ICC\_PPI\_SACTIVER<n>\_EL1 characteristics are:

#### Purpose

Set Active state for physical PPIs.

#### Configuration

AArch64 system register ICC\_PPI\_SACTIVER<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICC\_PPI\_CACTIVER<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_PPI\_SACTIVER<n>\_EL1 are UNDEFINED.

#### Attributes

ICC\_PPI\_SACTIVER<n>\_EL1 is a 64-bit register.

# **Field descriptions**

The ICC\_PPI\_SACTIVER<n>\_EL1 bit assignments are:



#### ACTIVE<x>, bits [x], for x = 63 to 0

Configures whether PPIs are Active.

Reads return the Active state of the INTID.

Writing 1 sets the Active state of the INTID. Writing 0 has no effect.

| ACTIVE <x></x> | Meaning  |
|----------------|----------|
| 0b0            | Inactive |
| 0b1            | Active   |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Access is RAZ/WI if all of the following are true:
   !IsPPIAssignedToCurrentDomain((n \* 64) + x)
  - PSTATE.EL IN {EL2, EL1}
- Otherwise, access to this field is W1S

#### Accessing ICC\_PPI\_SACTIVER<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_SACTIVER<n>\_EL1

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b01:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_ACTIVERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_SACTIVER_EL1[n];
    else
        X[t, 64] = ICC_PPI_SACTIVER_EL1[n];
    elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_SACTIVER_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_SACTIVER_EL1[n];
```

#### MSR ICC\_PPI\_SACTIVER<n>\_EL1, <Xt>

| орО  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b01:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
```

# Chapter 9. System registers 9.4. PPI registers

```
elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_ACTIVERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV_PPI_SACTIVER_EL1[n] = X[t, 64];
    else
        ICC_PPI_SACTIVER_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL2 then
        ICC_PPI_SACTIVER_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICC_PPI_SACTIVER_EL1[n] = X[t, 64];
```

# 9.4.8 ICC\_PPI\_SPENDR<n>\_EL1, Interrupt Controller Physical PPI Set Pending State Registers, n = 0 - 1

The ICC\_PPI\_SPENDR<n>\_EL1 characteristics are:

#### Purpose

Set pending state for Physical PPIs.

#### Configuration

AArch64 system register ICC\_PPI\_SPENDR<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICC\_PPI\_CPENDR<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented. Otherwise, direct accesses to ICC\_PPI\_SPENDR<n>\_EL1 are UNDEFINED.

#### Attributes

ICC\_PPI\_SPENDR<n>\_EL1 is a 64-bit register.

# **Field descriptions**

The ICC\_PPI\_SPENDR<n>\_EL1 bit assignments are:



# *PEND<x>, bits [x], for x = 63 to 0*

Controls the Pending state of PPIs.

Reads return the current state of the INTIDs.

Writing 1 to a field sets the Pending state of the corresponding INTID. Writing 0 has no effect.

| PEND <x></x> | Meaning     |
|--------------|-------------|
| 0d0          | Not pending |
| 0b1          | Pending     |

The reset behavior of this field is:

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

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Access is RAZ/WI if all of the following are true:
   !IsPPIAssignedToCurrentDomain((n \* 64) + x)
  - PSTATE.EL IN {EL2, EL1}
- When ICC\_PPI\_HMR<n>\_EL1.HM<x> == 1, access to this field is **RO**
- Otherwise, access to this field is W1S

#### Accessing ICC\_PPI\_SPENDR<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_SPENDR<n>\_EL1

| орО  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b11:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_PENDRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_SPENDR_EL1[n];
    else
        X[t, 64] = ICC_PPI_SPENDR_EL1[n];
    elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_SPENDR_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_SPENDR_EL1[n];
```

MSR ICC\_PPI\_SPENDR<n>\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b11:n[0] |

```
if PSTATE.EL == ELO then
```

```
UNDEFINED;
```

```
elsif PSTATE.EL == EL1 then
```

```
if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
```

# Chapter 9. System registers 9.4. PPI registers

```
UNDEFINED;
elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_PENDRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV_PPI_SPENDR_EL1[n] = X[t, 64];
else
        ICC_PPI_SPENDR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL2 then
        ICC_PPI_SPENDR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICC_PPI_SPENDR_EL1[n] = X[t, 64];
```

Chapter 9. System registers 9.5. Virtual PPI registers

# 9.5 Virtual PPI registers

 I\_QCYQL
 Each ICC\_PPI\_ system register which is accessible at EL1 has a corresponding virtual ICV\_PPI\_ register. The ICV\_PPI\_ registers are accessed using the same system register encodings as their ICC\_PPI\_ counterparts.

 Configuration and state of virtual PPIs.

ARM-AES-0070 00bet0

# 9.5.1 ICV\_PPI\_CACTIVER<n>\_EL1, Interrupt Controller Virtual PPI Clear Active Registers, n = 0 - 1

The ICV\_PPI\_CACTIVER<n>\_EL1 characteristics are:

#### Purpose

Clear Active state for virtual PPIs.

#### Configuration

AArch64 system register ICV\_PPI\_CACTIVER<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICH\_PPI\_ACTIVER<n>\_EL2[63:0].

AArch64 system register ICV\_PPI\_CACTIVER<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_SACTIVER<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_PPI\_CACTIVER<n>\_EL1 are UNDEFINED.

#### Attributes

ICV\_PPI\_CACTIVER<n>\_EL1 is a 64-bit register.

### **Field descriptions**

The ICV\_PPI\_CACTIVER<n>\_EL1 bit assignments are:



#### *ACTIVE<x>, bits* [*x*]*, for x =* 63 *to* 0

Configures whether PPIs are Active.

Reads return the Active state of the INTID.

Writing 1 clears the Active state of the INTID. Writing 0 has no effect.

| ACTIVE <x></x> | Meaning  |
|----------------|----------|
| 0b0            | Inactive |
| 0b1            | Active   |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Otherwise, access to this field is W1C

# Accessing ICV\_PPI\_CACTIVER<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_CACTIVER<n>\_EL1

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b00:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_ACTIVERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_CACTIVER_EL1[n];
    else
        X[t, 64] = ICC_PPI_CACTIVER_EL1[n];
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_CACTIVER_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_CACTIVER_EL1[n];
```

#### MSR ICC\_PPI\_CACTIVER<n>\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b00:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_ACTIVERn_EL1 == '0' then
```

# 9.5.2 ICV\_PPI\_CPENDR<n>\_EL1, Interrupt Controller Virtual PPI Clear Pending State Registers, n = 0 - 1

The ICV\_PPI\_CPENDR<n>\_EL1 characteristics are:

#### Purpose

Clear pending state for virtual PPIs.

#### Configuration

AArch64 system register ICV\_PPI\_CPENDR<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICH\_PPI\_PENDR<n>\_EL2[63:0].

AArch64 system register ICV\_PPI\_CPENDR<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_SPENDR<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_PPI\_CPENDR<n>\_EL1 are UNDEFINED.

#### Attributes

ICV\_PPI\_CPENDR<n>\_EL1 is a 64-bit register.

# **Field descriptions**

The ICV\_PPI\_CPENDR<n>\_EL1 bit assignments are:



#### PEND < x >, bits [x], for x = 63 to 0

Controls the Pending state of PPIs.

Reads return the current state of the INTIDs.

| PEND <x></x> | Meaning     |  |
|--------------|-------------|--|
| 060          | Not pending |  |
| 0b1          | Pending     |  |

Writing 1 to a field clears the Pending state of the corresponding INTID. Writing 0 has no effect.

When the Pending state of a physical PPI is directly injected to the Pending state of virtual PPI <x>, all of the following are true:

- Reads of Pend<x> return the value of the field corresponding to the physical PPI in ICC\_PPI\_CPENDR<n>\_EL1.
- Writes to Pend<x> have the same effect as writes to the field corresponding to the physical PPI in ICC\_PPI\_CPENDR<n>\_EL1.

Otherwise, all of the following are true:

- Reads of Pend<x> return the value of ICH\_PPI\_PENDR<n>\_EL2.Pend<x>.
- Writes to Pend<x> update the value of ICH\_PPI\_PENDR<n>\_EL2.Pend<x>.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- When ICV\_PPI\_HMR<n>\_EL1.HM<x> == 1, access to this field is **RO**
- Otherwise, access to this field is W1C

# Accessing ICV\_PPI\_CPENDR<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_CPENDR<n>\_EL1

| орО  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b10:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_PENDRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_CPENDR_EL1[n];
else
        X[t, 64] = ICC_PPI_CPENDR_EL1[n];
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_CPENDR_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_CPENDR_EL1[n];
```

MSR ICC\_PPI\_CPENDR<n>\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b10:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_PENDRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV_PPI_CPENDR_EL1[n] = X[t, 64];
    else
        ICC_PPI_CPENDR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL2 then
        ICC_PPI_CPENDR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICC_PPI_CPENDR_EL1[n] = X[t, 64];
```

# 9.5.3 ICV\_PPI\_ENABLER<n>\_EL1, Interrupt Controller Virtual PPI Clear Enable Registers, n = 0 - 1

The ICV\_PPI\_ENABLER<n>\_EL1 characteristics are:

#### Purpose

Access to Enabled state for virtual PPIs.

#### Configuration

AArch64 system register ICV\_PPI\_ENABLER<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICH\_PPI\_ENABLER<n>\_EL2[63:0].

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_PPI\_ENABLER<n>\_EL1 are UNDEFINED.

#### Attributes

ICV\_PPI\_ENABLER<n>\_EL1 is a 64-bit register.

#### **Field descriptions**

The ICV\_PPI\_ENABLER<n>\_EL1 bit assignments are:



#### *EN<x>, bits* [*x*]*, for x* = 63 *to* 0

Configures whether PPIs are enabled.

Reads return the current state of the INTID.

| EN <x></x> | Meaning  |  |
|------------|----------|--|
| 0b0        | Disabled |  |
| 0b1        | Enabled  |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Otherwise, access to this field is **RW**

### Accessing ICV\_PPI\_ENABLER<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_ENABLER<n>\_EL1

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b11:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_ENABLERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_ENABLER_EL1[n];
    else
        X[t, 64] = ICC_PPI_ENABLER_EL1[n];
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_ENABLER_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_ENABLER_EL1[n];
```

#### MSR ICC\_PPI\_ENABLER<n>\_EL1, <Xt>

| ор0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b11:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_ENABLERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
elsif EL2Enabled() && HCR_EL2.IMO == '1' then
```

#### Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

Chapter 9. System registers 9.5. Virtual PPI registers

# 9.5.4 ICV\_PPI\_HMR<n>\_EL1, Interrupt Controller Virtual PPI Handling mode Registers, n = 0 - 1

The ICV\_PPI\_HMR<n>\_EL1 characteristics are:

#### Purpose

Report whether virtual PPIs are Edge or Level.

#### Configuration

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_PPI\_HMR<n>\_EL1 are UNDEFINED.

#### Attributes

ICV\_PPI\_HMR<n>\_EL1 is a 64-bit register.

### **Field descriptions**

The ICV\_PPI\_HMR<n>\_EL1 bit assignments are:



#### HM<x>, bits [x], for x = 63 to 0

The PPI Handling mode.

| HM <x></x> | Meaning |  |
|------------|---------|--|
| 0b0        | Edge    |  |
| 0b1        | Level   |  |

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Otherwise, access to this field is **RO**

# Accessing ICV\_PPI\_HMR<n>\_EL1

Read-only

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_HMR<n>\_EL1

| ор0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1010 | 0b00:n[0] |

# 9.5.5 ICV\_PPI\_PRIORITYR<n>\_EL1, Interrupt Controller Virtual PPI Priority Registers, n = 0 - 15

The ICV\_PPI\_PRIORITYR<n>\_EL1 characteristics are:

#### Purpose

Configures the priority of virtual PPIs.

#### Configuration

AArch64 system register ICV\_PPI\_PRIORITYR<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICH\_PPI\_PRIORITYR<n>\_EL2[63:0].

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_PPI\_PRIORITYR<n>\_EL1 are UNDEFINED.

#### Attributes

ICV\_PPI\_PRIORITYR<n>\_EL1 is a 64-bit register.

# **Field descriptions**

The ICV\_PPI\_PRIORITYR<n>\_EL1 bit assignments are:

|     | 63 61 | 1 60 56   | 55 53 | 52 48     | 47 45 | 44 40     | <sub>1</sub> 39 37 | 36 32     |
|-----|-------|-----------|-------|-----------|-------|-----------|--------------------|-----------|
|     | RES0  | PRIORITY7 | RES0  | PRIORITY6 | RES0  | PRIORITY5 | RES0               | PRIORITY4 |
|     | 31 29 | 28 24     | 23 21 | 20 16     | 15 13 | 12 8      | 7 5                | 4 0       |
| - 1 | RES0  | PRIORITY3 | RES0  | PRIORITY2 | RES0  | PRIORITY1 | RES0               | PRIORITY0 |

#### Bits [63:61, 55:53, 47:45, 39:37, 31:29, 23:21, 15:13, 7:5]

Reserved, RESO.

*PRIORITY*<*x*>, bits [60:56, 52:48, 44:40, 36:32, 28:24, 20:16, 12:8, 4:0], for *x* = 7 to 0, where each field is 5 bits wide

Configures the priority of the corresponding PPI.

Only the upper N bits of each 5-bit Priority field are implemented where  $N = (ICC_IDR0_EL1.PRI_BITS + 1)$ . Unimplemented bits are RES0.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 8) + x)
- Otherwise, access to this field is **RW**

# Accessing ICV\_PPI\_PRIORITYR<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_PRIORITYR<n>\_EL1

| op0  | op1   | CRn    | CRm        | op2    |
|------|-------|--------|------------|--------|
| 0b11 | 0b000 | 0b1100 | 0b111:n[3] | n[2:0] |

# Chapter 9. System registers 9.5. Virtual PPI registers

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_PRIORITYRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_PRIORITYR_EL1[n];
    else
        X[t, 64] = ICC_PPI_PRIORITYR_EL1[n];
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_PRIORITYR_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_PRIORITYR_EL1[n];
```

MSR ICC\_PPI\_PRIORITYR<n>\_EL1, <Xt>

| op0  | op1   | CRn    | CRm        | op2    |  |
|------|-------|--------|------------|--------|--|
| 0b11 | 0b000 | 0b1100 | 0b111:n[3] | n[2:0] |  |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_PRIORITYRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV_PPI_PRIORITYR_EL1[n] = X[t, 64];
    else
        ICC_PPI_PRIORITYR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL2 then
        ICC_PPI_PRIORITYR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICC_PPI_PRIORITYR_EL1[n] = X[t, 64];
```

# 9.5.6 ICV\_PPI\_SACTIVER<n>\_EL1, Interrupt Controller Virtual PPI Set Active Registers, n = 0 - 1

The ICV\_PPI\_SACTIVER<n>\_EL1 characteristics are:

#### Purpose

Set Active state for virtual PPIs.

#### Configuration

AArch64 system register ICV\_PPI\_SACTIVER<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICH\_PPI\_ACTIVER<n>\_EL2[63:0].

AArch64 system register ICV\_PPI\_SACTIVER<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_CACTIVER<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_PPI\_SACTIVER<n>\_EL1 are UNDEFINED.

#### Attributes

ICV\_PPI\_SACTIVER<n>\_EL1 is a 64-bit register.

### **Field descriptions**

The ICV\_PPI\_SACTIVER<n>\_EL1 bit assignments are:



#### *ACTIVE<x>, bits* [*x*]*, for x =* 63 *to* 0

Configures whether PPIs are Active.

Reads return the Active state of the INTID.

Writing 1 sets the Active state of the INTID. Writing 0 has no effect.

| ACTIVE <x></x> | Meaning  |
|----------------|----------|
| 0b0            | Inactive |
| 0b1            | Active   |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Otherwise, access to this field is W1S

# Accessing ICV\_PPI\_SACTIVER<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_SACTIVER<n>\_EL1

| ор0  | op1   | CRn    | CRm    | ор2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b01:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_ACTIVERn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_SACTIVER_EL1[n];
    else
        X[t, 64] = ICC_PPI_SACTIVER_EL1[n];
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_SACTIVER_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_SACTIVER_EL1[n];
```

#### MSR ICC\_PPI\_SACTIVER<n>\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 06000 | 0b1100 | 0b1101 | 0b01:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_ACTIVERn_EL1 == '0' then
```

# 9.5.7 ICV\_PPI\_SPENDR<n>\_EL1, Interrupt Controller Virtual PPI Set Pending State Registers, n = 0 - 1

The ICV\_PPI\_SPENDR<n>\_EL1 characteristics are:

#### Purpose

Set pending state for virtual PPIs.

#### Configuration

AArch64 system register ICV\_PPI\_SPENDR<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICH\_PPI\_PENDR<n>\_EL2[63:0].

AArch64 system register ICV\_PPI\_SPENDR<n>\_EL1 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_CPENDR<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and EL2 is implemented. Otherwise, direct accesses to ICV\_PPI\_SPENDR<n>\_EL1 are UNDEFINED.

#### Attributes

ICV\_PPI\_SPENDR<n>\_EL1 is a 64-bit register.

# **Field descriptions**

The ICV\_PPI\_SPENDR<n>\_EL1 bit assignments are:



#### PEND < x >, bits [x], for x = 63 to 0

Controls the Pending state of PPIs.

Reads return the current state of the INTIDs.

| PEND <x></x> | Meaning     |
|--------------|-------------|
| 0b0          | Not pending |
| 0b1          | Pending     |

Writing 1 to a field sets the Pending state of the corresponding INTID. Writing 0 has no effect.

When the Pending state of a physical PPI is directly injected to the Pending state of virtual PPI <x>, all of the following are true:

- Reads of Pend<x> return the value of the field corresponding to the physical PPI in ICC\_PPI\_SPENDR<n>\_EL1.
- Writes to Pend<x> have the same effect as writes to the field corresponding to the physical PPI in ICC\_PPI\_SPENDR<n>\_EL1.

Otherwise, all of the following are true:

- Reads of Pend<x> return the value of ICH\_PPI\_PENDR<n>\_EL2.Pend<x>.
- Writes to Pend<x> update the value of ICH\_PPI\_PENDR<n>\_EL2.Pend<x>.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- When ICV\_PPI\_HMR<n>\_EL1.HM<x> == 1, access to this field is **RO**
- Otherwise, access to this field is W1S

# Accessing ICV\_PPI\_SPENDR<n>\_EL1

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICC\_PPI\_SPENDR<n>\_EL1

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b11:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
    elsif EL2Enabled() && ICH_HFGRTR_EL2.ICC_PPI_PENDRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        X[t, 64] = ICV_PPI_SPENDR_EL1[n];
    else
        X[t, 64] = ICC_PPI_SPENDR_EL1[n];
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICC_PPI_SPENDR_EL1[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICC_PPI_SPENDR_EL1[n];
```

MSR ICC\_PPI\_SPENDR<n>\_EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b000 | 0b1100 | 0b1101 | 0b11:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.IMO == '1' && ICH_VCTLR_EL2.V3 == '1' then
        UNDEFINED;
elsif EL2Enabled() && ICH_HFGWTR_EL2.ICC_PPI_PENDRn_EL1 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
elsif EL2Enabled() && HCR_EL2.IMO == '1' then
        ICV_PPI_SPENDR_EL1[n] = X[t, 64];
else
        ICC_PPI_SPENDR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL2 then
        ICC_PPI_SPENDR_EL1[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICC_PPI_SPENDR_EL1[n] = X[t, 64];
```

# 9.6 Hypervisor control registers

Registers to manage operation of the GICv5 and Legacy virtual CPU interface.

# 9.6.1 ICH\_APR\_EL2, Interrupt Controller Active Virtual Priorities Register

The ICH\_APR\_EL2 characteristics are:

#### Purpose

Records active priorities for the virtual interrupt domain.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

AArch64 system register ICH\_APR\_EL2 bits [63:0] are architecturally mapped to AArch64 system register ICV\_APR\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_APR\_EL2 are UNDEFINED.

#### Attributes

ICH\_APR\_EL2 is a 64-bit register.

# **Field descriptions**

The ICH\_APR\_EL2 bit assignments are:



# Bits [63:32]

Reserved, RESO.

#### *P*<*x*>, bits [*x*], for *x* = 31 to 0

Provides access to the active virtual priorities.

| P <x></x> | Meaning             |
|-----------|---------------------|
| 0b0       | Priority not active |
| 0b1       | Priority active     |

This field is an alias of the equivalent field in ICV\_APR\_EL1.

Accessing this field has the following behavior:

- Access is RES0 if all of the following are true:
   x MOD 2 == 1
   ICC\_IDR0\_EL1.PRI\_BITS == 0b011
- Otherwise, access to this field is **RW**

# Accessing ICH\_APR\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_APR\_EL2

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1000 | 0b100 |

| if PSTATE.EL == ELO then                                                                      |
|-----------------------------------------------------------------------------------------------|
| UNDEFINED;                                                                                    |
| elsif PSTATE.EL == EL1 then                                                                   |
| if EL2Enabled() && HCR_EL2. <nv2,nv> == '11' &amp;&amp; ICH_VCTLR_EL2.V3 == '0' then</nv2,nv> |
| X[t, 64] = NVMem[0xB00];                                                                      |
| elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then                       |
| AArch64.SystemAccessTrap(EL2, 0x18);                                                          |
| else                                                                                          |
| UNDEFINED;                                                                                    |
| elsif PSTATE.EL == EL2 then                                                                   |
| $X[t, 64] = ICH_APR_EL2;$                                                                     |
| elsif PSTATE.EL == EL3 then                                                                   |
| $X[t, 64] = ICH_APR_EL2;$                                                                     |

#### MSR ICH\_APR\_EL2, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1000 | 0b100 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB00] = X[t, 64];
elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        ICH_APR_EL2 = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICH_APR_EL2 = X[t, 64];
```

# 9.6.2 ICH\_CONTEXTR\_EL2, Interrupt Controller Virtual Context Register

The ICH\_CONTEXTR\_EL2 characteristics are:

#### Purpose

Selects the current resident VPE.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_CONTEXTR\_EL2 are UNDEFINED.

#### Attributes

ICH\_CONTEXTR\_EL2 is a 64-bit register.

# **Field descriptions**

The ICH\_CONTEXTR\_EL2 bit assignments are:



### V, bit [63]

Indicates whether a VPE is currently resident.

If EL2 is not enabled in the Security state identified by SCR\_EL3.{NSE,NS}, the Effective value of this field is 0.

| V   | Meaning             |  |
|-----|---------------------|--|
| 060 | No VPE is resident. |  |
| 0b1 | A VPE is resident.  |  |

The reset behavior of this field is:

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

# F, bit [62]

Indicates whether the last write that set V to 1 succeeded in making a VPE resident.

| F   | Meaning |  |
|-----|---------|--|
| 0b0 | Success |  |
| 0b1 | Fault   |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

### IRICHPPIDIS, bit [61]

Specifies whether the candidate HPPI presented by the IRI for the resident VPE is considered when selecting the HPPI for the Virtual Interrupt Domain.

When V is 0, this field is IGNORED.

| IRICHPPIDIS | Meaning                                                                                                                                                   |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0b0         | The CPU interface considers both the virtual PPIs and the candidate HPPI presented by the IRS when determining the HPPI for the Virtual Interrupt Domain. |  |
| 0b1         | The CPU interface only considers the virtual PPIs when determining the HPPI for the Virtual Interrupt Domain.                                             |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

### DB, bit [60]

Specifies whether a doorbell interrupt is requested when making a VPE non-resident.

| DB  | Meaning                |
|-----|------------------------|
| 0b0 | No doorbell requested. |
| 0b1 | Doorbell requested.    |

On a write that changes V from 1 to 0, this field specifies whether a doorbell interrupt is requested for the previously resident VPE.

For all other writes, and for reads, this field is RESO.

If the current value of SCR\_EL3.{NSE,NS} is different from the value at the time the VPE was made resident, this field behaves as if set to 0.

This field has no effect if EL2 is not enabled in the Security state identified by SCR\_EL3.{NSE,NS}.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### DBPM, bits [59:55]

Doorbell priority mask.

On writes, when DB is 1, this field specifies the minimum priority for a virtual interrupt to trigger the VPE's doorbell.

On writes, when DB is 0, this field is IGNORED.

On reads, this field is UNKNOWN.

This field has no effect if EL2 is not enabled in the Security state identified by SCR\_EL3.{NSE,NS}.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### Bits [54:48]

Reserved, RESO.

#### VPE, bits [47:32]

When V is 1, identifies the resident VPE.

When V is 0, this field is IGNORED.

This field has no effect if EL2 is not enabled in the Security state identified by SCR\_EL3.{NSE,NS}.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### Bits [31:16]

Reserved, RESO.

#### VM, bits [15:0]

When V is 1, identifies the resident VM.

When V is 0, this field is IGNORED.

This field has no effect if EL2 is not enabled in the Security state identified by SCR\_EL3.{NSE,NS}.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Accessing ICH\_CONTEXTR\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_CONTEXTR\_EL2

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b110 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0xB08];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_CONTEXTR_EL2;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_CONTEXTR_EL2;
```

#### MSR ICH\_CONTEXTR\_EL2, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b110 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB08] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        ICH_CONTEXTR_EL2 = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICH_CONTEXTR_EL2 = X[t, 64];
```

# 9.6.3 ICH\_HFGITR\_EL2, Hypervisor GIC Fine-Grained Instruction Trap Register

The ICH\_HFGITR\_EL2 characteristics are:

#### Purpose

Provides instruction trap controls for GIC System instructions.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_HFGITR\_EL2 are UNDEFINED.

#### Attributes

ICH\_HFGITR\_EL2 is a 64-bit register.

# **Field descriptions**

The ICH\_HFGITR\_EL2 bit assignments are:



# Bits [63:11]

Reserved, RESO.

# GICRCDNMIA, bit [10]

Trap execution of GICR CDNMIA at EL1 to EL2.

| GICRCDNMIA | Meaning                                                                                                                                                                                                                                  |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060        | If EL2 is implemented and enabled in the current Security<br>state, then execution of GICR CDNMIA at EL1 is trapped to<br>EL2 and reported with EC syndrome value 0x18, unless the<br>instruction generates a higher priority exception. |
| 0b1        | Execution of GICR CDNMIA is not trapped by this mechanism.                                                                                                                                                                               |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# GICRCDIA, bit [9]

Trap execution of GICR CDIA at EL1 to EL2.

| GICRCDIA | Meaning                                                                                                                                                                                                                                |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060      | If EL2 is implemented and enabled in the current Security<br>state, then execution of GICR CDIA at EL1 is trapped to EL2<br>and reported with EC syndrome value 0x18, unless the<br>instruction generates a higher priority exception. |
| 0b1      | Execution of GICR CDIA is not trapped by this mechanism.                                                                                                                                                                               |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### GICCDDI, bit [8]

Trap execution of GIC CDDI at EL1 to EL2.

| GICCDDI | Meaning                                                                                                                                                                                                                               |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0     | If EL2 is implemented and enabled in the current Security<br>state, then execution of GIC CDDI at EL1 is trapped to EL2<br>and reported with EC syndrome value 0x18, unless the<br>instruction generates a higher priority exception. |
| 0b1     | Execution of GIC CDDI is not trapped by this mechanism.                                                                                                                                                                               |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# GICCDEOI, bit [7]

Trap execution of GIC CDEOI at EL1 to EL2.

| GICCDEOI | Meaning                                                                                                                                                                                                                                |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060      | If EL2 is implemented and enabled in the current Security<br>state, then execution of GIC CDEOI at EL1 is trapped to EL2<br>and reported with EC syndrome value 0x18, unless the<br>instruction generates a higher priority exception. |
| 0b1      | Execution of GIC CDEOI is not trapped by this mechanism.                                                                                                                                                                               |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# GICCDHM, bit [6]

Trap execution of GIC CDHM at EL1 to EL2.

| GICCDHM | Meaning                                                                                                                                                                                                                      |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060     | If EL2 is implemented and enabled in the current Security state, then execution of GIC CDHM at EL1 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
| 0b1     | Execution of GIC CDHM is not trapped by this mechanism.                                                                                                                                                                      |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### GICCDRCFG, bit [5]

Trap execution of GIC CDRCFG at EL1 to EL2.

| GICCDRCFG | Meaning                                                                                                                                                                                                                                 |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0       | If EL2 is implemented and enabled in the current Security<br>state, then execution of GIC CDRCFG at EL1 is trapped to<br>EL2 and reported with EC syndrome value 0x18, unless the<br>instruction generates a higher priority exception. |
| 0b1       | Execution of GIC CDRCFG is not trapped by this mechanism.                                                                                                                                                                               |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# GICCDPEND, bit [4]

Trap execution of GIC CDPEND at EL1 to EL2.

| GICCDPEND | Meaning                                                                                                                                                                                                                                 |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060       | If EL2 is implemented and enabled in the current Security<br>state, then execution of GIC CDPEND at EL1 is trapped to<br>EL2 and reported with EC syndrome value 0x18, unless the<br>instruction generates a higher priority exception. |
| 0b1       | Execution of GIC CDPEND is not trapped by this mechanism.                                                                                                                                                                               |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# GICCDAFF, bit [3]

Trap execution of GIC CDAFF at EL1 to EL2.

| GICCDAFF | Meaning                                                                                                                                                                                                                                |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0d0      | If EL2 is implemented and enabled in the current Security<br>state, then execution of GIC CDAFF at EL1 is trapped to EL2<br>and reported with EC syndrome value 0x18, unless the<br>instruction generates a higher priority exception. |
| 0b1      | Execution of GIC CDAFF is not trapped by this mechanism.                                                                                                                                                                               |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## GICCDPRI, bit [2]

Trap execution of GIC CDPRI at EL1 to EL2.

| GICCDPRI | Meaning                                                                                                                                                                                                                                |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060      | If EL2 is implemented and enabled in the current Security<br>state, then execution of GIC CDPRI at EL1 is trapped to EL2<br>and reported with EC syndrome value 0x18, unless the<br>instruction generates a higher priority exception. |
| 0b1      | Execution of GIC CDPRI is not trapped by this mechanism.                                                                                                                                                                               |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## GICCDDIS, bit [1]

Trap execution of GIC CDDIS at EL1 to EL2.

| GICCDDIS | Meaning                                                                                                                                                                                                                                |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060      | If EL2 is implemented and enabled in the current Security<br>state, then execution of GIC CDDIS at EL1 is trapped to EL2<br>and reported with EC syndrome value 0x18, unless the<br>instruction generates a higher priority exception. |
| 0b1      | Execution of GIC CDDIS is not trapped by this mechanism.                                                                                                                                                                               |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### GICCDEN, bit [0]

Trap execution of GIC CDEN at EL1 to EL2.

| GICCDEN | Meaning                                                                                                                                                                                                                      |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060     | If EL2 is implemented and enabled in the current Security state, then execution of GIC CDEN at EL1 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
| 0b1     | Execution of GIC CDEN is not trapped by this mechanism.                                                                                                                                                                      |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## Accessing ICH\_HFGITR\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_HFGITR\_EL2

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1001 | 0b111 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0xB10];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_HFGITR_EL2;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_HFGITR_EL2;
```

#### MSR ICH\_HFGITR\_EL2, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1001 | 0b111 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB10] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    ICH_HFGITR_EL2 = X[t, 64];
elsif PSTATE.EL == EL3 then
    ICH_HFGITR_EL2 = X[t, 64];
```

# 9.6.4 ICH\_HFGRTR\_EL2, Hypervisor GIC Fine-Grained Read Trap Register

The ICH\_HFGRTR\_EL2 characteristics are:

#### Purpose

Provides controls for traps of MRS reads of GIC System registers.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_HFGRTR\_EL2 are UNDEFINED.

#### Attributes

ICH\_HFGRTR\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_HFGRTR\_EL2 bit assignments are:



## Bits [63:21]

Reserved, RESO.

## ICC\_PPI\_ACTIVERn\_EL1, bit [20]

Trap MRS reads of ICC\_PPI\_CACTIVER<n>\_EL1, ICC\_PPI\_SACTIVER<n>\_EL1, ICV\_PPI\_CACTIVER<n>\_EL1 and ICV\_PPI\_SACTIVER<n>\_EL1 at EL1 using AArch64 to EL2.

| ICC_PPI_ACTIVERn_EL1 | Meaning                                                                                                                                                                                                                                                         |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0d0                  | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1                  | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### ICC\_PPI\_PRIORITYRn\_EL1, bit [19]

Trap MRS reads of ICC\_PPI\_PRIORITYR<n>\_EL1 and ICV\_PPI\_PRIORITYR<n>\_EL1 at EL1 using AArch64 to EL2.

| ICC_PPI_PRIORITYRn_EL1 | Meaning                                                                                                                                                                                                                                             |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0                    | If EL2 is implemented and enabled in the current Security state, then MRS reads of the specified registers at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
| 0b1                    | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                             |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_PPI\_PENDRn\_EL1, bit [18]

Trap MRS reads of ICC\_PPI\_CPENDR<n>\_EL1, ICC\_PPI\_SPENDR<n>\_EL1 ICV\_PPI\_CPENDR<n>\_EL1 and ICV\_PPI\_SPENDR<n>\_EL1 at EL1 using AArch64 to EL2.

| ICC_PPI_PENDRn_EL1 | Meaning                                                                                                                                                                                                                                                         |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060                | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1                | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_PPI\_ENABLERn\_EL1, bit [17]

Trap MRS reads of ICC\_PPI\_ENABLER<n>\_EL1 and ICV\_PPI\_ENABLER<n>\_EL1 at EL1 using AArch64 to EL2.

| ICC_PPI_ENABLERn_EL1 | Meaning                                                                                                                                                                                                                                                         |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060                  | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1                  | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_PPI\_HMRn\_EL1, bit [16]

Trap MRS reads of ICC\_PPI\_HMR<n>\_EL1 and ICV\_PPI\_HMR<n>\_EL1 at EL1 using AArch64 to EL2.

| ICC_PPI_HMRn_EL1 | Meaning                                                                                                                                                                                                                                                         |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060              | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1              | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

### Bits [15:8]

Reserved, RESO.

#### ICC\_IAFFIDR\_EL1, bit [7]

Trap MRS reads of ICC\_IAFFIDR\_EL1 at EL1 using AArch64 to EL2.

| ICC_IAFFIDR_EL1 | Meaning                                                                                                                                                                                                                                                         |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 040             | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1             | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# ICC\_ICSR\_EL1, bit [6]

Trap MRS reads of ICC\_ICSR\_EL1 at EL1 using AArch64 to EL2.

| ICC_ICSR_EL1 | Meaning                                                                                                                                                                                                                                                         |  |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0Ъ0          | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |  |  |
| 0b1          | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |  |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_PCR\_EL1, bit [5]

Trap MRS reads of ICC\_PCR\_EL1 and ICV\_PCR\_EL1 at EL1 using AArch64 to EL2.

| ICC_PCR_EL1 | Meaning                                                                                                                                                                                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060         | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1         | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_HPPIR\_EL1, bit [4]

Trap MRS reads of ICC\_HPPIR\_EL1 and ICV\_HPPIR\_EL1 at EL1 using AArch64 to EL2.

| ICC_HPPIR_EL1 | Meaning                                                                                                                                                                                                                                             |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000           | If EL2 is implemented and enabled in the current Security state, then MRS reads of the specified registers at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
| 0b1           | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                             |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_HAPR\_EL1, bit [3]

Trap MRS reads of ICC\_HAPR\_EL1 and ICV\_HAPR\_EL1 at EL1 using AArch64 to EL2.

| ICC_HAPR_EL1 | Meaning                                                                                                                                                                                                                                                         |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0b0          | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |  |
| 0b1          | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_CR0\_EL1, bit [2]

Trap MRS reads of ICC\_CR0\_EL1 and ICV\_CR0\_EL1 at EL1 using AArch64 to EL2.

| ICC_CR0_EL1 | Meaning                                                                                                                                                                                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0d0         | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1         | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_IDRn\_EL1, bit [1]

Trap MRS reads of ICC\_IDR0\_EL1 at EL1 using AArch64 to EL2.

| ICC_IDRn_EL1 | Meaning                                                                                                                                                                                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000          | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1          | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_APR\_EL1, bit [0]

Trap MRS reads of ICC\_APR\_EL1 and ICV\_APR\_EL1 at EL1 using AArch64 to EL2.

| ICC_APR_EL1 | Meaning                                                                                                                                                                                                                                                         |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0         | If EL2 is implemented and enabled in the current Security<br>state, then MRS reads of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1         | MRS reads of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# Accessing ICH\_HFGRTR\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_HFGRTR\_EL2

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1001 | 0b100 |

| <pre>if PSTATE.EL == EL0 then     UNDEFINED;</pre>                                            |
|-----------------------------------------------------------------------------------------------|
| elsif PSTATE.EL == EL1 then                                                                   |
| if EL2Enabled() && HCR_EL2. <nv2,nv> == '11' &amp;&amp; ICH_VCTLR_EL2.V3 == '0' then</nv2,nv> |
| X[t, 64] = NVMem[0xB18];                                                                      |
| elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then                       |
| AArch64.SystemAccessTrap(EL2, 0x18);                                                          |
| else                                                                                          |
| UNDEFINED;                                                                                    |
| elsif PSTATE.EL == EL2 then                                                                   |
| X[t, 64] = ICH_HFGRTR_EL2;                                                                    |
| elsif PSTATE.EL == EL3 then                                                                   |
| $X[t, 64] = ICH_HFGRTR_EL2;$                                                                  |

#### MSR ICH\_HFGRTR\_EL2, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |  |
|------|-------|--------|--------|-------|--|
| 0b11 | 0b100 | 0b1100 | 0b1001 | 0b100 |  |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB18] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        ICH_HFGRTR_EL2 = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICH_HFGRTR_EL2 = X[t, 64];
```

# 9.6.5 ICH\_HFGWTR\_EL2, Hypervisor GIC Fine-Grained Write Trap Register

The ICH\_HFGWTR\_EL2 characteristics are:

#### Purpose

Provides controls for traps of MSR writes of GIC System registers.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_HFGWTR\_EL2 are UNDEFINED.

#### Attributes

ICH\_HFGWTR\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_HFGWTR\_EL2 bit assignments are:



## Bits [63:21]

Reserved, RESO.

## ICC\_PPI\_ACTIVERn\_EL1, bit [20]

Trap MSR writes of ICC\_PPI\_CACTIVER<n>\_EL1, ICC\_PPI\_SACTIVER<n>\_EL1, ICV\_PPI\_CACTIVER<n>\_EL1 and ICV\_PPI\_SACTIVER<n>\_EL1 at EL1 using AArch64 to EL2.

| ICC_PPI_ACTIVERn_EL1 | Meaning                                                                                                                                                                                                                                                          |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 040                  | If EL2 is implemented and enabled in the current Security<br>state, then MSR writes of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1                  | MSR writes of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## ICC\_PPI\_PRIORITYRn\_EL1, bit [19]

Trap MSR writes of ICC\_PPI\_PRIORITYR<n>\_EL1 and ICV\_PPI\_PRIORITYR<n>\_EL1 at EL1 using AArch64 to EL2.

| ICC_PPI_PRIORITYRn_EL1 | Meaning                                                                                                                                                                                                                                                          |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0                    | If EL2 is implemented and enabled in the current Security<br>state, then MSR writes of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1                    | MSR writes of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### ICC\_PPI\_PENDRn\_EL1, bit [18]

Trap MSR writes of ICC\_PPI\_CPENDR<n>\_EL1, ICC\_PPI\_SPENDR<n>\_EL1 ICV\_PPI\_CPENDR<n>\_EL1 and ICV\_PPI\_SPENDR<n>\_EL1 at EL1 using AArch64 to EL2.

| ICC_PPI_PENDRn_EL1 | Meaning                                                                                                                                                                                                                                                          |  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 060                | If EL2 is implemented and enabled in the current Security<br>state, then MSR writes of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |  |  |
| 0b1                | MSR writes of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |  |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

### ICC\_PPI\_ENABLERn\_EL1, bit [17]

Trap MSR writes of ICC\_PPI\_ENABLER<n>\_EL1 and ICV\_PPI\_ENABLER<n>\_EL1 at EL1 using AArch64 to EL2.

| ICC_PPI_ENABLERn_EL1 | Meaning                                                                                                                                                                                                                                                          |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0d0                  | If EL2 is implemented and enabled in the current Security<br>state, then MSR writes of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |  |  |
| 0b1                  | MSR writes of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |  |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## Bits [16:7]

Reserved, RESO.

## ICC\_ICSR\_EL1, bit [6]

Trap MSR writes of ICC\_ICSR\_EL1 at EL1 using AArch64 to EL2.

| ICC_ICSR_EL1 | Meaning                                                                                                                                                                                                                                                          |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0Ъ0          | If EL2 is implemented and enabled in the current Security<br>state, then MSR writes of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1          | MSR writes of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

# ICC\_PCR\_EL1, bit [5]

Trap MSR writes of ICC\_PCR\_EL1 and ICV\_PCR\_EL1 at EL1 using AArch64 to EL2.

| ICC_PCR_EL1 | Meaning                                                                                                                                                                                                                                                          |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 060         | If EL2 is implemented and enabled in the current Security<br>state, then MSR writes of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |  |  |
| 0b1         | MSR writes of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |  |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### Bits [4:3]

Reserved, RESO.

#### ICC\_CR0\_EL1, bit [2]

Trap MSR writes of ICC\_CR0\_EL1 and ICV\_CR0\_EL1 at EL1 using AArch64 to EL2.

| ICC_CR0_EL1 | Meaning                                                                                                                                                                                                                                                          |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0         | If EL2 is implemented and enabled in the current Security<br>state, then MSR writes of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |

| ICC_CR0_EL1 | Meaning                                                                  |
|-------------|--------------------------------------------------------------------------|
| 0b1         | MSR writes of the specified registers are not trapped by this mechanism. |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## Bit [1]

Reserved, RESO.

## ICC\_APR\_EL1, bit [0]

Trap MSR writes of ICC\_APR\_EL1 and ICV\_APR\_EL1 at EL1 using AArch64 to EL2.

| ICC_APR_EL1 | Meaning                                                                                                                                                                                                                                                          |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060         | If EL2 is implemented and enabled in the current Security<br>state, then MSR writes of the specified registers at EL1 using<br>AArch64 are trapped to EL2 and reported with EC syndrome<br>value 0x18, unless the read generates a higher priority<br>exception. |
| 0b1         | MSR writes of the specified registers are not trapped by this mechanism.                                                                                                                                                                                         |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

## Accessing ICH\_HFGWTR\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_HFGWTR\_EL2

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1001 | 0b110 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0xB20];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_HFGWTR_EL2;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_HFGWTR_EL2;
```

#### MSR ICH\_HFGWTR\_EL2, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1001 | 0b110 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB20] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        ICH_HFGWTR_EL2 = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICH_HFGWTR_EL2 = X[t, 64];
```

# 9.6.6 ICH\_HPPIR\_EL2, Interrupt Controller Hypervisor Highest Priority Pending Interrupt Register

The ICH\_HPPIR\_EL2 characteristics are:

#### Purpose

Reports the HPPI for the Virtual Interrupt Domain.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

AArch64 system register ICH\_HPPIR\_EL2 bits [63:0] are architecturally mapped to AArch64 system register ICV\_HPPIR\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_HPPIR\_EL2 are UNDEFINED.

#### Attributes

ICH\_HPPIR\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_HPPIR\_EL2 bit assignments are:



## Bits [63:33]

Reserved, RESO.

#### HPPIV, bit [32]

HPPI valid.

There is an HPPI with Sufficient priority for the Interrupt Domain.

| HPPIV | Meaning                                                                      |
|-------|------------------------------------------------------------------------------|
| 0b0   | Invalid: There is no HPPI with Sufficient priority for the Interrupt Domain. |
| 0b1   | VALID: There is an HPPI with Sufficient priority for the Interrupt Domain.   |

If ICH\_HPPIR\_EL2.HPPIV is 1, ID and TYPE together form the INTID of the HPPI for the Interrupt Domain. *TYPE, bits [31:29]* 

The encoding of this field depends on the value of HPPIV as described below:

- If ICH\_HPPIR\_EL2.HPPIV is 0, TYPE is RES0.
- If ICH\_HPPIR\_EL2.HPPIV is 1, TYPE specifies the Type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b001 | PPI     |  |
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Bits [28:24]

Reserved, RESO.

#### ID, bits [23:0]

The encoding of this field depends on the value of HPPIV as described below:

- If ICH\_HPPIR\_EL2.HPPIV is 0, ID is RES0.
- If ICH\_HPPIR\_EL2.HPPIV is 1, ID specifies the interrupt ID.

## Accessing ICH\_HPPIR\_EL2

Read-only

Accesses to this register use the following encodings in the System register encoding space:

## MRS <Xt>, ICH\_HPPIR\_EL2

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1000 | 0b101 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_HPPIR_EL2;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_HPPIR_EL2;
```

# 9.6.7 ICH\_PPI\_ACTIVER<n>\_EL2, Interrupt Controller Virtual Interrupt Active Registers, n = 0 - 1

The ICH\_PPI\_ACTIVER<n>\_EL2 characteristics are:

#### Purpose

Access to Active state for virtual PPIs.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

AArch64 system register ICH\_PPI\_ACTIVER<n>\_EL2 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_CACTIVER<n>\_EL1[63:0].

AArch64 system register ICH\_PPI\_ACTIVER<n>\_EL2 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_SACTIVER<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_PPI\_ACTIVER<n>\_EL2 are UNDEFINED.

#### Attributes

ICH\_PPI\_ACTIVER<n>\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_PPI\_ACTIVER<n>\_EL2 bit assignments are:



#### *ACTIVE<x>, bits* [*x*]*, for x = 63 to 0*

Accesses the Active state of the virtual PPI.

| ACTIVE <x></x> | Meaning  |
|----------------|----------|
| 0b0            | Inactive |
| 0b1            | Active   |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Otherwise, access to this field is **RW**

## Accessing ICH\_PPI\_ACTIVER<n>\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_PPI\_ACTIVER<n>\_EL2

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b100 | 0b1100 | 0b1010 | 0b11:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0xB30 + (8 * n)];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_PPI_ACTIVER_EL2[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_PPI_ACTIVER_EL2[n];
```

#### MSR ICH\_PPI\_ACTIVER<n>\_EL2, <Xt>

| op0  | op1   | CRn CRm |        | op2       |  |
|------|-------|---------|--------|-----------|--|
| 0b11 | 0b100 | 0b1100  | 0b1010 | 0b11:n[0] |  |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB30 + (8 * n)] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
```

#### Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

ICH\_PPI\_ACTIVER\_EL2[n] = X[t, 64]; elsif PSTATE.EL == EL3 then ICH\_PPI\_ACTIVER\_EL2[n] = X[t, 64];

# 9.6.8 ICH\_PPI\_DVIR<n>\_EL2, Interrupt Controller PPI Direct-inject Virtual Interrupt Registers, n = 0 - 1

The ICH\_PPI\_DVIR<n>\_EL2 characteristics are:

#### Purpose

Controls whether Pending physical PPIs are directly injected as virtual PPIs to the Virtual Interrupt Domain.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_PPI\_DVIR<n>\_EL2 are UNDEFINED.

#### Attributes

ICH\_PPI\_DVIR<n>\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_PPI\_DVIR<n>\_EL2 bit assignments are:



#### DVI<x>, bits [x], for x = 63 to 0

Controls whether the physical PPI Pending state is directly injected to a virtual PPI in the Virtual Interrupt Domain.

| DVI <x></x> | Meaning                                                         |
|-------------|-----------------------------------------------------------------|
| 0b0         | Physical PPI <x> is not directly injected as a virtual PPI.</x> |
| 0b1         | Physical PPI <x> is directly injected as a virtual PPI.</x>     |

The Effective value of DVI<x> is 0 if any of the following are true:

- Physical PPI <x> is not assigned to Current Physical Interrupt Domain.
- Physical PPI <x> is assigned to the EL3 Interrupt Domain.
- Physical PPI <x> is assigned to the Secure Interrupt Domain and SCR\_EL3.EEL2 is 0.

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Access is RAZ/WI if all of the following are true:
   !IsPPIAssignedToCurrentDomain((n \* 64) + x)
  - PSTATE.EL IN {EL2, EL1}
- Otherwise, access to this field is RW

## Accessing ICH\_PPI\_DVIR<n>\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_PPI\_DVIR<n>\_EL2

| ор0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b100 | 0b1100 | 0b1010 | 0b00:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0xB40 + (8 * n)];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_PPI_DVIR_EL2[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_PPI_DVIR_EL2[n];
```

#### MSR ICH\_PPI\_DVIR<n>\_EL2, <Xt>

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b100 | 0b1100 | 0b1010 | 0b00:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB40 + (8 * n)] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        ICH_PPI_DVIR_EL2[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICH_PPI_DVIR_EL2[n] = X[t, 64];
```

# 9.6.9 ICH\_PPI\_ENABLER<n>\_EL2, Interrupt Controller Virtual Interrupt Enable Registers, n = 0 - 1

The ICH\_PPI\_ENABLER<n>\_EL2 characteristics are:

#### Purpose

Access to Enable state for virtual PPIs.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

AArch64 system register ICH\_PPI\_ENABLER<n>\_EL2 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_ENABLER<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_PPI\_ENABLER<n>\_EL2 are UNDEFINED.

#### Attributes

ICH\_PPI\_ENABLER<n>\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_PPI\_ENABLER<n>\_EL2 bit assignments are:



#### *EN<x>, bits [x], for x = 63 to 0*

Alias of equivalent ICV\_PPI\_ENABLER<n>\_EL1 field.

Accessing this field has the following behavior:

• **RES0** if !IsPPIImplemented((n \* 64) + x)

• Otherwise, access to this field is **RW** 

## Accessing ICH\_PPI\_ENABLER<n>\_EL2

Accesses to this register use the following encodings in the System register encoding space:

## MRS <Xt>, ICH\_PPI\_ENABLER<n>\_EL2

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b100 | 0b1100 | 0b1010 | 0b01:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0xB50 + (8 * n)];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_PPI_ENABLER_EL2[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_PPI_ENABLER_EL2[n];
```

#### MSR ICH\_PPI\_ENABLER<n>\_EL2, <Xt>

| ор0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b100 | 0b1100 | 0b1010 | 0b01:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB50 + (8 * n)] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        ICH_PPI_ENABLER_EL2[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICH_PPI_ENABLER_EL2[n] = X[t, 64];
```

# 9.6.10 ICH\_PPI\_PENDR<n>\_EL2, Interrupt Controller Virtual Interrupt Pending State Registers, n = 0 - 1

The ICH\_PPI\_PENDR<n>\_EL2 characteristics are:

#### Purpose

Pending state for virtual PPIs.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

AArch64 system register ICH\_PPI\_PENDR<n>\_EL2 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_CPENDR<n>\_EL1[63:0].

AArch64 system register ICH\_PPI\_PENDR<n>\_EL2 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_SPENDR<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_PPI\_PENDR<n>\_EL2 are UNDEFINED.

#### Attributes

ICH\_PPI\_PENDR<n>\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_PPI\_PENDR<n>\_EL2 bit assignments are:



## *PEND<x>*, bits [*x*], for *x* = 63 to 0

Pend<x> accesses the Pending state of virtual PPI <x>.

| PEND <x></x> | Meaning     |
|--------------|-------------|
| 0b0          | Not pending |
| 0b1          | Pending     |

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 64) + x)
- Otherwise, access to this field is **RW**

## Accessing ICH\_PPI\_PENDR<n>\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_PPI\_PENDR<n>\_EL2

| op0 op1 |       | CRn    | CRm    | op2       |
|---------|-------|--------|--------|-----------|
| 0b11    | 0b100 | 0b1100 | 0b1010 | 0b10:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_PPI_PENDR_EL2[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_PPI_PENDR_EL2[n];
```

#### MSR ICH\_PPI\_PENDR<n>\_EL2, <Xt>

| op0  | op1   | CRn    | CRm    | op2       |
|------|-------|--------|--------|-----------|
| 0b11 | 0b100 | 0b1100 | 0b1010 | 0b10:n[0] |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        ICH_PPI_PENDR_EL2[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICH_PPI_PENDR_EL2[n] = X[t, 64];
```

# 9.6.11 ICH\_PPI\_PRIORITYR<n>\_EL2, Interrupt Controller Virtual Interrupt Priority Registers, n = 0 - 15

The ICH\_PPI\_PRIORITYR<n>\_EL2 characteristics are:

#### Purpose

Priority of virtual PPIs.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

AArch64 system register ICH\_PPI\_PRIORITYR<n>\_EL2 bits [63:0] are architecturally mapped to AArch64 system register ICV\_PPI\_PRIORITYR<n>\_EL1[63:0].

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_PPI\_PRIORITYR<n>\_EL2 are UNDEFINED.

#### Attributes

ICH\_PPI\_PRIORITYR<n>\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_PPI\_PRIORITYR<n>\_EL2 bit assignments are:

| I | 63 61 | 60 56     | <sub>1</sub> 55 53 | 52 48     | 47 45 | 44 40     | 39 37 | 36 32     |
|---|-------|-----------|--------------------|-----------|-------|-----------|-------|-----------|
|   | RES0  | PRIORITY7 | RES0               | PRIORITY6 | RES0  | PRIORITY5 | RES0  | PRIORITY4 |
|   | 31 29 | 28 24     | 23 21              | 20 16     | 15 13 | 12 8      | 7 5   | 4 0       |
|   | RES0  | PRIORITY3 | RES0               | PRIORITY2 | RES0  | PRIORITY1 | RES0  | PRIORITY0 |

#### Bits [63:61, 55:53, 47:45, 39:37, 31:29, 23:21, 15:13, 7:5]

Reserved, RESO.

# *PRIORITY<x>*, bits [60:56, 52:48, 44:40, 36:32, 28:24, 20:16, 12:8, 4:0], for x = 7 to 0, where each field is 5 bits wide

Alias of equivalent ICV\_PPI\_PRIORITY<n>\_EL1 field.

Fields corresponding to unimplemented INTIDs are RESO.

Accessing this field has the following behavior:

- **RES0** if !IsPPIImplemented((n \* 8) + x)
- Otherwise, access to this field is **RW**

# Accessing ICH\_PPI\_PRIORITYR<n>\_EL2

Accesses to this register use the following encodings in the System register encoding space:

## MRS <Xt>, ICH\_PPI\_PRIORITYR<n>\_EL2

| ор0  | op1   | CRn    | CRm        | op2    |
|------|-------|--------|------------|--------|
| 0b11 | 0b100 | 0b1100 | 0b111:n[3] | n[2:0] |

```
if PSTATE.EL == ELO then
```

```
UNDEFINED;
```

```
elsif PSTATE.EL == EL1 then
```

```
if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
```

#### Chapter 9. System registers 9.6. Hypervisor control registers

```
X[t, 64] = NVMem[0xB80 + (8 * n)];
elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_PPI_PRIORITYR_EL2[n];
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_PPI_PRIORITYR_EL2[n];
```

## MSR ICH\_PPI\_PRIORITYR<n>\_EL2, <Xt>

| op0  | op1   | CRn    | CRm        | op2    |  |
|------|-------|--------|------------|--------|--|
| 0b11 | 0b100 | 0b1100 | 0b111:n[3] | n[2:0] |  |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB80 + (8 * n)] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        ICH_PPI_PRIORITYR_EL2[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICH_PPI_PRIORITYR_EL2[n] = X[t, 64];
```

# 9.6.12 ICH\_VCTLR\_EL2, Interrupt Controller Virtual CPU interface Control Register

The ICH\_VCTLR\_EL2 characteristics are:

#### Purpose

Controls behavior of the Virtual CPU interface.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register is present only when FEAT\_GCIE is implemented and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_VCTLR\_EL2 are UNDEFINED.

#### Attributes

ICH\_VCTLR\_EL2 is a 64-bit register.

#### **Field descriptions**

The ICH\_VCTLR\_EL2 bit assignments are:



#### Bits [63:2]

Reserved, RESO.

#### V3, bit [1]

## When FEAT\_GCIE\_LEGACY is implemented:

Enable bit for Legacy operation.

If EL2 is not enabled in the Security state identified by SCR\_EL3.{NSE,NS}, the Effective value of this field is 0. When the Effective value of this field is 0, the Effective value of ICH\_HCR\_EL2.En is 0.

See 'Legacy virtual CPU interface' for more information.

| V3  | Meaning                    |  |
|-----|----------------------------|--|
| 0b0 | Legacy operation disabled. |  |
| 0b1 | Legacy operation enabled.  |  |

The reset behavior of this field is:

• On a Warm reset, this field resets to an architecturally UNKNOWN value.

#### Otherwise:

res0

## EN, bit [0]

When  $ICH_VCTLR\_EL2.V3 == 0$ :

Enable interrupts for the Virtual Interrupt Domain.

If EL2 is not enabled in the Security state identified by SCR\_EL3.{NSE,NS}, the Effective value of this field is 0.

| EN  | Meaning   |  |
|-----|-----------|--|
| 0b0 | Disabled. |  |
| 0b1 | Enabled.  |  |

When this field is 0, there is no HPPI of Sufficient priority for the Virtual Interrupt Domain.

The reset behavior of this field is:

• On a Warm reset, this field resets to an architecturally UNKNOWN value.

#### Otherwise:

res0

## Accessing ICH\_VCTLR\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_VCTLR\_EL2

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b100 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0xB28];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        X[t, 64] = ICH_VCTLR_EL2;
elsif PSTATE.EL == EL3 then
        X[t, 64] = ICH_VCTLR_EL2;
```

#### MSR ICH\_VCTLR\_EL2, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b100 |

#### Chapter 9. System registers 9.6. Hypervisor control registers

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0xB28] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
        ICH_VCTLR_EL2 = X[t, 64];
elsif PSTATE.EL == EL3 then
        ICH_VCTLR_EL2 = X[t, 64];
```

# 9.6.13 ICH\_VMCR\_EL2, Interrupt Controller Virtual Machine Control Register

The ICH\_VMCR\_EL2 characteristics are:

#### Purpose

Enables the hypervisor to save and restore the state of the Virtual CPU interface.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register is present only when (FEAT\_GICv3 is implemented or FEAT\_GCIE is implemented) and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_VMCR\_EL2 are UNDEFINED.

#### Attributes

ICH\_VMCR\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_VMCR\_EL2 bit assignments are:

## When ICH\_VCTLR\_EL2.V3 == 0:

| 63       |      |      | 32 |
|----------|------|------|----|
|          |      | RES0 |    |
| <br>, 31 | 27   | 26   |    |
|          | VPMR | RES0 | EN |

### Bits [63:32]

Reserved, RESO.

#### VPMR, bits [31:27]

Alias of ICV\_PCR\_EL1.Priority.

#### Bits [26:1]

Reserved, RESO.

#### EN, bit [0]

Alias of ICV\_CR0\_EL1.EN.

#### When ICH\_VCTLR\_EL2.V3 == 1:



Fields listed below are as described in the ICH\_VMCR\_EL2 register in [3].

Bits [63:32]

Reserved, RESO.

## VPMR, bits [31:24]

Alias of ICV\_PMR\_EL1.Priority.

## VBPR0, bits [23:21]

Alias of ICV\_BPR0\_EL1.BinaryPoint.

## VBPR1, bits [20:18]

Alias of ICV\_BPR1\_EL1.BinaryPoint.

## Bits [17:10]

Reserved, RESO.

## VEOIM, bit [9]

Alias of ICV\_CTLR\_EL1.EOImode.

## Bits [8:5]

Reserved, RESO.

## VCBPR, bit [4]

Alias of ICV\_CTLR\_EL1.CBPR.

#### VFIQEn, bit [3]

Virtual FIQ enable.

This field is RES1 as GICv2 compatibility is not supported.

#### VAckCtl, bit [2]

Virtual AckCtl.

#### VENG1, bit [1]

Alias ICV\_IGRPEN1\_EL1.Enable.

## VENG0, bit [0]

Alias of ICV\_IGRPEN0\_EL1.Enable.

## Accessing ICH\_VMCR\_EL2

Accesses to this register use the following encodings in the System register encoding space:

## MRS <Xt>, ICH\_VMCR\_EL2

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b111 |

```
if PSTATE.EL == ELO then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
   if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0x4C8];
   elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
   else
       UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
       AArch64.SystemAccessTrap(EL2, 0x18);
   else
       X[t, 64] = ICH_VMCR_EL2;
elsif PSTATE.EL == EL3 then
   if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
   else
       X[t, 64] = ICH_VMCR_EL2;
```

#### MSR ICH\_VMCR\_EL2, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |  |
|------|-------|--------|--------|-------|--|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b111 |  |

```
if PSTATE.EL == ELO then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0x4C8] = X[t, 64];
   elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
   else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
   else
       ICH VMCR EL2 = X[t, 64];
elsif PSTATE.EL == EL3 then
   if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
       AArch64.SystemAccessTrap(EL3, 0x18);
   else
       ICH_VMCR\_EL2 = X[t, 64];
```

#### 9.6.14 Nested virtualization

 IXDEPJ
 The Arm architecture's enhanced support for nested virtualization (FEAT\_NV2) provides a mechanism for hardware to transform reads and writes from System registers into reads and writes from memory.

See "Enhanced support for nested virtualization" in the Architecture Reference Manual for A-profile [1].

R<sub>KZTGX</sub> When system register accesses are transformed to memory accesses Table D8-63 (Memory address offset associated with transformed register access) in the Architecture Reference Manual for A-profile [1] describes the offsets used for each affected register. This table is extended as follows to cover the GICv5 system registers:

| Register access if HCR_EL2.NV1 is 0 | Register access if HCR_EL2.NV1 is 1 | Memory offset |
|-------------------------------------|-------------------------------------|---------------|
| ICH_APR_EL2                         | ICH_APR_EL2                         | OxB00         |
| ICH_CONTEXTR_EL2                    | ICH_CONTEXTR_EL2                    | OxB08         |
| ICH_HFGITR_EL2                      | ICH_HFGITR_EL2                      | OxB10         |
| ICH_HFGRTR_EL2                      | ICH_HFGRTR_EL2                      | OxB18         |
| ICH_HFGWTR_EL2                      | ICH_HFGWTR_EL2                      | OxB20         |
| ICH_PPI_ACTIVER <n>_EL2</n>         | ICH_PPI_ACTIVER <n>_EL2</n>         | OxB30 + 8*n   |
| ICH_PPI_DVIR <n>_EL2</n>            | ICH_PPI_DVIR <n>_EL2</n>            | OxB40 + 8*n   |
| ICH_PPI_ENABLER <n>_EL2</n>         | ICH_PPI_ENABLER <n>_EL2</n>         | OxB50 + 8*n   |
| ICH_PPI_PRIORITYR <n>_EL2</n>       | ICH_PPI_PRIORITYR <n>_EL2</n>       | OxB80 + 8*n   |
| ICH_VCTLR_EL2                       | ICH_VCTLR_EL2                       | OxB28         |
| ICH_VMCR_EL2                        | ICH_VMCR_EL2                        | Ox4C8         |

Offsets for registers introduced by GICv3 or GICv4 are unchanged.

# 9.7 Legacy hypervisor control registers

Registers to manage operation of the Legacy virtual CPU interface.

# 9.7.1 ICH\_AP0R<n>\_EL2, Interrupt Controller Active Virtual Priorities Registers 0, n = 0 - 3

The ICH\_AP0R<n>\_EL2 characteristics are:

#### Purpose

Records active Group 0 virtual priorities in the Legacy virtual CPU interface.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register has no effect if EL2 is not enabled in the current Security state.

This register is present only when (FEAT\_GICv3 is implemented or FEAT\_GCIE\_LEGACY is implemented) and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_AP0R<n>\_EL2 are UNDEFINED.

#### Attributes

ICH\_AP0R<n>\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_AP0R<n>\_EL2 bit assignments are:



All fields listed below are as described in the ICH\_APOR<n>\_EL2 register description in [3].

#### Bits [63:32]

Reserved, RESO.

#### *P*<*x*>, bits [*x*], for *x* = 31 to 0

Provides the access to the active virtual Group 0 priorities.

## Accessing ICH\_AP0R<n>\_EL2

When FEAT\_GCIE\_LEGACY is implemented, only 32 priority levels is supported meaning that ICH\_AP0R1\_EL2, ICH\_AP0R2\_EL2, and ICH\_AP0R3\_EL2 are not implemented.

Accesses to this register use the following encodings in the System register encoding space:

MRS <Xt>, ICH\_AP0R<m>\_EL2 ; Where m = 0-3

| op0  | op1   | CRn    | CRm    | op2        |
|------|-------|--------|--------|------------|
| 0b11 | 0b100 | 0b1100 | 0b1000 | 0b0:m[1:0] |

```
integer m = UInt(op2<1:0>);
if m == 1 && NUM_GIC_PREEMPTION_BITS < 6 then
    UNDEFINED;
elsif (m == 2 || m == 3) && NUM_GIC_PREEMPTION_BITS < 7 then
    UNDEFINED:
elsif PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR EL2.<NV2,NV> == '11' && ICH_VCTLR EL2.V3 == '0' then
        X[t, 64] = NVMem[0x480 + (8 * m)];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = ICH\_APOR\_EL2[m];
elsif PSTATE.EL == EL3 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = ICH\_APOR\_EL2[m];
```

MSR ICH\_AP0R<m>\_EL2, <Xt> ; Where m = 0-3

| ор0  | op1   | CRn    | CRm    | ор2        |
|------|-------|--------|--------|------------|
| 0b11 | 0b100 | 0b1100 | 0b1000 | 0b0:m[1:0] |

```
integer m = UInt(op2<1:0>);
```

```
if m == 1 && NUM_GIC_PREEMPTION_BITS < 6 then
   UNDEFINED;
elsif (m == 2 || m == 3) && NUM_GIC_PREEMPTION_BITS < 7 then
   UNDEFINED;
elsif PSTATE.EL == ELO then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
   if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
       NVMem[0x480 + (8 * m)] = X[t, 64];
   elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
       AArch64.SystemAccessTrap(EL2, 0x18);
   else
       UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
       AArch64.SystemAccessTrap(EL2, 0x18);
   else
       ICH\_APOR\_EL2[m] = X[t, 64];
elsif PSTATE.EL == EL3 then
   if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
       AArch64.SystemAccessTrap(EL3, 0x18);
   else
       ICH\_APOR\_EL2[m] = X[t, 64];
```

## 9.7.2 ICH\_AP1R<n>\_EL2, Interrupt Controller Active Virtual Priorities Registers 1, n = 0 - 3

The ICH\_AP1R<n>\_EL2 characteristics are:

#### Purpose

Records active Group 1 virtual priorities in the Legacy virtual CPU interface.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register has no effect if EL2 is not enabled in the current Security state.

This register is present only when (FEAT\_GICv3 is implemented or FEAT\_GCIE\_LEGACY is implemented) and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_AP1R<n>\_EL2 are UNDEFINED.

#### Attributes

ICH\_AP1R<n>\_EL2 is a 64-bit register.

#### **Field descriptions**

The ICH\_AP1R<n>\_EL2 bit assignments are:



All fields listed below are as described in the ICH\_AP1R<n>\_EL2 register description in [3].

#### NMI, bit [63]

#### When (FEAT\_GICv3\_NMI is implemented or FEAT\_GCIE\_LEGACY is implemented) and n == 0:

Indicates whether there is an active virtual NMI priority.

| NMI | Meaning                                                                                  |
|-----|------------------------------------------------------------------------------------------|
| 0b0 | There is no active Group 1 NMI, or all active Group 1 NMIs have undergone priority drop. |
| 0b1 | There is an active Group 1 NMI.                                                          |

The reset behavior of this field is:

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

#### Otherwise:

res0

#### Bits [62:32]

Reserved, RESO.

#### *P*<*x*>, bits [*x*], for *x* = 31 to 0

Provides the access to the active virtual Group 1 priorities.

If FEAT\_GCIE\_LEGACY is implemented, this field accesses the same state as ICH\_APR\_EL2

The number of implemented priority bits is reported by ICC\_IDR0\_EL1.PRI\_BITS. Fields corresponding to unimplemented priority levels are RES0.

## Accessing ICH\_AP1R<n>\_EL2

When FEAT\_GCIE\_LEGACY is implemented, only 32 priority levels is supported meaning that ICH\_AP1R1\_EL2, ICH\_AP1R2\_EL2, and ICH\_AP1R3\_EL2 are not implemented.

Accesses to this register use the following encodings in the System register encoding space:

#### MRS < Xt>, $ICH_AP1R < m$ >\_EL2; Where m = 0-3

| op0  | op1   | CRn    | CRm    | op2        |
|------|-------|--------|--------|------------|
| 0b11 | 0b100 | 0b1100 | 0b1001 | 0b0:m[1:0] |

integer m = UInt(op2<1:0>);

```
if m == 1 && NUM_GIC_PREEMPTION_BITS < 6 then
    UNDEFINED;
elsif (m == 2 || m == 3) && NUM_GIC_PREEMPTION_BITS < 7 then
    UNDEFINED;
elsif PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0x480 + (8 * m)];
   elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
       X[t, 64] = ICH\_AP1R\_EL2[m];
elsif PSTATE.EL == EL3 then
   if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = ICH\_AP1R\_EL2[m];
```

#### MSR ICH\_AP1R<m>\_EL2, <Xt> ; Where m = 0-3

| op0  | op1   | CRn    | CRm    | op2        |
|------|-------|--------|--------|------------|
| 0b11 | 0b100 | 0b1100 | 0b1001 | 0b0:m[1:0] |

```
integer m = UInt(op2<1:0>);
if m == 1 && NUM_GIC_PREEMPTION_BITS < 6 then
   UNDEFINED;
elsif (m == 2 || m == 3) && NUM_GIC_PREEMPTION_BITS < 7 then
    UNDEFINED;
elsif PSTATE.EL == ELO then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0x480 + (8 * m)] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
       AArch64.SystemAccessTrap(EL2, 0x18);
    else
       UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        ICH\_AP1R\_EL2[m] = X[t, 64];
elsif PSTATE.EL == EL3 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        ICH\_AP1R\_EL2[m] = X[t, 64];
```

## 9.7.3 ICH\_EISR\_EL2, Interrupt Controller End of Interrupt Status Register

The ICH\_EISR\_EL2 characteristics are:

#### Purpose

Enables a hypervisor to determine which List registers have outstanding EOI maintenance interrupts.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register has no effect if EL2 is not enabled in the current Security state.

This register is present only when (FEAT\_GICv3 is implemented or FEAT\_GCIE\_LEGACY is implemented) and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_EISR\_EL2 are UNDEFINED.

#### Attributes

ICH\_EISR\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_EISR\_EL2 bit assignments are:



All fields listed below are as described in the ICH\_EISR\_EL2 register description in [3].

#### Bits [63:16]

Reserved, RESO.

#### Status<x>, bits [x], for x = 15 to 0

EOI maintenance interrupt status bit for List register.

## Accessing ICH\_EISR\_EL2

Read-only

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_EISR\_EL2

| орО  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b011 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = ICH\_EISR\_EL2;
elsif PSTATE.EL == EL3 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = ICH\_EISR\_EL2;
```

## 9.7.4 ICH\_ELRSR\_EL2, Interrupt Controller Empty List Register Status Register

The ICH\_ELRSR\_EL2 characteristics are:

#### Purpose

Enables a hypervisor to locate a usable List register to deliver an interrupt to a VM.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register has no effect if EL2 is not enabled in the current Security state.

This register is present only when (FEAT\_GICv3 is implemented or FEAT\_GCIE\_LEGACY is implemented) and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_ELRSR\_EL2 are UNDEFINED.

#### Attributes

ICH\_ELRSR\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_ELRSR\_EL2 bit assignments are:



All fields listed below are as described in the ICH\_ELRSR\_EL2 register description in [3].

#### Bits [63:16]

Reserved, RESO.

#### Status<x>, bits [x], for x = 15 to 0

Status bit for List register.

## Accessing ICH\_ELRSR\_EL2

Read-only

Accesses to this register use the following encodings in the System register encoding space:

## MRS <Xt>, ICH\_ELRSR\_EL2

| орО  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b101 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = ICH\_ELRSR\_EL2;
elsif PSTATE.EL == EL3 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = ICH\_ELRSR\_EL2;
```

## 9.7.5 ICH\_HCR\_EL2, Interrupt Controller Hyp Control Register

The ICH\_HCR\_EL2 characteristics are:

#### Purpose

Enables the hypervisor to control the behavior of the Virtual CPU interface in Legacy operation

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register has no effect if EL2 is not enabled in the current Security state.

This register is present only when (FEAT\_GICv3 is implemented or FEAT\_GCIE\_LEGACY is implemented) and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_HCR\_EL2 are UNDEFINED.

#### Attributes

ICH\_HCR\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_HCR\_EL2 bit assignments are:



All fields listed below are as described in the ICH\_HCR\_EL2 register description in [3].

## Bits [63:32]

Reserved, RESO.

#### EOlcount, bits [31:27]

This field is incremented whenever a successful write to a virtual EOIR or DIR register would have resulted in a virtual interrupt deactivation.

#### Bits [26:16]

Reserved, RESO.

DVIM, bit [15]

When FEAT\_GICv3 is implemented:

Directly-injected Virtual Interrupt Mask.

Otherwise:

res0

TDIR, bit [14]

Trap EL1 writes to ICx\_DIR\_EL1 to EL2.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

TSEI, bit [13]

When FEAT\_GICv3 is implemented:

Trap all locally generated SEIs.

Otherwise:

res0

## TALL1, bit [12]

Trap all EL1 accesses to ICC\_\* and ICV\_\* System registers for Group 1 interrupts to EL2. When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## TALL0, bit [11]

Trap all EL1 accesses to ICC\_\* and ICV\_\* System registers for Group 0 interrupts to EL2.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## TC, bit [10]

Trap all EL1 accesses to System registers that are common to Group 0 and Group 1 to EL2.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## Bits [9:8]

Reserved, RESO.

## VGrp1DIE, bit [7]

VM Group 1 Disabled Interrupt Enable.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## VGrp1EIE, bit [6]

VM Group 1 Enabled Interrupt Enable.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## VGrp0DIE, bit [5]

VM Group 0 Disabled Interrupt Enable.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## VGrp0EIE, bit [4]

VM Group 0 Enabled Interrupt Enable.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## NPIE, bit [3]

No Pending Interrupt Enable.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## LRENPIE, bit [2]

List Register Entry Not Present Interrupt Enable.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## UIE, bit [1]

Underflow Interrupt Enable.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

#### En, bit [0]

Global enable bit for the virtual CPU interface.

When ICH\_VCTLR\_EL2.V3 == '0', the Effective value of this field is 0.

## Accessing ICH\_HCR\_EL2

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_HCR\_EL2

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b000 |

```
if PSTATE.EL == ELO then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
   if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0x4C0];
   elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
   else
       X[t, 64] = ICH_HCR_EL2;
elsif PSTATE.EL == EL3 then
   if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
   else
        X[t, 64] = ICH_HCR_EL2;
```

#### MSR ICH\_HCR\_EL2, <Xt>

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b000 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0x4C0] = X[t, 64];
elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
else
```

#### Chapter 9. System registers 9.7. Legacy hypervisor control registers

```
ICH_HCR_EL2 = X[t, 64];
elsif PSTATE.EL == EL3 then
  if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        ICH_HCR_EL2 = X[t, 64];
```

## 9.7.6 ICH\_LR<n>\_EL2, Interrupt Controller List Registers, n = 0 - 15

The ICH\_LR<n>\_EL2 characteristics are:

#### Purpose

Enables a hypervisor to provide interrupt context information to the Legacy virtual CPU interface.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

If list register n is not implemented, then accesses to this register are UNDEFINED.

This register has no effect if EL2 is not enabled in the current Security state.

This register is present only when (FEAT\_GICv3 is implemented or FEAT\_GCIE\_LEGACY is implemented) and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_LR<n>\_EL2 are UNDEFINED.

#### Attributes

ICH\_LR<n>\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_LR<n>\_EL2 bit assignments are:



All fields listed below are as described in the ICH\_LR<n>\_EL2 register description in [3].

#### State, bits [63:62]

See the register description in [3].

## HW, bit [61]

Indicates whether this virtual interrupt maps directly to a hardware interrupt, meaning that it corresponds to a physical interrupt. Deactivation of the virtual interrupt also causes the deactivation of the physical interrupt with the ID that the pINTID field indicates.

| HW  | Meaning                                                                                                                                                    |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0 | The interrupt is triggered entirely by software.                                                                                                           |
| 0b1 | The interrupt maps directly to a hardware interrupt.<br>Deactivating the virtual interrupt also deactivates the physical<br>interrupt specified in pINTID. |

The reset behavior of this field is:

• On a Warm reset, this field resets to an UNKNOWN value.

#### Group, bit [60]

See the register description in [3].

#### NMI, bit [59]

See the register description in [3].

#### Bits [58:56]

Reserved, RESO.

#### Priority, bits [55:48]

See the register description in [3].

When FEAT\_GCIE\_LEGACY is implemented, 5 bits of priority are implemented meaning that bits[50:48] are RES0.

#### Bits [47:45]

Reserved, RESO.

#### pINTID, bits [44:32]

When FEAT\_GICv3 is implemented

#### pINTID, bits [12:0] of bits [44:32]

See the register description in [3].

#### When FEAT\_GCIE\_LEGACY is implemented

#### pINTID, bits [12:0] of bits [44:32]

Physical PPI INTID, for hardware interrupts.

When ICH\_LR<n>\_EL2.HW is 0 (there is no corresponding physical interrupt), this field has the following meaning:

- Bits[44:42]: RESO.
- Bit[41]: EOI. If this bit is 1, then when the interrupt identified by vINTID is deactivated, a maintenance interrupt is asserted.
- Bits[40:32]: RESO.

When ICH\_LR<n>\_EL2.HW is 1 (there is a corresponding physical interrupt):

- This field specifies the ID of a physical PPI in the Current Physical Interrupt Domain.
- This field is only required to implement enough bits to hold a valid value for the implemented physical PPIs. Any unused higher order bits are RESO.
- If pINTID specifies an unreachable PPI, no physical interrupt is deactivated.

#### Otherwise:

res0

#### vINTID, bits [31:0]

See the register description in [3].

## Accessing ICH\_LR<n>\_EL2

Accesses to this register use the following encodings in the System register encoding space:

## MRS <Xt>, ICH\_LR<n>\_EL2

#### Chapter 9. System registers 9.7. Legacy hypervisor control registers

| op0  | op1   | CRn    | CRm        | op2    |
|------|-------|--------|------------|--------|
| 0b11 | 0b100 | 0b1100 | 0b110:n[3] | n[2:0] |

```
if n >= NUM_GIC_LIST_REGS then
   UNDEFINED;
elsif PSTATE.EL == ELO then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        X[t, 64] = NVMem[0x400 + (8 * n)];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = ICH_LR\_EL2[n];
elsif PSTATE.EL == EL3 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = ICH_LR_EL2[n];
```

#### MSR ICH\_LR<n>\_EL2, <Xt>

| op0  | op1   | CRn    | CRm        | op2    |
|------|-------|--------|------------|--------|
| 0b11 | 0b100 | 0b1100 | 0b110:n[3] | n[2:0] |

```
if n >= NUM_GIC_LIST_REGS then
   UNDEFINED;
elsif PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' && ICH_VCTLR_EL2.V3 == '0' then
        NVMem[0x400 + (8 * n)] = X[t, 64];
    elsif EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        ICH_LR_EL2[n] = X[t, 64];
elsif PSTATE.EL == EL3 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        ICH_LR_EL2[n] = X[t, 64];
```

## 9.7.7 ICH\_MISR\_EL2, Interrupt Controller Maintenance Interrupt State Register

The ICH\_MISR\_EL2 characteristics are:

#### Purpose

Indicates which maintenance interrupts are asserted.

#### Configuration

If EL2 is not implemented, this register is RESO from EL3.

This register has no effect if EL2 is not enabled in the current Security state.

This register is present only when (FEAT\_GICv3 is implemented or FEAT\_GCIE\_LEGACY is implemented) and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_MISR\_EL2 are UNDEFINED.

#### Attributes

ICH\_MISR\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_MISR\_EL2 bit assignments are:

| L              | 3                  |                |         |    |   |     |   |     | 32 | 1.  |
|----------------|--------------------|----------------|---------|----|---|-----|---|-----|----|-----|
|                | RESO               |                |         |    |   |     |   |     |    |     |
| L <sup>2</sup> | 1 8                | 7              | 6       | 15 | 4 | 3   | 2 | 11  | 0  | I   |
|                | RES0               |                |         |    |   | NP  |   | U   |    |     |
|                | VGrp1D<br>VGr<br>V | )<br>1E<br>Grp | <br>p0D |    |   | VGr |   | LRE |    | EOI |

All fields listed below are as described in the ICH\_MISR\_EL2 register description in [3].

Bits [63:8]

Reserved, RESO.

#### VGrp1D, bit [7]

vPE Group 1 Disabled.

#### VGrp1E, bit [6]

vPE Group 1 Enabled.

#### VGrp0D, bit [5]

vPE Group 0 Disabled.

#### VGrp0E, bit [4]

vPE Group 0 Enabled.

NP, bit [3]

## No Pending.

LRENP, bit [2]

List Register Entry Not Present.

U, bit [1]

Underflow.

#### EOI, bit [0]

End of Interrupt.

## Accessing ICH\_MISR\_EL2

#### Read-only

Accesses to this register use the following encodings in the System register encoding space:

#### MRS <Xt>, ICH\_MISR\_EL2

| ор0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b010 |

```
if PSTATE.EL == ELO then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
   if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
       AArch64.SystemAccessTrap(EL2, 0x18);
   else
       UNDEFINED;
elsif PSTATE.EL == EL2 then
   if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
   else
       X[t, 64] = ICH_MISR_EL2;
elsif PSTATE.EL == EL3 then
   if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
   else
```

Chapter 9. System registers 9.7. Legacy hypervisor control registers

 $X[t, 64] = ICH_MISR_EL2;$ 

## 9.7.8 ICH\_VTR\_EL2, Interrupt Controller VGIC Type Register

The ICH\_VTR\_EL2 characteristics are:

#### Purpose

Reports supported GIC virtualization features.

#### Configuration

If EL2 is not implemented, all bits in this register are RESO from EL3, except for nV4, which is RES1 from EL3 when EL2 is not implemented.

This register has no effect if EL2 is not enabled in the current Security state.

This register is present only when (FEAT\_GICv3 is implemented or FEAT\_GCIE\_LEGACY is implemented) and (EL2 is implemented or EL3 is implemented). Otherwise, direct accesses to ICH\_VTR\_EL2 are UNDEFINED.

#### Attributes

ICH\_VTR\_EL2 is a 64-bit register.

## **Field descriptions**

The ICH\_VTR\_EL2 bit assignments are:



All fields listed below are as described in the ICH\_VTR\_EL2 register description in [3].

#### Bits [63:32]

Reserved, RESO.

## PRIbits, bits [31:29]

The number of virtual priority bits implemented, minus one.

If FEAT\_GCIE\_LEGACY is implemented, this field returns 4 (5 bits of priority).

## PREbits, bits [28:26]

The number of virtual preemption bits implemented, minus one.

If FEAT\_GCIE\_LEGACY is implemented, this field returns 4 (5 bits of preemption).

## IDbits, bits [25:23]

The number of virtual interrupt identifier bits supported.

| IDbits | Meaning |  |
|--------|---------|--|
| 00000  | 16 bits |  |
| 0b001  | 24 bits |  |

## SEIS, bit [22] When FEAT\_GICv3 is implemented: SEI Support. Otherwise: RESO A3V, bit [21] Affinity 3 VALID.

| A3V | Meaning                                                                                                     |
|-----|-------------------------------------------------------------------------------------------------------------|
| 0b0 | The virtual CPU interface logic only supports zero values of Affinity 3 in SGI generation System registers. |
| 0b1 | The virtual CPU interface logic supports non-zero values of Affinity 3 in SGI generation System registers.  |

## nV4, bit [20]

Direct injection of virtual interrupts not supported.

This bit is RES1.

## TDS, bit [19]

When FEAT\_GICv3 is implemented:

Support for ICH\_HCR\_EL2.TDIR.

Otherwise:

res1

#### DVIM, bit [18]

#### When FEAT\_GICv3 is implemented:

Masking of directly-injected virtual interrupts.

Otherwise:

res0

#### Bits [17:5]

Reserved, RESO.

## ListRegs, bits [4:0]

The number of List Registers minus 1.

## Accessing ICH\_VTR\_EL2

Read-only

Accesses to this register use the following encodings in the System register encoding space:

## MRS <Xt>, ICH\_VTR\_EL2

#### Chapter 9. System registers 9.7. Legacy hypervisor control registers

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b100 | 0b1100 | 0b1011 | 0b001 |

```
if PSTATE.EL == ELO then
   UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' && ICH_VCTLR_EL2.V3 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL2.SRE == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        X[t, 64] = ICH_VTR_EL2;
elsif PSTATE.EL == EL3 then
    if IsFeatureImplemented(FEAT_GICv3) && ICC_SRE_EL3.SRE == '0' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = ICH_VTR_EL2;
```

## 9.7.9 Nested virtualization

I<sub>HPNKC</sub> The Arm architecture's enhanced support for nested virtualization (FEAT\_NV2) provides a mechanism for hardware to transform reads and writes from System registers into reads and writes from memory.

When accesses to system registers introduced by GICv3 are transformed into memory accesses, the offsets are unchanged by GICv5. See "Enhanced support for nested virtualization" in the Architecture Reference Manual for A-profile [1].

## 9.8 Legacy virtual CPU interface registers

Configuration and state of Legacy virtual CPU interface accessible from a GICv3.3 VM.

## 9.8.1 AArch64 Legacy virtual CPU interface registers

 $\mathsf{R}_{\mathsf{WSWHT}}$ 

When FEAT\_GICv3 or FEAT\_GCIE\_LEGACY is implemented, the following registers are present:

- ICV\_AP0R0\_EL1, Interrupt Controller Virtual Active Priorities Group 0 Registers
- ICV\_AP1R0\_EL1, Interrupt Controller Virtual Active Priorities Group 1 Registers
- ICV\_BPR0\_EL1, Interrupt Controller Virtual Binary Point Register 0
- ICV\_BPR1\_EL1, Interrupt Controller Virtual Binary Point Register 1
- ICV\_CTLR\_EL1, Interrupt Controller Virtual Control Register
- ICV\_DIR\_EL1, Interrupt Controller Deactivate Virtual Interrupt Register
- ICV\_EOIR0\_EL1, Interrupt Controller Virtual End Of Interrupt Register 0
- ICV\_EOIR1\_EL1, Interrupt Controller Virtual End Of Interrupt Register 1
- ICV\_HPPIR0\_EL1, Interrupt Controller Virtual Highest Priority Pending Interrupt Register 0
- ICV\_HPPIR1\_EL1, Interrupt Controller Virtual Highest Priority Pending Interrupt Register 1
- ICV\_IAR0\_EL1, Interrupt Controller Virtual Interrupt Acknowledge Register 0
- ICV\_IAR1\_EL1, Interrupt Controller Virtual Interrupt Acknowledge Register 1
- ICV\_IGRPEN0\_EL1, Interrupt Controller Virtual Interrupt Group 0 Enable Register
- ICV IGRPEN1 EL1, Interrupt Controller Virtual Interrupt Group 1 Enable Register
- ICV\_NMIAR1\_EL1, Interrupt Controller Virtual Non-maskable Interrupt Acknowledge Register 1
- ICV\_PMR\_EL1, Interrupt Controller Virtual Interrupt Priority Mask Register
- ICV\_RPR\_EL1, Interrupt Controller Virtual Running Priority Register

The above registers are as described in [3].

R<sub>XKKDD</sub> When either FEAT\_GICv3 or FEAT\_GCIE\_LEGACY is implemented, the registers listed in Table 9.184 are present.

When FEAT\_GCIE\_LEGACY is implemented, all of the following are true:

- When HCR\_EL2.IMO is 1 and Legacy operation is enabled, all of the following are true:
  - Accesses at EL1 to the registers listed in Table 9.184 generate a Trap exception taken to EL2 and reported using EC syndrome value 0x18.
  - Accesses at any Exception level other than EL1 to the registers listed in Table 9.184 are UNDEFINED.
- When HCR\_EL2.IMO is 0 or Legacy operation is disabled, the registers listed in Table 9.184 are UNDEFINED at any Exception level.

## Table 9.184: GICv3 CPU Interface registers

| Register       |
|----------------|
| ICC_SGI0R_EL1  |
| ICC_SGI1R_EL1  |
| ICC_ASGI1R_EL1 |

The registers listed in Table 9.184 are described in [3].

When either FEAT\_GICv3 or FEAT\_GCIE\_LEGACY is implemented, ICC\_SRE\_EL1 is present.

When FEAT\_GCIE\_LEGACY is implemented, all of the following are true:

• When HCR\_EL2.IMO is 1 and Legacy operation is enabled, all of the following are true: – For an access at EL1 to ICC\_SRE\_EL1, accesses to the following fields are RAO/WI:

R<sub>MCTMX</sub>

- \* ICC\_SRE\_EL1.SRE
- \* ICC\_SRE\_EL1.DFB
- \* ICC\_SRE\_EL1.DIB
- Access at any Exception level other than EL1 to ICC\_SRE\_EL1 is UNDEFINED.

When either FEAT\_GICv3 or FEAT\_GCIE\_LEGACY is implemented, the following fields are present:

• When HCR\_EL2.IMO is 0 or Legacy operation is disabled, ICC\_SRE\_EL1 is UNDEFINED at any Exception level.

ICC\_SRE\_EL1 Table 9.184 is described in [3].

 $R_{\text{PWDWZ}}$ 

- HFGRTR\_EL2.ICC\_IGRPENn\_EL1
  - HFGWTR\_EL2.ICC\_IGRPENn\_EL1

The above fields are described in [1].

# Chapter 10 Registers and memory maps

This chapter describes the registers and memory mapped interfaces of GICv5 components.

# 10.1 Memory-mapped programmer's model

| R <sub>JYKRN</sub> | Accesses to registers that are not implemented is CONSTRAINED UNPREDICTABLE and results in either:                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul><li>The access has RAZ/WI behavior.</li><li>The location has the same behavior as RES0.</li></ul>                                                                                                                                                                                                                                                                                                                                                                       |
| R <sub>JGRJR</sub> | The access type definitions for the memory-mapped register interface are:                                                                                                                                                                                                                                                                                                                                                                                                   |
|                    | <ul> <li>RW: Read and write.</li> <li>RO: Read only. Writes are ignored.</li> <li>WO: Write only. Reads return an UNKNOWN value.</li> <li>WI: Write ignore. Reads return an UNKNOWN value.</li> <li>UNKNOWN/WI: The same as WI.</li> <li>RAZ/WI: Read-As-Zero, Writes Ignored.</li> <li>RES0: RES0 as defined in [1].</li> <li>RES1: RES1 as defined in [1].</li> </ul>                                                                                                     |
| R <sub>dqmpd</sub> | In the register definitions, references to other registers are always to a register in the same register frame as where the access is made.                                                                                                                                                                                                                                                                                                                                 |
| R <sub>hqtxf</sub> | All registers for the IWB, the ITS, and IRS are little-endian.                                                                                                                                                                                                                                                                                                                                                                                                              |
| R <sub>wrlmj</sub> | All registers are either 32-bit or 64-bit.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | An implementation supports aligned 32-bit accesses to all registers and aligned 64-bit accesses to 64-bit registers. When a 32-bit access occurs to a 64-bit register, bits[63:32] of the register are accessed at offset +4 and bits[31:0] at offset 0.                                                                                                                                                                                                                    |
|                    | All aligned single-copy atomic accesses to a register of the same size as the access are treated as single-copy atomic accesses by the GIC.                                                                                                                                                                                                                                                                                                                                 |
|                    | Aligned 16-bit halfword accesses are supported only to the lower half of the following registers:                                                                                                                                                                                                                                                                                                                                                                           |
|                    | <ul><li>ITS_TRANSLATER</li><li>ITS_RL_TRANSLATER</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | All other accesses are <i>illegal accesses</i> .                                                                                                                                                                                                                                                                                                                                                                                                                            |
| R <sub>vxdyh</sub> | The behavior of an illegal access is CONSTRAINED UNPREDICTABLE to one of the following:                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | <ul> <li>The access is RAZ/WI.</li> <li>The access completes on the GIC and one of the following is true: <ul> <li>The access is a read and the read returns an UNKNOWN value.</li> <li>The access is a write and the write sets any field of the accessed register, including fields outside the access, to an UNKNOWN value. It is CONSTRAINED UNPREDICTABLE whether side effects of a write occur or not.</li> </ul> </li> <li>The access generates an abort.</li> </ul> |
|                    | A 64-bit access to two adjacent 32-bit registers is CONSTRAINED UNPREDICTABLE and has one of the following behaviors:                                                                                                                                                                                                                                                                                                                                                       |
|                    | <ul> <li>The access is RAZ/WI.</li> <li>A read returns the value of both registers and a write updates both registers, as though two 32-bit accesses were performed in an UNPREDICTABLE order.</li> <li>One of the pair of registers is read or written and the other register is RAZ/WI, as though a single 32-bit access was performed to an UNPREDICTABLE one of the pair of registers.</li> <li>The access generates an abort.</li> </ul>                               |
| D <sub>rflqg</sub> | Some register fields are <i>Guarded</i> by another field in the same or another register. In the GICv5 specification, a Guarded register field is <b>RO</b> or <b>WI</b> unless the field by which it is Guarded is in a certain state.                                                                                                                                                                                                                                     |

|                    | For example, IRS_IST_BASER.ADDR is Guarded by IRS_IST_BASER.VALID and IRS_PE_SELR.IAFFID is Guarded by IRS_PE_STATUSR.IDLE.                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>brrwq</sub> | Writing to Guarded register fields that are <b>RO</b> or <b>WI</b> have no effects beyond optionally reporting an error in the software error reporting mechanism.                                                                                                                                                                                                                                                                                                                                         |
| S <sub>MXQGP</sub> | Software must ensure proper ordering when updating Guarded fields.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | For a write that updates the field by which other fields are Guarded, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | <ul> <li>In order to update the Guarded fields, software must ensure that the GIC has observed the write before it observes a write to the Guarded fields .</li> <li>This ordering can be enforced through the use of an appropriate memory type for accesses and by issuing appropriate barriers, or by reading back the write before making another write to the Guarded fields.</li> </ul>                                                                                                              |
|                    | For a write that updates Guarded fields, all of the following are true:                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                    | <ul> <li>To make sure the GIC observes the write to the Guarded fields, software must ensure that the GIC has observed the write to the Guarded fields before it observes a write to the field by which they are Guarded.</li> <li>This ordering can be enforced through the use of an appropriate memory type for accesses and by issuing appropriate barriers, or by reading back the value written to the Guarded fields before making another write to the field by which they are Guarded.</li> </ul> |
| D <sub>dyzrk</sub> | Some registers that have write side-effects define an <i>action bit</i> . The side effects take place when a write occurs that sets the action bit to 1.                                                                                                                                                                                                                                                                                                                                                   |
|                    | Registers with an action bit are always tracked with an IDLE bit in a status register to indicate when the write side-effects are complete.                                                                                                                                                                                                                                                                                                                                                                |
| I <sub>twsrh</sub> | Following a write that sets the action bit to 1, when the corresponding IDLE bit is 1, another write that sets the action bit to 1, without any intervening write that sets the action bit to 0, will cause the side-effects defined by the register.                                                                                                                                                                                                                                                      |
| I <sub>XXQBX</sub> | If a write occurs to a register that has write side-effects and define an action bit, and the write does not write 1 to the action bit, the write side-effects will not take place and other registers controlled by the register with the action bit are not affected.                                                                                                                                                                                                                                    |
|                    | For example, if a write occurs to IRS_VPE_SELR that does not set IRS_VPE_SELR.S to 1, updates to any of the IRS_VPE_x registers apply to the VPE selected the last time a write occurred that set IRS_VPE_SELR.S to 1.                                                                                                                                                                                                                                                                                     |
| I <sub>ffyyh</sub> | 64-bit registers that have write side-effects, and support 32-bit accesses, define an action bit in either of the 32-bit halves.                                                                                                                                                                                                                                                                                                                                                                           |
|                    | The write side-effects can use the full 64-bit register value as input to their operation when a write follows this sequence:                                                                                                                                                                                                                                                                                                                                                                              |
|                    | <ol> <li>Write to the 32-bit half of the register which does not contain the action bit.</li> <li>Ensure the write is observed before a following write by using a barrier instruction or reading back the value written to the 32-bit half of the register.</li> <li>Write to the other 32-bit half of the register, which contains the action bit, setting the action bit to 1.</li> </ol>                                                                                                               |
| R <sub>SCDGF</sub> | Registers are not required to support being the target of exclusive or atomic read-modify-write update operations.                                                                                                                                                                                                                                                                                                                                                                                         |
| I <sub>VBHBM</sub> | Register frames associated with an Interrupt Domain are accessible via the PAS associated with that Interrupt Domain.                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | For register frames not associated with the MPPAS, except for the ITS_TRANSLATE_FRAME and IRS_SETLPI_FRAME, it is IMPLEMENTATION DEFINED whether the register frames are also accessible in the MPPAS at the same addresses.                                                                                                                                                                                                                                                                               |
| I <sub>WJTJR</sub> | Any memory-mapped access to a GICv5 register region is defined to be beyond the PE.                                                                                                                                                                                                                                                                                                                                                                                                                        |

# Chapter 10. Registers and memory maps 10.1. Memory-mapped programmer's model

S<sub>DGVJR</sub> Armv9 does not require the size of each element accessed by a multi-register load or store instruction to be identifiable by the memory system beyond the PE.

Software can use a Device-nGRE or stronger memory-type, and use only single register load and store instructions, to create memory accesses that are supported by a GICv5 implementation.

Reads and writes of the memory-mapped registers complete in the order in which they arrive at the GIC.

For accesses to different register locations, software can determine the order in which they are arrive at the GIC by doing all of the following:

- Accessing the GIC using the Device-nGnRnE or Device-nGnRE memory types.
- Using the appropriate memory barriers.

Software can determine the completion of a write by doing one of the following:

- Accessing the GIC using the Device-nGnRnE memory type and executing a DSB barrier.
- Reading back the value written.

For more information on memory types and barriers ensuring completion, see [1].

# 10.2 IRS register frames

| I <sub>DLZJM</sub> | For each Interrupt Domain, the IRS exposes the following register frames:                                                                                                                |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | 1. The IRS configuration frame.                                                                                                                                                          |
|                    | 2. Optionally, the SETLPI register frame.                                                                                                                                                |
|                    | Each register frame size is 64K.                                                                                                                                                         |
| I <sub>JWWVY</sub> | In the IRS register definitions, references to other registers are always to a register in the register frame for the same Interrupt Domain on the same IRS as where the access is made. |
|                    | •                                                                                                                                                                                        |

I<sub>GGXDW</sub> If IRS\_IDR0.SETLPI is 0, the SETLPI register frame is not present.

## 10.2.1 IRS\_CONFIG\_FRAME, IRS configuration register frame

The IRS\_CONFIG\_FRAME characteristics are:

#### Purpose

Contains control registers for an IRS for an Interrupt Domain.

An IRS configuration register frame is present for each supported Interrupt Domain on each IRS.

This register frame is accessible in the PAS associated with the Interrupt Domain.

It is IMPLEMENTATION DEFINED whether this register frame is also accessible in the MPPAS at the same address.

The base address is distinct from the base address of any other GIC register frame, including the configuration register frames for other Interrupt Domains on all IRSs.

The base address is aligned to 64KB.

#### Attributes

The IRS\_CONFIG\_FRAME block is of size 64KB

#### Default access

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

#### Contents

| Offset | Name              | Notes                      |
|--------|-------------------|----------------------------|
| 0x0000 | IRS_IDR0          | Most permissive access: RO |
| 0x0004 | IRS_IDR1          | Most permissive access: RO |
| 0x0008 | IRS_IDR2          | Most permissive access: RO |
| 0x000C | IRS_IDR3          | Most permissive access: RO |
| 0x0010 | IRS_IDR4          | Most permissive access: RO |
| 0x0014 | IRS_IDR5          | Most permissive access: RO |
| 0x0018 | IRS_IDR6          | Most permissive access: RO |
| 0x001C | IRS_IDR7          | Most permissive access: RO |
| 0x0040 | IRS_IIDR          | Most permissive access: RO |
| 0x0044 | IRS_AIDR          | Most permissive access: RO |
| 0x0080 | IRS_CR0           | Most permissive access: RW |
| 0x0084 | IRS_CR1           | Most permissive access: RW |
| 0x00C0 | IRS_SYNCR         | Most permissive access: WO |
| 0x00C4 | IRS_SYNC_STATUSR  | Most permissive access: RO |
| 0x0100 | IRS_SPI_VMR       | Most permissive access: RW |
| 0x0108 | IRS_SPI_SELR      | Most permissive access: WO |
| 0x010C | IRS_SPI_DOMAINR   | Most permissive access: RW |
| 0x0110 | IRS_SPI_RESAMPLER | Most permissive access: WO |
| 0x0114 | IRS_SPI_CFGR      | Most permissive access: RW |

Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

| Offset                            | Name                 | Notes                                         |
|-----------------------------------|----------------------|-----------------------------------------------|
| 0x0118                            | IRS_SPI_STATUSR      | Most permissive access: RO                    |
| 0x0140                            | IRS_PE_SELR          | Most permissive access: WO                    |
| 0x0144                            | IRS_PE_STATUSR       | Most permissive access: RO                    |
| 0x0148                            | IRS_PE_CR0           | Most permissive access: RW                    |
| 0x0180                            | IRS_IST_BASER        | Most permissive access: RW                    |
| 0x0190                            | IRS_IST_CFGR         | Most permissive access: RW                    |
| 0x0194                            | IRS_IST_STATUSR      | Most permissive access: RO                    |
| 0x01C0                            | IRS_MAP_L2_ISTR      | Most permissive access: WO                    |
| 0x0200                            | IRS_VMT_BASER        | Most permissive access: RW                    |
| 0x0210                            | IRS_VMT_CFGR         | Most permissive access: RW                    |
| 0x0214                            | IRS_VMT_STATUSR      | Most permissive access: RO                    |
| 0x0240                            | IRS_VPE_SELR         | Most permissive access: RW                    |
| 0x0248                            | IRS_VPE_DBR          | Most permissive access: RW                    |
| 0x0250                            | IRS_VPE_HPPIR        | Most permissive access: RO                    |
| 0x0258                            | IRS_VPE_CR0          | Most permissive access: RW                    |
| 0x025C                            | IRS_VPE_STATUSR      | Most permissive access: RO                    |
| 0x0280                            | IRS_VM_DBR           | Most permissive access: RW                    |
| 0x0288                            | IRS_VM_SELR          | Most permissive access: WO                    |
| 0x028C                            | IRS_VM_STATUSR       | Most permissive access: RO                    |
| 0x02C0                            | IRS_VMAP_L2_VMTR     | Most permissive access: RW                    |
| 0x02C8                            | IRS_VMAP_VMR         | Most permissive access: RW                    |
| 0x02D0                            | IRS_VMAP_VISTR       | Most permissive access: RW                    |
| 0x02D8                            | IRS_VMAP_L2_VISTR    | Most permissive access: RW                    |
| 0x02E0                            | IRS_VMAP_VPER        | Most permissive access: RW                    |
| 0x0300                            | IRS_SAVE_VMR         | Most permissive access: RW                    |
| 0x0308                            | IRS_SAVE_VM_STATUSR  | Most permissive access: RO                    |
| 0x0340                            | IRS_MEC_IDR          | Most permissive access: RO                    |
| 0x0344                            | IRS_MEC_MECID_R      | Most permissive access: RW                    |
| 0x0380                            | IRS_MPAM_IDR         | Most permissive access: RO                    |
| 0x0384                            | IRS_MPAM_PARTID_R    | Most permissive access: RW                    |
| 0x03C0                            | IRS_SWERR_STATUSR    | Most permissive access: RW                    |
| 0x03C8                            | IRS_SWERR_SYNDROMER0 | Most permissive access: RO                    |
| 0x03D0                            | IRS_SWERR_SYNDROMER1 | Most permissive access: RO                    |
| 0x0E00 + (4 * n)for n in<br>⇔63:0 | -                    | Most permissive access: ImplementationDefined |

## 10.2.1.1 IRS\_AIDR

The IRS\_AIDR characteristics are:

#### Purpose

IRS Architecture Identification Register. Identifies the GIC architecture version to which the implementation conforms.

#### Attributes

IRS\_AIDR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_AIDR bit assignments are:



#### Bits [31:12]

Reserved, RESO.

#### Component, bits [11:8]

GIC component

| Component | Meaning |  |
|-----------|---------|--|
| 000000    | IRS     |  |
| 0b0001    | ITS     |  |
| 0b0010    | IWB     |  |

## ArchMajorRev, bits [7:4]

Major Architecture revision.

| ArchMajorRev | Meaning |
|--------------|---------|
| 00000        | GICv5.x |

#### ArchMinorRev, bits [3:0]

Minor Architecture revision.

| ArchMinorRev | Meaning |
|--------------|---------|
| 060000       | GICv5.0 |

#### Accessing IRS\_AIDR

Accesses to this register use the following encodings:

#### Accessible at address 0x0044

Access on this interface is **RO**.

## 10.2.1.2 IRS\_CR0

The IRS\_CR0 characteristics are:

#### Purpose

IRS control register 0.

#### Attributes

IRS\_CR0 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_CR0 bit assignments are:



#### Bits [31:2]

Reserved, RESO.

#### IDLE, bit [1]

Whether the transition between enabled and disabled states of the IRS for the Interrupt Domain is complete.

| IDLE | Meaning                                                             |
|------|---------------------------------------------------------------------|
| 0b0  | The effects of updating IRSEN are not guaranteed to have completed. |
| 0b1  | The effects of updating IRSEN are have completed.                   |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

Access to this field is **RO**.

#### IRSEN, bit [0]

Controls whether the IRS Forwards and Recalls candidate HPPIs to PEs for the Interrupt Domain.

| IRSEN | Meaning                                       |
|-------|-----------------------------------------------|
| 0d0   | The IRS is disabled for the Interrupt Domain. |
| 0b1   | The IRS is enabled for the Interrupt Domain.  |

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b0.

Accessing this field has the following behavior:

- When IRS\_CR0.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

#### Accessing IRS\_CR0

Accesses to this register use the following encodings:

#### Accessible at address 0x0080

Access on this interface is **RW**.

## 10.2.1.3 IRS\_CR1

The IRS\_CR1 characteristics are:

#### Purpose

IRS configuration register 1

#### Attributes

IRS\_CR1 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_CR1 bit assignments are:



#### Bits [31:16]

Reserved, RESO.

#### VPED\_WA, bit [15]

When IRS\_IDR0.VIRT == 1:

Write-Allocate hint for the VPE descriptors.

| VPED_WA | Meaning            |
|---------|--------------------|
| 0b0     | No Write-Allocate. |
| 0b1     | Write-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

#### VPED\_RA, bit [14]

When IRS\_IDR0.VIRT == 1:

Read-Allocate hint for the VPE descriptors.

| VPED_RA | Meaning           |
|---------|-------------------|
| 0b0     | No Read-Allocate. |
| 0b1     | Read-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

#### VMD\_WA, bit [13]

#### When IRS\_IDR0.VIRT == 1:

Write-Allocate hint for the VM descriptors.

| VMD_WA | Meaning            |  |
|--------|--------------------|--|
| 0b0    | No Write-Allocate. |  |
| 0b1    | Write-Allocate.    |  |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

#### *VMD\_RA, bit [12]*

When IRS\_IDR0.VIRT == 1:

Read-Allocate hint for the VM descriptors.

| VMD_RA | Meaning           |
|--------|-------------------|
| 0b0    | No Read-Allocate. |
| 0b1    | Read-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

VPET\_WA, bit [11]

#### When IRS\_IDR0.VIRT == 1:

Write-Allocate hint for the VPE table.

| VPET_WA | Meaning            |
|---------|--------------------|
| 0b0     | No Write-Allocate. |
| 0b1     | Write-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

## VPET\_RA, bit [10]

## When IRS\_IDR0.VIRT == 1:

Read-Allocate hint for the VPE table.

| VPET_RA | Meaning           |
|---------|-------------------|
| 0b0     | No Read-Allocate. |
| 0b1     | Read-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Otherwise:

res0

## VMT\_WA, bit [9]

When IRS\_IDR0.VIRT == 1:

Write-Allocate hint for the VM table.

| VMT_WA | Meaning            |
|--------|--------------------|
| 0b0    | No Write-Allocate. |
| 0b1    | Write-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

#### VMT\_RA, bit [8]

## When IRS\_IDR0.VIRT == 1:

Read-Allocate hint for the VM table.

| VMT_RA | Meaning           |
|--------|-------------------|
| 0b0    | No Read-Allocate. |
| 0b1    | Read-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Otherwise:

res0

## IST\_WA, bit [7]

Write-Allocate hint for ISTs.

When IRS\_IDR0.VIRT is 1, this control applies to the virtual ISTs as well as the physical IST.

| IST_WA | Meaning            |
|--------|--------------------|
| 0b0    | No Write-Allocate. |
| 0b1    | Write-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## IST\_RA, bit [6]

Read-Allocate hint for ISTs.

When IRS\_IDR0.VIRT is 1, this control applies to the virtual ISTs as well as the physical IST.

| IST_RA | Meaning           |
|--------|-------------------|
| 0b0    | No Read-Allocate. |
| 0b1    | Read-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## IC, bits [5:4]

Controls the Inner Cacheability attribute used when the IRS accesses tables as a requester.

| IC   | Meaning                    |
|------|----------------------------|
| 0b00 | Non-cacheable.             |
| 0b01 | Write-Back Cacheable.      |
| 0b10 | Write-Through Cacheable.   |
| 0b11 | Reserved, treated as 0b00. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## OC, bits [3:2]

Controls the Outer Cacheability attribute used when the IRS accesses tables as a requester.

| OC   | Meaning        |
|------|----------------|
| 0b00 | Non-cacheable. |

| OC   | Meaning                    |
|------|----------------------------|
| 0b01 | Write-Back Cacheable.      |
| 0b10 | Write-Through Cacheable.   |
| 0b11 | Reserved, treated as 0b00. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## SH, bits [1:0]

Controls the Shareability attribute used when the IRS accesses tables as a requester.

| SH   | Meaning                    |
|------|----------------------------|
| 0b00 | Non-shareable.             |
| 0b01 | Reserved, treated as 0b00. |
| 0b10 | Outer Shareable.           |
| 0b11 | Inner Shareable.           |

When IRS\_CR1.OC is 0b00 and IRS\_CR1.IC is 0b00, this field is IGNORED and behaves as Outer Shareable.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Accessing IRS\_CR1

Accesses to this register use the following encodings:

- When IRS\_IST\_BASER.VALID == 1 or IRS\_IST\_STATUSR.IDLE == 0, access on this interface is **RO**.
- When IRS\_VMT\_BASER.VALID == 1 or IRS\_VMT\_STATUSR.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.4 IRS\_IDR0

The IRS\_IDR0 characteristics are:

## Purpose

IRS identification register 0. Contains read-only fields with information about the IRS GIC component.

## Attributes

IRS\_IDR0 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IDR0 bit assignments are:



## IRSID, bits [31:16]

Unique identifier for this IRS in the system.

This value is the same across all Interrupt Domains for this IRS.

## Bits [15:13]

Reserved, RESO.

## SWE, bit [12]

Software error reporting support in the Interrupt Domain.

| SWE | Meaning                                    |
|-----|--------------------------------------------|
| 0b0 | Software error reporting is not supported. |
| 0b1 | Software error reporting is supported.     |

Support for Software error reporting is optional.

## MPAM, bit [11]

Memory Partitioning And Monitoring (MPAM) support.

| MPAM | Meaning                |
|------|------------------------|
| 0b0  | MPAM is not supported. |
| 0b1  | MPAM is supported.     |

Support for MPAM is optional.

## MEC, bit [10]

## When IRS\_IDR0.INT\_DOM == 0b11:

Support for Memory Encryption Contexts (MEC) for the Realm Interrupt Domain.

| MEC | Meaning                                       |
|-----|-----------------------------------------------|
| 0b0 | Memory Encryption Contexts are not supported. |
| 0b1 | Memory Encryption Contexts are supported.     |

Support for MEC is optional.

Otherwise:

res0

#### SETLPI, bit [9]

## When IRS\_IDR2.LPI == 1:

Whether the IRS implements the IRS SETLPI register.

The IRS SETLPI register allows an MSI to set a physical LPI Pending without translation by an ITS.

| SETLPI | Meaning                                             |  |
|--------|-----------------------------------------------------|--|
| 0b0    | The IRS does not implement the IRS SETLPI register. |  |
| 0b1    | The IRS implements the IRS SETLPI register.         |  |

## Otherwise:

res0

## VIRT\_ONE\_N, bit [8]

Whether virtual 1ofN is supported.

| VIRT_ONE_N | Meaning                        |
|------------|--------------------------------|
| 0b0        | Virtual 1ofN is not supported. |
| 0b1        | Virtual 1ofN is supported.     |

This field is RESO, if any of the following are true:

- Virt is 0.
- ONE\_N is 0.

| NE_N |
|------|
|------|

## ONE\_N, bit [7]

| ONE_N | Meaning                |
|-------|------------------------|
| 0b0   | 1ofN is not supported. |
| 0b1   | 1ofN is supported.     |

## VIRT, bit [6]

This field is RESO for the EL3 Interrupt Domain

| VIRT | Meaning                          |
|------|----------------------------------|
| 0b0  | Virtualization is not supported. |
| 0b1  | Virtualization is supported.     |

## PA\_RANGE, bits [5:2]

Physical Address range supported.

The physical address range corresponds to the system physical address size.

The value of this field is the same for all Interrupt Domains across all IRSs in the system.

| PA_RANGE | Meaning        |
|----------|----------------|
| 000000   | 32 bits, 4GB   |
| 0b0001   | 36 bits, 64GB  |
| 0b0010   | 40 bits, 1TB   |
| 0b0011   | 42 bits, 4TB   |
| 0b0100   | 44 bits, 16TB  |
| 0b0101   | 48 bits, 256TB |
| 0b0110   | 52 bits, 4PB   |
| 0b0111   | 56 bits, 64PB  |

Values not defined above are reserved.

## INT\_DOM, bits [1:0]

The Interrupt Domain that the register frame containing this register controls.

| INT_DOM | Meaning    |
|---------|------------|
| 0000    | Secure     |
| 0b01    | Non-secure |

| INT_DOM | Meaning |
|---------|---------|
| 0b10    | EL3     |
| 0b11    | Realm   |

## Accessing IRS\_IDR0

Accesses to this register use the following encodings:

## Accessible at address 0x0000

# 10.2.1.5 IRS\_IDR1

The IRS\_IDR1 characteristics are:

## Purpose

IRS identification register 1. Contains read-only fields with information about the IRS GIC component.

## Attributes

IRS\_IDR1 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IDR1 bit assignments are:



## Bits [31:23]

Reserved, RESO.

## PRI\_BITS, bits [22:20]

The number of priority bits implemented, minus one.

| PRI_BITS | Meaning             |  |
|----------|---------------------|--|
| 00000    | 1 bit of priority.  |  |
| 0b001    | 2 bits of priority. |  |
| 0b010    | 3 bits of priority. |  |
| 0b011    | 4 bits of priority. |  |
| 0b100    | 5 bits of priority. |  |

Values not defined above are reserved.

When fewer than 5 bits are implemented, the lower order priority bits are RESO.

## IAFFID\_BITS, bits [19:16]

Number of bits of IAFFID supported - 1.

Unimplemented upper bits of IAFFID are RESO when sending and receiving commands between a PE and the IRS.

## PE\_CNT, bits [15:0]

The number of PEs connected to this IRS.

#### Accessing IRS\_IDR1

Accesses to this register use the following encodings:

## Accessible at address 0x0004

# 10.2.1.6 IRS\_IDR2

The IRS\_IDR2 characteristics are:

#### Purpose

IRS identification register 2. Contains read-only fields with information about the IRS GIC component.

## Attributes

IRS\_IDR2 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_IDR2 bit assignments are:



## Bits [31:20]

Reserved, RESO.

## ISTMD\_SZ, bits [19:15]

Describes the minimum number of INTID.ID bits which requires a level 2 ISTE size of 16 bytes to store metadata.

When the configured number of INTID.ID bits is smaller than ISTMD\_SZ, the minimum required size of a level 2 ISTE is 8 bytes.

When the configured number of INTID.ID bits is larger than or equal to ISTMD\_SZ, the minimum required size of a level 2 ISTE is 16 bytes.

When ISTMD is 0, this field is RES0.

## ISTMD, bit [14]

Whether the IST entries contain metadata storage.

When the IST entires contain metadata storage, the size of a level 2 ISTE is 8 bytes or 16 bytes.

The size of an IST entry containing metadata depends on the configured ID range and the values reported in ISTMD\_SZ.

| ISTMD | Meaning                                                                                             |
|-------|-----------------------------------------------------------------------------------------------------|
| 0b0   | The IST entries do not require storage for metadata and the size of a level 2 ISTE is 4 bytes.      |
| 0b1   | The IST entries require storage for metadata and the size of a level 2 ISTE is 8 bytes or 16 bytes. |

## IST\_L2SZ, bits [13:11]

Supported level 2 IST sizes when a 2-level IST structure is used.

| IST_L2SZ | Meaning                                          |
|----------|--------------------------------------------------|
| 0b001    | Level 2 IST sizes supported: 4KB                 |
| 0b010    | Level 2 IST sizes supported: 16KB                |
| 0b011    | Level 2 IST sizes supported: 4KB and 16KB        |
| 0b100    | Level 2 IST sizes supported: 64KB                |
| 0b101    | Level 2 IST sizes supported: 4KB and 64KB        |
| 0b110    | Level 2 IST sizes supported: 16KB and 64KB       |
| 0b111    | Level 2 IST sizes supported: 4KB, 16KB, and 64KB |

Values not defined above are reserved.

When IST\_LEVELS is 0, this field is RES0.

When LPI is 0, this field is RES0.

## IST\_LEVELS, bit [10]

Levels supported for the IST.

When LPI is 0, this field is RES0.

| IST_LEVELS | Meaning                                                             |
|------------|---------------------------------------------------------------------|
| 0b0        | Only a single level linear structure is supported.                  |
| 0b1        | 2-level structure is supported in addition to the linear structure. |

## MIN\_LPI\_ID\_BITS, bits [9:6]

The minimum number of LPI\_ID\_BITS supported.

The maximum value supported for this field is 14.

When LPI is 0, this field is RES0.

## LPI, bit [5]

Whether physical LPIs are implemented.

When physical LPIs are not supported, the physical IST registers are not implemented.

## ID\_BITS, bits [4:0]

The maximum number of INTID.ID bits that the IRS supports.

The maximum supported value of this field is 24.

## Accessing IRS\_IDR2

Accesses to this register use the following encodings:

## Accessible at address 0x0008

## 10.2.1.7 IRS\_IDR3

The IRS\_IDR3 characteristics are:

## Purpose

IRS identification register 3. Contains read-only fields with information about the IRS GIC component.

## Attributes

IRS\_IDR3 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IDR3 bit assignments are:

| 31 11 | 10 | 9 5        | 4 1    | 0 | J   |
|-------|----|------------|--------|---|-----|
| RES0  |    | VM_ID_BITS | VMD_SZ |   |     |
|       |    | VMT LEVELS |        | T | VMD |

## Bits [31:11]

Reserved, RESO.

## VMT\_LEVELS, bit [10]

## When IRS\_IDR0.VIRT == 1:

Levels supported for the VM table.

| VMT_LEVELS | Meaning                                                             |
|------------|---------------------------------------------------------------------|
| 0b0        | Only a single level linear structure is supported.                  |
| 0b1        | 2-level structure is supported in addition to the linear structure. |

#### Otherwise:

res0

#### VM\_ID\_BITS, bits [9:5]

#### When IRS\_IDR0.VIRT == 1:

The maximum number of VM ID bits that the IRS supports.

The minimum supported value of this field is 8 and the maximum supported value is 16.

Otherwise:

res0

VMD\_SZ, bits [4:1]

When IRS\_IDR0.VIRT == 1:

Specifies the size in bytes of a VM descriptor.

Each VM descriptor is 2<sup>(VMD\_SZ)</sup> bytes.

The minimum valid value for this field is 3 and the maximum valid value is 12.

This corresponds to a minimum descriptor size of 8 bytes and a maximum descriptor size of 4096 bytes.

#### Otherwise:

## res0

## VMD, bit [0]

## When IRS\_IDR0.VIRT == 1:

Whether each VM requires an IMPLEMENTATION DEFINED memory area.

| VMD | Meaning                                     |
|-----|---------------------------------------------|
| 0b0 | The VMs do not require VM descriptor areas. |
| 0b1 | Each VM requires a VM descriptor area.      |

## Otherwise:

res0

## Accessing IRS\_IDR3

Accesses to this register use the following encodings:

## Accessible at address 0x000C

# 10.2.1.8 IRS\_IDR4

The IRS\_IDR4 characteristics are:

## Purpose

IRS identification register 4. Contains read-only fields with information about the IRS GIC component.

## Attributes

IRS\_IDR4 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IDR4 bit assignments are:



## Bits [31:10]

Reserved, RESO.

## VPE\_ID\_BITS, bits [9:6]

The number of VPE ID bits supported - 1.

The minimum supported value of this field is 8 and the maximum supported value is 16.

Accessing this field has the following behavior:

- When IRS\_IDR0.VIRT == 0, access to this field is **RES0**
- Otherwise, access to this field is **RO**

## VPED\_SZ, bits [5:0]

Specifies the size in bytes of a VPE Descriptor.

Each VPE Descriptor is 2<sup>(VPED\_SZ)</sup> bytes.

The minimum valid value for this field is 3 and the maximum valid value is 12.

This corresponds to a minimum descriptor size of 8 bytes and a maximum descriptor size of 4096 bytes.

Accessing this field has the following behavior:

- When IRS\_IDR0.VIRT == 0, access to this field is **RES0**
- Otherwise, access to this field is **RO**

#### Accessing IRS\_IDR4

Accesses to this register use the following encodings:

#### Accessible at address 0x0010

# 10.2.1.9 IRS\_IDR5

The IRS\_IDR5 characteristics are:

## Purpose

IRS identification register 5. Contains read-only fields with information about the IRS GIC component.

## Attributes

IRS\_IDR5 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IDR5 bit assignments are:

| L <sup>31</sup> 25 | ا <sup>24</sup> و |
|--------------------|-------------------|
| RES0               | SPI_RANGE         |

## Bits [31:25]

Reserved, RESO.

## SPI\_RANGE, bits [24:0]

The total number of SPIs in the system.

The maximum value reported in this field is  $2^24$ .

The number reported in this register is the same across all Interrupt Domains and across all IRSs in a system.

## Accessing IRS\_IDR5

Accesses to this register use the following encodings:

## Accessible at address 0x0014

# 10.2.1.10 IRS\_IDR6

The IRS\_IDR6 characteristics are:

## Purpose

IRS identification register 6. Contains read-only fields with information about the range of SPI INTIDs managed by this IRS.

## Attributes

IRS\_IDR6 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IDR6 bit assignments are:



## Bits [31:25]

Reserved, RESO.

## SPI\_IRS\_RANGE, bits [24:0]

The number of SPI INTID.ID managed on this IRS.

The value reported in this field is less than or equal to the value reported in IRS\_IDR5.SPI\_RANGE.

If IRS\_IDR5.SPI\_RANGE is 0, this field is RES0.

## Accessing IRS\_IDR6

Accesses to this register use the following encodings:

## Accessible at address 0x0018

# 10.2.1.11 IRS\_IDR7

The IRS\_IDR7 characteristics are:

## Purpose

IRS identification register 7. Contains read-only fields with information about the minimum SPI INTID.ID value implemented on this IRS.

## Attributes

IRS\_IDR7 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IDR7 bit assignments are:



# Bits [31:24]

Reserved, RESO.

## SPI\_BASE, bits [23:0]

The minimum SPI INTID.ID implemented on this IRS.

If IRS\_IDR5.SPI\_RANGE is 0 or IRS\_IDR6.SPI\_IRS\_RANGE is 0, this field is RES0.

## Accessing IRS\_IDR7

Accesses to this register use the following encodings:

## Accessible at address 0x001C

# 10.2.1.12 IRS\_IIDR

The IRS\_IIDR characteristics are:

## Purpose

IRS Implementer Identification Register. Provides information about the implementation and implementer of the GIC, and architecture version supported.

## Attributes

IRS\_IIDR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IIDR bit assignments are:

| 31 |           | 20 | 19 16   | 15 12    | 11 0        |
|----|-----------|----|---------|----------|-------------|
|    | ProductID |    | Variant | Revision | Implementer |

## ProductID, bits [31:20]

IMPLEMENTATION DEFINED value identifying the GIC part

When the IRS\_PIDR $\{0,1\}$  registers are present, Arm expects that the IRS\_PIDR $\{0,1\}$ .PART\_ $\{0,1\}$  fields match the value of IRS\_IIDR.ProductID.

If required, however, an implementation is permitted to provide values for  $IRS_PIDR.\{0,1\}$ . PART\_ $\{0,1\}$  that do not match the value of  $IRS_IIDR$ . ProductID

## Variant, bits [19:16]

IMPLEMENTATION DEFINED value used to distinguish product variants, or major revisions of the product

## Revision, bits [15:12]

IMPLEMENTATION DEFINED value used to distinguish minor revisions of the product

## Implementer, bits [11:0]

Contains the JEP106 code of the company that implemented the GIC

For an Arm implementation, the JEP106 code is 0x43B

When the IRS\_PIDR $\{1,2,4\}$  registers are present, Arm expects that the IRS\_PIDR $\{0,1\}$ .PART\_ $\{0,1\}$  fields match the value of IRS\_IIDR.Implementer.

## Accessing IRS\_IIDR

Accesses to this register use the following encodings:

#### Accessible at address 0x0040

# 10.2.1.13 IRS\_IST\_BASER

The IRS\_IST\_BASER characteristics are:

## Purpose

IRS IST base address register

## Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_IST\_STATUSR.IDLE is 1.

## Attributes

IRS\_IST\_BASER is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IST\_BASER bit assignments are:



## Bits [63:56]

Reserved, RESO.

## ADDR, bits [55:6]

Bits[55:6] of the base physical address of the IST.

When IRS\_IST\_CFGR.STRUCTURE is 0, ADDR points to a linear IST and all of the following are true:

• Bits[N:0] of the resulting address are 0 where N depends on the ISTSZ and LPI\_ID\_BITS fields in IRS\_IST\_CFGR as follows:

 $N = Max(5, (ISTSZ + 1) + LPI_ID_BITS).$ 

• This means that the level 2 ISTE array is aligned to the size of the array or to a 64-byte boundary when its size is smaller than 64 bytes.

When IRS\_IST\_CFGR.STRUCTURE is 1, ADDR points to the level 1 table in a 2-level IST and all of the following are true:

• Bits[N:0] of the resulting address are 0 where N depends on L2SZ, ISTSZ, and LPI\_ID\_BITS in IRS\_IST\_CFGR as follows:

 $N = Max(5, LPI_ID_BITS - ((10 - ISTSZ) + (2 * L2SZ)) + 2)$ 

• This means that the level 1 IST is aligned to the size of the level 1 table or to a 64-byte boundary when its size is smaller than 64 bytes.

See 4.7 The interrupt state table (IST) for more information.

Access to any level of the IST and any additional memory accesses occurring as a result of the address in this field are performed using the PAS of the Interrupt Domain where this register is accessed.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RES0. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When IRS\_IST\_BASER.VALID == 1, access to this field is **RO**
- Otherwise, access to this field is **RW**

## Bits [5:1]

Reserved, RESO.

## VALID, bit [0]

Whether the ADDR points to a valid IST.

| VALID | Meaning                       |
|-------|-------------------------------|
| 0b0   | The IST address is not valid. |
| 0b1   | The IST address is valid.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b0.

## Accessing IRS\_IST\_BASER

Accesses to this register use the following encodings:

- When IRS\_IDR2.LPI == 0, access on this interface is **RAZ/WI**.
- When IRS\_IST\_STATUSR.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.14 IRS\_IST\_CFGR

The IRS\_IST\_CFGR characteristics are:

## Purpose

IRS IST configuration register

## Attributes

IRS\_IST\_CFGR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IST\_CFGR bit assignments are:



## Bits [31:17]

Reserved, RESO.

## STRUCTURE, bit [16]

Whether the IST uses a linear or 2-level structure.

| STRUCTURE | Meaning                          |
|-----------|----------------------------------|
| 0b0       | A linear IST structure is used.  |
| 0b1       | A 2-level IST structure is used. |

When IRS\_IDR2.IST\_LEVELS is 0, this field is RES0.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Bits [15:9]

Reserved, RESO.

## ISTSZ, bits [8:7]

The size of each level 2 ISTE.

Values not defined above are reserved.

If this field is programmed to specify a size smaller than the minimum required size or programmed to a reserved value, it is treated as having the value corresponding to the minimum required size for all other purposes than a direct read of the register.

See 4.7 *The interrupt state table (IST)* for more information about the minimum required size.

| ISTSZ | Meaning                                |
|-------|----------------------------------------|
| 0b00  | The size of a level 2 ISTE is 4 bytes. |
| 0b01  | The size of a level 2 ISTE is 8 bytes. |

| ISTSZ | Meaning                                 |
|-------|-----------------------------------------|
| 0b10  | The size of a level 2 ISTE is 16 bytes. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## L2SZ, bits [6:5]

Level 2 IST size when a 2-level IST structure is used.

| L2SZ | Meaning                       |
|------|-------------------------------|
| 0b00 | The level 2 IST size is 4KB.  |
| 0b01 | The level 2 IST size is 16KB. |
| 0b10 | The level 2 IST size is 64KB. |

Values not defined above are reserved.

IRS\_IDR2.IST\_L2SZ reports the supported values.

If LPI\_ID\_BITS <= ((10 - ISTSZ) + (2 \* L2SZ)) and STRUCTURE is 1, all of the following are true:

- The IST consists of a single L1\_ISTE and a single level 2 IST.
- The level 2 IST contains (2 ^ LPI\_ID\_BITS) entries.
- The IRS Domain is allowed to access the full level 2 IST size as specified by L2SZ.

Arm recommends that STRUCTURE is 0 when LPI\_ID\_BITS  $\leq ((10 - ISTSZ) + (2 * L2SZ))$ .

See 4.7 The interrupt state table (IST) for more information.

If programming a reserved value or an unsupported value, the IRS Domain behavior is CONSTRAINED UNPRE-DICTABLE to any behavior which could be achieved by programming a valid and supported value.

When STRUCTURE is 0, this field is RES0.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## LPI\_ID\_BITS, bits [4:0]

The number of LPIs for the IRS Domain.

The IST contains 2<sup>(LPI\_ID\_BITS)</sup> level 2 IST entries in total.

The minimum value for this field is IRS\_IDR2.MIN\_LPI\_ID\_BITS.

If programmed to a value smaller than the minimum, the field is treated as having the minimum value for all other purposes than reading back the field.

The maximum value for this field is IRS\_IDR2.ID\_BITS.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than a direct read of the register. The maximum value is reported in IRS\_IDR2.ID\_BITS.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Accessing IRS\_IST\_CFGR

Accesses to this register use the following encodings:

- When IRS\_IDR2.LPI == 0, access on this interface is **RAZ/WI**.
- When IRS\_IST\_BASER.Valid == 1 or IRS\_IST\_STATUSR.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.15 IRS\_IST\_STATUSR

The IRS\_IST\_STATUSR characteristics are:

#### Purpose

IRS physical IST management status register.

#### Attributes

IRS\_IST\_STATUSR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_IST\_STATUSR bit assignments are:



## Bits [31:1]

Reserved, RESO.

## IDLE, bit [0]

Whether the effects of any of the following writes are complete:

- A write that updates IRS\_IST\_BASER.VALID.
- A write to IRS\_MAP\_L2\_ISTR.ID.

| IDLE | Meaning                                    |
|------|--------------------------------------------|
| 0b0  | The effects of the write are not complete. |
| 0b1  | The effects of the write are complete.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

Access to this field is RO.

#### Accessing IRS\_IST\_STATUSR

Accesses to this register use the following encodings:

- When IRS\_IDR2.LPI == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RO**.

# 10.2.1.16 IRS\_MAP\_L2\_ISTR

The IRS\_MAP\_L2\_ISTR characteristics are:

## Purpose

IRS map physical level 2 IST register

## Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_IST\_STATUSR.IDLE is 1.

## Attributes

IRS\_MAP\_L2\_ISTR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_MAP\_L2\_ISTR bit assignments are:



A write to this register makes the specified physical level 2 IST valid.

There are no effects of a write to this register, if any of the following are true:

- The physical IST is invalid.
- The physical IST uses a linear structure.
- The LPI INTID.ID is outside the configured physical LPI range.
- The level 2 IST is already valid.

## Bits [31:24]

Reserved, RESO.

## ID, bits [23:0]

An LPI INTID.ID covered by the level 1 ISTE corresponding to the level 2 IST that is made valid.

If unimplemented upper bits of the INTID.ID are not zero, it is IMPLEMENTATION DEFINED whether the upper bits are treated as 0 or the interrupt message is ignored by the IRS.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

## Accessing IRS\_MAP\_L2\_ISTR

Accesses to this register use the following encodings:

- When IRS\_IDR2.LPI == 0, access on this interface is **RAZ/WI**.
- When IRS\_IST\_STATUSR.IDLE == 0, access on this interface is UNKNOWN/WI.
- When IRS\_IST\_BASER.VALID == 0, access on this interface is UNKNOWN/WI.
- When IRS\_IST\_CFGR.STRUCTURE == 0, access on this interface is UNKNOWN/WI.
- Otherwise, access on this interface is **WO**.

# 10.2.1.17 IRS\_MEC\_IDR

The IRS\_MEC\_IDR characteristics are:

## Purpose

IRS MEC identification register. Contains read-only fields with information about the IRS support for MEC.

## Attributes

IRS\_MEC\_IDR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_MEC\_IDR bit assignments are:



## Bits [31:4]

Reserved, RESO.

## MECIDSIZE, bits [3:0]

## When IRS\_IDR0.MEC == 1:

The number of bits minus one of MECID supported by the IRS.

The maximum permitted value is 0xF which indicates a MECID width of 16 bits.

The value 0x0 is a valid encoding and indicates that one bit of MECID is supported.

#### Otherwise:

res0

## Accessing IRS\_MEC\_IDR

Accesses to this register use the following encodings:

- When IRS\_IDR0.INT\_DOM != 0b11, access on this interface is RAZ/WI.
- When IRS\_IDR0.MEC != 1, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is RO.

# 10.2.1.18 IRS\_MEC\_MECID\_R

The IRS\_MEC\_MECID\_R characteristics are:

## Purpose

IRS MEC MECID register for the Realm PAS.

## Attributes

IRS\_MEC\_MECID\_R is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_MEC\_MECID\_R bit assignments are:

| L <sup>31</sup> |      | 16 | 15    | 0 |
|-----------------|------|----|-------|---|
|                 | RES0 |    | MECID |   |

## Bits [31:16]

Reserved, RESO.

## MECID, bits [15:0]

MECID for IRS access to Realm PA space for:

- Accesses to physical and virtual IST entries.
- Accesses to VM table entries and VPE table entrie.
- Accesses to VM descriptors and VPE descriptors.

Bits above the supported MECID size, indicated in IRS\_MEC\_IDR.MECIDSIZE are RES0.

If MECIDSIZE is less than 0xF, the IRS treats bits [15:MECIDSIZE+1] of this field as zero.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Accessing IRS\_MEC\_MECID\_R

Accesses to this register use the following encodings:

- When IRS\_IDR0.INT\_DOM != 0b11, access on this interface is **RAZ/WI**.
- When IRS\_IDR0.MEC != 1, access on this interface is RAZ/WI.
- When IRS\_IST\_BASER.VALID == 1 or IRS\_IST\_STATUSR.IDLE == 0, access on this interface is **RO**.
- When IRS\_VMT\_BASER.VALID == 1 or IRS\_VMT\_STATUSR.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is RW.

# 10.2.1.19 IRS\_MPAM\_IDR

The IRS\_MPAM\_IDR characteristics are:

## Purpose

IRS MPAM identification register. Contains read-only fields with information about the IRS support for MPAM.

## Attributes

IRS\_MPAM\_IDR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_MPAM\_IDR bit assignments are:



## Bits [31:25]

Reserved, RESO.

## HAS\_MPAM\_SP, bit [24]

Whether the IRS has support for MPAM PARTID space selection for the Interrupt Domain.

If HAS\_MPAM\_SP is 1, the IRS uses the MPAM PARTID specified by IRS\_MPAM\_PARTID\_R.MPAM\_SP.

If HAS\_MPAM\_SP is 0, the following PARTID space is used for IRS accesses to memory:

- Accesses made for the Secure Interrupt Domain use the Secure PARTID space.
- Accesses made for the Non-secure Interrupt Domain use the Non-secure PARTID space.
- Accesses made for the EL3 Interrupt Domain use the Root or Secure PARTID space.
- Accesses made for the Realm Interrupt Domain use the Realm PARTID space.

The value of this field is the same across all Interrupt Domains for an IRS.

## PMG\_MAX, bits [23:16]

The maximum PMG value that is permitted to be used for the IRS for the Interrupt Domain.

The PMG bit width is defined as the bit position of the most significant 1 in PMG\_MAX[7:0], plus one, or is defined as zero if PMG\_MAX is zero.

For example, if  $PMG_MAX == 0 \times 0 f$ , the PMG bit width is 4.

This field is permitted to be zero-sized.

## PARTID\_MAX, bits [15:0]

The maximum PARTID value that is permitted to be used for the IRS for the Interrupt Domain.

The PARTID bit width is defined as the bit position of the most significant 1 in PARTID\_MAX[15:0], plus one, or is defined as zero if PARTID\_MAX is zero.

For example, if PARTID\_MAX ==  $0 \times 0034$ , the PARTID bit width is 6.

This field is permitted to be zero-sized, but Arm recommends that it is non-zero when MPAM is implemented.

## Accessing IRS\_MPAM\_IDR

Accesses to this register use the following encodings:

- When IRS\_IDR0.MPAM != 1, access on this interface is RAZ/WI.
- Otherwise, access on this interface is **RO**.

# 10.2.1.20 IRS\_MPAM\_PARTID\_R

The IRS\_MPAM\_PARTID\_R characteristics are:

## Purpose

IRS MPAM PARTID and PMG register.

## Attributes

IRS\_MPAM\_PARTID\_R is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_MPAM\_PARTID\_R bit assignments are:



## IDLE, bit [31]

Whether the effects of the previous write to this register are complete.

| IDLE | Meaning                                                              |
|------|----------------------------------------------------------------------|
| 0b0  | The effects of the previous write to this register are not complete. |
| 0b1  | The effects of the previous write to this register are complete.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

Access to this field is RO.

## Bits [30:26]

Reserved, RESO.

## MPAM\_SP, bits [25:24]

## When IRS\_MPAM\_IDR.HAS\_MPAM\_SP == 1 and IRS\_IDR0.INT\_DOM == 0b00

## MPAM\_SP, bits [1:0] of bits [25:24]

MPAM PARTID space for the IRS for the Secure Interrupt Domain.

| MPAM_SP | Meaning                  |
|---------|--------------------------|
| 0b00    | Secure PARTID space.     |
| 0b01    | Non-secure PARTID space. |

Values not defined above are reserved.

Programming a reserved value results in the IRS using an UNKNOWN PARTID space.

The reset behavior of this field is:

• On a GIC reset, this field resets to an IMPLEMENTATION DEFINED value.

Accessing this field has the following behavior:

- When IRS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

When IRS\_MPAM\_IDR.HAS\_MPAM\_SP == 1 and IRS\_IDR0.INT\_DOM == 0b01

## MPAM\_SP, bits [1:0] of bits [25:24]

MPAM PARTID space for the IRS for the Non-secure Interrupt Domain.

| MPAM_SP | Meaning                  |
|---------|--------------------------|
| 0b01    | Non-secure PARTID space. |

Values not defined above are reserved.

Programming a reserved value results in the IRS using an UNKNOWN PARTID space.

The reset behavior of this field is:

• On a GIC reset, this field resets to an IMPLEMENTATION DEFINED value.

Accessing this field has the following behavior:

- When IRS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

## When IRS\_MPAM\_IDR.HAS\_MPAM\_SP == 1 and IRS\_IDR0.INT\_DOM == 0b10

## MPAM\_SP, bits [1:0] of bits [25:24]

MPAM PARTID space for the IRS for the EL3 Interrupt Domain.

| MPAM_SP | Meaning                  |
|---------|--------------------------|
| 00d0    | Secure PARTID space.     |
| 0b01    | Non-secure PARTID space. |
| 0b10    | Root PARTID space.       |
| 0b11    | Realm PARTID space.      |

Values not defined above are reserved.

Programming a reserved value results in the IRS using an UNKNOWN PARTID space.

The reset behavior of this field is:

• On a GIC reset, this field resets to an IMPLEMENTATION DEFINED value.

Accessing this field has the following behavior:

- When IRS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

## When IRS\_MPAM\_IDR.HAS\_MPAM\_SP == 1 and IRS\_IDR0.INT\_DOM == 0b11

## MPAM\_SP, bits [1:0] of bits [25:24]

MPAM PARTID space for the IRS for the Realm Interrupt Domain.

| MPAM_SP | Meaning                  |
|---------|--------------------------|
| 0b01    | Non-secure PARTID space. |
| 0b11    | Realm PARTID space.      |

Values not defined above are reserved.

Programming a reserved value results in the IRS using an UNKNOWN PARTID space.

The reset behavior of this field is:

• On a GIC reset, this field resets to an IMPLEMENTATION DEFINED value.

Accessing this field has the following behavior:

- When IRS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

Otherwise:

res0

#### PMG, bits [23:16]

PMG for accesses to memory by the IRS for the Interrupt Domain.

Bits above the supported PMG bit width, as indicated by IRS\_MPAM\_IDR.PMG\_MAX, are RESO.

If a value greater than IRS\_MPAM\_IDR.PMG\_MAX is programmed, an UNKNOWN PMG is used.

The reset behavior of this field is:

• On a GIC reset, this field resets to 0x00.

Accessing this field has the following behavior:

- When IRS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

#### PARTID, bits [15:0]

PARTID for accesses to memory by the IRS for the Interrupt Domain.

Bits above the supported PARTID bit width, as indicated by IRS\_MPAM\_IDR.PARTID\_MAX, are RESO.

If a value greater than IRS\_MPAM\_IDR.PARTID\_MAX is programmed, an UNKNOWN PARTID is used.

The reset behavior of this field is:

• On a GIC reset, this field resets to 0x0000.

Accessing this field has the following behavior:

- When IRS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

#### Accessing IRS\_MPAM\_PARTID\_R

Accesses to this register use the following encodings:

- When IRS\_IDR0.MPAM != 1, access on this interface is RAZ/WI.
- Otherwise, access on this interface is **RW**.

# 10.2.1.21 IRS\_PE\_CR0

The IRS\_PE\_CR0 characteristics are:

## Purpose

IRS PE control register 0.

## Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_PE\_STATUSR.IDLE is 1.

Following a write to this register, IRS\_PE\_STATUSR.V is updated.

## Attributes

IRS\_PE\_CR0 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_PE\_CR0 bit assignments are:

| 31   | 1 | 0 | L   |
|------|---|---|-----|
| RES0 |   |   |     |
|      |   | Τ | DPS |

The fields in this register provide access to the configuration of the PE specified in the last write to IRS\_PE\_SELR.

The PE configuration applies to the IRS Domain corresponding to the PAS that this register is accessed in.

## Bits [31:1]

Reserved, RESO.

## DPS, bit [0]

Disable 1ofN PE selection.

| DPS | Meaning                                                                                                                    |
|-----|----------------------------------------------------------------------------------------------------------------------------|
| 0b0 | 10fN PE selection is enabled. An interrupt configured to use<br>the 10fN Routing mode is permitted to select this PE.      |
| 0b1 | 10fN PE selection is disabled. An interrupt configured to use<br>the 10fN Routing mode is not permitted to select this PE. |

This field determines whether the selected PE is permitted to be selected for 1ofN interrupt delivery.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When IRS\_IDR0.ONE\_N == 0, access to this field is **RES0**
- Otherwise, access to this field is **RW**

## Accessing IRS\_PE\_CR0

Accesses to this register use the following encodings:

- When IRS\_PE\_STATUSR.[V,IDLE] != 0b11, access on this interface is UNKNOWN/WI.
- Otherwise, access on this interface is **RW**.

# 10.2.1.22 IRS\_PE\_SELR

The IRS\_PE\_SELR characteristics are:

## Purpose

IRS PE selection register.

## Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_PE\_STATUSR.IDLE is 1.

## Attributes

IRS\_PE\_SELR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_PE\_SELR bit assignments are:



## Bits [31:16]

Reserved, RESO.

## IAFFID, bits [15:0]

PE interrupt Affinity ID.

Selects a PE whose configuration can be accessed via IRS\_PE\_CR0.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Accessing IRS\_PE\_SELR

Accesses to this register use the following encodings:

- When IRS\_PE\_STATUSR.IDLE == 0, access on this interface is **WI**.
- Otherwise, access on this interface is **WO**.

# 10.2.1.23 IRS\_PE\_STATUSR

The IRS\_PE\_STATUSR characteristics are:

#### Purpose

IRS PE status register

#### Attributes

IRS\_PE\_STATUSR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

## Field descriptions

The IRS\_PE\_STATUSR bit assignments are:



The fields in this register return information about the PE specified in the last write to IRS\_PE\_SELR and the status of the last write to IRS\_PE\_CR0.

## Bits [31:3]

Reserved, RESO.

## ONLINE, bit [2]

Whether the PE is online or offline.

When the IRS determines that there is a candidate HPPI for the PE and the PE is offline the IRS generates a Wake Request to the PE.

When the IRS determines that there is a candidate HPPI for the PE and the PE is online the IRS Forwards the candidate HPPI to the PE.

When {V, IDLE} is not '0b11', the value of this field is UNKNOWN.

| ONLINE | Meaning            |
|--------|--------------------|
| 0b0    | The PE is offline. |
| 0b1    | The PE is online.  |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## V, bit [1]

Whether the value last written to IRS\_PE\_SELR selected a valid PE.

When IDLE is 0, the value of this field is UNKNOWN.

| V   | Meaning                                         |
|-----|-------------------------------------------------|
| 060 | The PE selected using IRS_PE_SELR is not valid. |
| 0b1 | The PE selected using IRS_PE_SELR is valid.     |

This field resets to 0 to indicate that there was no write to IRS\_PE\_SELR that selected a valid PE since the IRS was reset.

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b0.

## IDLE, bit [0]

Following a write to IRS\_PE\_SELR, when this field returns 1 and V is 1, a read from IRS\_PE\_CR0 returns the configuration value for the PE when the accesses are performed on the same IRS.

Following a write to IRS\_PE\_CR0, when this field returns 1, the effects of the write have completed.

| IDLE | Meaning                                                                                 |
|------|-----------------------------------------------------------------------------------------|
| 0b0  | The effects of writing to IRS_PE_SELR and IRS_PE_CR0 are not guaranteed to be complete. |
| 0b1  | The effects of writing to IRS_PE_SELR and IRS_PE_CR0 are complete.                      |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

## Accessing IRS\_PE\_STATUSR

Accesses to this register use the following encodings:

## Accessible at address 0x0144

# 10.2.1.24 IRS\_SAVE\_VMR

The IRS\_SAVE\_VMR characteristics are:

## Purpose

IRS save VM register

## Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_SAVE\_VM\_STATUSR.IDLE is 1.

#### Attributes

IRS\_SAVE\_VMR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_SAVE\_VMR bit assignments are:



# S, bit [63]

Writing 1 to this field saves the state of virtual interrupts to the virtual ISTs for the VM specified by VM\_ID.

| S   | Meaning                                                              |  |
|-----|----------------------------------------------------------------------|--|
| 0b0 | The write has no effect on the virtual ISTs.                         |  |
| 0b1 | The write saves the state of virtual interrupts to the virtual ISTs. |  |

Access to this field is WO/UNKNOWN.

# Q, bit [62]

Writing 1 to this field queries whether he VM specified by VM\_ID is Quiesced on all IRSs since the last write that set S to 1 and returns the result in IRS\_SAVE\_VM\_STATUSR.Q when IRS\_SAVE\_VM\_STATUSR.IDLE is 1.

When a write sets S to 1, the Effective value written to this field is 1.

Following a write that updates VM\_ID, if there has been no write that set S to 1, the value returned in IRS\_SAVE\_VM\_STATUSR.Q is UNKNOWN.

| Q   | Meaning                                                                                        |
|-----|------------------------------------------------------------------------------------------------|
| 0b0 | The write has no effect on the value returned in IRS_SAVE_VM_STATUSR.Q.                        |
| 0b1 | The write queries whether the VM is Quiesced on all IRSs since the last write that set S to 1. |

Access to this field is **WO/UNKNOWN**.

Chapter 10. Registers and memory maps 10.2. IRS register frames

# Bits [61:16]

Reserved, RESO.

# VM\_ID, bits [15:0]

The VM ID specifying the VM whose virtual interrupt state should be written to the ISTs.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing IRS\_SAVE\_VMR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_SAVE\_VM\_STATUSR.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.25 IRS\_SAVE\_VM\_STATUSR

The IRS\_SAVE\_VM\_STATUSR characteristics are:

#### Purpose

IRS save VM status register.

#### Attributes

IRS\_SAVE\_VM\_STATUSR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_SAVE\_VM\_STATUSR bit assignments are:



The fields in this register return information about the last write to IRS\_SAVE\_VMR.

# Bits [31:2]

Reserved, RESO.

## Q, bit [1]

Reports whether the VM specified by IRS\_SAVE\_VMR.VM\_ID is Quiesced since the last write that set IRS\_SAVE\_VMR.S to 1.

If there has been no write that set IRS\_SAVE\_VMR.S to 1 since IRS\_SAVE\_VMR.VM\_ID was updated, the value of this field is UNKNOWN.

If the VM ID specified an invalid VM, the value of this field is UNKNOWN.

| Q   | Meaning                 |  |
|-----|-------------------------|--|
| 0b0 | The VM is Quiesced.     |  |
| 0b1 | The VM is not Quiesced. |  |

If IDLE is 0, this field is UNKNOWN.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# IDLE, bit [0]

Reports the status of the last write to IRS\_SAVE\_VMR.

| IDLE Meaning |                                                                                  |
|--------------|----------------------------------------------------------------------------------|
| 060          | The effects of the last write to IRS_SAVE_VMR are not guaranteed to be complete. |
| 0b1          | The effects of the last write to IRS_SAVE_VMR are complete.                      |

This field resets to 1 to allow initial writes to registers Guarded by this field. Because there has been no write at reset, this does not imply that any invalidate operation is complete.

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

# Accessing IRS\_SAVE\_VM\_STATUSR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RO**.

# 10.2.1.26 IRS\_SPI\_CFGR

The IRS\_SPI\_CFGR characteristics are:

#### Purpose

IRS SPI configuration register.

Allows software to read and update the configuration of the SPI selected by IRS\_SPI\_SELR.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_SPI\_STATUSR.IDLE is 1.

Following a write to this register, IRS\_SPI\_STATUSR.V is updated.

#### Attributes

IRS\_SPI\_CFGR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_SPI\_CFGR bit assignments are:

| 31  | 1   0 |
|-----|-------|
| RES | Э ТМ  |

This register is updated after a write to IRS\_SPI\_SELR when IRS\_SPI\_STATUSR.{V, IDLE} is {1, 1}.

# Bits [31:1]

Reserved, RESO.

# TM, bit [0]

The Trigger mode of the SPI.

| ТМ  | TM Meaning      |  |
|-----|-----------------|--|
| 0b0 | Edge-triggered  |  |
| 0b1 | Level-sensitive |  |

It is IMPLEMENTATION DEFINED whether access to this field for the selected SPI is **RW** or **RO**.

Note: This field controls the type of event generated by SPI signals. This is a separate control from the INTID Handling mode.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing IRS\_SPI\_CFGR

Accesses to this register use the following encodings:

- When IRS\_SPI\_STATUSR.[V,IDLE] != 0b11, access on this interface is UNKNOWN/WI.
- Otherwise, access on this interface is **RW**.

# 10.2.1.27 IRS\_SPI\_DOMAINR

The IRS\_SPI\_DOMAINR characteristics are:

#### Purpose

IRS SPI Interrupt Domain configuration Register.

Allows software to read and update the Interrupt Domain assignment of the SPI selected by IRS\_SPI\_SELR.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_SPI\_STATUSR.IDLE is 1.

Following a write to this register, IRS\_SPI\_STATUSR.V is updated.

#### Attributes

IRS\_SPI\_DOMAINR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_SPI\_DOMAINR bit assignments are:

| 31 2 | 1 ( | Θ    |     |
|------|-----|------|-----|
| RES0 |     |      |     |
|      | L   | DOMA | AIN |

This register is updated after a write to IRS\_SPI\_SELR when IRS\_SPI\_STATUSR.{V, IDLE} is {1, 1}.

#### Bits [31:2]

Reserved, RESO.

# DOMAIN, bits [1:0]

Configures the Interrupt Domain associated with the SPI.

Some SPIs may be statically assigned to a Domain, in which case this field always returns the statically assigned Domain for the SPI.

To check if a SPI can be dynamically assigned to a Domain, software must read back the value in this field after attempting an update to establish if the update was successful once IRS\_SPI\_STATUSR.IDLE is 1.

| DOMAIN | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

Programming an Interrupt Domain not supported by the IRS results in CONSTRAINED UNPREDICTABLE behavior with the following options:

- The SPI behaves as if it is not assigned to any Interrupt Domain.
- The SPI is treated as being assigned to another supported Interrupt Domain for all other purposes than reading back this field

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing IRS\_SPI\_DOMAINR

Accesses to this register use the following encodings:

- When IRS\_IDR0.INT\_DOM != 0b10, access on this interface is **RAZ/WI**.
- When IRS\_SPI\_STATUSR.[V,IDLE] != 0b11, access on this interface is UNKNOWN/WI.
- Otherwise, access on this interface is **RW**.

# 10.2.1.28 IRS\_SPI\_RESAMPLER

The IRS\_SPI\_RESAMPLER characteristics are:

#### Purpose

IRS SPI resample register.

Resample an SPI signal.

#### Attributes

IRS\_SPI\_RESAMPLER is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_SPI\_RESAMPLER bit assignments are:

| L <sup>31</sup> 24 | ا <sup>23</sup> و |
|--------------------|-------------------|
| RES0               | SPI_ID            |

This register allows resampling an SPI.

# Bits [31:24]

Reserved, RESO.

# SPI\_ID, bits [23:0]

SPI INTID.ID of the SPI to resample.

Following a write to this register, if all of the following are true, the SPI is resampled:

- The SPI is managed on this IRS.
- The SPI can be accessed in this IRS Domain.

Otherwise, the write to this register has no effect.

See 'Physical SPIs' for more information.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing IRS\_SPI\_RESAMPLER

Accesses to this register use the following encodings:

# Accessible at address 0x0110

Access on this interface is **WO**.

# 10.2.1.29 IRS\_SPI\_SELR

The IRS\_SPI\_SELR characteristics are:

## Purpose

IRS SPI selection register.

## Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_SPI\_STATUSR.IDLE is 1.

#### Attributes

IRS\_SPI\_SELR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_SPI\_SELR bit assignments are:



# Bits [31:24]

Reserved, RESO.

# ID, bits [23:0]

Selects the SPI that the following registers access:

- IRS\_SPI\_CFGR
- IRS\_SPI\_DOMAINR
- IRS\_SPI\_VMR

Only implemented SPIs with INTID.ID in the range from IRS\_IDR7.SPI\_BASE to (IRS\_IDR7.SPI\_BASE + IRS\_IDR6.SPI\_IRS\_RANGE - 1) may be selected.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing IRS\_SPI\_SELR

Accesses to this register use the following encodings:

- When IRS\_SPI\_STATUSR.IDLE == 0, access on this interface is **WI**.
- Otherwise, access on this interface is WO.

# 10.2.1.30 IRS\_SPI\_STATUSR

The IRS\_SPI\_STATUSR characteristics are:

#### Purpose

IRS SPI status register.

#### Attributes

IRS\_SPI\_STATUSR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_SPI\_STATUSR bit assignments are:



# Bits [31:2]

Reserved, RESO.

#### V, bit [1]

Whether the value last written to IRS\_SPI\_SELR selects a valid SPI that is managed on this IRS and can be accessed in this IRS Domain.

This field is updated if and only if a write occurs to any of the following registers in this IRS Domain:

- IRS\_SPI\_CFGR
- IRS\_SPI\_SELR
- IRS\_SPI\_VMR

Following a write to any of the above registers, if this field returns 0, the write to the register has no effects other than updating the values in this register.

SPIs with INTID.ID in the range described by IRS\_IDR7.SPI\_BASE and IRS\_IDR6.SPI\_IRS\_RANGE are managed on this IRS.

If the in IRS\_SPI\_SELR specifies an SPI and all of the following are true, this field returns 1:

- The selected SPI is implemented.
- The selected SPI is managed by this IRS.
- The selected SPI is assigned to this IRS Domain or this IRS Domain is the EL3 IRS Domain.

Otherwise, this field returns 0.

When IDLE is 0, the value of this field is UNKNOWN.

| V   | Meaning                                                                                                                    |
|-----|----------------------------------------------------------------------------------------------------------------------------|
| 060 | The SPI selected using IRS_SPI_SELR is not a valid SPI that is managed on this IRS and can be accessed in this IRS Domain. |
| 0b1 | The SPI selected using IRS_SPI_SELR is a valid SPI that is managed on this IRS and can be accessed in this IRS Domain.     |

This field resets to 0 to indicate that there was no write to IRS\_SPI\_SELR that selected a valid SPI that is managed on this IRS since the IRS was reset.

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b0.

# IDLE, bit [0]

Whether writes to any of the following registers have completed:

- IRS\_SPI\_CFGR
- IRS\_SPI\_DOMAINR
- IRS\_SPI\_SELR
- IRS\_SPI\_VMR

Following a write to IRS\_SPI\_SELR, when  $\{IDLE, V\}$  is  $\{1, 1\}$ , a read from any of the other registers returns the configuration value for the SPI.

Following a write to any of the registers listed above, on this IRS, when  $\{IDLE, V\}$  is  $\{1, 1\}$ , the effects of the write are complete.

| IDLE | Meaning                                                                                                       |
|------|---------------------------------------------------------------------------------------------------------------|
| 000  | The effects of writing to the SPI selection and configuration registers are not guaranteed to have completed. |
| 0b1  | The effects of writing to the SPI selection and configuration registers have completed.                       |

This field resets to 1 to allow initial writes to registers Guarded by this field. Because there has been no write at reset, this does not imply that any invalidate operation is complete.

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b1.

# Accessing IRS\_SPI\_STATUSR

Accesses to this register use the following encodings:

# Accessible at address 0x0118

Access on this interface is RO.

# 10.2.1.31 IRS\_SPI\_VMR

The IRS\_SPI\_VMR characteristics are:

#### Purpose

IRS SPI VM assignment register.

Allows software to read and update the VM assignment of the SPI selected by 'IRS\_SPI\_SELR'.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_SPI\_STATUSR.IDLE is 1.

Following a write to this register, IRS\_SPI\_STATUSR.V is updated.

#### Attributes

IRS\_SPI\_VMR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_SPI\_VMR bit assignments are:

| 63 6 | 52   | 32     |
|------|------|--------|
|      | F    | RESO   |
| Lv   | IRT  |        |
| 31   | 16   | ا 15 O |
|      | RES0 | VM_ID  |

This register is updated after a write to IRS\_SPI\_SELR when IRS\_SPI\_STATUSR.{V, IDLE} is {1, 1}.

# VIRT, bit [63]

Whether the SPI selected by IRS\_SPI\_SELR is assigned as a virtual SPI to the VM.

| VIRT | Meaning                                           |  |  |  |  |
|------|---------------------------------------------------|--|--|--|--|
| 0b0  | The SPI is not assigned to a VM.                  |  |  |  |  |
| 0b1  | The SPI is assigned to the VM specified by VM_ID. |  |  |  |  |

## Bits [62:16]

Reserved, RESO.

#### VM\_ID, bits [15:0]

Identifies the VM.

On a read, when VIRT is 0, the value of this field is UNKNOWN.

On a write, if the existing value of VIRT is 1, the write to this field is IGNORED.

# Accessing IRS\_SPI\_VMR

When the value of VIRT in the register is 1, meaning that the selected SPI is assigned to a VM, any write that does not set VIRT to 0 is ignored.

To assign an SPI to a different VM, the SPI must first be unassigned from the old VM, and then subsequently assigned to the new VM.

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_SPI\_STATUSR.[V,IDLE] != 0b11, access on this interface is UNKNOWN/WI.
- When !IsSPIDVISupported(IRS\_SPI\_SELR.ID), access on this interface is RAZ/WI.
- Otherwise, access on this interface is **RW**.

# 10.2.1.32 IRS\_SWERR\_STATUSR

The IRS\_SWERR\_STATUSR characteristics are:

## Purpose

IRS software error status register. Specifies whether a software error has been reported. If an error is reported, it contains syndrome information for the error.

#### Attributes

IRS\_SWERR\_STATUSR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_SWERR\_STATUSR bit assignments are:



# Bits [63:32]

Reserved, RESO.

# IMP\_EC, bits [31:24]

IMPLEMENTATION DEFINED error code when  $IRS_SWERR_STATUS.EC == 0$ .

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- Access is **RES0** if any of the following are true:
  - IRS\_SWERR\_STATUSR.V == 0
  - IRS\_SWERR\_STATUSR.EC != 0
- Otherwise, access to this field is **RO**

# EC, bits [23:16]

Specifies the error code that software can use to triage and handle the error.

| EC   | Meaning                                                            |  |  |  |  |
|------|--------------------------------------------------------------------|--|--|--|--|
| 0x00 | An error was reported because of an IMPLEMENTATION DEFINED reason. |  |  |  |  |
| 0x01 | Failed lookup of L1_ISTE due to an external abort.                 |  |  |  |  |
| 0x02 | Failed lookup of L2_ISTE due to an external abort.                 |  |  |  |  |
| 0x03 | Failed lookup of L1_VMTE due to an external abort.                 |  |  |  |  |
| 0x04 | Failed lookup of L2_VMTE due to an external abort.                 |  |  |  |  |
| 0x05 | Failed lookup of VPE Table due to an external abort.               |  |  |  |  |
| 0x06 | Failed lookup of VPE descriptor due to an external abort.          |  |  |  |  |
| 0x07 | Failed lookup of VM descriptor due to an external abort.           |  |  |  |  |

| EC   | Meaning                                                                                                                                                                                                          |  |  |  |  |  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0x08 | A physical LPI could not be processed because IRS_IST_BASER.VALID is 0.                                                                                                                                          |  |  |  |  |  |
| 0x09 | A physical LPI could not be processed because L1_ISTE.VALID is 0.                                                                                                                                                |  |  |  |  |  |
| 0x0A | A physical LPI was not processed because the LPI INTID.ID > (2 ^ IRS_IST_CFGR.LPI_ID_BITS) - 1.                                                                                                                  |  |  |  |  |  |
| 0x0B | A virtual interrupt could not be processed because L1_ISTE.VALID is 0                                                                                                                                            |  |  |  |  |  |
| 0x0C | A virtual interrupt could not be processed because L1_VMTE.VALID is 0.                                                                                                                                           |  |  |  |  |  |
| 0x0D | A virtual interrupt could not be processed because L2_VMTE.VALID is 0.                                                                                                                                           |  |  |  |  |  |
| 0x0E | A virtual LPI was not processed because L2_VMTE.LPI_IST_VALID is 0.                                                                                                                                              |  |  |  |  |  |
| 0×0F | A virtual SPI was not processed because L2_VMTE.SPI_IST_VALID is 0.                                                                                                                                              |  |  |  |  |  |
| 0x10 | A virtual LPI was not processed because the LPI INTID.ID > (2 ^ L2_VMTE.LPI_ID_BITS) - 1.                                                                                                                        |  |  |  |  |  |
| 0x11 | A virtual SPI was not processed because the SPI INTID.ID > (2 ^ L2_VMTE.SPI_ID_BITS) - 1.                                                                                                                        |  |  |  |  |  |
| 0x12 | A virtual LPI signaled by an ITS was not processed because<br>the VM ID > $(2 \cap IRS_VMT_CFGR.VM_ID_BITS) - 1$ .                                                                                               |  |  |  |  |  |
| 0x13 | A virtual interrupt was not processed because the VPE ID > $(2 L_2VMTE.VPE_ID_BITS) - 1$ .                                                                                                                       |  |  |  |  |  |
| 0x14 | A virtual interrupt was signaled in a non-EL3 Interrupt<br>Domain by an ITS, or via the GIC VDPEND system instruction,<br>and the interrupt was unreachable because IRS_IDR0.VIRT is<br>0 or the VM was invalid. |  |  |  |  |  |
| 0x15 | A physical interrupt whose Routing mode is Targeted specified an invalid IAFFID.                                                                                                                                 |  |  |  |  |  |
| 0x16 | A virtual interrupt whose Routing mode is Targeted specified a VPE ID that is < 2 ^ L2_VMTE.VPE_ID_BITS but invalid otherwise.                                                                                   |  |  |  |  |  |
| 0x17 | The IRS was trying to signal a VPE doorbell but the VPE doorbell INTID is unreachable.                                                                                                                           |  |  |  |  |  |
| 0x19 | The IRS has detected corrupt metadata in the L2_ISTE.                                                                                                                                                            |  |  |  |  |  |
| 0x1A | The IRS has detected corrupt metadata in a VPE descriptor.                                                                                                                                                       |  |  |  |  |  |
| 0x1B | The IRS has detected corrupt metadata in a VM descriptor.                                                                                                                                                        |  |  |  |  |  |
| 0x1C | IRS_MAP_L2_ISTR was written when<br>IRS_IST_STATUSR.IDLE == 0.                                                                                                                                                   |  |  |  |  |  |
| 0x1D | IRS_VMAP_L2_VMTR was written when IRS_VMT_STATUSR.IDLE == 0.                                                                                                                                                     |  |  |  |  |  |

| EC   | Meaning                                                                 |
|------|-------------------------------------------------------------------------|
| 0x1E | IRS_VMAP_VMR was written when IRS_VMT_STATUSR.IDLE == 0.                |
| 0x1F | IRS_VMAP_VISTR was written when<br>IRS_VMT_STATUSR.IDLE == 0.           |
| 0x20 | IRS_VMAP_L2_VISTR was written when IRS_VMT_STATUSR.IDLE == $0$ .        |
| 0x21 | IRS_VMAP_VPER was written when<br>IRS_VMT_STATUSR.IDLE == 0.            |
| 0x22 | IRS_IST_BASER was written when<br>IRS_IST_STATUSR.IDLE == 0.            |
| 0x23 | IRS_PE_SELR was written when IRS_PE_STATUSR.IDLE == 0.                  |
| 0x24 | IRS_SAVE_VMR was written when<br>IRS_SAVE_VM_STATUSR.IDLE == 0.         |
| 0x25 | IRS_SPI_SELR was written when IRS_SPI_STATUSR.IDLE == 0.                |
| 0x26 | IRS_SYNCR was written when IRS_SYNC_STATUSR.IDLE == 0.                  |
| 0x27 | IRS_VM_SELR was written when IRS_VM_STATUSR.IDLE == 0.                  |
| 0x28 | IRS_VMT_BASER was written when<br>IRS_VMT_STATUSR.IDLE == 0.            |
| 0x29 | IRS_VPE_SELR was written when<br>IRS_VPE_STATUSR.IDLE == 0.             |
| 0x2A | The IRS has detected that L2_ISTE.IRM is 1 and 1ofN is not supported.   |
| 0x2B | A resample request for an SPI from a write to IRS_SPI_RESAMPLER failed. |

All other values are reserved.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When IRS\_SWERR\_STATUSR.V == 0, access to this field is UNKNOWN/WI
- Otherwise, access to this field is **RO**

# Bits [15:4]

Reserved, RESO.

# OF, bit [3]

Specifies whether multiple software errors have been detected.

When this field is 1, the syndrome information reports information about the error that last caused IRS\_SWERR\_STATUSR.V to transition from 0 to 1.

Chapter 10. Registers and memory maps 10.2. IRS register frames

| OF  | Meaning                                                                                                                         |
|-----|---------------------------------------------------------------------------------------------------------------------------------|
| 0b0 | No errors have been detected, since the error that was reported when IRS_SWERR_STATUSR.V last transitioned from 0 to 1.         |
| 0b1 | At least one error has been detected, since the error that was reported when IRS_SWERR_STATUSR.V last transitioned from 0 to 1. |

When clearing IRS\_SWERR\_STATUSR.V to 0, if this field is nonzero, software writes 1 to clear this field to zero.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When IRS\_SWERR\_STATUSR.V == 0, access to this field is UNKNOWN/WI
- Otherwise, access to this field is W1C

## S1V, bit [2]

Specifies whether IRS\_SWERR\_SYNDROMER1 is valid.

| S1V | Meaning                            |
|-----|------------------------------------|
| 0b0 | IRS_SWERR_SYNDROMER1 is not valid. |
| 0b1 | IRS_SWERR_SYNDROMER1 is valid.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When IRS\_SWERR\_STATUSR.V == 0, access to this field is UNKNOWN/WI
- Otherwise, access to this field is **RO**

# S0V, bit [1]

Specifies whether IRS\_SWERR\_SYNDROMER0 is valid.

| SOV | Meaning                            |
|-----|------------------------------------|
| 060 | IRS_SWERR_SYNDROMER0 is not valid. |
| 0b1 | IRS_SWERR_SYNDROMER0 is valid.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When IRS\_SWERR\_STATUSR.V == 0, access to this field is UNKNOWN/WI
- Otherwise, access to this field is **RO**

# V, bit [0]

Specifies whether other fields in this register are valid and at least one software error has been reported.

| V   | Meaning                         |  |  |  |
|-----|---------------------------------|--|--|--|
| 060 | IRS_SWERR_STATUSR is not valid. |  |  |  |
| 0b1 | IRS_SWERR_STATUSR is valid.     |  |  |  |

Software writes 1 to this field to clear it to zero.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Access to this field is W1C.

# Accessing IRS\_SWERR\_STATUSR

After reading IRS\_SWERR\_STATUSR, software clears the valid fields in the register to allow new errors to be reported.

However, between reading the register and clearing the valid fields, a new error might have overwritten the register.

To prevent this error being lost by software, the register prevents updates to fields that might have been updated by a new error.

This is done by ensuring a write to the register is ignored if all of the following are true:

- Any of IRS\_SWERR\_STATUSR.{V, OF} are nonzero before the write.
- The write does not clear the nonzero IRS\_SWERR\_STATUSR.{V, OF} fields to zero by writing ones to the applicable field or fields.

Accesses to this register use the following encodings:

- When IRS\_IDR0.SWE != 1, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.33 IRS\_SWERR\_SYNDROMER0

The IRS\_SWERR\_SYNDROMER0 characteristics are:

#### Purpose

IRS software error syndrome register 0. Records IRS specific software error syndrome information.

## Attributes

IRS\_SWERR\_SYNDROMER0 is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_SWERR\_SYNDROMER0 bit assignments are:

| 63   | 62 60    | 59 | 1    | 56 I | 55    | 32   |  |  |
|------|----------|----|------|------|-------|------|--|--|
|      | TYPE     |    | RES0 |      | ID    |      |  |  |
|      | LVIRTUAL |    |      |      |       |      |  |  |
| 31   |          |    |      |      | 16    | 15 0 |  |  |
| RES0 |          |    | RE   | S0   | VM_ID |      |  |  |

# VIRTUAL, bit [63]

Specifies whether the error syndrome information is for a physical or virtual interrupt.

| VIRTUAL | Meaning                                                    |
|---------|------------------------------------------------------------|
| 0b0     | The error syndrome information is for a physical interrupt |
| 0b1     | The error syndrome information is for a virtual interrupt  |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# TYPE, bits [62:60]

The type of the interrupt for which an error was detected.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Bits [59:56]

Reserved, RESO.

#### ID, bits [55:32]

ID of the interrupt for which an error was detected.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Chapter 10. Registers and memory maps 10.2. IRS register frames

# Bits [31:16]

Reserved, RESO.

# VM\_ID, bits [15:0]

Bits[15:0] of the VM ID of the virtual interrupt that could not be routed by the IRS as described below.

- For a virtual LPI, this is the VM ID specified in the incoming interrupt event.
- For a virtual SPI, this is the VM ID to which the virtual SPI was assigned.

When VIRTUAL is 0, this field is RES0.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing IRS\_SWERR\_SYNDROMER0

Accesses to this register use the following encodings:

- When IRS\_IDR0.SWE != 1, access on this interface is **RAZ/WI**.
- When IRS\_SWERR\_STATUSR.V == 1 and IRS\_SWERR\_STATUSR.SOV == 1, access on this interface is **RO**.
- Otherwise, access on this interface is UNKNOWN/WI.

# 10.2.1.34 IRS\_SWERR\_SYNDROMER1

The IRS\_SWERR\_SYNDROMER1 characteristics are:

# Purpose

IRS software error syndrome register 1. Records IRS specific software error syndrome information.

#### Attributes

IRS\_SWERR\_SYNDROMER1 is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_SWERR\_SYNDROMER1 bit assignments are:



# Bits [63:56]

Reserved, RESO.

#### ADDR, bits [55:3]

Bits[55:3] of the physical address of a translation structure associated with the detected error.

The address in this field is associated with the PAS of the Interrupt Domain where the error is detected.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RESO. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Bits [2:0]

Reserved, RESO.

# Accessing IRS\_SWERR\_SYNDROMER1

Accesses to this register use the following encodings:

- When IRS\_IDR0.SWE != 1, access on this interface is **RAZ/WI**.
- When IRS\_SWERR\_STATUSR.V == 1 and IRS\_SWERR\_STATUSR.S1V == 1, access on this interface is **RO**.
- Otherwise, access on this interface is UNKNOWN/WI.

# 10.2.1.35 IRS\_SYNCR

The IRS\_SYNCR characteristics are:

# Purpose

IRS synchronize interrupt events register.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_SYNC\_STATUSR.IDLE is 1.

#### Attributes

IRS\_SYNCR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_SYNCR bit assignments are:

| 31 | 30   | 0 |
|----|------|---|
|    | RES0 |   |
| L  | SYNC |   |

# SYNC, bit [31]

Writing 1 to this field requests synchronization of interrupt events for the IRS Domain.

Writing 0 to this field has no effect.

See 'IRS synchronization requests' for more information.

| SYNC | Meaning                        |
|------|--------------------------------|
| 0b0  | Ignored.                       |
| 0b1  | Issue synchronization request. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Bits [30:0]

Reserved, RESO.

# Accessing IRS\_SYNCR

Accesses to this register use the following encodings:

- When IRS\_SYNC\_STATUSR.IDLE == 0, access on this interface is **WI**.
- Otherwise, access on this interface is **WO**.

# 10.2.1.36 IRS\_SYNC\_STATUSR

The IRS\_SYNC\_STATUSR characteristics are:

## Purpose

IRS synchronize interrupt events status register.

## Attributes

IRS\_SYNC\_STATUSR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_SYNC\_STATUSR bit assignments are:



# Bits [31:1]

Reserved, RESO.

# IDLE, bit [0]

Whether the effects of the last write to IRS\_SYNCR have completed.

| IDLE | Meaning                                                               |
|------|-----------------------------------------------------------------------|
| 0d0  | The effects of writing to IRS_SYNCR not guaranteed to have completed. |
| 0b1  | The effects of writing to IRS_SYNCR have completed.                   |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

Access to this field is RO.

# Accessing IRS\_SYNC\_STATUSR

This register is read-only.

Accesses to this register use the following encodings:

# Accessible at address 0x00C4

Access on this interface is RO.

# 10.2.1.37 IRS\_VM\_DBR

The IRS\_VM\_DBR characteristics are:

# Purpose

IRS VM 1ofN doorbell configuration register.

## Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VM\_STATUSR.IDLE is 1.

Following a write to this register, IRS\_VM\_STATUSR.V is updated

#### Attributes

IRS\_VM\_DBR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VM\_DBR bit assignments are:

| 63 | 62          | 32     |  |
|----|-------------|--------|--|
| EN | F           | ES0    |  |
| 31 | 131 16 l 15 |        |  |
|    | RES0        | VPE_ID |  |

The fields in this register return information about the VM selected in IRS\_VM\_SELR.

This register is updated after a write to IRS\_VM\_SELR when IRS\_VM\_STATUSR.{V, IDLE} is {1, 1}.

# EN, bit [63]

Whether the doorbell settings are valid for the VM.

| EN  | Meaning                                 |  |
|-----|-----------------------------------------|--|
| 0b0 | 1ofN doorbells are disabled for the VM. |  |
| 0b1 | lofN doorbells are enabled for the VM.  |  |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Bits [62:16]

Reserved, RESO.

# VPE\_ID, bits [15:0]

The VPE ID of the 1ofN VPE doorbell target.

See 'VPE doorbells for 1ofN interrupts' for more information.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing IRS\_VM\_DBR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0 or IRS\_IDR0.VIRT\_ONE\_N == 0, access on this interface is **RAZ/WI**.
- When IRS\_VM\_STATUSR.[V,IDLE] != 0b11, access on this interface is UNKNOWN/WI.
- Otherwise, access on this interface is **RW**.

# 10.2.1.38 IRS\_VM\_SELR

The IRS\_VM\_SELR characteristics are:

## Purpose

IRS VM selection register.

Selects a VM whose 1ofN doorbell configuration can be accessed via IRS\_VM\_DBR.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VM\_STATUSR.IDLE is 1.

#### Attributes

IRS\_VM\_SELR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VM\_SELR bit assignments are:



# Bits [31:16]

Reserved, RESO.

VM\_ID, bits [15:0]

Identifies the VM.

# Accessing IRS\_VM\_SELR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0 or IRS\_IDR0.VIRT\_ONE\_N == 0, access on this interface is **RAZ/WI**.
- When IRS\_VM\_STATUSR.IDLE == 0, access on this interface is **WI**.
- Otherwise, access on this interface is **WO**.

# 10.2.1.39 IRS\_VM\_STATUSR

The IRS\_VM\_STATUSR characteristics are:

#### Purpose

IRS VM status register

#### Attributes

IRS\_VM\_STATUSR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_VM\_STATUSR bit assignments are:



# Bits [31:2]

Reserved, RESO.

# V, bit [1]

Whether IRS\_VM\_SELR selects a valid VM.

This field is updated if and only if any of following occur:

- A write to IRS\_VM\_DBR.
- A write to IRS\_VM\_SELR

When IDLE is 0, the value of this field is UNKNOWN.

| v   | Meaning                                         |
|-----|-------------------------------------------------|
| 0b0 | The VM selected using IRS_VM_SELR is not valid. |
| )b1 | The VM selected using IRS_VM_SELR is valid.     |

This field resets to 0 to indicate that there was no write to IRS\_VM\_SELR that selected a valid VM since the IRS was reset.

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b0.

# IDLE, bit [0]

When this field returns 1 and V is 1, a read from IRS\_VM\_CR0 returns the VM configuration for the selected VM. Following a write to IRS\_VM\_CR0, when this field returns 1 and V is 1, the effects of the write have completed:

| IDLE | Meaning                                                                                                      |
|------|--------------------------------------------------------------------------------------------------------------|
| 0b0  | The effects of writing to the VM selection and configuration registers are not guaranteed to have completed. |
| 0b1  | The effects of writing to the VM selection and configuration registers have completed.                       |

This field resets to 1 to allow initial writes to registers Guarded by this field. Because there has been no write at reset, this does not imply that any invalidate operation is complete.

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

# Accessing IRS\_VM\_STATUSR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0 or IRS\_IDR0.VIRT\_ONE\_N == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RO**.

# 10.2.1.40 IRS\_VMAP\_L2\_VISTR

The IRS\_VMAP\_L2\_VISTR characteristics are:

## Purpose

IRS map level 2 virtual IST register

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VMT\_STATUSR.IDLE is 1.

#### Attributes

IRS\_VMAP\_L2\_VISTR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VMAP\_L2\_VISTR bit assignments are:



# M, bit [63]

Writing 1 to this field makes the virtual level 2 IST specified by TYPE and ID for the VM specified by VM\_ID valid.

| Μ   | Meaning                                                                |
|-----|------------------------------------------------------------------------|
| 0b0 | The write to this field has no effect.                                 |
| 0b1 | The write to this field makes the specified virtual level 2 IST valid. |

There are no effects to the virtual IST on a write to this register, if any of the following are true:

- The VM specified by VM\_ID is invalid.
- The virtual IST is invalid.
- The virtual IST uses a linear format.
- The INTID.ID is outside the configured virtual interrupt range for the specified VM.
- The level 2 IST is valid.
- The write to this register does not set this field to 1.

If this field is not set to 1 on a write to this register, updates to any other field in this register has no effect beyond updating the value of that field.

# Access to this field is WO/UNKNOWN.

# Bits [62:48]

Reserved, RESO.

# VM\_ID, bits [47:32]

The VM ID specifying the VM for which a virtual level 2 IST is being made valid.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# TYPE, bits [31:29]

Whether the operation applies to the virtual LPI IST or virtual SPI IST.

Values not defined are reserved.

When programming a reserved value, it is CONSTRAINED UNPREDICTABLE whether the invalidate is IGNORED or an UNKNOWN value is used for this field.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# Bits [28:24]

Reserved, RESO.

#### ID, bits [23:0]

An INTID.ID covered by the level 1 ISTE corresponding to the level 2 IST that is made valid.

If unimplemented upper bits of the INTID.ID are not zero, it is CONSTRAINED UNPREDICTABLE whether the upper bits are treated as 0 or a request to invalidate is IGNORED.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# Accessing IRS\_VMAP\_L2\_VISTR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_STATUSR.IDLE == 0, access on this interface is **RO**.
- When IRS\_VMT\_BASER.VALID == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.41 IRS\_VMAP\_L2\_VMTR

The IRS\_VMAP\_L2\_VMTR characteristics are:

## Purpose

IRS map level 2 VM table register

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VMT\_STATUSR.IDLE is 1.

#### Attributes

IRS\_VMAP\_L2\_VMTR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VMAP\_L2\_VMTR bit assignments are:



# M, bit [63]

Writing 1 to this field makes the level 2 VM table specified by VM\_ID valid.

| М   | Meaning                                                             |
|-----|---------------------------------------------------------------------|
| 0b0 | The write to this field has no effect.                              |
| 0b1 | The write to this field makes the specified level 2 VM table valid. |

There are no effects to the VM table on a write to this register, if any of the following are true:

- The VM table is invalid.
- The VM table uses a linear structure.
- The VM ID specified by VM\_ID is outside the configured VM ID range.
- The level 2 VM table is valid.
- The write to this register does not set this field to 1.

If this field is not set to 1 on a write to this register, updates to any other field in this register has no effect beyond updating the value of that field.

Access to this field is WO/UNKNOWN.

# Chapter 10. Registers and memory maps 10.2. IRS register frames

# Bits [62:16]

Reserved, RESO.

# VM\_ID, bits [15:0]

The VM ID specifying the level 2 VM table being made valid.

# Accessing IRS\_VMAP\_L2\_VMTR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_STATUSR.IDLE == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_CFGR.STRUCTURE == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_BASER.VALID == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.42 IRS\_VMAP\_VISTR

The IRS\_VMAP\_VISTR characteristics are:

## Purpose

IRS map virtual IST register

## Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VMT\_STATUSR.IDLE is 1.

#### Attributes

IRS\_VMAP\_VISTR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VMAP\_VISTR bit assignments are:



# M, bit [63]

Writing 1 to this field makes the virtual IST specified by TYPE for the VM specified by VM\_ID valid or invalid as specified by U.

| Μ   | Meaning                                                        |
|-----|----------------------------------------------------------------|
| 0b0 | The write to this field has no effect.                         |
| 0b1 | The write to this field makes the specified virtual IST valid. |

There are no effects to the validity of the virtual IST on a write to this register, if any of the following are true:

- The VM specified by VM\_ID is invalid.
- The VM ID is outside the configured VM ID range.
- The virtual IST is valid and U is 0.
- The virtual IST is invalid and U is 1.
- The write to this register does not set this field to 1.

If this field is not set to 1 on a write to this register, updates to any other field in this register has no effect beyond updating the value of that field.

Access to this field is **WO/UNKNOWN**.

# U, bit [62]

Whether a write that sets M to 1 makes the specified virtual IST valid or invalid.

| U   | Meaning                                                           |
|-----|-------------------------------------------------------------------|
| 0b0 | A write that sets M to 1 makes the specified virtual IST valid.   |
| 0b1 | A write that sets M to 1 makes the specified virtual IST invalid. |

Chapter 10. Registers and memory maps 10.2. IRS register frames

# Bits [61:48]

Reserved, RESO.

# VM\_ID, bits [47:32]

The VM ID specifying the VM for which a virtual IST is being made valid.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# TYPE, bits [31:29]

Whether the operation applies to the virtual LPI IST or virtual SPI IST.

Values not defined are reserved.

When programming a reserved value, it is CONSTRAINED UNPREDICTABLE whether the invalidate is IGNORED or an UNKNOWN value is used for this field.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# Bits [28:0]

Reserved, RESO.

# Accessing IRS\_VMAP\_VISTR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_STATUSR.IDLE == 0, access on this interface is **RO**.
- When IRS\_VMT\_BASER.VALID == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.43 IRS\_VMAP\_VMR

The IRS\_VMAP\_VMR characteristics are:

## Purpose

IRS map VM register

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VMT\_STATUSR.IDLE is 1.

#### Attributes

IRS\_VMAP\_VMR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VMAP\_VMR bit assignments are:



# M, bit [63]

Writing 1 to this field makes the VM specified by VM\_ID valid or invalid as specified by U.

| М   | Meaning                                                          |
|-----|------------------------------------------------------------------|
| 0b0 | The write to this field has no effect.                           |
| 0b1 | The write to this field makes the specified VM valid or invalid. |

There are no effects to the validity of the VM on a write to this register, if any of the following are true:

- The level 2 VM table containing the entry corresponding to the VM specified by VM\_ID is invalid.
- The VM ID is outside the configured VM ID range.
- The VM valid and U is 0.
- The VM invalid and U is 1.
- The write to this register does not set this field to 1.

If this field is not set to 1 on a write to this register, updates to any other field in this register has no effect beyond updating the value of that field.

#### Access to this field is WO/UNKNOWN.

# U, bit [62]

Whether a write that sets M to 1 makes the specified VM valid or invalid.

| U   | Meaning                                                  |
|-----|----------------------------------------------------------|
| 0b0 | A write that sets M to 1 makes the specified VM valid.   |
| 0b1 | A write that sets M to 1 makes the specified VM invalid. |

# Chapter 10. Registers and memory maps 10.2. IRS register frames

# Bits [61:16]

Reserved, RESO.

# VM\_ID, bits [15:0]

The VM ID specifying the VM being made valid or invalid.

# Accessing IRS\_VMAP\_VMR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_STATUSR.IDLE == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_BASER.VALID == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.44 IRS\_VMAP\_VPER

The IRS\_VMAP\_VPER characteristics are:

#### Purpose

IRS map VPE register

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VMT\_STATUSR.IDLE is 1.

#### Attributes

IRS\_VMAP\_VPER is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

#### Field descriptions

The IRS\_VMAP\_VPER bit assignments are:



# M, bit [63]

Writing 1 to this field makes the VPE specified by VM\_ID and VPE\_ID valid.

| Μ   | Meaning                                                |
|-----|--------------------------------------------------------|
| 0b0 | The write to this field has no effect.                 |
| 0b1 | The write to this field makes the specified VPE valid. |

There are no effects to the validity of the VPE on a write to this register, if any of the following are true:

- The VM specified by VM\_ID is invalid.
- The VM ID is outside the configured VM ID range.
- The VPE ID is outside the configured VPE range for the VM.
- The VPE is valid.
- The write to this register does not set this field to 1.

If this field is not set to 1 on a write to this register, updates to any other field in this register has no effect beyond updating the value of that field.

Access to this field is WO/UNKNOWN.

#### Bits [62:48]

Reserved, RESO.

#### VM\_ID, bits [47:32]

Identifies the VM.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# Bits [31:16]

Reserved, RESO.

# VPE\_ID, bits [15:0]

Identifies the VPE.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# Accessing IRS\_VMAP\_VPER

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_STATUSR.IDLE == 0, access on this interface is **RO**.
- When IRS\_VMT\_BASER.VALID == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.45 IRS\_VMT\_BASER

The IRS\_VMT\_BASER characteristics are:

#### Purpose

IRS VM table base address register

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VMT\_STATUSR.IDLE is 1.

#### Attributes

IRS\_VMT\_BASER is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VMT\_BASER bit assignments are:



# Bits [63:56]

Reserved, RESO.

# ADDR, bits [55:3]

Bits[55:3] of the VM table base physical address.

When IRS\_VMT\_CFGR.STRUCTURE is 0, ADDR points to a linear VM table and all of the following are true:

- Bits[N:0] of the resulting address are 0 where N = 4 + IRS\_VMT\_CFGR.VM\_ID\_BITS.
- This means that the level 2 VMTE array is aligned to the size of the array.

When IRS\_VMT\_CFGR.STRUCTURE is 1, ADDR points to the level 1 table in a 2-level VM table and all of the following are true:

- Bits[N:0] of the resulting address are 0 where N depends on VM\_ID\_BITS in IRS\_VMT\_CFGR as follows: N = Max(2, VM\_ID\_BITS - 7 + 2)
- This means that the level 1 VMT is aligned to the size of the level 1 VMTE array.

Access to any level of the VM table and any additional memory accesses occurring as a result of the address in this field are performed using the PAS of the IRS Domain where this register is accessed.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RES0. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When IRS\_VMT\_BASER.VALID == 1, access to this field is **RO**
- Otherwise, access to this field is **RW**

# Bits [2:1]

Reserved, RESO.

# VALID, bit [0]

Whether the ADDR points to a valid VM table.

| VALID | Meaning                            |
|-------|------------------------------------|
| 0b0   | The VM table address is not valid. |
| 0b1   | The VM table address is valid.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b0.

# Accessing IRS\_VMT\_BASER

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_STATUSR.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.46 IRS\_VMT\_CFGR

The IRS\_VMT\_CFGR characteristics are:

#### Purpose

IRS VM table configuration register

#### Attributes

IRS\_VMT\_CFGR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VMT\_CFGR bit assignments are:



# Bits [31:17]

Reserved, RESO.

# STRUCTURE, bit [16]

Whether the VM table uses a linear or 2-level structure.

| STRUCTURE | Meaning                               |
|-----------|---------------------------------------|
| 0b0       | A linear VM table structure is used.  |
| 0b1       | A 2-level VM table structure is used. |

If VM\_ID\_BITS < 8 and STRUCTURE is 1, all of the following are true:

- The IST consists of a single level 1 VM table entry and a single level 2 VM table.
- The level 2 VM table contains (2 ^ VM\_ID\_BITS) entries.
- The IRS is allowed to access the full 4KB levl 2 VM table.

Arm recommends that STRUCTURE is 0 when VM\_ID\_BITS < 8.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Bits [15:5]

Reserved, RESO.

# VM\_ID\_BITS, bits [4:0]

The number of VM\_ID bits for the IRS Domain.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than a direct read of the register. The maximum value is reported in IRS\_IDR3.VM\_ID\_BITS.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing IRS\_VMT\_CFGR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VMT\_BASER.Valid == 1 or IRS\_VMT\_STATUSR.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.47 IRS\_VMT\_STATUSR

The IRS\_VMT\_STATUSR characteristics are:

#### Purpose

IRS virtualization data structures management status register.

#### Attributes

IRS\_VMT\_STATUSR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VMT\_STATUSR bit assignments are:



# Bits [31:1]

Reserved, RESO.

#### IDLE, bit [0]

Whether the effects of any of the following writes are complete:

- A write that updates IRS\_VMT\_BASER.Valid.
- A write that sets IRS\_VMAP\_L2\_VMTR.M to 1.
- A write that sets IRS\_VMAP\_VMR.M to 1.
- A write that sets IRS\_VMAP\_VPER.M to 1.
- A write that sets IRS\_VMAP\_VISTR.M to 1.
- A write that sets IRS\_VMAP\_L2\_VISTR.M to 1.

| IDLE | Meaning                                                                                               |
|------|-------------------------------------------------------------------------------------------------------|
| 0b0  | The effects a write to any of the virtualization data structure management registers are not complete |
| 0b1  | The effects a write to any of the virtualization data structure management registers are complete     |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

Access to this field is RO.

# Accessing IRS\_VMT\_STATUSR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RO**.

# 10.2.1.48 IRS\_VPE\_CR0

The IRS\_VPE\_CR0 characteristics are:

#### Purpose

IRS VPE Control Register 0

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VPE\_STATUSR.IDLE is 1.

Following a write to this register, IRS\_VPE\_STATUSR.V is updated.

#### Attributes

IRS\_VPE\_CR0 is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VPE\_CR0 bit assignments are:

| 131  | 1 | 0 | 1   |
|------|---|---|-----|
| RES0 |   |   |     |
|      |   |   | DPS |

This register is updated after a write that sets IRS\_VPE\_SELR.S to 1 when IRS\_VPE\_STATUSR.{V, IDLE} is {1, 1}.

#### Bits [31:1]

Reserved, RESO.

# DPS, bit [0]

Disable 1ofN PE selection.

| DPS | Meaning                                                                                                                            |
|-----|------------------------------------------------------------------------------------------------------------------------------------|
| 0b0 | 10fN PE selection is enabled. A virtual interrupt configured to use the 10fN Routing mode is permitted to select this VPE.         |
| 0b1 | 1ofN PE selection is disabled. A virtual interrupt configured to<br>use the 1ofN Routing mode is not permitted to select this VPE. |

This field determines whether the selected VPE is permitted to be selected for 1ofN interrupt delivery.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing IRS\_VPE\_CR0

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VPE\_STATUSR.[V,IDLE] != 0b11, access on this interface is UNKNOWN/WI.
- Otherwise, access on this interface is **RW**.

# 10.2.1.49 IRS\_VPE\_DBR

The IRS\_VPE\_DBR characteristics are:

#### Purpose

IRS VPE doorbell settings register.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VPE\_STATUSR.IDLE is 1.

Following a write to this register, IRS\_VPE\_STATUSR.V is updated.

#### Attributes

IRS\_VPE\_DBR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VPE\_DBR bit assignments are:



This register is updated after a write that sets IRS\_VPE\_SELR.S to 1 when IRS\_VPE\_STATUSR.{V, IDLE} is {1, 1}.

# DBV, bit [63]

Whether the doorbell settings for the VPE are valid.

| DBV | Meaning                                          |
|-----|--------------------------------------------------|
| 0b0 | The doorbell settings for the VPE are not valid. |
| 0b1 | The doorbell settings for the VPE are valid.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# REQ\_DB, bit [62]

Whether a doorbell is requested for the VPE.

When a VPE doorbell is requested for the VPE, the doorbell event is generated when the VPE doorbell conditions are met.

See 'VPE doorbells' for more information.

| REQ_DB | Meaning                                 |
|--------|-----------------------------------------|
| 0b0    | A doorbell is not requested for the VPE |
| 0b1    | A doorbell is requested for the VPE.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When IRS\_VPE\_DBR.DBV == 1, access to this field is **RW**
- Otherwise, access to this field is **WO/UNKNOWN**

#### Bits [61:37]

Reserved, RESO.

#### DBPM, bits [36:32]

Doorbell priority mask.

This field specifies the minimum priority for a virtual interrupt to trigger the VPE's doorbell.

Accessing this field has the following behavior:

- When IRS\_VPE\_DBR.REQ\_DB == 1, access to this field is **RW**
- Otherwise, access to this field is **WO/UNKNOWN**

# Bits [31:24]

Reserved, RESO.

# INTID, bits [23:0]

If ext-IRS\_IDR2.LPI is 1, this field specifies the LPI INTID.ID of the VPE doorbell.

The number of ID bits implemented is reported in IRS\_IDR2.ID\_BITS. Unimplemented upper bits are RESO.

If ext-IRS\_IDR2.LPI is 0, this field is IMPLEMENTATION DEFINED.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When IRS\_VPE\_DBR.DBV == 1, access to this field is **RW**
- Otherwise, access to this field is **WO/UNKNOWN**

# Accessing IRS\_VPE\_DBR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VPE\_STATUSR.[V,IDLE] != 0b11, access on this interface is UNKNOWN/WI.
- Otherwise, access on this interface is **RW**.

# 10.2.1.50 IRS\_VPE\_HPPIR

The IRS\_VPE\_HPPIR characteristics are:

#### Purpose

IRS VPE HPPI register.

#### Attributes

IRS\_VPE\_HPPIR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VPE\_HPPIR bit assignments are:



This register reports information about the candidate HPPI for the VPE selected by IRS\_VPE\_SELR.

This register is updated after a write that sets IRS\_VPE\_SELR.S to 1 when IRS\_VPE\_STATUSR.{V, IDLE} is {1, 1}.

If there is a change in the HPPI for the VPE following the write that set IRS\_VPE\_SELR.S to 1, it is IMPLEMEN-TATION DEFINED whether the old or the new HPPI is reported in this register.

# Bits [63:33]

Reserved, RESO.

# HPPIV, bit [32]

Whether there is a candidate HPPI for the VPE.

| HPPIV | Meaning                                          |
|-------|--------------------------------------------------|
| 0b0   | Invalid: There is no candidate HPPI for the VPE. |
| 0b1   | VALID: There is a candidate HPPI for the VPE.    |

When the value of this field is 1, ID and TYPE together form the INTID of the candidate HPPI for the VPE.

# TYPE, bits [31:29]

The encoding of this field depends upon the value in HPPIV as described below:

- If HPPIV is 0, this field is RES0.
- If HPPIV is 1, this field contains valid information.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

# Bits [28:24]

Reserved, RESO.

# ID, bits [23:0]

The encoding of this field depends upon the value in HPPIV as described below:

- If HPPIV is 0, this field is RES0.
- If HPPIV is 1, this field contains valid information.

# Accessing IRS\_VPE\_HPPIR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VPE\_STATUSR.[V,IDLE] != 0b11, access on this interface is UNKNOWN/WI.
- Otherwise, access on this interface is **RO**.

# 10.2.1.51 IRS\_VPE\_SELR

The IRS\_VPE\_SELR characteristics are:

#### Purpose

IRS VPE selection register.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before IRS\_VPE\_STATUSR.IDLE is 1.

#### Attributes

IRS\_VPE\_SELR is a 64-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VPE\_SELR bit assignments are:



# S, bit [63]

Writing 1 to this field selects a VPE whose configuration can be accessed via the following registers:

- IRS\_VPE\_DBR
- IRS\_VPE\_HPPIR
- IRS\_VPE\_CR0

| S   | Meaning                                   |
|-----|-------------------------------------------|
| 0b0 | The write to this register has no effect. |
| 0b1 | The write to this register selects a VPE. |

If this field is not set to 1 on a write to this register, updates to any other field in this register has no effect beyond updating the value of that field.

This means that if IRS\_VPE\_STATUSR.V is updated as a result of a write to another register, the value returned reflects the VPE selected when this field was set to 1.

Access to this field is WO/UNKNOWN.

# Bits [62:48]

Reserved, RESO.

# VPE\_ID, bits [47:32]

Identifies the VPE.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# Bits [31:16]

Reserved, RESO.

# VM\_ID, bits [15:0]

Identifies the VM.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# Accessing IRS\_VPE\_SELR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- When IRS\_VPE\_STATUSR.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.2.1.52 IRS\_VPE\_STATUSR

The IRS\_VPE\_STATUSR characteristics are:

#### Purpose

IRS VPE status register

#### Attributes

IRS\_VPE\_STATUSR is a 32-bit register.

This register is part of the IRS\_CONFIG\_FRAME block.

# Field descriptions

The IRS\_VPE\_STATUSR bit assignments are:



# Bits [31:2]

Reserved, RESO.

# V, bit [1]

Whether the value last written to IRS\_VPE\_SELR selects a valid VPE.

This field is updated if and only if any of following occur:

- A write to IRS\_VPE\_CR0.
- A write to IRS\_VPE\_DBR.
- A write that sets IRS\_VPE\_SELR.S to 1.

When IDLE is 0, the value of this field is UNKNOWN.

| V   | Meaning                                           |
|-----|---------------------------------------------------|
| 0b0 | The VPE selected using IRS_VPE_SELR is not valid. |
| 0b1 | The VPE selected using IRS_VPE_SELR is valid.     |

This field resets to 0 to indicate that there was no write to IRS\_VPE\_SELR that selected a valid VPE that is managed on this IRS since the IRS was reset.

The reset behavior of this field is:

- On a GIC reset, this field resets to  $\tt 0b0.$ 

# IDLE, bit [0]

A write that sets IRS\_VPE\_SELR.S to 1 is complete when this field is 1.

When this field is 1 and V is 1, a read from any of the following registers returns values for the selected VPE:

- IRS\_VPE\_DBR.
- IRS\_VPE\_HPPIR.
- IRS\_VPE\_CR0.

Following a write to one of the following registers, when this field returns 1, the effects of the write have completed:

- IRS\_VPE\_DBR.
- IRS\_VPE\_CR0.

| IDLE | Meaning                                                                                                                                          |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0  | The effects of the last write that set IRS_VPE_SELR.S to 1<br>and any write to VPE configuration registers are not<br>guaranteed to be complete. |
| 0b1  | The effects of the last write that set IRS_VPE_SELR.S to 1 and any write to VPE configuration registers are complete.                            |

This field resets to 1 to allow initial writes to registers Guarded by this field. Because there has been no write at reset, this does not imply that any invalidate operation is complete.

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b1.

# Accessing IRS\_VPE\_STATUSR

Accesses to this register use the following encodings:

- When IRS\_IDR0.VIRT == 0, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RO**.

# 10.2.2 IRS\_SETLPI\_FRAME, IRS SETLPI register frame

The IRS\_SETLPI\_FRAME characteristics are:

#### Purpose

Contains the IRS\_SETLPIR register used to generate a SET\_EDGE message for an LPI without going through an ITS.

An IRS SETLPI register frame is present for each supported Interrupt Domain on each IRS where IRS\_IDR0.SETLPI is 1.

Arm strongly recommends that this register frame is not accessible by PEs. This is because a write to this register can require the IRS access to memory, leading to in-out dependencies than can potentially lead to deadlocks in the system. If this register frame is not accessible by PEs, the behavior on an attempted access from a PE is IMPLEMENTATION DEFINED and is likely to result in an External abort.

This register frame is only accessible in the PAS associated with the Interrupt Domain.

The base address is distinct from addresses of registers accessible in any other PAS.

The base address is aligned to 64KB.

#### Configuration

This Register Block is present only when IRS\_IDR0.SETLPI == 1.

#### Attributes

The IRS\_SETLPI\_FRAME block is of size 64KB

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

#### Contents

| Offset | Name        | Notes                      |
|--------|-------------|----------------------------|
| 0x0000 | IRS_SETLPIR | Most permissive access: WO |

# 10.2.2.1 IRS\_SETLPIR

The IRS\_SETLPIR characteristics are:

# Purpose

IRS SETLPI register.

A write to this register generates a SET\_EDGE message for the LPI ID specified as part of the write.

#### Configuration

This register is present only when IRS\_IDR0.SETLPI == 1. Otherwise, direct accesses to IRS\_SETLPIR are RAZ/WI.

# Attributes

IRS\_SETLPIR is a 32-bit register.

This register is part of the IRS\_SETLPI\_FRAME block.

# Field descriptions

The IRS\_SETLPIR bit assignments are:



# Bits [31:24]

Reserved, RESO.

# ID, bits [23:0]

Bits[23:0] of the LPI INTID.ID to set generate a SET\_EDGE message for.

If unimplemented upper bits of the INTID.ID are not zero, it is IMPLEMENTATION DEFINED whether the upper bits are treated as 0 or the interrupt message is ignored by the IRS.

# Accessing IRS\_SETLPIR

Writes to this register are ignored if the IRS is not enabled for the Interrupt Domain.

Accesses to this register use the following encodings:

# Accessible at address 0x0000

Access on this interface is WO.

# 10.3 ITS register frames

 $I_{DQKQD}$  Each ITS Domain exposes the following two register frames:

- The ITS configuration register frame.
- The ITS translation register frame.

Different from GICv3, the GICv5 architecture does not require the ITS register frames to be contiguous with respect to each other.

 $I_{BHGQG}$  In the ITS register definitions, references to other registers are always to a register in the register frame for the same ITS Domain as where the access is made.

# 10.3.1 ITS\_CONFIG\_FRAME, ITS configuration register frame

The ITS\_CONFIG\_FRAME characteristics are:

#### Purpose

Contains control registers for an ITS Domain.

An ITS configuration register frame is present for each supported ITS Domain.

This register frame is accessible in the PAS associated with the ITS Domain.

It is IMPLEMENTATION DEFINED whether this register frame is also accessible in the MPPAS at the same address.

The base address is distinct from the base address of any other GIC register frame, including the ITS configuration register frames for other ITS Domains.

The base address is aligned to 64KB.

#### Attributes

The ITS\_CONFIG\_FRAME block is of size 64KB

#### Default access

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

#### Contents

| Offset | Name                 | Notes                      |
|--------|----------------------|----------------------------|
| 0x0000 | ITS_IDR0             | Most permissive access: RO |
| 0x0004 | ITS_IDR1             | Most permissive access: RO |
| 0x0008 | ITS_IDR2             | Most permissive access: RO |
| 0x0040 | ITS_IIDR             | Most permissive access: RO |
| 0x0044 | ITS_AIDR             | Most permissive access: RO |
| 0x0080 | ITS_CR0              | Most permissive access: RW |
| 0x0084 | ITS_CR1              | Most permissive access: RW |
| 0x00C0 | ITS_DT_BASER         | Most permissive access: RW |
| 0x00D0 | ITS_DT_CFGR          | Most permissive access: RW |
| 0x0100 | ITS_DIDR             | Most permissive access: RW |
| 0x0108 | ITS_EIDR             | Most permissive access: RW |
| 0x010C | ITS_INV_EVENTR       | Most permissive access: WO |
| 0x0110 | ITS_INV_DEVICER      | Most permissive access: WO |
| 0x0114 | ITS_READ_EVENTR      | Most permissive access: WO |
| 0x0118 | ITS_READ_EVENT_DATAR | Most permissive access: RO |
| 0x0120 | ITS_STATUSR          | Most permissive access: RO |
| 0x0140 | ITS_SYNCR            | Most permissive access: WO |
| 0x0148 | ITS_SYNC_STATUSR     | Most permissive access: RO |
| 0x0180 | ITS_GEN_EVENT_DIDR   | Most permissive access: RW |

Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

| Offset                            | Name                  | Notes                                         |
|-----------------------------------|-----------------------|-----------------------------------------------|
| 0x0188                            | ITS_GEN_EVENT_EIDR    | Most permissive access: RW                    |
| 0x018C                            | ITS_GEN_EVENTR        | Most permissive access: WO                    |
| 0x0190                            | ITS_GEN_EVENT_STATUSR | Most permissive access: RO                    |
| 0x01C0                            | ITS_MEC_IDR           | Most permissive access: RO                    |
| 0x01C4                            | ITS_MEC_MECID_R       | Most permissive access: RW                    |
| 0x0200                            | ITS_MPAM_IDR          | Most permissive access: RO                    |
| 0x0204                            | ITS_MPAM_PARTID_R     | Most permissive access: RW                    |
| 0x0240                            | ITS_SWERR_STATUSR     | Most permissive access: RW                    |
| 0x0248                            | ITS_SWERR_SYNDROMER0  | Most permissive access: RO                    |
| 0x0250                            | ITS_SWERR_SYNDROMER1  | Most permissive access: RO                    |
| 0x0E00 + (4 * n)for n in<br>⇔63:0 | -                     | Most permissive access: ImplementationDefined |

# 10.3.1.1 ITS\_AIDR

The ITS\_AIDR characteristics are:

#### Purpose

ITS Architecture Identification Register. Identifies the GIC architecture version to which the implementation conforms.

# Attributes

ITS\_AIDR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_AIDR bit assignments are:



# Bits [31:12]

Reserved, RESO.

#### Component, bits [11:8]

GIC component

| Component | Meaning |  |
|-----------|---------|--|
| 0b0000    | IRS     |  |
| 0b0001    | ITS     |  |
| 0b0010    | IWB     |  |

# ArchMajorRev, bits [7:4]

Major Architecture revision.

| ArchMajorRev | Meaning |
|--------------|---------|
| 00000        | GICv5.x |

# ArchMinorRev, bits [3:0]

Minor Architecture revision.

| ArchMinorRev | Meaning |
|--------------|---------|
| 00000        | GICv5.0 |

# Accessing ITS\_AIDR

Accesses to this register use the following encodings:

# Accessible at address 0x0044

Access on this interface is **RO**.

# 10.3.1.2 ITS\_CR0

The ITS\_CR0 characteristics are:

#### Purpose

ITS configuration register 0

#### Attributes

ITS\_CR0 is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

# Field descriptions

The ITS\_CR0 bit assignments are:



# Bits [31:2]

Reserved, RESO.

# IDLE, bit [1]

Whether the transition between enabled and disabled states of the ITS Domain is complete.

| IDLE | Meaning                                                             |
|------|---------------------------------------------------------------------|
| 000  | The effects of updating ITSEN are not guaranteed to have completed. |
| 0b1  | The effects of updating ITSEN have completed.                       |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

Access to this field is **RO**.

# ITSEN, bit [0]

Controls if the ITS Domain is enabled and whether it can generate interrupt messages to an IRS for the Interrupt Domain.

| ITSEN | Meaning                                                                             |
|-------|-------------------------------------------------------------------------------------|
| 0b0   | Disabled. The ITS does not generate any interrupt messages for the Interrupt Domain |
| 0b1   | Enabled. The ITS may generate interrupt messages for the Interrupt Domain           |

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b0.

Accessing this field has the following behavior:

- When ITS\_CR0.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

# Accessing ITS\_CR0

Accesses to this register use the following encodings:

# Accessible at address 0x0080

Access on this interface is **RW**.

# 10.3.1.3 ITS\_CR1

The ITS\_CR1 characteristics are:

#### Purpose

ITS configuration register 1

#### Attributes

ITS\_CR1 is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_CR1 bit assignments are:



# Bits [31:8]

Reserved, RESO.

# ITT\_RA, bit [7]

Read-Allocate hint for the interrupt translation tables.

| ITT_RA | Meaning           |
|--------|-------------------|
| 0b0    | No Read-Allocate. |
| 0b1    | Read-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# DT\_RA, bit [6]

Read-Allocate hint for the device table.

| DT_RA | Meaning           |
|-------|-------------------|
| 0b0   | No Read-Allocate. |
| 0b1   | Read-Allocate.    |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# IC, bits [5:4]

Controls the Inner Cacheability attribute used when the ITS accesses tables as a requester.

| IC   | Meaning                    |
|------|----------------------------|
| 0b00 | Non-cacheable.             |
| 0b01 | Write-Back Cacheable.      |
| 0b10 | Write-Through Cacheable.   |
| 0b11 | Reserved, treated as 0b00. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### OC, bits [3:2]

Controls the Outer Cacheability attribute used when the ITS accesses tables as a requester.

| OC   | Meaning                    |  |
|------|----------------------------|--|
| 0b00 | Non-cacheable              |  |
| 0b01 | Write-Back Cacheable.      |  |
| 0b10 | Write-Through Cacheable.   |  |
| 0b11 | Reserved, treated as 0b00. |  |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# SH, bits [1:0]

Controls the Shareability attribute used when the ITS accesses tables as a requester.

| SH   | Meaning                    |
|------|----------------------------|
| 0b00 | Non-shareable.             |
| 0b01 | Reserved, treated as 0b00. |
| 0b10 | Outer Shareable.           |
| 0b11 | Inner Shareable.           |

When ITS\_CR1.OC is 0b00 and ITS\_CR1.IC is 0b00, this field is IGNORED and behaves as Outer Shareable. The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Accessing ITS\_CR1

Accesses to this register use the following encodings:

- When ITS\_CR0.ITSEN == 1 or ITS\_CR0.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.3.1.4 ITS\_DIDR

The ITS\_DIDR characteristics are:

#### Purpose

ITS DeviceID Register.

This register is used to specify the DeviceID for the following requests:

- Invalidation of cached information for DeviceIDs issued by a write to ITS\_INV\_DEVICER.
- Invalidation of cached information for EventIDs issued by a write to ITS\_INV\_EVENTR.
- Requesting the read of the translation for an event by a write to ITS\_READ\_EVENTR.

#### Attributes

ITS\_DIDR is a 64-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_DIDR bit assignments are:

| 1 | 63 32     | 2 |
|---|-----------|---|
|   | RESO      |   |
|   | 31 0      |   |
|   | DEVICE_ID |   |

# Bits [63:32]

Reserved, RESO.

# DEVICE\_ID, bits [31:0]

The DeviceID as it should apply to a cache invalidation or reading an event translation request.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing ITS\_DIDR

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_STATUSR.IDLE != 1, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.3.1.5 ITS\_DT\_BASER

The ITS\_DT\_BASER characteristics are:

#### Purpose

ITS device table base address register

#### Attributes

ITS\_DT\_BASER is a 64-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_DT\_BASER bit assignments are:



#### Bits [63:56]

Reserved, RESO.

#### ADDR, bits [55:3]

Bits[55:3] of the DT base physical address.

When ITS\_DT\_CFGR.STRUCTURE is 0, ADDR points to a linear DT and all of the following are true:

- Bits[N:0] of the resulting address are 0 where N = 2 + ITS\_DT\_CFGR.DEVICEID\_BITS.
- This means that the level 2 DTE array is aligned to the size of the array.

When ITS\_DT\_CFGR.STRUCTURE is 1, ADDR points to the level 1 table in a 2-level DT and all of the following are true:

• Bits[N:0] of the resulting address are 0 where N depends on L2SZ and DEVICEID\_BITS in ITS\_DT\_CFGR as follows:

 $Max(2, DEVICEID_BITS - (9 + (2 * L2SZ)) + 2)$ 

• This means that the level 1 DT is aligned to the size of the table.

Access to any level of the DT and any additional memory accesses occurring as a result of the address in this field are performed using the PAS of the ITS Domain where this register is accessed.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RES0. The number of implemented address bits is reported in ITS\_IDR0.PA\_RANGE.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Bits [2:0]

Reserved, RESO.

#### Accessing ITS\_DT\_BASER

Accesses to this register use the following encodings:

#### Accessible at address 0x00C0

• When ITS\_CR0.ITSEN == 1 or ITS\_CR0.IDLE == 0, access on this interface is **RO**.

• Otherwise, access on this interface is **RW**.

# 10.3.1.6 ITS\_DT\_CFGR

The ITS\_DT\_CFGR characteristics are:

#### Purpose

ITS device table base address configuration register

#### Attributes

ITS\_DT\_CFGR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_DT\_CFGR bit assignments are:



# Bits [31:17]

Reserved, RESO.

#### STRUCTURE, bit [16]

Whether the device table uses a linear or 2-level structure.

If ITS\_IDR1.DT\_LEVELS is 0, this field is RES0.

| STRUCTURE | Meaning                                   |
|-----------|-------------------------------------------|
| 0b0       | A linear device table structure is used.  |
| 0b1       | A 2-level device table structure is used. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Bits [15:8]

Reserved, RESO.

# L2SZ, bits [7:6]

Level 2 device table size when a 2-level device table structure is used.

| L2SZ | Meaning                                                                  |
|------|--------------------------------------------------------------------------|
| 0600 | A level 2 device table is maximum 4KB and resolves 9 bits of DeviceID.   |
| 0b01 | A level 2 device table is maximum 16KB and resolves 11 bits of DeviceID. |
| 0b10 | A level 2 device table is maximum 64KB and resolves 13 bits of DeviceID. |

Values not defined above are reserved.

If DEVICEID\_BITS <= (9 + (2 \* L2SZ)) and STRUCTURE is 1, the DT consists of a single L1\_DTE and a single L2\_DT.

The L2\_DT contains (2 ^ DEVICEID\_BITS) entries.

When the value of L1\_DTE.SPAN is programmed to a value larger than DEVICEID\_BITS, the ITS is allowed to access memory in the range specified by L1\_DTE.SPAN.

Arm recommends that STRUCTURE is 0 when DEVICEID\_BITS  $\leq (9 + (2 * L2SZ))$ .

When programming a reserved value or an unsupported value, the ITS behavior is CONSTRAINED UNPREDICTABLE to any behavior which could be achieved by programming a valid and supported value.

When STRUCTURE is 0, this field is RES0.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# DEVICEID\_BITS, bits [5:0]

The number of DeviceID bits which can be translated for the accessing Security state by the ITS.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than a direct read of the register. The maximum value is reported in ITS\_IDR1.DEVICEID\_BITS.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Accessing ITS\_DT\_CFGR

Accesses to this register use the following encodings:

- When ITS\_CR0.ITSEN == 1 or ITS\_CR0.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.3.1.7 ITS\_EIDR

The ITS\_EIDR characteristics are:

#### Purpose

ITS EventID Register.

This register is used to specify the EventID for the following requests:

- Invalidation of cached information for EventIDs issued by a write to ITS\_INV\_EVENTR.
- Requesting the read of the configuration for an event by a write to ITS\_READ\_EVENTR.

#### Attributes

ITS\_EIDR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_EIDR bit assignments are:

| 31   | 16 <sub>1</sub> 15 0 <sub>1</sub> |
|------|-----------------------------------|
| RES0 | EVENT_ID                          |

# Bits [31:16]

Reserved, RESO.

# EVENT\_ID, bits [15:0]

The EventID as it should apply to a cache invalidation or reading an event translation request.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

# Accessing ITS\_EIDR

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_STATUSR.IDLE != 1, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.3.1.8 ITS\_GEN\_EVENTR

The ITS\_GEN\_EVENTR characteristics are:

#### Purpose

ITS generate incoming event register.

This register is used to generate a SET\_EDGE event for the EventID specified in ITS\_GEN\_EVENT\_EIDR and the DeviceID specified in ITS\_GEN\_EVENT\_DIDR.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before ITS\_GEN\_EVENT\_STATUSR.IDLE is 1.

#### Attributes

ITS\_GEN\_EVENTR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_GEN\_EVENTR bit assignments are:

| 31 | 30 2 | 1 0 | J         |
|----|------|-----|-----------|
| R  | RES0 |     |           |
|    |      | LT  | ARGET_DOM |

# R, bit [31]

Request the ITS to generate an incoming event.

| R   | Meaning                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0 | The write has no effect on the ITS.                                                                                                                                                                                                                                                                                                                                                             |
| 0b1 | <ul> <li>Generate an incoming event with the following information:</li> <li>Event is associated with the Interrupt Domain associated with the PAS of the write.</li> <li>The event is translated in the ITS Domain specified in TARGET_DOMAIN.</li> <li>DeviceID is specified in the ITS_GEN_EVENT_DIDR register.</li> <li>EventID is specified in the ITS_GEN_EVENT_EIDR register.</li> </ul> |

# Bits [30:2]

Reserved, RESO.

# TARGET\_DOMAIN, bits [1:0]

Specifies the ITS Domain in which the incoming event is translated.

If the specified ITS Domain is not enabled, the write to this register does not generate an incoming event.

| TARGET_DOMAIN | Meaning                                                                           | Applies                             |
|---------------|-----------------------------------------------------------------------------------|-------------------------------------|
| 0b00          | The incoming event is translated in the ITS Domain specified by ITS_IDR0.INT_DOM. |                                     |
| 0b01          | The incoming event is translated in the Realm ITS Domain.                         | When<br>ITS_IDR0.INT_DOM<br>== 0b01 |

Values not defined above are reserved.

Values corresponding to unimplemented Domains are reserved.

If a reserved value is programmed, the ITS behavior is CONSTRAINED UNPREDICTABLE to any behavior which could be achieved by programming a valid value.

#### Accessing ITS\_GEN\_EVENTR

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_GEN\_EVENT\_STATUSR.IDLE != 1, access on this interface is **WI**.
- Otherwise, access on this interface is WO.

# 10.3.1.9 ITS\_GEN\_EVENT\_STATUSR

The ITS\_GEN\_EVENT\_STATUSR characteristics are:

# Purpose

ITS generate incoming event status register.

Reports the status of a request to generate an incoming event via a write to the ITS\_GEN\_EVENTR register.

#### Attributes

ITS\_GEN\_EVENT\_STATUSR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

# Field descriptions

The ITS\_GEN\_EVENT\_STATUSR bit assignments are:



# Bits [31:1]

Reserved, RESO.

# IDLE, bit [0]

Reports whether the effects of the last write to ITS\_GEN\_EVENTR are complete.

| IDLE | Meaning                                                                            |
|------|------------------------------------------------------------------------------------|
| 0b0  | The effects of the last write to ITS_GEN_EVENTR are not guaranteed to be complete. |
| 0b1  | The effects of the last write to ITS_GEN_EVENTR are complete.                      |

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

Access to this field is **RO**.

# Accessing ITS\_GEN\_EVENT\_STATUSR

Accesses to this register use the following encodings:

# Accessible at address 0x0190

Access on this interface is RO.

# 10.3.1.10 ITS\_GEN\_EVENT\_EIDR

The ITS\_GEN\_EVENT\_EIDR characteristics are:

# Purpose

ITS generate incoming event EventID register.

This register is used to specify the EventID in a request to the ITS to generate an incoming event. The DeviceID of the event is specified in the ITS\_GEN\_EVENT\_DIDR register.

## Attributes

ITS\_GEN\_EVENT\_EIDR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_GEN\_EVENT\_EIDR bit assignments are:



## Bits [31:16]

Reserved, RESO.

## EVENT\_ID, bits [15:0]

EventID in the ITS Domain containing the register.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

## Accessing ITS\_GEN\_EVENT\_EIDR

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_GEN\_EVENT\_STATUSR.IDLE != 1, access on this interface is **RO**.
- Otherwise, access on this interface is RW.

# 10.3.1.11 ITS\_GEN\_EVENT\_DIDR

The ITS\_GEN\_EVENT\_DIDR characteristics are:

## Purpose

ITS generate incoming event DeviceID register.

This register is used to specify the DeviceID in a request to the ITS to generate an incoming event. The EventID of the event is specified in the ITS\_GEN\_EVENT\_EIDR register.

#### Attributes

ITS\_GEN\_EVENT\_DIDR is a 64-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_GEN\_EVENT\_DIDR bit assignments are:



## Bits [63:32]

Reserved, RESO.

# DEVICE\_ID, bits [31:0]

The DeviceID for the event generated as the result of a write to ITS\_GEN\_EVENTR.

The reset behavior of this field is:

• This field resets to an UNKNOWN value.

## Accessing ITS\_GEN\_EVENT\_DIDR

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_GEN\_EVENT\_STATUSR.IDLE != 1, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.3.1.12 ITS\_IDR0

The ITS\_IDR0 characteristics are:

#### Purpose

ITS identification register 0. Contains read-only fields with information about the ITS GIC component.

#### Attributes

ITS\_IDR0 is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_IDR0 bit assignments are:



## ITSID, bits [31:16]

Unique identifier for this ITS in the system.

This value is the same across all Interrupt Domains for this ITS.

#### Bits [15:9]

Reserved, RESO.

## SWE, bit [8]

Software error reporting support in the Interrupt Domain.

| SWE | Meaning                                    |
|-----|--------------------------------------------|
| 0b0 | Software error reporting is not supported. |
| 0b1 | Software error reporting is supported.     |

Support for Software error reporting is optional.

## MPAM, bit [7]

Memory Partitioning And Monitoring (MPAM) support.

| MPAM | Meaning                |
|------|------------------------|
| 0b0  | MPAM is not supported. |
| 0b1  | MPAM is supported.     |

Support for MPAM is optional.

# MEC, bit [6]

#### When ITS\_IDR0.INT\_DOM == 0b11:

Support for Memory Encryption Contexts (MEC) for the Realm ITS Domain.

| MEC | Meaning                                       |
|-----|-----------------------------------------------|
| 0b0 | Memory Encryption Contexts are not supported. |
| 0b1 | Memory Encryption Contexts are supported.     |

Support for MEC is optional.

Otherwise:

res0

# PA\_RANGE, bits [5:2]

Physical Address range supported.

The physical address range corresponds to the system physical address size.

The value of this field is the same for all ITS Domains across all ITSs in the system

| PA_RANGE | Meaning        |
|----------|----------------|
| 000000   | 32 bits, 4GB   |
| 0b0001   | 36 bits, 64GB  |
| 0b0010   | 40 bits, 1TB   |
| 0b0011   | 42 bits, 4TB   |
| 0b0100   | 44 bits, 16TB  |
| 0b0101   | 48 bits, 256TB |
| 0b0110   | 52 bits, 4PB   |
| 0b0111   | 56 bits, 64PB  |

Values not defined above are reserved.

# INT\_DOM, bits [1:0]

The ITS Domain that the register frame containing this register controls.

| INT_DOM | Meaning    |
|---------|------------|
| 0b00    | Secure     |
| 0b01    | Non-secure |
| 0b10    | EL3        |
| 0b11    | Realm      |

Chapter 10. Registers and memory maps 10.3. ITS register frames

## Accessing ITS\_IDR0

Accesses to this register use the following encodings:

#### Accessible at address 0x0000

# 10.3.1.13 ITS\_IDR1

The ITS\_IDR1 characteristics are:

#### Purpose

ITS identification register 1. Contains read-only fields with information about the ITS GIC component.

#### Attributes

ITS\_IDR1 is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_IDR1 bit assignments are:

| 131 |      | 11  | 10 8   | 7 | 6 | 5         | 0    |
|-----|------|-----|--------|---|---|-----------|------|
|     | RES0 |     | L2SZ   |   |   | DEVICEID_ | BITS |
|     |      | ITI | LEVELS |   | L | DT LEVELS |      |

# Bits [31:11]

Reserved, RESO.

## L2SZ, bits [10:8]

Supported level 2 ITS table sizes when a 2-level table structure is used.

| L2SZ  | Meaning                                   |
|-------|-------------------------------------------|
| 0b1xx | Level 2 DT and ITT sizes supported: 64KiB |
| 0bx1x | Level 2 DT and ITT sizes supported: 16KiB |
| 0bxx1 | Level 2 DT and ITT sizes supported: 4KiB  |

Values not defined above are reserved.

When both ITT\_LEVELS and DT\_LEVELS are 0, this field is RES0.

Arm strongly recommends that the ITS supports L2SZ value <code>Ob111</code>

# ITT\_LEVELS, bit [7]

Levels supported for the ITT.

| ITT_LEVELS | Meaning                                                 |
|------------|---------------------------------------------------------|
| 0b0        | Only a linear ITT structure is supported                |
| 0b1        | Both a 2-level and a linear ITT structure is supported. |

# DT\_LEVELS, bit [6]

Levels supported for the device table.

Chapter 10. Registers and memory maps 10.3. ITS register frames

| DT_LEVELS | Meaning                                                          |
|-----------|------------------------------------------------------------------|
| 0d0       | Only a linear device table structure is supported                |
| 0b1       | Both a 2-level and a linear device table structure is supported. |

# DEVICEID\_BITS, bits [5:0]

The ITS can support translation of up to (2 ^ DEVICEID\_BITS) DeviceIDs.

The maximum permitted value of this field is 32.

# Accessing ITS\_IDR1

Accesses to this register use the following encodings:

#### Accessible at address 0x0004

# 10.3.1.14 ITS\_IDR2

The ITS\_IDR2 characteristics are:

#### Purpose

ITS identification register 2. Contains read-only fields with information about how the ITS GIC component is implemented.

#### Attributes

ITS\_IDR2 is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_IDR2 bit assignments are:



# Bits [31:7]

Reserved, RESO.

## XDMN\_EVENTS, bits [6:5]

Indicates whether the ITS Domain supports translation of events associated with other Interrupt Domains.

| XDMN_EVENTS | Meaning                                                                                                 | Applies                             |
|-------------|---------------------------------------------------------------------------------------------------------|-------------------------------------|
| 0000        | The ITS Domain does not support translation of incoming events associated with other Interrupt Domains. |                                     |
| 0b01        | The ITS Domain supports translation of incoming events associated with the Non-secure Interrupt Domain. | When<br>ITS_IDR0.INT_DOM<br>== 0b11 |

Values not defined above are reserved.

## EVENTID\_BITS, bits [4:0]

The ITS can support translation of up to 2<sup>(EVENTID\_BITS)</sup> EventIDs.

The maximum permitted value of this field is 16.

## Accessing ITS\_IDR2

Accesses to this register use the following encodings:

## Accessible at address 0x0008

# 10.3.1.15 ITS\_IIDR

The ITS\_IIDR characteristics are:

## Purpose

ITS Implementer Identification Register. Provides information about the implementation and implementer of the GIC, and architecture version supported.

# Attributes

ITS\_IIDR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

# Field descriptions

The ITS\_IIDR bit assignments are:

| 31 | 20        | 19 16   | 15 12    | 11 0        |
|----|-----------|---------|----------|-------------|
|    | ProductID | Variant | Revision | Implementer |

# ProductID, bits [31:20]

IMPLEMENTATION DEFINED value identifying the GIC part

When the ITS\_PIDR $\{0,1\}$  registers are present, Arm expects that the ITS\_PIDR $\{0,1\}$ .PART\_ $\{0,1\}$  fields match the value of ITS\_IIDR.ProductID.

If required, however, an implementation is permitted to provide values for ITS\_PIDR. $\{0,1\}$ .PART\_ $\{0,1\}$  that do not match the value of ITS\_IIDR.ProductID

## Variant, bits [19:16]

IMPLEMENTATION DEFINED value used to distinguish product variants, or major revisions of the product

## Revision, bits [15:12]

IMPLEMENTATION DEFINED value used to distinguish minor revisions of the product

## Implementer, bits [11:0]

Contains the JEP106 code of the company that implemented the GIC

For an Arm implementation, the JEP106 code is 0x43B

When the ITS\_PIDR $\{1,2,4\}$  registers are present, Arm expects that the ITS\_PIDR $\{0,1\}$ .PART\_ $\{0,1\}$  fields match the value of ITS\_IIDR.Implementer.

## Accessing ITS\_IIDR

Accesses to this register use the following encodings:

## Accessible at address 0x0040

# 10.3.1.16 ITS\_INV\_DEVICER

The ITS\_INV\_DEVICER characteristics are:

#### Purpose

ITS cache invalidation register for a single device or a range of devices.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before ITS\_STATUSR.IDLE is 1.

#### Attributes

ITS\_INV\_DEVICER is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_INV\_DEVICER bit assignments are:



# l, bit [31]

Writing 1 to this field invalidates cached information from DTEs for the DeviceID specified in ITS\_DIDR.DEVICE\_ID.

| I   | Meaning                                                   |
|-----|-----------------------------------------------------------|
| 0b0 | The write has no effect.                                  |
| 0b1 | Invalidate cached information for the specified DeviceID. |

## Bits [30:6]

Reserved, RESO.

## EVENTID\_BITS, bits [5:1]

The range of EventIDs that the invalidation operation applies to for the specified DeviceID.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than reading back the field.

The maximum value is reported in ITS\_IDR2.EVENTID\_BITS.

If ITS\_INV\_DEVICER.L1 is 1, the effective value of this field is the maximum value reported in ITS\_IDR2.EVENTID\_BITS.

## L1, bit [0]

Controls which cached information the invalidation operation applies to.

When this field is 0, the operation invalidates cached information from the single level 2 DTE specified by ITS\_DIDR.DEVICE\_ID.

When this field is 1, the operation invalidates cached information from the level 1 DTE specified by ITS\_DIDR.DEVICE\_ID as well as any level 2 DTE covered by the range of DeviceIDs given by ITS\_DT\_CFGR.L2SZ for the DeviceID specified in ITS\_DIDR.DEVICE\_ID.

If ITS\_DT\_CFGR.STRUCTURE is 0, the effective value of this field is 0.

Chapter 10. Registers and memory maps 10.3. ITS register frames

| L1  | Meaning                                                                                                      |
|-----|--------------------------------------------------------------------------------------------------------------|
| 0b0 | The cache invalidation operation invalidates information from the specified level 2 DTE.DEVICE_ID.           |
| 0b1 | The cache invalidation operation invalidates information from<br>the specified level 1 DTE and level 2 DTEs. |

# Accessing ITS\_INV\_DEVICER

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_STATUSR.IDLE != 1, access on this interface is WI.
- Otherwise, access on this interface is **WO**.

# 10.3.1.17 ITS\_INV\_EVENTR

The ITS\_INV\_EVENTR characteristics are:

## Purpose

ITS cache invalidation register for a single event or a range of events.

## Configuration

The effects of a write to this register are not guaranteed to have completed before ITS\_STATUSR.IDLE is 1.

## Attributes

ITS\_INV\_EVENTR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

# Field descriptions

The ITS\_INV\_EVENTR bit assignments are:



# l, bit [31]

Writing 1 to this field invalidates cached information from ITTEs for the DeviceID and EventID specified in ITS\_DIDR.DEVICE\_ID and ITS\_EIDR.EVENT\_ID, respectively.

| I   | Meaning                                                               |
|-----|-----------------------------------------------------------------------|
| 0b0 | The write has no effect.                                              |
| 0b1 | Invalidate cached information for the specified DeviceID and EventID. |

# Bits [30:3]

Reserved, RESO.

# ITT\_L2SZ, bits [2:1]

The range of EventIDs that the invalidation operation applies to.

| ITT_L2SZ | Meaning                                                                                                                                               |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b00     | The invalidate operation applies to cached information from<br>any level 2 ITTE whose EventID bits [15:9] matches<br>ITS_EIDR.EVENT_ID bits [15:9].   |
| 0b01     | The invalidate operation applies to cached information from<br>any level 2 ITTE whose EventID bits [15:11] matches<br>ITS_EIDR.EVENT_ID bits [15:11]. |
| 0b10     | The invalidate operation applies to cached information from<br>any level 2 ITTE whose EventID bits [15:13] matches<br>ITS_EIDR.EVENT_ID bits [15:13]. |

If ITS\_INV\_EVENTR.L1 is 0, this field is IGNORED.

Values not defined are reserved.

When programming a reserved value or an unsupported value, the ITS behavior is CONSTRAINED UNPREDICTABLE to any behavior which could be achieved by programming a valid and supported value.

# L1, bit [0]

Controls which cached information the invalidation operation applies to.

When this field is 0, the operation invalidates cached information from the single level 2 ITTE specified by ITS\_DIDR.DEVICE\_ID and ITS\_EIDR.EVENT\_ID.

When this field is 1, the operation invalidates cached information from the level 1 ITTE specified by ITS\_DIDR.DEVICE\_ID and ITS\_EIDR.EVENT\_ID as well as any level 2 ITTE covered by the range of EventIDs given by ITS\_EIDR.EVENT\_ID and ITT\_L2SZ for the DeviceID specified in ITS\_DIDR.DEVICE\_ID.

| L1  | Meaning                                                                                                     |
|-----|-------------------------------------------------------------------------------------------------------------|
| 0b0 | The cache invalidation operation invalidates information from the specified level 2 ITTE.                   |
| 0b1 | The cache invalidation operation invalidates information from the specified level 1 ITTE and level 2 ITTEs. |

# Accessing ITS\_INV\_EVENTR

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_STATUSR.IDLE != 1, access on this interface is **WI**.
- Otherwise, access on this interface is **WO**.

# 10.3.1.18 ITS\_MEC\_IDR

The ITS\_MEC\_IDR characteristics are:

#### Purpose

ITS MEC identification register. Contains read-only fields with information about the ITS support for MEC.

# Attributes

ITS\_MEC\_IDR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_MEC\_IDR bit assignments are:



# Bits [31:4]

Reserved, RESO.

## MECIDSIZE, bits [3:0]

## When ITS\_IDR0.MEC == 1:

The number of bits minus one of MECID supported by the ITS.

The maximum permitted value is 0xF which indicates a MECID width of 16 bits.

The value 0x0 is a valid encoding and indicates that one bit of MECID is supported.

#### Otherwise:

res0

## Accessing ITS\_MEC\_IDR

Accesses to this register use the following encodings:

- When ITS\_IDR0.INT\_DOM != 0b11, access on this interface is RAZ/WI.
- When ITS\_IDR0.MEC != 1, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RO**.

# 10.3.1.19 ITS\_MEC\_MECID\_R

The ITS\_MEC\_MECID\_R characteristics are:

#### Purpose

ITS MEC MECID register for the Realm PAS.

#### Attributes

ITS\_MEC\_MECID\_R is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_MEC\_MECID\_R bit assignments are:

| Ľ | 31 16 | 15 0  |
|---|-------|-------|
|   | RES0  | MECID |

## Bits [31:16]

Reserved, RESO.

#### MECID, bits [15:0]

MECID for ITS access to Realm PA space for:

- Fetches of device table entries.
- Fetches of interrupt translation table entries.

Bits above the supported MECID size, indicated in ITS\_MEC\_IDR.MECIDSIZE are RES0.

If MECIDSIZE is less than 0xF, the ITS treats bits [15:MECIDSIZE+1] of this field as zero.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Accessing ITS\_MEC\_MECID\_R

Accesses to this register use the following encodings:

- When ITS\_IDR0.INT\_DOM != 0b11, access on this interface is **RAZ/WI**.
- When ITS\_IDR0.MEC != 1, access on this interface is **RAZ/WI**.
- When ITS\_CR0.ITSEN == 1 or ITS\_CR0.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.3.1.20 ITS\_MPAM\_IDR

The ITS\_MPAM\_IDR characteristics are:

#### Purpose

ITS MPAM identification register. Contains read-only fields with information about the ITS support for MPAM.

#### Attributes

ITS\_MPAM\_IDR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_MPAM\_IDR bit assignments are:



# Bits [31:25]

Reserved, RESO.

# HAS\_MPAM\_SP, bit [24]

Whether the ITS Domain has support for MPAM PARTID space selection.

If HAS\_MPAM\_SP is 1, the ITS uses the MPAM PARTID specified by ITS\_MPAM\_PARTID\_R.MPAM\_SP.

If HAS\_MPAM\_SP is 0, the following PARTID space is used for ITS accesses to memory:

- Accesses made by the Secure ITS Domain use the Secure PARTID space.
- Accesses made by the Non-secure ITS Domain use the Non-secure PARTID space.
- Accesses made by the EL3 ITS Domain use the Root or Secure PARTID space.
- Accesses made by the Realm ITS Domain use the Realm PARTID space.

The value of this field is the same across all ITS Domains for an ITS.

# PMG\_MAX, bits [23:16]

The maximum PMG value that is permitted to be used in the ITS Domain.

The PMG bit width is defined as the bit position of the most significant 1 in PMG\_MAX[7:0], plus one, or is defined as zero if PMG\_MAX is zero.

For example, if  $PMG_MAX == 0 \times 0 f$ , the PMG bit width is 4.

This field is permitted to be zero-sized.

# PARTID\_MAX, bits [15:0]

The maximum PARTID value that is permitted to be used in the ITS Domain.

The PARTID bit width is defined as the bit position of the most significant 1 in PARTID\_MAX[15:0], plus one, or is defined as zero if PARTID\_MAX is zero.

For example, if PARTID\_MAX ==  $0 \times 0034$ , the PARTID bit width is 6.

This field is permitted to be zero-sized, but Arm recommends that it is non-zero when MPAM is implemented.

## Accessing ITS\_MPAM\_IDR

Accesses to this register use the following encodings:

- When ITS\_IDR0.MPAM != 1, access on this interface is RAZ/WI.
- Otherwise, access on this interface is **RO**.

# 10.3.1.21 ITS\_MPAM\_PARTID\_R

The ITS\_MPAM\_PARTID\_R characteristics are:

#### Purpose

ITS MPAM PARTID and PMG register.

#### Attributes

ITS\_MPAM\_PARTID\_R is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_MPAM\_PARTID\_R bit assignments are:



# IDLE, bit [31]

Whether the effects of the previous write to this register are complete.

Following a write to this register, when this field is 1, the new values written to this register is guaranteed to be used for subsequent memory accesses by the ITS.

| IDLE | Meaning                                                              |
|------|----------------------------------------------------------------------|
| 0b0  | The effects of the previous write to this register are not complete. |
| 0b1  | The effects of the previous write to this register are complete.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

Access to this field is RO.

## Bits [30:26]

Reserved, RESO.

#### MPAM\_SP, bits [25:24]

When ITS\_MPAM\_IDR.HAS\_MPAM\_SP == 1 and ITS\_IDR0.INT\_DOM == 0b00

## MPAM\_SP, bits [1:0] of bits [25:24]

MPAM PARTID space for the Secure ITS Domain.

| MPAM_SP | Meaning                  |
|---------|--------------------------|
| 0b00    | Secure PARTID space.     |
| 0b01    | Non-secure PARTID space. |

Values not defined above are reserved.

# Chapter 10. Registers and memory maps 10.3. ITS register frames

Programming a reserved value results in the ITS using an UNKNOWN PARTID space.

The reset behavior of this field is:

• On a GIC reset, this field resets to an IMPLEMENTATION DEFINED value.

Accessing this field has the following behavior:

- When ITS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

#### When ITS\_MPAM\_IDR.HAS\_MPAM\_SP == 1 and ITS\_IDR0.INT\_DOM == 0b01

#### MPAM\_SP, bits [1:0] of bits [25:24]

MPAM PARTID space for the Non-secure ITS Domain.

| MPAM_SP | Meaning                  |
|---------|--------------------------|
| 0b01    | Non-secure PARTID space. |

Values not defined above are reserved.

Programming a reserved value results in the ITS using an UNKNOWN PARTID space.

The reset behavior of this field is:

• On a GIC reset, this field resets to an IMPLEMENTATION DEFINED value.

Accessing this field has the following behavior:

- When ITS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

#### When ITS\_MPAM\_IDR.HAS\_MPAM\_SP == 1 and ITS\_IDR0.INT\_DOM == 0b10

#### MPAM\_SP, bits [1:0] of bits [25:24]

MPAM PARTID space for the EL3 ITS Domain.

| MPAM_SP | Meaning                  |
|---------|--------------------------|
| 0b00    | Secure PARTID space.     |
| 0b01    | Non-secure PARTID space. |
| 0b10    | Root PARTID space.       |
| 0b11    | Realm PARTID space.      |

Values not defined above are reserved.

Programming a reserved value results in the ITS using an UNKNOWN PARTID space.

The reset behavior of this field is:

• On a GIC reset, this field resets to an IMPLEMENTATION DEFINED value.

Accessing this field has the following behavior:

- When ITS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

# When ITS\_MPAM\_IDR.HAS\_MPAM\_SP == 1 and ITS\_IDR0.INT\_DOM == 0b11

# MPAM\_SP, bits [1:0] of bits [25:24]

MPAM PARTID space for the Realm ITS Domain.

| MPAM_SP | Meaning                  |
|---------|--------------------------|
| 0b01    | Non-secure PARTID space. |
| 0b11    | Realm PARTID space.      |

Values not defined above are reserved.

Programming a reserved value results in the ITS using an UNKNOWN PARTID space.

The reset behavior of this field is:

• On a GIC reset, this field resets to an IMPLEMENTATION DEFINED value.

Accessing this field has the following behavior:

- When ITS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

#### Otherwise:

res0

## PMG, bits [23:16]

PMG for accesses to memory by the ITS Domain.

Bits above the supported PMG bit width, as indicated by ITS\_MPAM\_IDR.PMG\_MAX, are RESO.

If a value greater than ITS\_MPAM\_IDR.PMG\_MAX is programmed, an UNKNOWN PMG is used.

The reset behavior of this field is:

• On a GIC reset, this field resets to  $0 \times 00$ .

Accessing this field has the following behavior:

- When ITS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

## PARTID, bits [15:0]

PARTID for accesses to memory by the ITS Domain.

Bits above the supported PARTID bit width, as indicated by ITS\_MPAM\_IDR.PARTID\_MAX, are RESO.

If a value greater than ITS\_MPAM\_IDR.PARTID\_MAX is programmed, an UNKNOWN PARTID is used.

The reset behavior of this field is:

• On a GIC reset, this field resets to 0x0000.

Accessing this field has the following behavior:

- When ITS\_MPAM\_PARTID\_R.IDLE == 0, access to this field is **RO**
- Otherwise, access to this field is **RW**

## Accessing ITS\_MPAM\_PARTID\_R

Accesses to this register use the following encodings:

- When ITS\_IDR0.MPAM != 1, access on this interface is **RAZ/WI**.
- Otherwise, access on this interface is **RW**.

# 10.3.1.22 ITS\_READ\_EVENTR

The ITS\_READ\_EVENTR characteristics are:

#### Purpose

ITS read event request register.

This register is used to read the translation information for an EventID and DeviceID specified in ITS\_EIDR and ITS\_DIDR registers, respectively.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before ITS\_STATUSR.IDLE is 1.

#### Attributes

ITS\_READ\_EVENTR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_READ\_EVENTR bit assignments are:

| 31 | 30 |      | Θ |
|----|----|------|---|
| R  |    | RES0 |   |

# R, bit [31]

Request ITS to read event translation information.

| R   | Meaning                                                                                            |
|-----|----------------------------------------------------------------------------------------------------|
| 0b0 | The write has no effect on the ITS.                                                                |
| 0b1 | Read the translation information for the specified DeviceID and EventID into ITS_READ_EVENT_DATAR. |

# Bits [30:0]

Reserved, RESO.

## Accessing ITS\_READ\_EVENTR

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_STATUSR.IDLE != 1, access on this interface is WI.
- Otherwise, access on this interface is **WO**.

# 10.3.1.23 ITS\_READ\_EVENT\_DATAR

The ITS\_READ\_EVENT\_DATAR characteristics are:

#### Purpose

ITS read event data register.

This register is used to return translation information for an EventID and DeviceID specified in ITS\_EIDR and ITS\_DIDR registers, respectively.

#### Attributes

ITS\_READ\_EVENT\_DATAR is a 64-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_READ\_EVENT\_DATAR bit assignments are:



# VIRT, bit [63]

#### When ITS\_IDR0.INT\_DOM != 0b10:

Specifies if the interrupt message generated by the ITS to the IRS in response to this event is for a physical or a virtual interrupt.

| VIRT | Meaning                                                                |
|------|------------------------------------------------------------------------|
| 0b0  | The interrupt message generated by the ITS is for a physical interrupt |
| 0b1  | The interrupt message generated by the ITS is for a virtual interrupt  |

If VALID is 0, the value of this field is UNKNOWN.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

#### Bits [62:48]

Reserved, RESO.

## VM\_ID, bits [47:32]

Bits[15:0] of the VM ID passed to the IRS as part of the interrupt message targeting virtual interrupts.

If VIRT is 0, this field is RES0.

If VALID 0, the value of this field is UNKNOWN.

# Chapter 10. Registers and memory maps 10.3. ITS register frames

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# VALID, bit [31]

Specifies whether the ITS has valid translation information for the specified EventID and DeviceID.

| VALID | Meaning                                        |
|-------|------------------------------------------------|
| 0b0   | The EventID does not have a valid translation. |
| 0b1   | The EventID has a valid translation.           |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Bits [30:24]

Reserved, RESO.

# LPI\_ID, bits [23:0]

Bits[23:0] of the LPI ID for the specified EventID.

If unimplemented upper bits of the LPI\_ID are not zero, it is IMPLEMENTATION DEFINED whether the upper bits are treated as 0 or the interrupt message is ignored by the IRS.

If VALID 0, the value of this field is UNKNOWN.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Accessing ITS\_READ\_EVENT\_DATAR

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_STATUSR.IDLE != 1, access on this interface is UN-KNOWN/WI.
- Otherwise, access on this interface is **RO**.

# 10.3.1.24 ITS\_STATUSR

The ITS\_STATUSR characteristics are:

#### Purpose

ITS Status Register.

Reports whether the effects of the last write to all of the following registers are complete:

- ITS\_INV\_DEVICER.
- ITS\_INV\_EVENTR.
- ITS\_READ\_EVENTR.

#### Attributes

ITS\_STATUSR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_STATUSR bit assignments are:

| 31 | 1    | 0 | _    |
|----|------|---|------|
|    | RESO |   |      |
|    |      |   |      |
|    |      |   | IDLE |

## Bits [31:1]

Reserved, RESO.

# IDLE, bit [0]

Reports the status of the last write to all of the following registers:

- ITS INV DEVICER.
- ITS\_INV\_EVENTR.
- ITS\_READ\_EVENTR.

| IDLE | Meaning                                                          |
|------|------------------------------------------------------------------|
| 0b0  | The effects of the last write are not guaranteed to be complete. |
| 0b1  | The effects of the last write are guaranteed to be complete.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Access to this field is RO.

## Accessing ITS\_STATUSR

Accesses to this register use the following encodings:

## Accessible at address 0x0120

# 10.3.1.25 ITS\_SWERR\_STATUSR

The ITS\_SWERR\_STATUSR characteristics are:

#### Purpose

ITS software error status register. Specifies whether a software error has been reported. If an error is reported, it contains syndrome information for the error.

#### Attributes

ITS\_SWERR\_STATUSR is a 64-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_SWERR\_STATUSR bit assignments are:



# Bits [63:32]

Reserved, RESO.

# IMP\_EC, bits [31:24]

IMPLEMENTATION DEFINED error code when  $ITS_SWERR_STATUS.EC == 0$ .

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- Access is **RES0** if any of the following are true:
  - ITS\_SWERR\_STATUSR.V == 0
  - ITS\_SWERR\_STATUSR.EC != 0
- Otherwise, access to this field is **RO**

# EC, bits [23:16]

Specifies the error code that software can use to triage and handle the error.

| EC   | Meaning                                                              |
|------|----------------------------------------------------------------------|
| 0x00 | An error was reported because of an IMPLEMENTATION DEFINED reason.   |
| 0x01 | Failed lookup of L1_DTE due to an external abort.                    |
| 0x02 | Failed lookup of L2_DTE due to an external abort.                    |
| 0x03 | Failed lookup of L1_ITTE due to an external abort.                   |
| 0x04 | Failed lookup of L2_ITTE due to an external abort.                   |
| 0x05 | An incoming event could not be translated because L1_DTE.VALID is 0. |

| EC   | Meaning                                                                                                                                                                                     |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x06 | An incoming event could not be translated because L2_DTE.VALID is 0.                                                                                                                        |
| 0x07 | An incoming event could not be translated because L1_ITTE.VALID is 0.                                                                                                                       |
| 0x08 | An incoming event could not be translated because L2_ITTE.VALID is 0.                                                                                                                       |
| 0x09 | An incoming event could not be translated because the DeviceID > (2 ^ ITS_DT_CFGR.DEVICEID_BITS) - 1.                                                                                       |
| 0x0A | An incoming event could not be translated because the EventID > $(2 \ L2_DTE.EVENTID_BITS) - 1$ .                                                                                           |
| 0x0B | An incoming event could not be translated because the DeviceID exceeds the L1_DTE.SPAN.                                                                                                     |
| 0x0C | An incoming event could not be translated because the EventID exceeds the L1_ITTE.SPAN.                                                                                                     |
| 0x0D | An incoming event could not be translated because the event is<br>associated with the Non-secure Interrupt Domain and<br>L2_ITTE.DAC = 0.<br>The error is reported in the Realm ITS Domain. |
| 0x0E | ITS_GEN_EVENTR was written when<br>ITS_GEN_EVENT_STATUSR.IDLE == 0.                                                                                                                         |
| 0x0F | ITS_READ_EVENTR was written when<br>ITS_STATUSR.IDLE == 0.                                                                                                                                  |
| 0x10 | ITS_INV_DEVICER was written when ITS_STATUSR.IDLE == 0.                                                                                                                                     |
| 0x11 | ITS_INV_EVENTR was written when ITS_STATUSR.IDLE $== 0.$                                                                                                                                    |
| 0x12 | ITS_SYNCR was written when ITS_SYNC_STATUSR.IDLE == 0.                                                                                                                                      |
| 0x13 | An incoming event could not be translated because the EventID exceeds (2 ^ ITS_IDR2.EVENTID_BITS) - 1.                                                                                      |
| 0x14 | An incoming event specified an EventID with a write to a reserved location.                                                                                                                 |

All other values are reserved.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When ITS\_SWERR\_STATUSR.V == 0, access to this field is UNKNOWN/WI
- Otherwise, access to this field is **RO**

# Bits [15:4]

Reserved, RESO.

# OF, bit [3]

Specifies whether multiple software errors have been detected.

When this field is 1, the syndrome information reports information about the error that last caused ITS\_SWERR\_STATUSR.V to transition from 0 to 1.

| OF  | Meaning                                                                                                                         |
|-----|---------------------------------------------------------------------------------------------------------------------------------|
| 0b0 | No errors have been detected, since the error that was reported when ITS_SWERR_STATUSR.V last transitioned from 0 to 1.         |
| 0b1 | At least one error has been detected, since the error that was reported when ITS_SWERR_STATUSR.V last transitioned from 0 to 1. |

When clearing ITS\_SWERR\_STATUSR.V to 0, if this field is nonzero, software writes 1 to clear this field to zero. The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When ITS\_SWERR\_STATUSR.V == 0, access to this field is UNKNOWN/WI
- Otherwise, access to this field is W1C

## S1V, bit [2]

Specifies whether ITS\_SWERR\_SYNDROMER1 is valid.

| S1V | Meaning                            |
|-----|------------------------------------|
| 0b0 | ITS_SWERR_SYNDROMER1 is not valid. |
| 0b1 | ITS_SWERR_SYNDROMER1 is valid.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When ITS\_SWERR\_STATUSR.V == 0, access to this field is UNKNOWN/WI
- Otherwise, access to this field is **RO**

## S0V, bit [1]

Specifies whether ITS\_SWERR\_SYNDROMER0 is valid.

| SOV | Meaning                            |
|-----|------------------------------------|
| 060 | ITS_SWERR_SYNDROMER0 is not valid. |
| 0b1 | ITS_SWERR_SYNDROMER0 is valid.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- When ITS\_SWERR\_STATUSR.V == 0, access to this field is UNKNOWN/WI
- Otherwise, access to this field is **RO**

## V, bit [0]

Specifies whether ITS\_SWERR\_STATUSR is valid and at least one software error has been reported.

| V   | Meaning                         |
|-----|---------------------------------|
| 0b0 | ITS_SWERR_STATUSR is not valid. |
| 0b1 | ITS_SWERR_STATUSR is valid.     |

Software writes 1 to this field to clear it to zero.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Access to this field is **W1C**.

#### Accessing ITS\_SWERR\_STATUSR

After reading ITS\_SWERR\_STATUSR, software clears the valid fields in the register to allow new errors to be reported.

However, between reading the register and clearing the valid fields, a new error might have overwritten the register.

To prevent this error being lost by software, the register prevents updates to fields that might have been updated by a new error.

This is done by ensuring a write to the register is ignored if all of the following are true:

- Any of ITS\_SWERR\_STATUSR.{V, OF} are nonzero before the write.
- The write does not clear the nonzero ITS\_SWERR\_STATUSR.{V, OF} fields to zero by writing ones to the applicable field or fields.

Accesses to this register use the following encodings:

- When ITS\_IDR0.SWE != 1, access on this interface is RAZ/WI.
- Otherwise, access on this interface is RW.

# 10.3.1.26 ITS\_SWERR\_SYNDROMER0

The ITS\_SWERR\_SYNDROMER0 characteristics are:

## Purpose

ITS software error syndrome register 0. Records ITS specific software error syndrome information.

#### Attributes

ITS\_SWERR\_SYNDROMER0 is a 64-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_SWERR\_SYNDROMER0 bit assignments are:



# DEVICE\_ID, bits [63:32]

The DeviceID for the incoming event that generated the software error.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Bits [31:16]

Reserved, RESO.

#### EVENT\_ID, bits [15:0]

The EventID for the incoming event that generated the software error.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Accessing ITS\_SWERR\_SYNDROMER0

Accesses to this register use the following encodings:

- When ITS\_IDR0.SWE != 1, access on this interface is **RAZ/WI**.
- When ITS\_SWERR\_STATUSR.V == 1 and ITS\_SWERR\_STATUSR.SOV == 1, access on this interface is **RO**.
- Otherwise, access on this interface is UNKNOWN/WI.

# 10.3.1.27 ITS\_SWERR\_SYNDROMER1

The ITS\_SWERR\_SYNDROMER1 characteristics are:

#### Purpose

ITS software error syndrome register 1. Records ITS specific software error syndrome information.

#### Attributes

ITS\_SWERR\_SYNDROMER1 is a 64-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

#### Field descriptions

The ITS\_SWERR\_SYNDROMER1 bit assignments are:



## Bits [63:56]

Reserved, RESO.

#### ADDR, bits [55:3]

Bits[55:3] of the physical address of a translation structure associated with the detected error.

The address in this field is associated with the PAS of the ITS Domain where the error is detected.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RESO. The number of implemented address bits is reported in ITS\_IDR0.PA\_RANGE.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Bits [2:0]

Reserved, RESO.

#### Accessing ITS\_SWERR\_SYNDROMER1

Accesses to this register use the following encodings:

- When ITS\_IDR0.SWE != 1, access on this interface is **RAZ/WI**.
- When ITS\_SWERR\_STATUSR.V == 1 and ITS\_SWERR\_STATUSR.S1V == 1, access on this interface is **RO**.
- Otherwise, access on this interface is UNKNOWN/WI.

# 10.3.1.28 ITS\_SYNCR

The ITS\_SYNCR characteristics are:

#### Purpose

ITS synchronize translation events register.

#### Configuration

The effects of a write to this register are not guaranteed to have completed before ITS\_SYNC\_STATUSR.IDLE is 1.

#### Attributes

ITS\_SYNCR is a 64-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

# Field descriptions

The ITS\_SYNCR bit assignments are:

| 63 | 62 33 32  |         |
|----|-----------|---------|
|    | RES0      |         |
| Ľ  | SYNC      | SYNCALL |
| 31 | 0         |         |
|    | DEVICE_ID |         |

# SYNC, bit [63]

A synchronization request applies to the following Accepted events:

- Events that are generated from an IWB.
- Events that are generated from a system peripheral using an IMPLEMENTATION DEFINED mechanism.
- Events that are generated as a result of a write to ITS\_GEN\_EVENTR.
- Events that are generated as a result of a write to a register in an ITS translate register frame associated with the ITS Domain.

Writing 0 to this field has no effect.

| SYNC | Meaning                                                        |
|------|----------------------------------------------------------------|
| 0b0  | The write is IGNORED.                                          |
| 0b1  | The write issuess a synchronization request to the ITS Domain. |

All events covered by the synchronization request, that are Accepted at the time of the write to this register, are guaranteed to have been translated when ITS\_SYNC\_STATUSR.IDLE is 1.

For each such event, if the event has a valid translation, the ITS has generated an interrupt event that is Accepted by the associated IRS.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# Chapter 10. Registers and memory maps 10.3. ITS register frames

# Bits [62:33]

Reserved, RESO.

# SYNCALL, bit [32]

Whether a synchronization request issued by writing 1 to SYNC applies to all Accepted ITS events or is only required to apply to those with specified DeviceID.

| SYNCALL | Meaning                                             |  |
|---------|-----------------------------------------------------|--|
| 0b0     | Synchronize only events for the specified DeviceID. |  |
| 0b1     | Synchronize all events for the ITS Domain.          |  |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

# DEVICE\_ID, bits [31:0]

An ITS synchronization request synchronized all Accepted ITS events with the specified DeviceID.

When SYNCALL is 1, this field is IGNORED.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Accessing ITS\_SYNCR

Accesses to this register use the following encodings:

- When ITS\_CR0.[IDLE,ITSEN] != 0b11 or ITS\_SYNC\_STATUSR.IDLE != 1, access on this interface is WI.
- Otherwise, access on this interface is WO.

# 10.3.1.29 ITS\_SYNC\_STATUSR

The ITS\_SYNC\_STATUSR characteristics are:

#### Purpose

ITS synchronize interrupt events status register.

#### Attributes

ITS\_SYNC\_STATUSR is a 32-bit register.

This register is part of the ITS\_CONFIG\_FRAME block.

## Field descriptions

The ITS\_SYNC\_STATUSR bit assignments are:



# Bits [31:1]

Reserved, RESO.

# IDLE, bit [0]

Whether the effects of the last write to ITS\_SYNCR have completed.

| IDLE | Meaning                                                               |  |
|------|-----------------------------------------------------------------------|--|
| 0b0  | The effects of writing to ITS_SYNCR not guaranteed to have completed. |  |
| 0b1  | The effects of writing to ITS_SYNCR have completed.                   |  |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

Access to this field is RO.

## Accessing ITS\_SYNC\_STATUSR

This register is read-only.

Accesses to this register use the following encodings:

## Accessible at address 0x0148

# 10.3.2 ITS\_TRANSLATE\_FRAME, ITS translate register frame

The ITS\_TRANSLATE\_FRAME characteristics are:

#### Purpose

Contains translate registers used to generate translated interrupts for an ITS Domain.

One or more ITS translate register frames are present for each supported ITS Domain.

Arm strongly recommends that translate register frame is not accessible by PEs. This is because a write to an translate register may require the ITS access to memory, leading to in-out dependencies than can potentially lead to deadlocks in the system. The translate register frames may be mapped in stage 2 translation tables shared between an SMMU and a PE, and software in a VM may perform an access to any of the mapped translate register frames. If the translate register frames are not accessible by PEs, the behavior on an attempted access from a PE is IMPLEMENTATION DEFINED and is likely to result in an External abort. If the translate register frames are accessible by PEs, writes from each PE must use a unique DeviceID that cannot spoof a write originating from a different PE or requesting device.

Each translate register frame is only accessible in the PAS associated with the ITS Domain.

The base address of each translate register frame is distinct from addresses of registers accessible in any other PAS.

The base address of each translate register frame is aligned to 64KB.

#### Attributes

The ITS\_TRANSLATE\_FRAME block is of size 64KB

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

## Contents

| Offset | Name              | Notes                      |
|--------|-------------------|----------------------------|
| 0x0000 | ITS_TRANSLATER    | Most permissive access: WO |
| 0x0008 | ITS_RL_TRANSLATER | Most permissive access: WO |

# 10.3.2.1 ITS\_TRANSLATER

The ITS\_TRANSLATER characteristics are:

## Purpose

ITS translate event register.

A write to this register generates a SET\_EDGE event for the DeviceID of the agent writing to the register and the EventID specified as part of the write.

#### Attributes

ITS\_TRANSLATER is a 32-bit register.

This register is part of the ITS\_TRANSLATE\_FRAME block.

## Field descriptions

The ITS\_TRANSLATER bit assignments are:



## Bits [31:16]

Reserved, RESO.

#### EVENT\_ID, bits [15:0]

The EventID to translate.

## Accessing ITS\_TRANSLATER

This register is write-only.

16-bit access to bits [15:0] of this register must be supported. When this register is written by a 16-bit transaction, bits [31:16] are written as zero.

Implementations must ensure that a unique DeviceID is provided for each requesting device, and the DeviceID is presented to the ITS when a write to this register occurs in a manner that cannot be spoofed by any agent capable of performing writes.

Writes to this register are ignored if the ITS Domain is not enabled.

See Chapter 5 Interrupt translation service (ITS) for more information about ordering and completion requirements for writes to this register.

Accesses to this register use the following encodings:

#### Accessible at address 0x0000

# 10.3.2.2 ITS\_RL\_TRANSLATER

The ITS\_RL\_TRANSLATER characteristics are:

#### Purpose

ITS translate event in Realm ITS Domain register.

A write to this register that uses the Non-secure PAS, generates a SET\_EDGE event for the DeviceID of the agent writing to the register and the EventID specified as part of the write.

The SET\_EDGE event is associated with the Non-secure Interrupt Domain and processed by the ITS in the Realm ITS Domain.

If the translation of the SET\_EDGE event is successful, a SET\_EDGE interrupt event is generated for the IRS in the Realm Interrupt Domain

#### Attributes

ITS\_RL\_TRANSLATER is a 32-bit register.

This register is part of the ITS\_TRANSLATE\_FRAME block.

#### Field descriptions

The ITS\_RL\_TRANSLATER bit assignments are:

| 31 16 | 15 0     |
|-------|----------|
| RES0  | EVENT_ID |

## Bits [31:16]

Reserved, RESO.

## EVENT\_ID, bits [15:0]

The EventID to translate.

## Accessing ITS\_RL\_TRANSLATER

This register is write-only.

16-bit access to bits [15:0] of this register must be supported. When this register is written by a 16-bit transaction, bits [31:16] are written as zero.

Implementations must ensure that a unique DeviceID is provided for each requesting device, and the DeviceID is presented to the ITS when a write to this register occurs in a manner that cannot be spoofed by any agent capable of performing writes.

Writes to this register are IGNORED if any of the following are true:

- The Non-secure ITS Domain is not enabled.
- The Realm ITS Domain is not enabled.

See Chapter 5 Interrupt translation service (ITS) for more information about ordering and completion requirements for writes to this register.

Accesses to this register use the following encodings:

#### Accessible at address 0x0008

- When ITS\_IDR0.INT\_DOM == 0b01 and IsITSDomainImplemented(Realm), access on this interface is WO.
- Otherwise, access on this interface is RAZ/WI.

# 10.4 IWB register frames

# 10.4.1 IWB\_CONFIG\_FRAME, IWB configuration registers frame

The IWB\_CONFIG\_FRAME characteristics are:

#### Purpose

Contains control registers for an IWB.

The base address is aligned to 64KB.

Access to this register frame in a PAS associated with an unimplemented Interrupt Domain is CON-STRAINED UNPREDICTABLE with a choice of:

- The access is RAZ/WI
- The access is made to an implemented Interrupt Domain as follows:
- An access in the Realm PAS is translated to an access in the Non-secure Interrupt Domain
- An access in the Secure PAS is translated to an access in the Non-secure Interrupt Domain
- An access in the Root PAS is translated to an access in the MPPAS of the IWB

#### Attributes

The IWB\_CONFIG\_FRAME block is of size 64KB

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

#### Contents

| Offset                            | Offset Name Notes   |                                               |
|-----------------------------------|---------------------|-----------------------------------------------|
| 0x0000                            | IWB_IDR0            | Most permissive access: RO                    |
| 0x0040                            | IWB_IIDR            | Most permissive access: RO                    |
| 0x0044                            | IWB_AIDR            | Most permissive access: RO                    |
| 0x0080                            | IWB_CR0             | Most permissive access: RW                    |
| 0x00C0                            | IWB_WENABLE_STATUSR | Most permissive access: RO                    |
| 0x00C4                            | IWB_WDOMAIN_STATUSR | Most permissive access: RO                    |
| 0x00C8                            | IWB_WRESAMPLER      | Most permissive access: WO                    |
| 0x2000 + (4 * n)                  | IWB_WENABLER[n]     | Most permissive access: RW                    |
| 0x4000 + (4 * n)                  | IWB_WTMR[n]         | Most permissive access: RW                    |
| 0x6000 + (4 * n)                  | IWB_WDOMAINR[n]     | Most permissive access: RW                    |
| 0x0E00 + (4 * n)for n in<br>⇔63:0 | -                   | Most permissive access: ImplementationDefined |

# 10.4.1.1 IWB\_AIDR

The IWB\_AIDR characteristics are:

#### Purpose

IWB Architecture Identification Register. Identifies the GIC architecture version to which the implementation conforms.

## Attributes

IWB\_AIDR is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

#### Field descriptions

The IWB\_AIDR bit assignments are:



## Bits [31:12]

Reserved, RESO.

#### Component, bits [11:8]

GIC component

| Component | Meaning |  |
|-----------|---------|--|
| 0b0000    | IRS     |  |
| 0b0001    | ITS     |  |
| 0b0010    | IWB     |  |

## ArchMajorRev, bits [7:4]

Major Architecture revision.

| ArchMajorRev | Meaning |
|--------------|---------|
| 00000        | GICv5.x |

## ArchMinorRev, bits [3:0]

Minor Architecture revision.

| ArchMinorRev | Meaning |
|--------------|---------|
| 00000        | GICv5.0 |

#### Accessing IWB\_AIDR

Accesses to this register use the following encodings:

#### Accessible at address 0x0044

# 10.4.1.2 IWB\_IDR0

The IWB\_IDR0 characteristics are:

#### Purpose

IWB ID register 0. Contains read-only fields with information about the IWB GIC component.

#### Attributes

IWB\_IDR0 is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

#### Field descriptions

The IWB\_IDR0 bit assignments are:

| L <sup>31</sup> | 15   | 14  | 11    | 10       | 0 |
|-----------------|------|-----|-------|----------|---|
|                 | RES0 | INT | _DOMS | IW_RANGE |   |

#### Bits [31:15]

Reserved, RESO.

## INT\_DOMS, bits [14:11]

The Interrupt Domains supported by the IWB.

| INT_DOMS | Meaning                                                                |
|----------|------------------------------------------------------------------------|
| 0b0001   | Only the Secure Interrupt Domain is supported                          |
| 0b0010   | Only the Non-secure Interrupt Domain is supported                      |
| 0b0111   | The EL3, Secure and Non-secure Interrupt Domains are supported         |
| 0b1110   | The EL3, Realm, and Non-secure Interrupt Domains are supported         |
| 0b1111   | The EL3, Realm, Secure, and Non-secure Interrupt Domains are supported |

All values not listed are reserved.

## IW\_RANGE, bits [10:0]

Indicates the number of implemented wire control registers.

The number is reported as the highest numbered wire control field as multiple of 32 minus one.

For example:

- A value of 0 means that the IWB supports register accesses to control wires 0-31
- A value of 1 means that the IWB supports register accesses to control wires 0-63
- ... and so on until 0-65535.

#### Accessing IWB\_IDR0

Accesses to this register use the following encodings:

#### Accessible at address 0x0000

# 10.4.1.3 IWB\_IIDR

The IWB\_IIDR characteristics are:

#### Purpose

IWB Implementer Identification Register. Provides information about the implementation and implementer of the GIC, and architecture version supported.

#### Attributes

IWB\_IIDR is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

## Field descriptions

The IWB\_IIDR bit assignments are:

| 131 | 20        | 19 16   | 15 12    | l 11 0      |
|-----|-----------|---------|----------|-------------|
|     | ProductID | Variant | Revision | Implementer |

## ProductID, bits [31:20]

IMPLEMENTATION DEFINED value identifying the GIC part

When the IWB\_PIDR $\{0,1\}$  registers are present, Arm expects that the IWB\_PIDR $\{0,1\}$ .PART\_ $\{0,1\}$  fields match the value of IWB\_IIDR.ProductID.

If required, however, an implementation is permitted to provide values for IWB\_PIDR.{0,1}.PART\_{0,1} that do not match the value of IWB\_IIDR.ProductID

#### Variant, bits [19:16]

IMPLEMENTATION DEFINED value used to distinguish product variants, or major revisions of the product

## Revision, bits [15:12]

IMPLEMENTATION DEFINED value used to distinguish minor revisions of the product

#### Implementer, bits [11:0]

Contains the JEP106 code of the company that implemented the GIC

For an Arm implementation, the JEP106 code is 0x43B

When the IWB\_PIDR $\{1,2,4\}$  registers are present, Arm expects that the IWB\_PIDR $\{0,1\}$ .PART\_ $\{0,1\}$  fields match the value of IWB\_IIDR.Implementer.

#### Accessing IWB\_IIDR

Accesses to this register use the following encodings:

#### Accessible at address 0x0040

# 10.4.1.4 IWB\_CR0

The IWB\_CR0 characteristics are:

#### Purpose

IWB control register 0.

#### Attributes

IWB\_CR0 is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

#### Field descriptions

The IWB\_CR0 bit assignments are:



## Bits [31:2]

Reserved, RESO.

# IDLE, bit [1]

Whether the transition between enabled and disabled states of the IWB is complete.

| IDLE | Meaning                                                             |
|------|---------------------------------------------------------------------|
| 000  | The effects of updating IWBEN are not guaranteed to have completed. |
| 0b1  | The effects of updating IWBEN have completed.                       |

The reset behavior of this field is:

• On a GIC reset, this field resets to Ob1.

Access to this field is **RO**.

#### IWBEN, bit [0]

Controls if the IWB is enabled.

| IWBEN | Meaning                                                         |
|-------|-----------------------------------------------------------------|
| 060   | Disabled. The IWB does not generate any events its destination. |
| 0b1   | Enabled. The IWB may generate events to its destination.        |

The reset behavior of this field is:

• On a GIC reset, this field resets to 0b0.

Accessing this field has the following behavior:

- When IWB\_CR0.IDLE == 0, access to this field is **RO**
- RO if !IsAccessIWBMPPAS()
- Otherwise, access to this field is **RW**

## Accessing IWB\_CR0

Accesses to this register use the following encodings:

#### Accessible at address 0x0080

# 10.4.1.5 IWB\_WDOMAIN\_STATUSR

The IWB\_WDOMAIN\_STATUSR characteristics are:

#### Purpose

IWB wire assignment status register for an Interrupt Domain.

#### Attributes

IWB\_WDOMAIN\_STATUSR is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

## Field descriptions

The IWB\_WDOMAIN\_STATUSR bit assignments are:



# Bits [31:1]

Reserved, RESO.

## IDLE, bit [0]

Tracks status of writes to IWB\_WDOMAINR<n> on this IWB.

| IDLE | Meaning                                          |
|------|--------------------------------------------------|
| 0b0  | A write to IWB_WDOMAINR <n> is in progress.</n>  |
| 0b1  | No write to IWB_WDOMAINR <n> is in progress.</n> |

## Accessing IWB\_WDOMAIN\_STATUSR

Accesses to this register use the following encodings:

## Accessible at address 0x00C4

- When IsAccessIWBMPPAS(), access on this interface is **RO**.
- Otherwise, access on this interface is RAZ/WI.

# 10.4.1.6 IWB\_WDOMAINR<n>, n = 0 - 4095

The IWB\_WDOMAINR<n> characteristics are:

#### Purpose

IWB wire Interrupt Domain selection register. Allows software to configure the Interrupt Domain that wires n \* 16 through ((n \* 16) + 15) are assigned to.

#### Configuration

The number of implemented IWB\_WDOMAINR<n> registers is (IWB\_IDR0.IW\_RANGE + 1) \* 2.

The effects of a write to this register are not guaranteed to have completed until IWB\_WDOMAIN\_STATUSR.IDLE is 1.

#### Attributes

IWB\_WDOMAINR<n> is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

## Field descriptions

The IWB\_WDOMAINR<n> bit assignments are:



## WDOM < x >, bits [2x+1:2x], for x = 15 to 0

Configures the Interrupt Domain that wire ((16 \* n) + x) is assigned to.

Programming an Interrupt Domain not supported by the IWB results in CONSTRAINED UNPREDICTABLE behavior with the following options:

- No signals are generated by the IWB for a wire assigned to an unsupported Interrupt Domain.
- The wire is treated as being assigned to another supported Interrupt Domain and a read of this field returns the Interrupt Domain the wire is assigned to.

Access to control fields for wires which are not implemented are RAZ/WI.

| WDOM <x></x> | Meaning    |
|--------------|------------|
| 0000         | Secure     |
| 0b01         | Non-secure |
| 0b10         | EL3        |
| 0b11         | Realm      |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RO** if IsWireDomainRO((n \* 16) + x)
- Otherwise, access to this field is **RW**

#### Accessing IWB\_WDOMAINR<n>

When the Interrupt Domain assigned of a wire is fixed, access to the corresponding field is RO.

This register can only be accessed through the MPPAS of the IWB.

Accesses to this register use the following encodings:

#### Accessible at address 0x6000 + (4 \* n)

- When IWB\_CR0.IDLE == 0, access on this interface is **RO**.
- When !IsAccessIWBMPPAS(), access on this interface is RAZ/WI.
- Otherwise, access on this interface is **RW**.

# 10.4.1.7 IWB\_WENABLE\_STATUSR

The IWB\_WENABLE\_STATUSR characteristics are:

#### Purpose

IWB wire enable status register for an Interrupt Domain.

#### Attributes

IWB\_WENABLE\_STATUSR is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

## Field descriptions

The IWB\_WENABLE\_STATUSR bit assignments are:



# Bits [31:1]

Reserved, RESO.

## IDLE, bit [0]

Tracks status of writes to IWB\_WENABLER<n> on this IWB where the writes used the same PAS that was used to access this register.

| IDLE | Meaning                                                                                              |
|------|------------------------------------------------------------------------------------------------------|
| 060  | A write to IWB_WENABLER <n> using the PAS that was used to access this register is in progress.</n>  |
| 0b1  | No write to IWB_WENABLER <n> using the PAS that was used to access this register is in progress.</n> |

# Accessing IWB\_WENABLE\_STATUSR

Accesses to this register use the following encodings:

## Accessible at address 0x00C0

# 10.4.1.8 IWB\_WENABLER<n>, n = 0 - 2047

The IWB\_WENABLER<n> characteristics are:

#### Purpose

IWB wire enable register. Allows software to configure if individual wires are enabled or disabled.

#### Configuration

The number of implemented IWB\_WENABLER<n> registers is IWB\_IDR0.IW\_RANGE + 1.

The effects of a write to this register are not guaranteed to have completed before IWB\_WENABLE\_STATUSR.IDLE is 1.

#### Attributes

IWB\_WENABLER<n> is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

#### Field descriptions

The IWB\_WENABLER<n> bit assignments are:



## WEN<x>, bits [x], for x = 31 to 0

Configures if wire ((32 \* n) + x) is enabled or disabled.

Access to control fields for wires which are not implemented are RAZ/WI.

| WEN <x></x> | Meaning       |  |
|-------------|---------------|--|
| 0b0         | Wire disabled |  |
| 0b1         | Wire enabled  |  |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- **RAZ/WI** if !IsWireAccessible(n, x)
- Otherwise, access to this field is RW

## Accessing IWB\_WENABLER<n>

When accessed using the MPPAS of the IWB, all fields are RW.

When accessed using any other PAS, a field is RW if all of the following are true:

- The wire corresponding to the field is assigned to an Interrupt Domain that is implemented by the IWB.
- The PAS corresponding to the access is same as the PAS associated with the Interrupt Domain to which the wire is assigned.

Otherwise, the field is RAZ/WI for that access.

Accesses to this register use the following encodings:

#### Accessible at address 0x2000 + (4 \* n)

- When IWB\_CR0.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.4.1.9 IWB\_WRESAMPLER

The IWB\_WRESAMPLER characteristics are:

#### Purpose

IWB wire resample register.

#### Attributes

IWB\_WRESAMPLER is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

#### Field descriptions

The IWB\_WRESAMPLER bit assignments are:



#### Bits [31:16]

Reserved, RESO.

#### IWI, bits [15:0]

Input Wire Index. Specifies the wire to resample.

Following a write to this register, if all of the following are true, the wire is resampled:

- The access to this register is performed using the PAS associated with the Interrupt Domain that the wire is assigned to or the MPPAS of the IWB.
- The specified wire is enabled.

If the specified wire is disabled, the write to this register has no effect.

See 'IWB wire control registers' for more information.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Accessing IWB\_WRESAMPLER

Accesses to this register use the following encodings:

#### Accessible at address 0x00C8

- When IWB\_CR0.IDLE == 0, access on this interface is **WI**.
- Otherwise, access on this interface is **WO**.

# 10.4.1.10 IWB\_WTMR<n>, n = 0 - 2047

The IWB\_WTMR<n> characteristics are:

#### Purpose

IWB Wire Trigger mode register. Allows software to configure if the wire signal is level-sensitive or edge-triggered.

#### Configuration

The number of implemented IWB\_WTMR<n> registers is IWB\_IDR0.IW\_RANGE + 1.

#### Attributes

IWB\_WTMR<n> is a 32-bit register.

This register is part of the IWB\_CONFIG\_FRAME block.

## Field descriptions

The IWB\_WTMR<n> bit assignments are:



## *TM*<*x*>, bits [*x*], for *x* = 31 to 0

Configures if wire ((32 \* n) + x) is level-sensitive or edge-triggered.

When the wire is configured as level-sensitive, a CLEAR event is sent to the ITS when the wire signal is de-asserted, and a SET\_LEVEL event is sent to the ITS when the wire signal is asserted.

When the wire is configured as edge-triggered, only SET\_EDGE event are generated to the ITS and only when the wire changes from de-asserted to asserted.

When IsWireConfigRO(n \* 32 + x) is 0, this field resets to 0.

Access to control fields for wires which are not implemented are RAZ/WI.

| TM <x></x> | Meaning         |
|------------|-----------------|
| 0b0        | Edge-triggered  |
| 0b1        | Level-sensitive |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Accessing this field has the following behavior:

- Access is **RO** if any of the following are true:
  - !IsWireAccessible(n, x)
  - IsWireConfigRO((n \* 32) + x)
- Otherwise, access to this field is **RW**

#### Accessing IWB\_WTMR<n>

When the Trigger mode of a wire is software programmable, all of the following are true:

- When accessed using the MPPAS of the IWB, all fields are RW.
- When accessed using any other PAS, a field is RW if all of the following are true:
  - The wire corresponding to the field is assigned to an Interrupt Domain that is implemented by the IWB.
  - The PAS corresponding to the access is same as the PAS associated with the Interrupt Domain to which the wire is assigned.

Otherwise, the field is **RO** for that access.

Accesses to this register use the following encodings:

#### Accessible at address 0x4000 + (4 \* n)

- When IWB\_CR0.IDLE == 0, access on this interface is **RO**.
- Otherwise, access on this interface is **RW**.

# 10.5 GIC PMU register frame

# 10.5.1 GIC\_PMU\_FRAME, GIC PMU register frame

The GIC\_PMU\_FRAME characteristics are:

#### Purpose

Contains GIC PMU registers.

The GIC PMU register frame is accessible in each PAS corresponding to an Interrupt Domain that the PMU can count events for.

The base address of the GIC PMU register frame is distinct from any other GIC register frame.

The base address of the GIC PMU register frame is aligned to 64KB.

## Attributes

The GIC\_PMU\_FRAME block is of size 64KB

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

#### Contents

| Offset          | Name              | Notes                      |
|-----------------|-------------------|----------------------------|
| 0x400 + (8 * n) | GIC_PMEVTYPER[n]  | Most permissive access: RW |
| 0x800 + (8 * n) | GIC_PMEVFILT2R[n] | Most permissive access: RW |
| 0xA00 + (8 * n) | GIC_PMEVFILTR[n]  | Most permissive access: RW |
| 0xD80           | GIC_PMIDR0        | Most permissive access: RO |

 $\mathbb{I}_{KCDRK}$  The GIC PMU frame describes the register frame of a GIC PMU compliant with the register formats and layouts defined by the  $Arm^{\textcircled{0}}$  CoreSight<sup>TM</sup> Architecture Performance Monitoring Unit Architecture[11].

Not all registers are shown. Only those registers where the ITS architecture specifies an architected behavior of an IMPLEMENTATION DEFINED field as specified in [11] are shown. These registers are renamed as their behavior is specified by the GICv5 architecture. For the remaining offsets and register definitions, see [11].

# 10.5.1.1 GIC\_PMEVFILT2R<n>, n = 0 - 63

The GIC\_PMEVFILT2R<n> characteristics are:

#### Purpose

GIC PMU Event Filter 2 Register

#### Attributes

GIC\_PMEVFILT2R<n> is a 64-bit register.

This register is part of the GIC\_PMU\_FRAME block.

#### Field descriptions

The GIC\_PMEVFILT2R<n> bit assignments are:

#### When GIC\_PMEVTYPER<n>.PMEVTYPE IN {0b01x}:



#### Bits [63:61]

Reserved, RESO.

#### FILTER\_EID\_SPAN, bit [60]

## When GIC\_PMEVTYPER<n>.FS == 1, GIC\_PMEVTYPER<n>.FSPAN == 1 and FILTER\_EID == 1:

Controls if filtering using EventID uses exact matching or matches a range of values.

If the ITS being monitored only implements support for 1 bit of EventID, this field is treated as 0.

See 'GIC Performance Monitoring Units' for more information.

| FILTER_EID_SPAN | Meaning                                                              |
|-----------------|----------------------------------------------------------------------|
| 060             | GIC_PMEVFILTR <n>.EVENT_ID filters EventID on an exact match.</n>    |
| 0b1             | GIC_PMEVFILTR <n>.EVENT_ID filters EventID on a range of values.</n> |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

### Otherwise:

res0

#### FILTER\_EID, bit [59]

## When GIC\_PMEVTYPER<n>.FS == 1 and FILTER\_DID == 1:

Controls whether filtering using EventID is enabled.

Filtering on EventID is only supported when also filtering on DeviceID.

See 'GIC Performance Monitoring Units' for more information.

| FILTER_EID | Meaning                                                              |
|------------|----------------------------------------------------------------------|
| 0b0        | Count events from all EventIDs for the matched DeviceIDs.            |
| 0b1        | Count events that match the DeviceID and EventID filter programming. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

#### FILTER\_DID\_SPAN, bit [58]

## When GIC\_PMEVTYPER<n>.FS == 1, GIC\_PMEVTYPER<n>.FSPAN == 1 and FILTER\_DID == 1:

Controls if filtering using DeviceID uses exact matching or matches a range of values.

If the ITS being monitored only implements support for 1 bit of DeviceID, this field is treated as 0.

See 'GIC Performance Monitoring Units' for more information.

| FILTER_DID_SPAN | Meaning                                                                |
|-----------------|------------------------------------------------------------------------|
| 0d0             | GIC_PMEVFILTR <n>.DEVICE_ID filters DeviceID on an exact match.</n>    |
| 0b1             | GIC_PMEVFILTR <n>.DEVICE_ID filters DeviceID on a range of values.</n> |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Otherwise:

res0

#### FILTER\_DID, bit [57]

#### When GIC\_PMEVTYPER<n>.FS == 1:

Controls whether filtering using DeviceID is enabled.

| FILTER_DID | Meaning                                                  |
|------------|----------------------------------------------------------|
| 0d0        | Count events from all DeviceIDs.                         |
| 0b1        | Count events that match the DeviceID filter programming. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

Bits [56:16]

Reserved, RESO.

#### ITSID, bits [15:0]

Events from the ITS that match this value are counted.

If the agent being monitored does not contain more than one ITS, this field is RESO.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### When GIC\_PMEVTYPER<n>.PMEVTYPE IN {0b00x}:



#### FILTER\_VM\_ID, bit [63]

#### When GIC\_PMEVTYPER<n>.FS == 1 and FILTER\_VIRT == 0b01:

Controls whether counting of virtual events is filtered based on their VM ID.

When an event is selected that does not support filtering on virtual events, this field is RESO and has no impact on the counted events.

| FILTER_VM_ID | Meaning                                                                                                                                       |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0          | Events translated to virtual interrupt events are not filtered on VM ID.                                                                      |
| 0b1          | Events translated to virtual interrupt events are only counted if<br>the VM ID matches the value specified in<br>GIC_PMEVFILTR <n>.VM_ID.</n> |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

#### FILTER\_VIRT, bits [62:61]

#### When GIC\_PMEVTYPER<n>.FS == 1:

Controls whether counting of events is filtered based on whether they are virtual or physical.

When an event is selected that does not support filtering on virtual events, this field is RESO and has no impact on the counted events.

| FILTER_VIRT | Meaning                                            |
|-------------|----------------------------------------------------|
| 0000        | Physical and virtual interrupt events are counted. |
| 0b01        | Only virtual interrupt events are counted.         |
| 0b10        | Only physical interrupt events are counted.        |

Values not defined are reserved.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

#### FILTER\_INTID\_SPAN, bit [60]

#### When GIC\_PMEVTYPER<n>.FS == 1, GIC\_PMEVTYPER<n>.FSPAN == 1 and FILTER\_INTID == 1:

Controls if filtering using INTID uses exact matching or matches a range of INTID.ID values.

When an event is selected that does not support filtering on INTID, this field is RESO and has no impact on the counted events.

See 'GIC Performance Monitoring Units' for more information.

| FILTER_INTID_SPAN | Meaning                                                         |
|-------------------|-----------------------------------------------------------------|
| 0b0               | GIC_PMEVFILTR <n>.ID filters INTID.ID on an exact match.</n>    |
| 0b1               | GIC_PMEVFILTR <n>.ID filters INTID.ID on a range of values.</n> |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

#### FILTER\_INTID, bit [59]

#### When GIC\_PMEVTYPER<n>.FS == 1:

Controls whether filtering using INTID is enabled.

When an event is selected that does not support filtering on INTID, this field is RESO and has no impact on the counted events.

| FILTER_INTID | Meaning                                                                               |
|--------------|---------------------------------------------------------------------------------------|
| 0b0          | Count interrupt events for all INTIDs.                                                |
| 0b1          | Count interrupt events that match the GIC_PMEVFILTR <n>.INTID filter programming.</n> |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

FILTER\_RW, bits [58:57]

#### When GIC\_PMEVTYPER<n>.FS == 1:

Controls whether counting of events is filtered based on whether they are read or write events.

When an event is selected that does not support filtering on reads or writes, this field is RESO and has no impact on the counted events.

| FILTER_RW | Meaning                                 |
|-----------|-----------------------------------------|
| 0000      | Both read and write events are counted. |
| 0b01      | Only read events are counted.           |
| 0b10      | Only write events are counted.          |

Values not defined are reserved.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

#### FILTER\_SRC\_PE, bit [56]

#### When GIC\_PMEVTYPER<n>.FS == 1:

Controls whether filtering of PE commands using source PE IAFFID is enabled.

When an event is selected that does not support filtering on source PE IAFFID, this field is RESO and has no impact on the counted events.

| FILTER_SRC_PE | Meaning                                                                                           |
|---------------|---------------------------------------------------------------------------------------------------|
| 0b0           | Count PE commands from all PEs.                                                                   |
| 0b1           | Count PE commands sent from PEs whose IAFFID match the GIC_PMEVFILTR <n>.IAFFID filter value.</n> |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

Bits [55:16]

Reserved, RESO.

IAFFID, bits [15:0]

#### When GIC\_PMEVTYPER<n>.FS == 1 and FILTER\_SRC\_PE == 1:

When filtering on source PE IAFFID, only PE commands from a PE whose IAFFID matches this value are counted.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

## Accessing GIC\_PMEVFILT2R<n>

Accesses to this register use the following encodings:

## Accessible at address 0x800 + (8 \* n)

# 10.5.1.2 GIC\_PMEVFILTR<n>, n = 0 - 63

The GIC\_PMEVFILTR<n> characteristics are:

#### Purpose

GIC PMU Event Filter Register

#### Attributes

GIC\_PMEVFILTR<n> is a 64-bit register.

This register is part of the GIC\_PMU\_FRAME block.

#### Field descriptions

The GIC\_PMEVFILTR<n> bit assignments are:

## When GIC\_PMEVTYPER<n>.PMEVTYPE IN {0b01x}:



#### Bits [63:48]

Reserved, RESO.

#### EVENT\_ID, bits [47:32]

When filtering by EventID, the EventIDs that match this value are counted.

When GIC\_PMEVFILT2R<n>.FILTER\_EID is 0, this field is IGNORED.

When GIC\_PMEVFILT2R<n>.FILTER\_EID is 1, GIC\_PMEVFILT2R<n>.FILTER\_EID\_SPAN controls how the EventID is matched against this value.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## DEVICE\_ID, bits [31:0]

When filtering by DeviceID, the DeviceIDs that match this value are counted.

When GIC\_PMEVFILT2R<n>.FILTER\_DID is 0, this field is IGNORED.

When GIC\_PMEVFILT2R<n>.FILTER\_DID is 1, GIC\_PMEVFILT2R<n>.FILTER\_DID\_SPAN controls how the DeviceID is matched against this value.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### When GIC\_PMEVTYPER<n>.PMEVTYPE IN {0b00x}:



#### Bits [63:48]

Reserved, RESO.

## VM\_ID, bits [47:32]

#### When GIC\_PMEVFILT2R<n>.FILTER\_VM\_ID == 1:

When filtering on VM\_ID only events that are translated to virtual interrupt events matching this VM\_ID are counted.

When an event is selected that does not support filtering on VM ID, this field is RES0 and has no impact on the counted events.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

TYPE, bits [31:29]

#### When GIC\_PMEVFILT2R<n>.FILTER\_INTID == 1:

Type of the interrupt.

When an event is selected that does not support filtering on INTID, this field is RESO and has no impact on the counted events.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

Bits [28:24]

Reserved, RESO.

ID, bits [23:0]

When GIC\_PMEVFILT2R<n>.FILTER\_INTID == 1:

The ID of the interrupt.

ID and TYPE together form an INTID.

The monitored IRS may implement fewer than 24 bits of ID. Unimplemented upper bits are RESO.

When GIC\_PMEVFILT2R<n>.FILTER\_INTID is 1, GIC\_PMEVFILT2R<n>.FILTER\_INTID\_SPAN controls how the INTID is matched against this value.

When an event is selected that does not support filtering on INTID, this field is RESO and has no impact on the counted events.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

## Accessing GIC\_PMEVFILTR<n>

Accesses to this register use the following encodings:

## Accessible at address 0xA00 + (8 \* n)

# 10.5.1.3 GIC\_PMEVTYPER<n>, n = 0 - 63

The GIC\_PMEVTYPER<n> characteristics are:

#### Purpose

GIC PMU Event Type Select Register

#### Attributes

GIC\_PMEVTYPER<n> is a 64-bit register.

This register is part of the GIC\_PMU\_FRAME block.

#### Field descriptions

The GIC\_PMEVTYPER<n> bit assignments are:

| Le | 53     |        |        |    |     |    |      |    |          |         | 32 |
|----|--------|--------|--------|----|-----|----|------|----|----------|---------|----|
|    |        |        |        |    |     |    |      | RE | S0       |         |    |
| 13 | 31   3 | 30   2 | 9 1 28 | 27 | 26  | 25 | 1 24 | 16 | 15 12    | 11      |    |
|    | VF     | S      | RL     |    | NS  | S  | RES0 |    | PMEVTYPE | PMEVTID |    |
| F  | SP/    | ΔN_    |        |    | ELS | 3  |      |    |          |         |    |

## Bits [63:32]

Reserved, RESO.

## V, bit [31]

Whether PMEVTYPE and PMEVTID select a valid event.

| V   | Meaning                                                |
|-----|--------------------------------------------------------|
| 0b0 | The event selected by PMEVTYPE and PMEVTID is invalid. |
| 0b1 | The event selected by PMEVTYPE and PMEVTID is valid.   |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Access to this field is RO.

## FS, bit [30]

Whether filtering is supported for the event selected in GIC\_PMEVTID.

When V is 0, the value of this field is UNKNOWN.

| FS  | Meaning                                            |
|-----|----------------------------------------------------|
| 0b0 | Filtering for the selected event is not supported. |
| 0b1 | Filtering for the selected event is supported.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Access to this field is RO.

## FSPAN, bit [29]

Whether filtering using a range of values is supported for the event selected in GIC\_PMEVTID. See 'GIC Performance Monitoring Units' for more information about filtering on a range of values.

When V is 0 or FS is 0, the value of this field is UNKNOWN.

| FSPAN | Meaning                                             |
|-------|-----------------------------------------------------|
| 0b0   | Filtering using a range of values is not supported. |
| 0b1   | Filtering using a range of values is supported.     |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Access to this field is RO.

## RL, bit [28]

#### When GIC\_PMIDR0.OACE == 1 and GIC\_PMIDR0.DOM\_RL == 1:

Configures matching the Realm Interrupt Domain.

| RL  | Meaning                                                                                          |
|-----|--------------------------------------------------------------------------------------------------|
| 0b0 | Events or characteristics attributable to the Realm Interrupt Domain are unaffected by this bit. |
| 0b1 | Do not count events or monitor characteristics attributable to the Realm Interrupt Domain.       |

This bit is ignored by the PMU when the PMU is not allowed to observe events or characteristics attributable to Realm operation of the agent being monitored.

Accessing this bit has the following behavior:

- This bit reads-as-zero if the PMU is never allowed to observe events or characteristics attributable to Realm operation of the agent being monitored.
- Otherwise, this bit is read/write.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

EL3, bit [27]

## When GIC\_PMIDR0.OACE == 1 and GIC\_PMIDR0.DOM\_EL3 == 1:

Configures matching the EL3 Interrupt Domain.

| EL3 | Meaning                                                     |
|-----|-------------------------------------------------------------|
| 0b0 | Events or characteristics attributable to the EL3 Interrupt |
|     | Domain are unaffected by this bit.                          |

| EL3 | Meaning                                                                                  |
|-----|------------------------------------------------------------------------------------------|
| 0b1 | Do not count events or monitor characteristics attributable to the EL3 Interrupt Domain. |

This bit is ignored by the PMU when the PMU is not allowed to observe events or characteristics attributable to EL3 operation of the agent being monitored.

Accessing this bit has the following behavior:

- This bit reads-as-zero if the PMU is never allowed to observe events or characteristics attributable to EL3 operation of the agent being monitored.
- Otherwise, this bit is read/write.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

NS, bit [26]

#### When GIC\_PMIDR0.OACE == 1 and GIC\_PMIDR0.DOM\_NS == 1:

Configures matching the Non-secure Interrupt Domain.

| NS  | Meaning                                                                                               |
|-----|-------------------------------------------------------------------------------------------------------|
| 0b0 | Events or characteristics attributable to the Non-secure Interrupt Domain are unaffected by this bit. |
| 0b1 | Do not count events or monitor characteristics attributable to the Non-secure Interrupt Domain.       |

This bit is ignored by the PMU when the PMU is not allowed to observe events or characteristics attributable to Non-secure operation of the agent being monitored.

Accessing this bit has the following behavior:

- This bit reads-as-zero if the PMU is never allowed to observe events or characteristics attributable to Non-secure operation of the agent being monitored.
- Otherwise, this bit is read/write.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

Otherwise:

res0

S, bit [25]

When GIC\_PMIDR0.OACE == 1 and GIC\_PMIDR0.DOM\_S == 1:

Configures matching the Secure Interrupt Domain.

| s   | Meaning                                                                                           |
|-----|---------------------------------------------------------------------------------------------------|
| 0b0 | Events or characteristics attributable to the Secure Interrupt Domain are unaffected by this bit. |
| 0b1 | Do not count events or monitor characteristics attributable to the Secure Interrupt Domain.       |

This bit is ignored by the PMU when the PMU is not allowed to observe events or characteristics attributable to Secure operation of the agent being monitored.

Accessing this bit has the following behavior:

- This bit reads-as-zero if the PMU is never allowed to observe events or characteristics attributable to Secure operation of the agent being monitored.
- Otherwise, this bit is read/write.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### Otherwise:

res0

#### Bits [24:16]

Reserved, RESO.

#### PMEVTYPE, bits [15:12]

The performance monitor event type.

The value in this field selects the event for the type selected in PMEVTYPE.

Values not defined are reserved.

| PMEVTYPE | Meaning                           |
|----------|-----------------------------------|
| 000000   | Architected IRS event.            |
| 0b0001   | IMPLEMENTATION DEFINED IRS event. |
| 0b0010   | Architected ITS event.            |
| 0b0011   | IMPLEMENTATION DEFINED ITS event. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## PMEVTID, bits [11:0]

The performance monitor event ID.

The value in this field selects the event for the type selected in PMEVTYPE.

If the value in this field combined with the value in PMEVTYPE selects an invalid event, all other fields in this register are IGNORED.

If less than 16 bits of event ID is implemented, unimplemented upper bits are RESO.

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

## Accessing GIC\_PMEVTYPER<n>

Accesses to this register use the following encodings:

#### Accessible at address 0x400 + (8 \* n)

# 10.5.1.4 GIC\_PMIDR0

The GIC\_PMIDR0 characteristics are:

#### Purpose

GIC PMU identification register 0. Contains read-only fields with information about the GIC PMU.

#### Attributes

GIC\_PMIDR0 is a 32-bit register.

This register is part of the GIC\_PMU\_FRAME block.

#### Field descriptions

The GIC\_PMIDR0 bit assignments are:



## Bits [31:7]

Reserved, RESO.

## DOM\_RL, bit [6]

Whether a component in the agent being monitored supports the Realm Interrupt Domain.

| DOM_RL | Meaning                                                                                    |
|--------|--------------------------------------------------------------------------------------------|
| 0b0    | The Realm Interrupt Domain is not supported by any component in the agent being monitored. |
| 0b1    | The Realm Interrupt Domain is supported by a component in the agent being monitored.       |

## DOM\_EL3, bit [5]

Whether a component in the agent being monitored supports the EL3 Interrupt Domain.

| DOM_EL3 | Meaning                                                                                  |
|---------|------------------------------------------------------------------------------------------|
| 0d0     | The EL3 Interrupt Domain is not supported by any component in the agent being monitored. |
| 0b1     | The EL3 Interrupt Domain is supported by a component in the agent being monitored.       |

## DOM\_NS, bit [4]

Whether a component in the agent being monitored supports the Non-secure Interrupt Domain.

| DOM_NS | Meaning                                                                                         |
|--------|-------------------------------------------------------------------------------------------------|
| 0b0    | The Non-secure Interrupt Domain is not supported by any component in the agent being monitored. |
| 0b1    | The Non-secure Interrupt Domain is supported by a component in the agent being monitored.       |

## DOM\_S, bit [3]

Whether a component in the agent being monitored supports the Secure Interrupt Domain.

| DOM_S | Meaning                                                                                     |
|-------|---------------------------------------------------------------------------------------------|
| 000   | The Secure Interrupt Domain is not supported by any component in the agent being monitored. |
| 0b1   | The Secure Interrupt Domain is supported by a component in the agent being monitored.       |

## OACE, bit [2]

Whether the PMU implements the observability and access control extension.

| OACE | Meaning                                                                    |
|------|----------------------------------------------------------------------------|
| 0b0  | The PMU does not implement the observability and access control extension. |
| 0b1  | The PMU implements the observability and access control extension.         |

#### ITS\_PMU, bit [1]

Whether this PMU counts events from an ITS.

This field can be interpreted in combination with IRS\_PMU to determine the GIC PMU configuration.

See 'GIC Performance Monitoring Unit (PMU)' for more information.

| ITS_PMU | Meaning                                       |
|---------|-----------------------------------------------|
| 0b0     | This PMU does not count events from an ITS.   |
| 0b1     | This PMU counts events from at least one ITS. |

#### IRS\_PMU, bit [0]

Whether this PMU counts events from an ITS.

This field can be interpreted in combination with ITS\_PMU to determine the GIC PMU configuration.

See 'GIC Performance Monitoring Unit (PMU)' for more information.

Chapter 10. Registers and memory maps 10.5. GIC PMU register frame

| IRS_PMU | Meaning                                     |
|---------|---------------------------------------------|
| 0b0     | This PMU does not count events from an IRS. |
| 0b1     | This PMU counts events from an IRS.         |

#### Accessing GIC\_PMIDR0

Accesses to this register use the following encodings:

#### Accessible at address 0xD80

Access on this interface is **RO**.

## 10.6 Identification registers

R<sub>JTSPV</sub> In the following register frames, offsets 0xFFD0-0xFFFC are defined as read-only identification register space:

- IRS\_CONFIG\_FRAME
- ITS\_CONFIG\_FRAME
- IWB\_CONFIG\_FRAME

I<sub>SMPQP</sub> For Arm implementations, the following assignment of fields, consistent with CoreSight ID registers[12], is used:

| Offset | Name                    | Field   | Value                  | Meaning                                      |
|--------|-------------------------|---------|------------------------|----------------------------------------------|
| 0xFFF0 | x_CIDR0, Component ID0  | [7:0]   | 0x0D                   | Preamble                                     |
| 0xFFF4 | x_CIDR1, Component ID1  | [7:4]   | 0xF                    | CLASS                                        |
|        |                         | [3:0]   | 0x0                    | Preamble                                     |
| 0xFFF8 | x_CIDR2, Component ID2  | [7:0]   | 0x05                   | Preamble                                     |
| 0xFFFC | x_CIDR3, Component ID3  | [7:0]   | 0xB1                   | Preamble                                     |
| 0xFFE0 | x_PIDR0, Peripheral ID0 | [7:0]   | IMPLEMENTATION DEFINED | Bits [7:0] of the Part number                |
| 0xFFE4 | x_PIDR1, Peripheral ID1 | [7:4]   | IMPLEMENTATION DEFINED | Bits [3:0] of the JEP106 Designer code       |
|        |                         | [3:0]   | IMPLEMENTATION DEFINED | Bits [11:8] of the Part number               |
| 0xFFE8 | x_PIDR2, Peripheral ID2 | [7:4]   | IMPLEMENTATION DEFINED | REVISION                                     |
|        |                         | [3]     | 1                      | JEDEC-assigned value for DES always used     |
|        |                         | [2:0]   | IMPLEMENTATION DEFINED | Bits [6:4] bits of the JEP106 Designer code  |
| 0xFFEC | x_PIDR3, Peripheral ID3 | [7:4]   | IMPLEMENTATION DEFINED | REVAND                                       |
|        |                         | [3:0]   | IMPLEMENTATION DEFINED | CMOD                                         |
| 0xFFD0 | x_PIDR4, Peripheral ID4 | [7:4]   | 0                      | SIZE                                         |
|        |                         | [3:0]   | IMPLEMENTATION DEFINED | JEP106 Designer continuation code            |
| 0xFFD4 | x_PIDR5, Peripheral ID5 | -       | res0                   | Reserved                                     |
| 0xFFD8 | x_PIDR6, Peripheral ID6 | -       | res0                   | Reserved                                     |
| 0xFFEC | x_PIDR7, Peripheral ID7 | -       | res0                   | Reserved                                     |
| 0xFFBC | x_DEVARCH               | [31:21] | 0x23b                  | JEP106 continuation and identification codes |
|        |                         | [20]    | 1                      | DEVARCH is present.                          |
|        |                         | [19:16] | 0                      | GICv5.0                                      |
|        |                         | [15:0]  | TBC                    | ARCHID, GICv5.                               |

Where "x" is replaced with:

- IRS for the IRS\_CONFIG\_FRAME
- ITS for the ITS\_CONFIG\_FRAME
- IWB for the IWB\_CONFIG\_FRAME

Offsets and fields outside of those defined in this table are RESO.

Arm recommends that implementers use this scheme to provide a consistent software discovery model. If the CoreSight ID registers are not implemented, Arm recommends that all the locations in the table are RESO.

# Chapter 10. Registers and memory maps 10.6. Identification registers

The Designer code fields for Arm-designed implementations use continuation code 0x4 and Designer code 0x3B. Non-Arm implementations that follow this CoreSight ID register layout set the Designer fields appropriate to the implementer.

I<sub>LFDTN</sub> For a full descriptions of the CoreSight ID registers see the Arm CoreSight Architecture Specification [12].

# Chapter 11 Data structures

This chapter describes the GICv5 data structures.

Chapter 11. Data structures 11.1. ITS Data Structures

## 11.1 ITS Data Structures

## 11.1.1 L1\_DTE, Level 1 device table entry

The L1\_DTE characteristics are:

#### Attributes

L1\_DTE is a 8-byte structure.

## **Field descriptions**

The L1\_DTE bit assignments are:

| 63   | 60 | 59 | !    | 56 | 55      | 32       |       |
|------|----|----|------|----|---------|----------|-------|
| SPAN |    |    | RES0 |    |         | L2_ADDR  |       |
| 31   |    |    |      |    |         | 3,2,1,0, |       |
|      |    |    |      |    | L2_ADDR | RES0     |       |
|      |    |    |      |    |         | Lv       | /ALID |

#### VALID, bit [0]

Entry is valid

| VALID | Meaning                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------|
| 060   | This entry is invalid. All events identified by a DeviceID and EventID covered by this entry are ignored. |
| 0b1   | This entry is valid and L2_ADDR points to a level 2 device table.                                         |

## Bits [2:1]

Reserved, RESO.

#### L2\_ADDR, bits [55:3]

Bits[55:3] of the address of the start of the level 2 array of device table entries.

Bits[N:0] of the resulting address are 0 where N = 2 + SPAN.

This means that the level 2 DTE array is aligned to the size of the array.

The level 2 array is accessed using the same PAS as the level 1 DTE.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RESO. The number of implemented address bits is reported in ITS\_IDR0.PA\_RANGE.

#### Bits [59:56]

Reserved, RESO.

#### SPAN, bits [63:60]

Size of the structure pointed to by L2\_ADDR

The level 2 device table pointed to by L2\_ADDR contains 2 ^ SPAN entries.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than reading back the field. The maximum allowed value of this field is determined by ITS\_DT\_CFGR.L2SZ.

If ITS\_DT\_CFGR.L2SZ is 0b00, then the maximum value of this field is 9. If ITS\_DT\_CFGR.L2SZ is 0b01, then the maximum value of this field is 11. If ITS\_DT\_CFGR.L2SZ is 0b10, then the maximum value of this field is 13.

## 11.1.2 L2\_DTE, Level 2 device table entry

The L2\_DTE characteristics are:

#### Attributes

L2\_DTE is a 8-byte structure.

## **Field descriptions**

The L2\_DTE bit assignments are:



#### VALID, bit [0]

Entry is valid

| VALID | Meaning                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------|
| 0b0   | This entry is invalid. All events identified by a DeviceID and EventID covered by this entry are ignored. |
| 0b1   | This entry is valid and ITT_ADDR points to a valid ITT.                                                   |

## ITT\_L2SZ, bits [2:1]

Level 2 ITT size when a 2-level ITT structure is used.

| ITT_L2SZ | Meaning                                                        |
|----------|----------------------------------------------------------------|
| 0b00     | A level 2 ITT is maximum 4KB and resolves 9 bits of EventID.   |
| 0b01     | A level 2 ITT is maximum 16KB and resolves 11 bits of EventID. |
| 0b10     | A level 2 ITT is maximum 64KB and resolves 13 bits of EventID. |

Values not defined above are reserved.

If EVENTID\_BITS <=  $(9 + (2 * ITT_L2SZ))$  and ITT\_STRUCTURE is 1, the ITT consists of a single L1\_ITTE and a single L2\_ITT.

The L2\_ITT contains (2 ^ EVENTID\_BITS) entries.

If ITT\_STRUCTURE is 1, and EVENTID\_BITS <  $(9 + (2 * ITT_L2SZ))$ , it is possible to program L1\_ITTE.SPAN to a value larger than EVENTID\_BITS. In this case, the number of EventIDs for the DeviceID is defined by 2<sup>^</sup> EVENTID\_BITS, but the ITS is permitted to access all the L2\_ITTEs in the range described by L1\_ITTE.SPAN.

Arm recommends that ITT\_STRUCTURE is 0 when EVENTID\_BITS  $\leq (9 + (2 * ITT_L2SZ))$ .

When programming a reserved value or an unsupported value, the ITS behavior is CONSTRAINED UNPREDICTABLE to any behavior which could be achieved by programming a valid and supported value.

#### ITT\_ADDR, bits [55:3]

Bits[55:3] of the base physical address of the ITT for the device described by this entry.

When ITT\_STRUCTURE is 0, ITT\_ADDR points to a linear ITT and all of the following are true:

- Bits[N:0] of the resulting address are 0 where N = 2 + EVENTID\_BITS.
- This means that the level 2 ITTE array is aligned to the size of the array.

When ITT\_STRUCTURE is 1, ITT\_ADDR points to a 2-level ITT and all of the following are true:

• Bits[N:0] of the resulting address are 0 where N is:

 $Max(2, (EVENTID\_BITS - (9 + (2 * ITT\_L2SZ)) + 2)$ 

• This means that the level 1 ITT is aligned to the size of the table.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RES0. The number of implemented address bits is reported in ITS\_IDR0.PA\_RANGE.

#### Bit [56]

Reserved, RESO.

#### DSWE, bit [57]

For any ITS event generated by the device described by this entry, disable reporting of software errors for the following error codes in ITS\_SWERR\_STATUSR.EC:

- 0x03.
- 0x04.
- 0x06.
- 0x07.
- 0x08.
- 0x0A.
- 0x0C.
- 0x0D.
- 0x13.
- 0x14.

| DSWE | Meaning                                                    |
|------|------------------------------------------------------------|
| 0b0  | Error reporting for the specified error codes is disabled. |
| 0b1  | Error reporting for the specified error codes is enabled.  |

This field is RESO, if ITS\_IDR0.SWE is 0.

#### ITT\_STRUCTURE, bit [58]

Whether the ITT pointed to by ITT\_ADDR uses a linear or 2-level structure.

| ITT_STRUCTURE | Meaning                         |
|---------------|---------------------------------|
| 060           | A linear ITT structure is used. |

| ITT_STRUCTURE | Meaning                          |
|---------------|----------------------------------|
| 0b1           | A 2-level ITT structure is used. |

If ITS\_IDR1.ITT\_LEVELS is 0, this field is RES0.

#### EVENTID\_BITS, bits [63:59]

The number of EventID bits which can be translated for this device.

The ITT pointed to by ITT\_ADDR contains 2 ^ EVENTID\_BITS level 2 ITT entries in total.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than reading back the field. The maximum value is reported in ITS\_IDR2.EVENTID\_BITS.

## 11.1.3 L1\_ITTE, Level 1 interrupt translation table entry

The L1\_ITTE characteristics are:

#### Attributes

L1\_ITTE is a 8-byte structure.

## **Field descriptions**

The L1\_ITTE bit assignments are:

| L | 63   | 60 | 59 |      | 56 j | 55      |        |      | 32 | 1.    |
|---|------|----|----|------|------|---------|--------|------|----|-------|
|   | SPAN |    |    | RES0 |      | L       | 2_ADDR |      |    |       |
| - | 31   |    |    |      |      |         | 3      | 2 1  | 0  |       |
|   |      |    |    |      |      | L2_ADDR |        | RES0 |    |       |
|   |      |    |    |      |      |         |        |      | L  | VALID |

#### VALID, bit [0]

Entry is valid

| VALID | Meaning                                                                                                   |
|-------|-----------------------------------------------------------------------------------------------------------|
| 000   | This entry is invalid. All events identified by a DeviceID and EventID covered by this entry are ignored. |
| 0b1   | This entry is valid and L2_ADDR points to a level 2 ITT.                                                  |

#### Bits [2:1]

Reserved, RESO.

## L2\_ADDR, bits [55:3]

Bits[55:3] of the level 2 array of ITT entries.

Bits[N:0] of the resulting address are 0 where N = 2 + SPAN.

This means that the level 2 ITTE array is aligned to the size of the array.

The level 2 array is accessed using the same PAS as the level 1 ITTE.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RES0. The number of implemented address bits is reported in ITS\_IDR0.PA\_RANGE.

#### Bits [59:56]

Reserved, RESO.

#### SPAN, bits [63:60]

Size of structure pointed to by L2\_ADDR

The level 2 ITT pointed to by L2\_ADDR contains 2 ^ SPAN entries.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than reading back the field. The maximum allowed value of this field is constrained by L2DTE.ITT\_L2SZ.

If L2\_DTE.ITT\_L2SZ is 0b00, then the maximum value of this field is 9. If L2\_DTE.ITT\_L2SZ is 0b01, then the maximum value of this field is 11. If L2\_DTE.ITT\_L2SZ is 0b10, then the maximum value of this field is 13.

## 11.1.4 L2\_ITTE, Level 2 interrupt translation table entry

The L2\_ITTE characteristics are:

#### Attributes

L2\_ITTE is a 8-byte structure.

### **Field descriptions**

The L2\_ITTE bit assignments are:

|       | 63                  |   |       |    |   |     | 48 | 14     | 47 3. | 2 |
|-------|---------------------|---|-------|----|---|-----|----|--------|-------|---|
|       |                     |   |       |    | R | RES | 50 |        | VM_ID |   |
|       | 31,30,29,28,27 24,2 |   |       |    |   | 4   | 23 |        | 6     | _ |
|       | DAC RESO LPI_ID     |   |       |    |   |     |    | LPI_ID |       |   |
| VALID |                     | L | VIRTU | AL |   |     |    |        |       | _ |

#### LPI\_ID, bits [23:0]

Bits[23:0] of the LPI ID for the event described by this entry.

If unimplemented upper bits of the LPI\_ID are not zero, it is IMPLEMENTATION DEFINED whether the upper bits are treated as 0 or the interrupt message is ignored by the IRS.

#### Bits [27:24]

Reserved, RESO.

#### DAC, bits [29:28]

Controls whether the event described by this entry can be associated with an Interrupt Domain different from the one associated with this ITS Domain.

| DAC  | Meaning                                                                                                                                                                | Applies                                 |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| 0600 | The event described by this entry is not permitted to be<br>translated when it is generated by a write to a register in the<br>PAS associated with another ITS Domain. |                                         |
| 0b01 | The event described by this entry is permitted to be translated<br>when it is generated by a write to a register in the Non-secure<br>PAS.                             | When<br>ITS_IDR2.XDMN_EVENTS<br>== 0b01 |

Values not defined above are reserved.

The event is ignored and not translated if any of the following are true:

- The event is not associated with the Interrupt Domain specified by this field.
- A reserved value is programmed into this field.

#### VIRTUAL, bit [30]

Controls if the interrupt message generated to the IRS is for a physical or a virtual interrupt.

| VIRTUAL | Meaning                                                             |
|---------|---------------------------------------------------------------------|
| 0b0     | The interrupt message generated by the ITS is a physical interrupt. |

| VIRTUAL | Meaning                                                            |
|---------|--------------------------------------------------------------------|
| 0b1     | The interrupt message generated by the ITS is a virtual interrupt. |

When the ITT is used in the EL3 ITS Domain, this field is RESO.

### VALID, bit [31]

Interrupt translation entry is valid.

| VALID | Meaning                                                                                                                                                                 |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b0   | This entry is invalid. All events identified by a DeviceID and EventID covered by this entry are ignored.                                                               |
| 0b1   | This entry is valid and events identified by a DeviceID and<br>EventID covered by this entry are translated into events to the<br>IRS using the VM ID and LPI ID above. |

#### VM\_ID, bits [47:32]

Bits[15:0] of the VM ID passed to the IRS as part of the interrupt message targeting virtual interrupts.

When Virtual is 0, this field is RES0.

## Bits [63:48]

Reserved, RESO.

Chapter 11. Data structures 11.2. IRS Data Structures

## 11.2 IRS Data Structures

## 11.2.1 L1\_VMTE, Level 1 VM table entry

The L1\_VMTE characteristics are:

#### Attributes

L1\_VMTE is a 8-byte structure.

## **Field descriptions**

The L1\_VMTE bit assignments are:



## VALID, bit [0]

Entry is valid

| VALID | Meaning                                                                          |
|-------|----------------------------------------------------------------------------------|
| 060   | This entry is invalid. All lookups of a VM ID covered by this entry are ignored. |
| 0b1   | This entry is valid and L2_ADDR points to a level 2 VMT.                         |

#### Bits [11:1]

Reserved, RESO.

## L2\_ADDR, bits [55:12]

Bits[55:12] of the address of the start of the array of level 2 VMT entries.

This means that the level 2 VMTE array is aligned to the size of a level 2 VMT (4KB).

The level 2 array is accessed using the same PAS as the level 1 VMTE.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RES0. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

## Bits [63:56]

Reserved, RESO.

## 11.2.2 L2\_VMTE, Level 2 VM table entry

The L2\_VMTE characteristics are:

#### Attributes

L2\_VMTE is a 32-byte structure.

## **Field descriptions**

The L2\_VMTE bit assignments are:



## VALID, bit [0]

Entry is valid

| VALID | Meaning                             |
|-------|-------------------------------------|
| 0b0   | This entry describes an invalid VM. |
| 0b1   | This entry describes a valid VM.    |

## Bits [2:1]

Reserved, RESO.

VMD\_ADDR, bits [55:3]

#### When IRS\_IDR3.VMD == 1:

Bits[55:3] of the base address of the VM Descriptor for the VM described by this entry.

The VM Descriptor address is aligned to its size as follows:

• Bits[N:0] of the resulting address are 0 where N = IRS\_IDR3.VMD\_SZ - 1.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RES0. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

Otherwise:

res0

#### Bits [63:56]

Reserved, RESO.

#### Bits [66:64]

Reserved, RESO.

#### VPET\_ADDR, bits [119:67]

Bits[55:3] of the base physical address of the array of VPE table entries for the VM described by this entry.

The VPE table always uses a linear structure and is aligned as follows:

- Bits[N:0] of the resulting address are 0 where N = 2 + VPE\_ID\_BITS.
- This means that the level 2 VPETE array is aligned to the size of the array.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RES0. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

#### Bits [122:120]

Reserved, RESO.

#### VPE\_ID\_BITS, bits [127:123]

The number of VPEs which are supported for this VM.

The VPE table must contain (2 ^ VPE\_ID\_BITS) VPE table entries in total.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than reading back the field.

The maximum value is reported in IRS\_IDR4.VPE\_ID\_BITS.

#### LPI\_IST\_VALID, bit [128]

LPI\_IST\_ADDR points to a valid IST

| LPI_IST_VALID | Meaning                                                                                        |
|---------------|------------------------------------------------------------------------------------------------|
| 0d0           | LPI_IST_ADDR is not valid. All accesses to LPI configuration and state for the VM are dropped. |
| 0b1           | LPI_IST_ADDR is valid and points to a valid IST.                                               |

### LPI\_IST\_L2SZ, bits [130:129]

Level 2 IST size when a 2-level IST structure is used.

| LPI_IST_L2SZ | Meaning                |
|--------------|------------------------|
| 0600         | A level 2 IST is 4KB.  |
| 0b01         | A level 2 IST is 16KB. |

| LPI_IST_L2SZ | Meaning                |
|--------------|------------------------|
| 0b10         | A level 2 IST is 64KB. |

Values not defined above are reserved.

IRS\_IDR2.IST\_L2SZ reports the supported values.

If LPI\_ID\_BITS <=  $(10 - LPI_ISTSZ) + (2 * LPI_IST_L2SZ)$  and LPI\_IST\_STRUCTURE is 1, all of the following are true:

- The IST consists of a single level 1 IST entry and a single level 2 IST.
- The level 2 IST contains (2 ^ LPI\_ID\_BITS) entries.
- The IRS is allowed to access the full level 2 IST size as specified by LPI\_IST\_L2SZ.

Arm recommends that LPI\_IST\_STRUCTURE is 0 when LPI\_ID\_BITS <=  $(10 - LPI_ISTSZ) + (2 * LPI_IST_L2SZ)$ .

If programming a reserved value or an unsupported value, the IRS behavior is CONSTRAINED UNPREDICTABLE to any behavior which could be achieved by programming a valid and supported value.

When LPI\_IST\_STRUCTURE is 0, this field is RES0.

#### Bits [133:131]

Reserved, RESO.

#### LPI\_IST\_ADDR, bits [183:134]

Bits[55:6] of the base physical address of the LPI IST for the VM described by this entry.

When LPI\_IST\_STRUCTURE is 0, LPI\_IST\_ADDR points to a linear IST and all of the following are true:

- Bits[N:0] of the resulting address are 0 where  $N = Max(5, ((LPI_ISTSZ + 2) + LPI_ID_BITS) 1)$ .
- This means that the level 2 IST entry array is aligned to the size of the array or to a 64-bytes boundary when its size is smaller than 64 bytes.

When LPI\_IST\_STRUCTURE is 1, LPI\_IST\_ADDR points to the level 1 table in a 2-level IST and all of the following are true:

• Bits[N:0] of the resulting address are 0 where N depends on LPI\_IST\_L2SZ and LPI\_ID\_BITS as follows:

 $N = Max(5, LPI\_ID\_BITS - ((10 - LPI\_ISTSZ) + (2 * LPI\_IST\_L2SZ)) + 2)$ 

• This means that the level 1 IST is aligned to the size of the level 1 IST entry array or to a 64-byte boundary when its size is smaller than 64 bytes.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RESO. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

#### LPI\_ISTSZ, bits [185:184]

The size of each level 2 IST entry in the virtual LPI IST.

Values not defined above are reserved.

If this field is programmed to specify a size smaller than the minimum required size or programmed to a reserved value, it is treated as having the value corresponding to the minimum required size for all other purposes than a read of the enty.

| LPI_ISTSZ | Meaning                                          |
|-----------|--------------------------------------------------|
| 0b00      | The size of a level 2 LPI IST entry is 4 bytes.  |
| 0b01      | The size of a level 2 LPI IST entry is 8 bytes.  |
| 0b10      | The size of a level 2 LPI IST entry is 16 bytes. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### LPI\_IST\_STRUCTURE, bit [186]

Structure of the LPI IST pointed to by LPI\_IST\_ADDR.

| LPI_IST_STRUCTURE | Meaning                          |
|-------------------|----------------------------------|
| 000               | A linear IST structure is used.  |
| 0b1               | A 2-level IST structure is used. |

Values not defined above are reserved.

When programming a reserved value, the IRS behavior is CONSTRAINED UNPREDICTABLE to any behavior which could be achieved by programming a valid value.

When IRS\_IDR2.IST\_LEVELS is 0, this field is treated as 0 for all other purposes than reading back the field.

#### LPI\_ID\_BITS, bits [191:187]

The number of LPIs which are supported for this VM.

The IST must contain 2<sup>(LPI\_ID\_BITS)</sup> level 2 IST entries in total.

The minimum value for this field is IRS\_IDR2.MIN\_LPI\_ID\_BITS.

If programmed to a value smaller than the minimum, the field is treated as having the minimum value for all other purposes than reading back the field.

The maximum value for this field is IRS\_IDR2.ID\_BITS.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than reading back the field. The maximum value is reported in IRS\_IDR2.ID\_BITS.

#### SPI\_IST\_VALID, bit [192]

Whether SPI\_IST\_ADDR points to a valid IST.

| SPI_IST_VALID | Meaning                                                                                        |
|---------------|------------------------------------------------------------------------------------------------|
| 060           | SPI_IST_ADDR is not valid. All accesses to SPI configuration and state for the VM are dropped. |
| 0b1           | SPI_IST_ADDR is valid and points to a valid IST.                                               |

#### SPI\_IST\_L2SZ, bits [194:193]

Level 2 IST size when a 2-level SPI IST structure is used.

| SPI_IST_L2SZ | Meaning                |
|--------------|------------------------|
| 0b00         | A level 2 IST is 4KB.  |
| 0b01         | A level 2 IST is 16KB. |
| 0b10         | A level 2 IST is 64KB. |

Values not defined above are reserved.

IRS\_IDR2.IST\_L2SZ reports the supported values.

If SPI\_ID\_BITS <= ((10 - SPI\_ISTSZ) + (2 \* SPI\_IST\_L2SZ)) and SPI\_IST\_STRUCTURE is 1, all of the following are true:

- The IST consists of a single level 1 IST entry and a single level 2 IST.
- The level 2 IST contains (2 ^ SPI\_ID\_BITS) entries.
- The IRS is allowed to access the full level 2 IST size as specified by SPI\_IST\_L2SZ.

Arm recommends that SPI\_IST\_STRUCTURE is 0 when SPI\_ID\_BITS <=  $(10 - SPI_ISTSZ) + (2 * SPI_IST_L2SZ)$ .

If programming a reserved value or an unsupported value, the IRS behavior is CONSTRAINED UNPREDICTABLE to any behavior which could be achieved by programming a valid and supported value.

When SPI\_IST\_STRUCTURE is 0, this field is RES0.

#### Bits [197:195]

Reserved, RESO.

#### SPI\_IST\_ADDR, bits [247:198]

Bits[55:6] of the base physical address of the SPI IST for the VM described by this entry.

When SPI\_IST\_STRUCTURE is 0, SPI\_IST\_ADDR points to a linear IST and all of the following are true:

- Bits[N:0] of the resulting address are 0 where  $N = Max(5, ((SPI_ISTSZ + 2) + SPI_ID_BITS) 1)$ .
- This means that the level 2 IST entry array is aligned to the size of the array or to a 64-byte boundary when its size is smaller than 64 bytes.

When SPI\_IST\_STRUCTURE is 1, SPI\_IST\_ADDR points to the level 1 table in a 2-level IST and all of the following are true:

• Bits[N:0] of the resulting address are 0 where N depends on the SPI\_IST\_L2SZ and SPI\_ID\_BITS field as follows:

 $N = Max(5, SPI\_ID\_BITS - ((10 - SPI\_ISTSZ) + (2 * SPI\_IST\_L2SZ)) + 2)$ 

• This means that the level 1 IST is aligned to the size of the level 1 IST entry array or to a 64-byte boundary when its size is smaller than 64 bytes.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RES0. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

#### SPI\_ISTSZ, bits [249:248]

The size of each level 2 IST entry in the virtual SPI IST.

Values not defined above are reserved.

If this field is programmed to specify a size smaller than the minimum required size or programmed to a reserved value, it is treated as having the value corresponding to the minimum required size for all other purposes than a read of the enty.

| SPI_ISTSZ | Meaning                                          |
|-----------|--------------------------------------------------|
| 0000      | The size of a level 2 SPI IST entry is 4 bytes.  |
| 0b01      | The size of a level 2 SPI IST entry is 8 bytes.  |
| 0b10      | The size of a level 2 SPI IST entry is 16 bytes. |

The reset behavior of this field is:

• On a GIC reset, this field resets to an UNKNOWN value.

#### SPI\_IST\_STRUCTURE, bit [250]

Structure of the SPI IST pointed to by SPI\_IST\_ADDR.

| SPI_IST_STRUCTURE | Meaning                          |
|-------------------|----------------------------------|
| 0b0               | A linear IST structure is used.  |
| 0b1               | A 2-level IST structure is used. |

Values not defined above are reserved.

When programming a reserved value, the IRS behavior is CONSTRAINED UNPREDICTABLE to any behavior which could be achieved by programming a valid value.

When IRS\_IDR2.IST\_LEVELS is 0, this field is treated as 0 for all other purposes than reading back the field.

#### SPI\_ID\_BITS, bits [255:251]

The number of SPIs which are supported for this VM.

The SPI IST must contain 2^(SPI\_ID\_BITS) level 2 IST entries in total.

The minimum value for this field is 0, which is equivalent to a minimum of 1 SPI in the VM.

If the VM has no SPIs, SPI\_IST\_VALID is 0.

If this field is programmed to a value larger than the maximum, it is treated as having the maximum value for all other purposes than reading back the field. The maximum value is reported in IRS\_IDR2.ID\_BITS.

## 11.2.3 L1\_ISTE, Level 1 interrupt state table entry

The L1\_ISTE characteristics are:

#### Attributes

L1\_ISTE is a 8-byte structure.

## **Field descriptions**

The L1\_ISTE bit assignments are:



## VALID, bit [0]

Whether the entry is valid.

| VALID | Meaning                                                                  |  |  |
|-------|--------------------------------------------------------------------------|--|--|
| 0b0   | This entry is invalid. All INTIDs covered by this entry are unreachable. |  |  |
| 0b1   | This entry is valid and L2_ADDR points to a level 2 IST.                 |  |  |

## Bits [11:1]

Reserved, RESO.

## L2\_ADDR, bits [55:12]

Bits[55:12] of the address of the start of the array of level 2 IST entries.

Bits[N:0] of the resulting address are 0 where N = 11 + (2 \* L2SZ)

This means that the level 2 ISTE array is aligned to the size of a level 2 IST.

The level 2 array is accessed using the same PAS as the level 1 ISTE.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RESO. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

#### Bits [63:56]

Reserved, RESO.

## 11.2.4 L2\_ISTE, Level 2 interrupt state table entry

The L2\_ISTE characteristics are:

#### Purpose

This data structure shows the 4 lowest address bytes of a single level 2 ISTE.

The size of a complete level 2 ISTE can be 4 bytes, 8 bytes, or 16 bytes.

If the size of a level 2 ISTE is more than 4 bytes, the higher address bytes are RESO.

See 4.7 *The interrupt state table (IST)* for more information.

#### Attributes

L2\_ISTE is a 4-byte structure.

#### **Field descriptions**

The L2\_ISTE bit assignments are:



#### Pending, bit [0]

Interrupt Pending state

| Pending | Meaning                       |
|---------|-------------------------------|
| 0b0     | The interrupt is not Pending. |
| 0b1     | The interrupt is Pending.     |

#### Active, bit [1]

Interrupt Active state

| Active | Meaning                      |
|--------|------------------------------|
| 0b0    | The interrupt is not Active. |
| 0b1    | The interrupt is Active.     |

#### HM, bit [2]

Handling mode of the interrupt.

| НМ  | Meaning                                                                               |
|-----|---------------------------------------------------------------------------------------|
| 0b0 | Edge: The interrupt becomes Pending when the interrupt is acknowledged.               |
| 0b1 | Level: The interrupt Pending state is unmodified when the interrupts is acknowledged. |

Copyright © 2022-2025 Arm Limited or its affiliates. All rights reserved. Non-confidential

#### Enable, bit [3]

Interrupt Enabled setting

| Enable | Meaning                    |  |
|--------|----------------------------|--|
| 0b0    | The interrupt is Disabled. |  |
| 0b1    | The interrupt is Enabled.  |  |

#### IRM, bit [4]

Interrupt Routing mode.

| IRM | Meaning                                 |
|-----|-----------------------------------------|
| 0d0 | The interrupt Routing mode is Targeted. |
| 0b1 | The interrupt Routing mode is 1ofN.     |

This field is RESO, if any of the following are true:

- IRS\_IDR0.ONE\_N is 0.
- The entry is part of a virtual IST and IRS\_IDR0.VIRT\_ONE\_N is 0.

#### Bits [8:5]

Reserved, RESO.

#### HWU, bits [10:9]

Reserved for hardware use.

This field should be zero when an IST becomes valid and is otherwise IMPLEMENTATION DEFINED.

#### Priority, bits [15:11]

The Priority value of the interrupt.

Bits [4:N] of the priority value are implemented, where N = (4 - IRS\_IDR1.PRI\_BITS). Unimplemented bits are RES0.

This means that when fewer than 5 bits of priority is implemented, Priority[14 - IRS\_IDR1.PRI\_BITS:11] are RESO.

#### IAFFID, bits [31:16]

Interrupt Affinity ID.

When this entry is part of a physical IST, this field specifies a PE.

When this entry is part of a virtual IST, this field specifies a VPE.

Chapter 11. Data structures 11.2. IRS Data Structures

## 11.2.5 VPETE, VPE table entry

The VPETE characteristics are:

#### Attributes

VPETE is a 8-byte structure.

### **Field descriptions**

The VPETE bit assignments are:

| L | 63 56 | <sub>1</sub> 55 | -    | 32 |       |
|---|-------|-----------------|------|----|-------|
|   | RES0  | VPED_ADDR       |      |    |       |
| - | 31    | 3               | 2 1  | 0  |       |
|   |       | VPED_ADDR       | RES0 |    |       |
|   |       |                 |      | ٦  | /ALID |

## VALID, bit [0]

Entry is valid

| VALID | Meaning                              |
|-------|--------------------------------------|
| 0b0   | This entry describes an invalid VPE. |
| 0b1   | This entry describes a valid VPE.    |

#### Bits [2:1]

Reserved, RESO.

#### VPED\_ADDR, bits [55:3]

Bits[55:3] of the base address of the VPE Descriptor for the VPE described by this entry if used.

The VPE Descriptor address is aligned to its size as follows:

• Bits[N:0] of the resulting address are 0 where N = IRS\_IDR4.VPED\_SZ - 1.

In implementations that support fewer than 56 bits of physical address, any unimplemented upper bits are RESO. The number of implemented address bits is reported in IRS\_IDR0.PA\_RANGE.

#### Bits [63:56]

Reserved, RESO.

Chapter 11. Data structures 11.2. IRS Data Structures

## 11.2.6 VM\_DESC, VM descriptor

The VM\_DESC characteristics are:

#### Purpose

The size, format, and content of this structure is IMPLEMENTATION DEFINED.

This shows an example size of 8-byte.

#### Attributes

VM\_DESC is a 8-byte structure.

## **Field descriptions**

The VM\_DESC bit assignments are:



#### IMPDEF, bits [63:0]

IMPLEMENTATION DEFINED

## 11.2.7 VPE\_DESC, VPE descriptor

The VPE\_DESC characteristics are:

#### Purpose

The size, format, and content of this structure is IMPLEMENTATION DEFINED.

This shows an example size of 32-byte.

#### Attributes

VPE\_DESC is a 32-byte structure.

## **Field descriptions**

The VPE\_DESC bit assignments are:

| 255   |        | 224 |
|-------|--------|-----|
|       | IMPDEF |     |
| 223   |        | 192 |
| 223   | IMPDEF |     |
| . 191 |        | 160 |
| 191   | IMPDEF |     |
| 159   |        | 128 |
|       | IMPDEF |     |
| 127   |        | 96  |
|       | IMPDEF |     |
| 95    |        | 64  |
| 95    | IMPDEF |     |
| 63    |        | 32  |
| 03    | IMPDEF |     |
| :131  |        | 0   |
|       | IMPDEF |     |

## IMPDEF, bits [255:0]

IMPLEMENTATION DEFINED

Part A GICv5 Stream Protocol interface

# Chapter A1 GICv5 Stream Protocol overview

| I <sub>tgpmy</sub> | The GICv5 Stream Protocol is one approach to connecting an IRS and a CPU interface. The GICv5 Stream Protocol supports independent development of an IRS and a PE. Arm recommends that a GICv5 implementation uses the GICv5 Stream Protocol. |  |  |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| I <sub>VPFYV</sub> | The GICv5 Stream Protocol is based on the GIC Stream Protocol defined by GICv3[3].                                                                                                                                                            |  |  |
| D <sub>KNBQZ</sub> | An <i>end-point</i> means either a CPU interface or an interrupt source.                                                                                                                                                                      |  |  |
| I <sub>WYMBT</sub> | The GICv5 Stream Protocol supports the connection between an IRS and one or more end-points.                                                                                                                                                  |  |  |
| D <sub>NXTBL</sub> | The connection between an IRS and a CPU interface is referred to as an Interrupt Handling channel.                                                                                                                                            |  |  |
| D <sub>SBHHG</sub> | The connection between an IRS and an interrupt source is referred to as an Interrupt Signaling channel.                                                                                                                                       |  |  |
| I <sub>fstmd</sub> | GICv5 Stream Protocol uses a transport layer formed of a pair of AMBA AXI5-Stream Protocol links:                                                                                                                                             |  |  |
|                    | <ul><li>From the IRS to one or more end-points.</li><li>From one or more end-points to the IRS.</li></ul>                                                                                                                                     |  |  |
|                    | See AMBA <sup>®</sup> AXI Protocol Specification[7] for information about the AMBA AXI5-Stream Protocol.                                                                                                                                      |  |  |
| $D_{WBVHL}$        | AXI Stream connection refers to the transport layer connection between an IRS and one or more end-points.                                                                                                                                     |  |  |
| D <sub>DCXRX</sub> | A command sent by the IRS to an end-point is defined as a Downstream command.                                                                                                                                                                 |  |  |
| D <sub>ptttr</sub> | A command sent by an end-point to the IRS is defined as an Upstream command.                                                                                                                                                                  |  |  |

# Chapter A2 AMBA AXI5-Stream Transport Layer

 ${\tt I}_{\tt VSYKR}$ 

The GICv5 Stream Protocol is based on the following unidirectional AXI5-Stream connections:

- A downstream AXI5-Stream Interface containing connections from an IRS to one or more end-points.
- An upstream AXI5-Stream Interface containing connections from one or more end-points to an IRS.



Figure A2.1: GICv5 Stream Protocol Interface

A GICv5 Stream Protocol connection connects a combination of end-point types:



Figure A2.2: GICv5 Stream Protocol Interface

An IRS might have multiple GICv5 Stream Protocol connections to different groups of PEs, for example to connect to multiple clusters.



#### Figure A2.3: IRS with multiple GICv5 Stream Interfaces

 $\mathsf{R}_{\mathsf{XRVGD}}$ 

An interconnect between an IRS and a CPU interface must ensure that the stream packet sequence is transferred over the stream protocol interface in the same order in which it was created.

Chapter A2. AMBA AXI5-Stream Transport Layer A2.1. Signals

## A2.1 Signals

R<sub>JSSRX</sub> The interface requires a global clock, ACLK, and a reset signal, ARESETn.

I<sub>vplgv</sub>

- For the GICv5 Stream Protocol, each stream interface is identified by a prefix to the AXI Stream signal names:
  - Downstream signals from an IRS to the CPU interface are prefixed with the letters IRS.
  - Upstream signals from the CPU interface to an IRS are prefixed with the letters ICC.
- R<sub>GQLTR</sub> The following table illustrates the GICv5 Stream Protocol interface signals from the IRS to the downstream end-point:

| Signal                   | Description                                                                                         |
|--------------------------|-----------------------------------------------------------------------------------------------------|
| IRSTVALID                | When set to 1, this signal indicates that the Requester is driving a valid transfer.                |
| IRSTREADY                | When set to 1, this signal indicates that the Completer can accept a transfer in the current cycle. |
| IRSTDATA[BN:0]           | The interface data path.                                                                            |
| IRSTLAST                 | When set to 1, this signal indicates the final transfer of a command.                               |
| IRSTID                   | This signal identifies the channel the transfer is associated with.                                 |
| <pre>IRSTDEST[N:0]</pre> | This signal identifies the target CPU interface to provide routing information for the stream.      |
| IRSTWAKEUP               | Indicates if there is activity associated with the AXI5-Stream interface.                           |

The following table illustrates the GICv5 Stream Protocol interface signals from the end-point to the upstream IRS:

| Signal                 | Description                                                                                          |
|------------------------|------------------------------------------------------------------------------------------------------|
| ICCTVALID              | When set to 1, this signal indicates that the Requester is driving a valid transfer.                 |
| ICCTREADY              | When set to 1, this signal indicates that the Completer can accept a transfer in the current cycle.  |
| ICCTDATA[BN:0]         | The interface data path.                                                                             |
| ICCTLAST               | When set to 1, this signal indicates the final transfer of a command.                                |
| <pre>ICCTID[N:0]</pre> | This signal identifies the originating CPU interface, to provide routing information for the stream. |
| ICCTDEST               | This signal identifies the channel the transfer is associated with.                                  |
| ICCTWAKEUP             | Indicates if there is activity associated with the AXI5-Stream interface.                            |

Where:

- BN is the number associated with the most significant bit on a datapath that is required to be an integral number of bytes wide.
- N is the value log<sub>2</sub>(M) rounded up to the nearest integer, where M is the number of PEs supported by the interface plus 1.

ISRVVS

In the GICv5 Stream Protocol, all commands have a length which is a multiple of 16 bits.

# Chapter A2. AMBA AXI5-Stream Transport Layer A2.1. Signals

| I <sub>DWDQB</sub> | The xTKEEP and xTSTRB signals are defined as optional in AMBA® AXI-Stream Protocol Specification[13].                                                                                                                                 |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | If the AXI5-Stream interfaces used for a GICv5 Stream Protocol link have data path that is 16-bit or smaller, Arm recommends that xTKEEP is not implemented. Otherwise, Arm recommends that xTKEEP is implemented.                    |
|                    | If the xTKEEP signal is implemented, it is asserted for bytes required for the command and deasserted for all the other bytes. If the xTKEEP signal is not implemented, any bytes not required to transmit a command are set to 0b00. |
|                    | Arm recommends that the xTSTRB signal is not implemented. If xTSTRB is implemented, it is asserted for all bytes for which xTKEEP is asserted and deasserted for all the other bytes.                                                 |
| R <sub>zzdqv</sub> | The xTLAST signal is asserted to indicate the last transfer for a command.                                                                                                                                                            |
|                    | A sender may assert xTLAST before all bytes of a command have been transferred. Any untransferred bytes in the command are treated as having the value 0b00 by the receiver.                                                          |
|                    | A sender may assert xTLAST late, making additional transfers not needed for the command. The receiver ignores any bytes not needed to represent the command.                                                                          |
| $I_{QDLHQ}$        | If parity checking is required, Arm recommends implementing the support for parity in AXI Stream defined in <i>AMBA® AXI-Stream Protocol Specification</i> [13].                                                                      |
| I <sub>INVVV</sub> | For further information about the signals used by the GICv5 Stream Protocol interface, and for details about handshaking, see <i>AMBA</i> <sup>®</sup> <i>AXI-Stream Protocol Specification</i> [13].                                 |

# A2.2 Channel identification

| I <sub>NMPSG</sub> | The AXI Stream connection can connect one IRS to multiple end-points. A connection between the IRS and an end-point is referred to as a channel. An Interrupt Handling channel connects an IRS to a CPU interface. An Interrupt Signaling channel connects an IRS to an interrupt source. |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| I <sub>PDQSW</sub> | The xTID and xTDEST signals are used to route packets and identify the type of channel.                                                                                                                                                                                                   |  |
| R <sub>brzbr</sub> | For downstream commands, IRSTID indicates the channel type:                                                                                                                                                                                                                               |  |
|                    | <ul> <li>0: Interrupt Handling channel IRSTDEST indicates the target CPU interface. Values are allocated contiguously from 0, in order of ascending affinity.</li> <li>1: Interrupt Signaling channel IRSTDEST indicates the target interrupt source.</li> </ul>                          |  |
| R <sub>rbspn</sub> | For upstream commands, ICCTDEST indicates the channel type:                                                                                                                                                                                                                               |  |
|                    | <ul><li>0: Interrupt Handling channel. ICCTID indicates the originating CPU interface.</li><li>1: Interrupt Signaling channel. ICCTID indicates the originating interrupt source.</li></ul>                                                                                               |  |
| R <sub>tcscp</sub> | The order and encoding of end-points is the same for IRSTDEST and IDDTID.                                                                                                                                                                                                                 |  |
| R <sub>JCRRQ</sub> | The values used to identify CPU interfaces are allocated contiguously from 0, in order of ascending affinity.                                                                                                                                                                             |  |
| R <sub>WZJVS</sub> | The values used to identify interrupt sources is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                  |  |
| I <sub>zjtkx</sub> | Arm recommends that the values used to identify interrupt sources are allocated contiguously from 0.                                                                                                                                                                                      |  |
| R <sub>NDDWL</sub> | Transfers on the same AXI5-Stream Interface for different commands are not interleaved. Once transmission of a command is started subsequent transfers continue the same command, with the same values of xTID and xTDEST until xTLAST is asserted.                                       |  |
| I <sub>rqbrs</sub> | The restriction on interleaving transfers does not prevent upstream and downstream commands being sent in parallel.                                                                                                                                                                       |  |
| I <sub>DMDNC</sub> | An example system might have two CPU interfaces and an interrupt source sharing an AXI Stream connection, as shown in the diagram below:                                                                                                                                                  |  |

Chapter A2. AMBA AXI5-Stream Transport Layer A2.2. Channel identification



Figure A2.4: GICv5 Stream Protocol Interface

Downstream commands:

| IRSTID | IRSTDEST | Channel type        | Target             |
|--------|----------|---------------------|--------------------|
| 0      | 0        | Interrupt Handling  | CPU interface 0    |
| 0      | 1        | Interrupt Handling  | CPU interface 1    |
| 1      | 0        | Interrupt Signaling | Interrupt source 0 |

Upstream commands:

| ICCTDEST | ICCTID | Channel type        | Source             |
|----------|--------|---------------------|--------------------|
| 0        | 0      | Interrupt Handling  | CPU interface 0    |
| 0        | 1      | Interrupt Handling  | CPU interface 1    |
| 1        | 0      | Interrupt Signaling | Interrupt source 0 |

Chapter A2. AMBA AXI5-Stream Transport Layer A2.3. Link status

## A2.3 Link status

- D<sub>WDBCG</sub> When the AXI Stream connection is described as *online*, data can be transferred across the upstream and downstream AXI Stream links. When a AXI Stream connection is described as *offline*, no data can be transferred across the AXI Stream links.
- R<sub>SMLNR</sub> When one or more of the channels that share the AXI Stream connection is online the AXI Stream connection is online.
- R<sub>DGDFT</sub> When none of the channels that share the AXI Stream connection is online, it is IMPLEMENTATION DEFINED whether the AXI Stream connection is online or offline.
- R<sub>NBCWM</sub> How the AXI Stream connection transitions from online to offline, or offline to online, is IMPLEMENTATION DEFINED.

# Chapter A3 Common behaviors

| т      | This section defines behaviors common  | a to the Interment Handlin | a and Interment Cianaling channels  |
|--------|----------------------------------------|----------------------------|-------------------------------------|
| LOHRMH | I his section defines behaviors common | т ю тпе ппеттирг папани    | g and interrupt Signating channels. |
|        |                                        |                            |                                     |

- D<sub>PWLWC</sub> Some commands require an acknowledgement from the receiver. A command that requires an acknowledgement is defined as *outstanding* until the acknowledgement is received.
- D<sub>TYKBT</sub> A command that requires acknowledgement is described as *complete* once the acknowledgement is received. All other commands are described as complete once received by the recipient.
- $R_{NQQBH}$  If multiple transfers are required to transmit a command, the receiver does not acknowledge the command until all of the command has been received.

# Chapter A4 Interrupt Handling channel

| I <sub>hthmk</sub> | The Interrupt Handling channel defines the connection between one CPU interface and one IRS, it includes the |
|--------------------|--------------------------------------------------------------------------------------------------------------|
|                    | following capabilities:                                                                                      |
|                    |                                                                                                              |

- Forwarding candidate HPPIs to the CPU interface.
- Activating and deactivating interrupts as they are handled.
- Managing the current resident VPE.
- Managing interrupt configuration and state.

 $I_{LYNNC}$  The rules in this section only apply to the Interrupt Handling channel.

## A4.1 Command summary

 $I_{LHGVT}$  The upstream commands that a CPU interface can send to the IRS are:

| ID  | Command                | Description                                                                          |
|-----|------------------------|--------------------------------------------------------------------------------------|
| 0x0 | UpstreamControl        | Communicates control information from the CPU interface to the IRS.                  |
| 0x1 | -                      | -                                                                                    |
| 0x2 | Activate               | Activates a previously sent interrupt.                                               |
| 0x3 | Release                | Releases a previously sent interrupt.                                                |
| 0x4 | DownstreamControl Ack  | Acknowledges a DownstreamControl command.                                            |
| 0x5 | -                      | -                                                                                    |
| 0x6 | Deactivate             | Deactivates an interrupt.                                                            |
| 0x7 | IMPLEMENTATION DEFINED | Reserved for IMPLEMENTATION DEFINED functionality.                                   |
| 0x8 | SetEnabled             | Sets the individual Enabled value of an interrupt.                                   |
| 0x9 | SetTarget              | Sets an LPI or SPI's target PE.                                                      |
| 0xA | SetPriority            | Sets an interrupt's priority.                                                        |
| 0xB | SetHandling            | Sets an interrupt's Handling mode.                                                   |
| 0xC | RequestConfig          | Requests an interrupt's configuration and state                                      |
| 0xD | Sync                   | Requests confirmation that the effects of previous commands are globally observable. |
| 0xE | SetPending             | Sets an LPI or SPI's Pending state.                                                  |
| 0xF | SetResident            | Sets the current resident VPE.                                                       |

## $I_{PYPQZ}$ The downstream commands that an IRS can send to the CPU interface are:

| ID  | Command                | Description                                                                            |
|-----|------------------------|----------------------------------------------------------------------------------------|
| 0x0 | UpstreamControl Ack    | Acknowledges an UpstreamControl command.                                               |
| 0x1 | Forward                | Sets an interrupt as pending on the CPU interface.                                     |
| 0x2 | Activate Ack           | Acknowledges an Activate command.                                                      |
| 0x3 | Recall                 | Recalls a previously sent pending interrupt.                                           |
| 0x4 | DownstreamControl      | Communicates control information from the IRS to the CPU interface.                    |
| 0x5 | WakeRequest            | Requests the channel is brought online.                                                |
| 0x6 | Deactivate Ack         | Acknowledges a Deactivate command.                                                     |
| 0x7 | IMPLEMENTATION DEFINED | Reserved for IMPLEMENTATION DEFINED functionality.                                     |
| 0x8 | Set Ack                | Acknowledges a SetEnabled, SetPending, SetPriority, SetTarget, or SetHandling command. |
| 0x9 | -                      | -                                                                                      |
| 0xA | -                      | -                                                                                      |
| 0xB | -                      | -                                                                                      |

# Chapter A4. Interrupt Handling channel A4.1. Command summary

| ID  | Command           | Description                                                                      |
|-----|-------------------|----------------------------------------------------------------------------------|
| 0xC | RequestConfig Ack | Acknowledges a RequestConfig command and returns the requested data.             |
| 0xD | Sync Ack          | Acknowledges a Sync command, indicating that the effect of previous commands are |
|     |                   | globally observable.                                                             |
| 0xE | -                 | -                                                                                |
| 0xF | SetResident Ack   | Acknowledges a SetResident command.                                              |

R<sub>LDZYS</sub> ID 0x7 in upstream and downstream is reserved for IMPLEMENTATION DEFINED functionality.

When supported, IMPLEMENTATION DEFINED commands do not impact the functionality of other commands. If not supported, IMPLEMENTATION DEFINED commands are ignored.

Arm strongly recommends that IMPLEMENTATION DEFINED commands are not used unless it can be guaranteed that both the sender and receiver agree on the usage.

## A4.2 Outstanding commands

R<sub>DGPBP</sub> Commands which require acknowledgement are acknowledged in finite time, apart from Forward commands.

**I**<sub>YYGKH</sub> The following commands require acknowledgement:

| Command           | Direction  | Acknowledged by                                         |
|-------------------|------------|---------------------------------------------------------|
| Activate          | Upstream   | Activate Ack or Forward with ActivateAck set to 1.      |
| Deactivate        | Upstream   | Deactivate Ack                                          |
| DownstreamControl | Downstream | DowstreamControl Ack.                                   |
| RequestConfig     | Upstream   | RequestConfig Ack                                       |
| Forward           | Downstream | Activate or Release.                                    |
|                   |            | SetResident, with Valid set to 0.                       |
|                   |            | UpstreamControl with Identifier set to 0b0001 (Quiesce) |
| SetEnabled        | Upstream   | Set Ack                                                 |
| SetPending        | Upstream   | Set Ack                                                 |
| SetHandling       | Upstream   | Set Ack                                                 |
| SetPriority       | Upstream   | Set Ack                                                 |
| SetResident       | Upstream   | SetResident Ack                                         |
| SetTarget         | Upstream   | Set Ack                                                 |
| Sync              | Upstream   | Sync Ack                                                |
| UpstreamControl   | Upstream   | UpstreamControl Ack                                     |

All other commands do not require acknowledgement.

- I<sub>CWTZR</sub> For commands that require acknowledgement, the architecture places limits on the number of outstanding commands that are permitted.
- IYYPPQAn UpstreamControl command with Identifier set to 0b0000 (Reset) initiates a reset of the channel. Resetting the<br/>channel returns pending interrupts to the IRS and cancels outstanding commands. Acknowledges to commands<br/>issued before the reset started might still be received during the reset process.
- R<sub>YDBHS</sub> For each Interrupt Handling channel, the IRS is permitted to have one DownstreamControl command outstanding.
- $\mathbb{I}_{\text{KGXBV}}$  The WakeRequest command does not have an acknowledge, meaning that is considered complete after being sent rather than requiring an explicit acknowledge. WakeRequests are implicitly acknowledged by the CPU interface sending UpstreamControl with Identifier set to 0b0000 (Reset) to bring the channel online.
- $I_{MJDMH}$  Arm recommends that once an IRS has issued a WakeRequest command it does not send further wake requests until the next time the channel is offline.
- R<sub>PSRJH</sub> For each Interrupt Handling channel, the CPU interface is permitted to have the following numbers of outstanding commands:
  - One Activate command.
  - One RequestConfig command.
  - One SetResident command.
  - One UpstreamControl command.
  - One Sync command.

# Chapter A4. Interrupt Handling channel A4.2. Outstanding commands

- One Deactivate command.
- In total, one of the following commands:
  - SetEnabled.
  - SetHandling.
  - SetPending.
  - SetPriority.
  - SetTarget.

## A4.3 Connection management

| D <sub>GRHNS</sub> | When an Interrupt Handling channel is described as <i>online</i> , upstream and downstream commands can be sent between the IRS and CPU interface. When an Interrupt Handling channel is described as <i>offline</i> , the only commands that can be sent are those to bring the channel online.                                                                                                                                                    |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>gywdk</sub> | When an Interrupt Handling channel is offline:                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>The IRS sends no commands other than WakeRequest.</li> <li>The CPU interface sends no commands other than UpstreamControl with Identifier set to 0b0000 (Reset).</li> </ul>                                                                                                                                                                                                                                                                |
| $R_{WZVTW}$        | If an Interrupt Handling channel is offline, the IRS may send a WakeRequest command to request the channel to be brought online.                                                                                                                                                                                                                                                                                                                    |
|                    | Whether an IRS sends wake requests over GICv5 Stream is IMPLEMENTATION DEFINED and an IRS might use other IMPLEMENTATION DEFINED mechanisms as well as or instead of GICv5 Stream.                                                                                                                                                                                                                                                                  |
| I <sub>TXLVK</sub> | Arm expects an IRS to only send a wake request if there is a candidate HPPI for the PE.                                                                                                                                                                                                                                                                                                                                                             |
| R <sub>zpmwq</sub> | The IRS does not send WakeRequest commands if the Interrupt Handling channel is online.                                                                                                                                                                                                                                                                                                                                                             |
| I <sub>ISRMX</sub> | A WakeRequest is implicitly acknowledged by an UpstreamControl command with Identifier set to 0b0000 (Reset).                                                                                                                                                                                                                                                                                                                                       |
| R <sub>btjbs</sub> | To bring an Interrupt Handling channel online, or reset an online channel:                                                                                                                                                                                                                                                                                                                                                                          |
|                    | <ul> <li>The CPU interface sends an UpstreamControl command with Identifier set to 0b0000 (Reset).</li> <li>The IRS responds with a DownstreamControl command with Identifier set to 0b0001 (Flush).</li> <li>The CPU interface acknowledges the DownstreamControl command, with Flush set to 1.</li> <li>The IRS acknowledges the UpstreamControl command.</li> </ul>                                                                              |
|                    | Once the UpstreamControl command is acknowledged, the Interrupt Handling channel is online.                                                                                                                                                                                                                                                                                                                                                         |
| R <sub>rnzyl</sub> | When an UpstreamControl command with Identifier set to 0b0000 (Reset) is acknowledged:                                                                                                                                                                                                                                                                                                                                                              |
|                    | <ul> <li>There are no outstanding upstream or downstream commands.</li> <li>There are no pending physical or virtual interrupts from the IRS pending on the CPU interface.</li> <li>There is no resident VPE.</li> <li>There are no 1ofN selection hints set.</li> </ul>                                                                                                                                                                            |
| R <sub>mshyj</sub> | Between sending an UpstreamControl command with Identifier set to 0b0000 (Reset) and the command being acknowledged, the CPU interface sends no commands other than to acknowledge a DownstreamControl with Identifier set to 0b0001 (Flush).                                                                                                                                                                                                       |
|                    | Between receiving an UpstreamControl command with Identifier set to 0b0000 (Reset) and sending the acknowledge, the IRS sends no other commands than DownstreamControl with Identifier set to 0b0001 (Flush).                                                                                                                                                                                                                                       |
| I <sub>PQTNY</sub> | If a reset request is received part way through a previous incomplete reset sequence, it is possible that operations are seen out of order or repeated.                                                                                                                                                                                                                                                                                             |
| R <sub>dlbtv</sub> | If the IRS receives a DownstreamControl Acknowledge with Flush set to 1 before it has sent the DownstreamControl with Identifier set to 0b0001 (Flush) due the most recent UpstreamControl command with Identifier set to 0b0000 (Reset), it is IMPLEMENTATION DEFINED whether the IRS sends DownstreamControl. If the DownstreamControl command with Identifier set to 0b0001 (Flush) is sent, the IRS treats the command as already acknowledged. |
|                    | If the CPU interface receives a DownstreamControl with Identifier set to 0b0001 (Flush) after it has sent DownstreamControl Acknowledge with Flush sent to 1, the command is ignored and the DownstreamControl is treated as already acknowledged.                                                                                                                                                                                                  |
| I <sub>gsqpk</sub> | GICv5 uses IAFFIDs to identify the different connected PEs. The IRS informs the CPU interface of its IAFFID as part of bringing the Interrupt Handling Channel online.                                                                                                                                                                                                                                                                              |
|                    | Some systems might require an IMPLEMENTATION DEFINED sequence before the correct IAFFIDs are known for the CPU interfaces. If the Interrupt Handling Channel is brought online before this sequence is completed the                                                                                                                                                                                                                                |

|                    | IRS can re-communicate the correct IAFFID using DownstreamControl command with Identifier set to 0b0010 (IAFFID).                                                                                                                                                                                                                                                                                      |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | In the PE, the IAFFID is reported in ICC_IAFFIDR_EL1.                                                                                                                                                                                                                                                                                                                                                  |
| I <sub>CDBHF</sub> | If a system requires an IMPLEMENTATION DEFINED sequence to initialise the correct IAFFIDs, Arm recommends that this occurs no more than once between GIC resets.                                                                                                                                                                                                                                       |
| R <sub>gyhsp</sub> | The CPU interface does not cache the IAFFID value across resets of the Interrupt Handling Channel.                                                                                                                                                                                                                                                                                                     |
| I <sub>SYLKT</sub> | Under normal operation, an UpstreamControl command with Identifier set to 0b0000 (Reset) is sent only to bring the connection between the CPU interface and IRS online. In which case there are no other outstanding commands, outstanding pending interrupts or resident VPE.                                                                                                                         |
|                    | However, the CPU interface may send an UpstreamControl command with Identifier set to 0b0000 when the Interrupt Handling channel is already online. Sending the command resets the connection, returning all pending interrupts and cancelling outstanding commands.                                                                                                                                   |
|                    | When an online connection is being reset, it is possible that the CPU interface receives downstream commands between sending the UpstreamControl and seeing the acknowledgement. The CPU interface does not respond to these commands and the IRS does not expect to receive responses.                                                                                                                |
| R <sub>HXGXY</sub> | To take an Interrupt Handling channel offline:                                                                                                                                                                                                                                                                                                                                                         |
|                    | <ul> <li>The CPU interface sends an UpstreamControl command with Identifier set to 0b0001 (Quiesce).</li> <li>The CPU interface sends no further commands, other than acknowledgements to downstream commands, until UpstreamControl Ack is received.</li> <li>The IRS completes any outstanding requests from the CPU interface, then sends an UpstreamControl Ack.</li> </ul>                        |
|                    | Once the UpstreamControl command is acknowledged, the Interrupt Handling channel is offline.                                                                                                                                                                                                                                                                                                           |
| I <sub>QDJXY</sub> | There is a single Interrupt Handling channel between the CPU interface and the IRS, shared by all implemented Interrupt Domains. Therefore, the UpstreamControl commands are independent of Interrupt Domain.                                                                                                                                                                                          |
| $R_{\rm YZFJG}$    | When the Interrupt Handling channel is offline, the IRS and CPU interface treat all previously forwarded physical or virtual interrupts having been recalled.                                                                                                                                                                                                                                          |
| I <sub>QNSGW</sub> | Taking the Interrupt Handling channel offline acts as an implicit Release for any pending physical or virtual interrupts of any Interrupt Domain, including Forwards received after the Quiesce is sent. If there is an outstanding acknowledge for an interrupt, the CPU interface must send the Activate command before sending the UpstreamControl command with Identifier set to 0b0001 (Quiesce). |
| I <sub>gwcsk</sub> | The UpstreamControl command provides a mechanism for the CPU interface to provide hints to the 1ofN selection algorithm in the IRS. The algorithm for 1ofN selection is IMPLEMENTATION DEFINED and might ignore any hints provided by the CPU interface. Whether a CPU interface sends 1ofN hints is IMPLEMENTATION DEFINED.                                                                           |
| R <sub>FMGVS</sub> | When an Interrupt Handling channel is online, the CPU interface can set hints for 1ofN target selection.                                                                                                                                                                                                                                                                                               |
|                    | The CPU interface sends an UpstreamControl command with:                                                                                                                                                                                                                                                                                                                                               |
|                    | <ul> <li>Identifier set to 0b0010 to set 1ofN hints.</li> <li>Identifier set to 0b0011 to clear 1ofN hints.</li> </ul>                                                                                                                                                                                                                                                                                 |
|                    | The Data field in the UpstreamControl command specifies which hints are being set or cleared. The state of a 1ofN hint not specified in Data is unaffected by set or clear operations.                                                                                                                                                                                                                 |
|                    | Unsupported or unknown hints are ignored by the IRS.                                                                                                                                                                                                                                                                                                                                                   |
| I <sub>MLPDY</sub> | The CPU interface is permitted to clear hints that it has not previously set.                                                                                                                                                                                                                                                                                                                          |
| I <sub>YCCYG</sub> | Each hint defines which Interrupt Domain, or Domains, it applies to.                                                                                                                                                                                                                                                                                                                                   |

## A4.4 Managing the resident VPE

| I <sub>XNGZK</sub> | When an Interrupt Handling channel transitions from offline to online, there is no resident VPE.                                                                                                                                                                                                                                                          |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $R_{\text{TPKML}}$ | To make a VPE resident, the CPU interface sends a SetResident command with Valid set to 1. The VPE being made resident is identified by the following fields:                                                                                                                                                                                             |
|                    | <ul> <li>Domain - the Physical Interrupt Domain the VPE is associated with.</li> <li>VM - the virtual machine the VPE is associated with.</li> <li>VPE - the VPE within the specified virtual machine.</li> </ul>                                                                                                                                         |
|                    | The IRS acknowledges the SetResident command with a SetResident Ack command with Fault set to indicate whether specified VPE was made resident.                                                                                                                                                                                                           |
|                    | The IRS does not generate a SetResident Ack until one of the following is true:                                                                                                                                                                                                                                                                           |
|                    | <ul> <li>The specified VPE was made resident and one of the following is true: <ul> <li>The IRS has forwarded the first virtual interrupt for the VPE.</li> <li>The IRS has determined that there is no virtual interrupt to forward.</li> </ul> </li> <li>The IRS has determined that it is unable to make the specified VPE resident.</li> </ul>        |
|                    | Once the SetResident Ack command with Fault set to 0 is sent, the specified VPE is resident.                                                                                                                                                                                                                                                              |
| I <sub>HSHXS</sub> | An IRS might be unable to make the requested VPE resident, for example because the VPE is invalid or the VPE is already resident on a different CPU interface.                                                                                                                                                                                            |
| I <sub>VSJLW</sub> | There might be no virtual interrupt to forward because there is no candidate HPPI for the VPE.                                                                                                                                                                                                                                                            |
| $R_{\rm HLJNT}$    | To clear the resident VPE, the CPU interface sends a SetResident command with Valid set to 0. When the IRS acknowledges the SetResident command by sending a SetResident Ack, there is no resident VPE.                                                                                                                                                   |
|                    | When the IRS acknowledges the SetResident command by sending a SetResident Ack, the IRS and CPU interface treat all previously forwarded virtual interrupts for the VPE as having been recalled.                                                                                                                                                          |
| I <sub>QTCTP</sub> | Clearing the resident VPE acts as an implicit Release for any outstanding pending virtual interrupts, returning the interrupts to the IRS.                                                                                                                                                                                                                |
|                    | If there is any outstanding Activate for a virtual interrupt, the CPU interface must send the Activate command before sending SetResident.                                                                                                                                                                                                                |
| I <sub>ldfmm</sub> | The CPU interface might send a SetResident command with Valid set to 0 while earlier virtual commands remain outstanding. The IRS is not required to delay sending SetResident Ack until it has acknowledged those earlier virtual commands. However, the IRS must process commands with the context that was valid at the time the command was received. |
| R <sub>VCZPC</sub> | The CPU interface does not send a SetResident command with Valid set to 1 when there is a resident VPE.                                                                                                                                                                                                                                                   |
| R <sub>rzrym</sub> | Between sending SetResident and receiving SetResident Ack, the CPU interface sends no commands with Virtual set to 1 other than SetPending, and commands that acknowledge downstream commands.                                                                                                                                                            |
| A4.4.1             | Interrupt Handling Channel behaviors when there is a resident VPE                                                                                                                                                                                                                                                                                         |
| $R_{MGZZN}$        | All downstream and upstream commands with Virtual set to 1, other than SetPending, are for the resident VPE. The VM targeted by SetPending is specified as part of the command's payload.                                                                                                                                                                 |
| $R_{PYWKM}$        | If the IRS receives a command with Virtual set to 1 where Domain does not correspond to the IRS's record of the resident VPE, the behavior depends on the type of the command as follows:                                                                                                                                                                 |
|                    | • RequestConfig Ack commands return F as 1 with zeros for all configuration fields.                                                                                                                                                                                                                                                                       |

- SetResident commands with Valid set to 0 clear the resident VPE, and DB is treated as being 0.
- All other commands are acknowledged but otherwise have no effect.

R<sub>QMVYG</sub> If the CPU interface receives a command with Virtual set to 1 and where Domain does not correspond to the current value of SCR\_EL3.{NSE,NS}, the behavior depends on the type of the command as follows:

- Forward command: The command replaces any previously received virtual interrupts, but the new interrupt is not considered when determining the virtual HPPI.
  - If the Forward command results in an implicit Recall, the CPU interface sets Domain in the Release or Activate command to the Interrupt Domain of the interrupt that is being Recalled.
- Recall command: Any resulting Activate or Release command is issued with Domain set to the Interrupt Domain of the interrupt that is being Recalled.

## A4.4.2 Interrupt Handling Channel behaviors when there is no resident VPE

 $R_{JRPVW}$  If there is no resident VPE:

- The IRS:
  - Does not issue Forward commands with Virtual set to 1, except as part of the sequence to make a VPE resident.
  - Acknowledges RequestConfig commands that have Virtual set to 1 with RequestConfig Ack commands that have F set to 1.
  - Acknowledges, but otherwise ignores, all other upstream commands with Virtual set to 1.
- The CPU interface:
  - Does not issue upstream commands with Virtual set to 1, other than SetResident and SetPending.
  - Downstream Forward commands with Virtual set to 1 are not considered when determining the virtual HPPI until a VPE is resident.

## A4.5 Forwarding, recalling, and releasing interrupts

| I <sub>GLBSF</sub> | The IRS forwards a candidate HPPI for an Interrupt Domain, or for the resident VPE, using a Forward command.<br>An interrupt can be retrieved from the CPU interface using a Recall command, or by sending another Forward command for the same Interrupt Domain.                                                                                                                                                                                                                                                                                                                               |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | For each Physical Interrupt Domain, and for the resident VPE, the IRS presents at most one candidate HPPI at a time. If the selected candidate HPPI changes, the IRS sends a replacement Forward command, which acts an implicit Recall if there is an outstanding Forward for the same Interrupt Domain.                                                                                                                                                                                                                                                                                       |
|                    | A CPU interface might issue an Activate instead of a Release for the previous pending interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                    | The protocol does not require that the new Forward is for an interrupt with higher priority than the outstanding Forward it replaces. A lower priority interrupt might replace a higher priority interrupt. For example, if an LPI is being re-targeted while it is pending, it must be retrieved from the old target CPU interface before being presented to the new target CPU interface. If there are other pending interrupts for the old target, one of these might now be presented to the CPU interface and this interrupt could be lower priority than the interrupt being re-targeted. |
| $I_{\rm TZBHV}$    | There is no limit on the number of Forward commands that can be outstanding.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| R <sub>KNCCF</sub> | For a given Interrupt Domain, there can never be multiple outstanding Forward commands for the same INTID.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| I <sub>CLNKP</sub> | If the IRS needs to re-issue a pending interrupt with new properties, for example a different priority value, it must first fully retrieve the previous pending interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| R <sub>GGHVV</sub> | When issuing a Forward command, the IRS sets Returnable based on the routing mode of the pending interrupt being forwarded:                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | <ul> <li>Targeted: Returnable is set to 0.</li> <li>1ofN: It is IMPLEMENTATION DEFINED whether Returnable is set to 0 or 1.</li> <li>Arm recommends that an implementation does not set Returnable to 1 unless there are other valid targets for the interrupt.</li> </ul>                                                                                                                                                                                                                                                                                                                      |
| R <sub>hwrfh</sub> | Forward commands are acknowledged by either an Activate command or Release command. For a given Interrupt Domain, or for the resident VPE, Forward commands are acknowledged in order.                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | A single Release command can acknowledge multiple Forward commands. The Release command acknowledges the INTID specified in the command, and all earlier unacknowledged Forward commands for the same Interrupt Domain or resident VPE.                                                                                                                                                                                                                                                                                                                                                         |
| I <sub>hjmsr</sub> | For example, the CPU interface will acknowledge all the Forward commands for physical interrupts for the Non-secure Domain in the order it received them. But Forward commands for different Domains might be acknowledged out of order with respect to each other.                                                                                                                                                                                                                                                                                                                             |
| R <sub>myxcz</sub> | For edge-triggered interrupts, receiving an ActivateAck command from the IRS in response to an Activate command guarantees that an edge generated by an interrupt source as a direct or indirect result of an instruction executed on the PE after observing the ActivateAck will not be merged into the acknowledged instance of the interrupt.                                                                                                                                                                                                                                                |
| R <sub>xsdst</sub> | The CPU interface issues Release commands in response to:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | <ul> <li>A Recall command.</li> <li>A Forward that has been replaced by a subsequent Forward for the same Interrupt Domain.</li> <li>The most recent Forward for an Interrupt Domain had Returnable set to 1 and the CPU interface has for IMPLEMENTATION DEFINED reasons decided to return the interrupt.</li> </ul>                                                                                                                                                                                                                                                                           |
| R <sub>mpthb</sub> | For a given Interrupt Domain, or for the resident VPE, a Recall command applies to the most recent Forward command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| R <sub>PKSKS</sub> | If a Recall command is received when there is no outstanding Forward command, the command is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| R <sub>GMQMJ</sub> | An IRS is able to accept an Activate or Release command for any outstanding Forward.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### Chapter A4. Interrupt Handling channel A4.5. Forwarding, recalling, and releasing interrupts

IThe GICv5 Stream Protocol has no way for an IRS to signal that a Release or Activate has failed. Therefore, an<br/>IRS only forwards an interrupt to a CPU interface if it can accept either an Activate or Release for that interrupt.

## A4.6 INTID configuration

R<sub>DHHRZ</sub> For any of the following the commands, when the IRS acknowledges the command, the IRS has observed the command and the effects of the command will be globally observable in finite time:

- Deactivate
- SetEnabled
- SetHandling
- SetPending
- SetPriority
- SetTarget

R<sub>DTMNP</sub> The CPU interface issues an upstream Sync command to synchronize the effects of earlier commands.

The IRS responds with a Sync Ack once all the following are true:

- Any Activate, Deactivate, Disable, SetEnabled, SetPending, SetPriority, or SetTarget command received before the Sync has been acknowledged.
- The effects of any Activate, Deactivate, Disable, SetEnabled, SetHandling, SetPending, SetPriority, or SetTarget command received before the Sync are globally observable.
- R<sub>RXYSV</sub> Between sending Sync and receiving Sync Ack, the CPU interface sends no commands other than to acknowledge downstream commands.
- IPLQBYThe CPU interface might send an UpstreamControl command with Identifier set to Reset between sending a<br/>Sync and receiving the Sync Ack.

Arm expects resetting an online channel to be rare and be due to the PE resetting. If an online channel is reset, it is possible that some stale downstream commands are received from the IRS. The CPU interface ignores such commands.

- I<sub>MDVSS</sub> The CPU interface can request the current configuration and state of an INTID by sending a RequestConfig command. The IRS returns the requested INTID's configuration when acknowledging the command with RequestConfig Ack.
- R<sub>DBJFG</sub> Between sending RequestConfig and receiving RequestConfig Ack, the CPU interface sends no commands other than to acknowledge downstream commands.
- IGSGBSThe CPU interface might send an UpstreamControl command with Identifier set to Reset between sending a<br/>RequestConfig and receiving the RequestConfig Ack.

Arm expects resetting an online channel to be rare and be due to the PE resetting. If an online channel is reset, it is possible that some stale downstream commands are received from the IRS. The CPU interface ignores such commands.

## A4.7 IRS and CPU interface capabilities

| The GICv5 Stream interface supports independent development of an IRS and a PE containing a CPU interface.<br>This could lead to mismatches between the capabilities of the IRS and the connected PEs.                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| The CPU interface and IRS connected by an Interrupt Handling channel implement the same set of Interrupt Domains. Neither the CPU interface nor IRS generate any command with the Domain field set to an unimplemented Interrupt Domain.                                                                                      |
| Support for virtualization is reported in the IRS by IRS_IDR0.VIRT and in the PE by ID_AA64PFR0_EL1.EL2.                                                                                                                                                                                                                      |
| In GICv5, either both the IRS and CPU interface support virtualization or neither support virtualization.                                                                                                                                                                                                                     |
| GICv5 supports up to 5 bits of interrupts priority. The number of supported priority bits is reported by the IRS in IRS_IDR1.PRI_BITS and by the CPU interface in ICC_IDR0_EL1.PRI_BITS.                                                                                                                                      |
| In GICv5 Stream, if the component receiving a command implements fewer than 5 bits of priority, the unimplemented least significant priority bits in the command are ignored and treated as being 0.                                                                                                                          |
| If the CPU interface and IRS implement different number of priority bits, Arm recommends that software restricts its usage to only those bits supported by both components.                                                                                                                                                   |
| GICv5 supports up to 24 bits of INTID.ID namespace for each interrupt type The number of supported INTID.ID bits is reported by the IRS in IRS_IDR2.ID_bits and by the CPU interface in ICC_IDR0_EL1.ID_Bits. When fewer than 24 bits of identifier bits are supported, the unimplemented bits are the most significant bits. |
| Arm recommends that all components in a GICv5 system implement the same number of INTID identifier bits. If different components support different number of INTID.ID bits, Arm recommends that software restricts its usage to only those bits supported by all components.                                                  |
| If the IRS receives a command with INTID.ID beyond the implemented range, the command is acknowledged but otherwise ignored.                                                                                                                                                                                                  |
| If the CPU interface receives a command with INTID.ID beyond the implemented range, the behavior depends on the type of command as follows:                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                               |

- Forward command: The command is treated as an implicit Recall of any outstanding Forward for the specified Interrupt Domain or resident VPE, but is otherwise ignored.
- Recall command: The command is ignored.

# Chapter A5 Interrupt Signaling channel

. ...

...

| ⊥ <sub>TJQNR</sub> | to using dedicated interrupt signals or MSIs.                                                                    |
|--------------------|------------------------------------------------------------------------------------------------------------------|
| I <sub>HRNDT</sub> | The rules in this section only apply to the Interrupt Signaling channel.                                         |
| I <sub>gsnzt</sub> | How interrupts delivered by an Interrupt Signaling channel map to SPIs or IWB inputs is IMPLEMENTATION SPECIFIC. |

.

TD C

I<sub>QBKQL</sub> Each Interrupt Source connected via an Interrupt Signaling channel can have one or more distinct interrupts.

Chapter A5. Interrupt Signaling channel A5.1. Command summary

## A5.1 Command summary

 $I_{WSFCN}$  The upstream commands that the Interrupt Source can send to the IRS are:

| ID  | Command                | Description                                        |
|-----|------------------------|----------------------------------------------------|
| 0x0 | Reset                  | Resets the channel and deasserts all interrupts.   |
| 0x1 | INT                    | Communicates the current state of an interrupt.    |
| 0x2 | Resample Ack           | Acknowledges a Resample command.                   |
| 0x3 | Quiesce                | Requests the channel is taken offline.             |
| 0x4 | Flush Ack              | Acknowledges a Flush command.                      |
| 0x7 | IMPLEMENTATION DEFINED | Reserved for IMPLEMENTATION DEFINED functionality. |

#### All other IDs are reserved.

#### ${\tt I}_{\tt YMHFW}$

The downstream commands that an IRS can send to the Interrupt Source are:

| ID  | Command                | Description                                                |
|-----|------------------------|------------------------------------------------------------|
| 0x0 | Reset Ack              | Acknowledges a Reset command.                              |
| 0x1 | -                      | -                                                          |
| 0x2 | Resample               | Requests current state of interrupt or interrupt levels.   |
| 0x3 | Quiesce Ack            | Acknowledges a Quiesce command.                            |
| 0x4 | Flush                  | Flushes commands from the IRS as part of a reset sequence. |
| 0x7 | IMPLEMENTATION DEFINED | Reserved for IMPLEMENTATION DEFINED functionality.         |

All other IDs are reserved.

R<sub>DNTTB</sub> ID 0x7 in upstream and downstream is reserved for IMPLEMENTATION DEFINED functionality.

When supported, IMPLEMENTATION DEFINED commands do not impact the functionality of other commands. If not supported, IMPLEMENTATION DEFINED commands are ignored.

Arm strongly recommends that IMPLEMENTATION DEFINED commands are not used unless it can be guaranteed that both the sender and receiver agree on the usage.

Chapter A5. Interrupt Signaling channel A5.2. Outstanding commands

## A5.2 Outstanding commands

I<sub>QBJBL</sub> The following commands require acknowledgement:

| Command  | Direction  | Acknowledged by       |
|----------|------------|-----------------------|
| Reset    | Upstream   | Reset Ack             |
| Resample | Downstream | Resample Ack or Reset |
| Quiesce  | Upstream   | Quiesce Ack           |
| Flush    | Downstream | Flush Ack             |

|                    | All other commands do not require acknowledgement.                                                                                  |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|
| R <sub>ffyph</sub> | Commands which require acknowledgement are acknowledged in finite time.                                                             |  |
| I <sub>BBGBS</sub> | For commands that require acknowledgement, the architecture places limits on the number of outstanding commands that are permitted. |  |
| R <sub>SWNBP</sub> | For each Interrupt Signaling channel, the IRS can have:                                                                             |  |
|                    | <ul><li> Up to one Resample command outstanding.</li><li> Up to one Flush command outstanding.</li></ul>                            |  |
| R <sub>HNKHF</sub> | For each Interrupt Signaling channel, the CPU interface can have:                                                                   |  |
|                    | • Up to one Quiesce command outstanding.                                                                                            |  |
| I <sub>ONLWZ</sub> | See A5.4 Connection management for more information about outstanding Reset commands.                                               |  |

## A5.3 Signaling interrupts to the IRS

- R<sub>NVLNT</sub> An Interrupt Source can support up to 256 interrupts, numbered 0 to 255.
- R<sub>GYFBQ</sub> An Interrupt Source sends an INT command to indicate the state of an interrupt:
  - INT. ID specifies the interrupt whose state is being communicated.
  - INT.Edge and INT.Level indicate the current state of the interrupt.

| Edge | Level | Meaning                                            | Usage                                                             |
|------|-------|----------------------------------------------------|-------------------------------------------------------------------|
| 0    | 0     | The interrupt is de-asserted.                      | Used to indicate a level-sensitive interrupt has become           |
|      |       |                                                    | de-asserted.                                                      |
| 0    | 1     | The interrupt is asserted.                         | Used to respond to Resample commands.                             |
| 1    | 0     | The interrupt was asserted and became de-asserted. | Used for edge-triggered interrupts to indicate a pulse.           |
| 1    | 1     | The interrupt is asserted and remains asserted.    | Used to indicate a level-sensitive interrupt has become asserted. |

- I<sub>CDSPZ</sub> INT.Edge is used to identify positive edges, it is not used to indicate negative edges.
- R<sub>DBMYY</sub> When an interrupt changes state, the Interrupt Source sends an INT command in finite time.
- IWhen the state of an interrupt changes multiple times before an INT command can be sent, and the interrupt is<br/>level-sensitive, it is permissable for the Interrupt Source to only present the final state of the interrupt.
- $I_{MPJMH}$  Arm recommends that an Interrupt Source does not send INT commands unless the interrupt has changed state or it has received a Resample command.
- R<sub>TVKMG</sub> It is IMPLEMENTATION DEFINED which values of INT. ID that a CPU interface may send.
- R<sub>TLDXR</sub> The IRS can request the current state of an interrupt or of all interrupts by issuing a Resample command.
  - On receiving a Resample command:
    - If Resample.IDV is 0:
      - The Interrupt Source sends an INT command for any interrupt source that is currently asserted, then sends a Resample Acknowledge command.
      - Any interrupt, for which the Interrupt Source does not send an INT command, between the Resample and Resample Acknowledge, is treated by the IRS as being de-asserted.
    - If Resample.IDV is 1:
      - If the interrupt identified by Resample.ID is invalid, the Interrupt Source sends a Resample Acknowledge command.
      - If the interrupt identified by Resample.ID is valid and asserted, the Interrupt Source sends an INT command, then sends a Resample Acknowledge command.
      - If the interrupt identified by Resample.ID is valid and not asserted, the Interrupt Source sends a Resample Acknowledge command.

## A5.4 Connection management

| R <sub>XSJTH</sub> | The Interrupt Source sending a Reset command sets all interrupts to de-asserted and acknowledges any outstanding downstream commands.                                                                                                                                                                                                                                                                       |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| R <sub>vrgrt</sub> | To bring an Interrupt Signaling channel online, or reset an online channel:                                                                                                                                                                                                                                                                                                                                 |  |
|                    | <ul> <li>The Interrupt Source sends a Reset command.</li> <li>The IRS responds with a Flush command.</li> <li>The Interrupt Source acknowledges the Flush command.</li> <li>The IRS acknowledges the Reset command.</li> </ul>                                                                                                                                                                              |  |
|                    | Once the Reset command is acknowledged, the Interrupt Handling channel is online.                                                                                                                                                                                                                                                                                                                           |  |
| R <sub>fwszj</sub> | When a Reset command is acknowledged:                                                                                                                                                                                                                                                                                                                                                                       |  |
|                    | <ul><li>There are no outstanding upstream or downstream commands.</li><li>All interrupts are treated as de-asserted.</li></ul>                                                                                                                                                                                                                                                                              |  |
| R <sub>csvkh</sub> | Between sending a Reset command and the command being acknowledged, the CPU interface sends no commands other than to acknowledge a Flush command.                                                                                                                                                                                                                                                          |  |
|                    | Between receiving Reset command and sending the acknowledge, the IRS sends no other commands than Flush.                                                                                                                                                                                                                                                                                                    |  |
| $R_{TMFQN}$        | The IRS generates a Flush command at most once per channel reset. The Interrupt Source generates a Flush Acknowledge command at most once per channel reset.                                                                                                                                                                                                                                                |  |
| I <sub>lfqpr</sub> | If multiple Reset commands are issued in quick succession, the Interrupt Source might not be able to determine whether a received Flush is due to the most recent Reset or the previous Reset. To avoid the Interrupt Source sending more Flush Acknowledge commands than there are Flush commands, the Interrupt Source is restricted to sending Flush Acknowledge once per-Reset.                         |  |
| R <sub>znkng</sub> | If the IRS receives Flush Acknowledge before it has sent Flush in the channel reset flow, it is IMPLEMENTATION DEFINED whether the IRS sends a Flush command. If the Flush command is sent after receiving a Flush Acknowledge, the IRS treats the command as already acknowledged.                                                                                                                         |  |
|                    | If the Interrupt source receives a Flush command after it has sent a Flush Acknowledge, the Flush command is ignored and treated as acknowledged.                                                                                                                                                                                                                                                           |  |
| R <sub>gdbxw</sub> | To take an Interrupt Signaling channel offline:                                                                                                                                                                                                                                                                                                                                                             |  |
|                    | <ul> <li>The Interrupt Source sends a Quiesce command.</li> <li>The Interrupt Source sends no further commands, other than acknowledgements to downstream commands, until Quiesce Ack is received.</li> <li>The IRS completes any outstanding commands and then sends Quiesce Ack.</li> <li>Once the IRS has received an upstream Quiesce command it does not send further Resample commands.</li> </ul>    |  |
|                    | Once the IRS responds with Quiesce Acknowledge, the channel is offline.                                                                                                                                                                                                                                                                                                                                     |  |
| I <sub>WMGGK</sub> | It is possible that the Interrupt Source receives a downstream Resample command after the upstream Quiesce command is sent. The Interrupt Source is required to send Resample Ack before the IRS can respond with Quiesce Ack.                                                                                                                                                                              |  |
|                    | Taking an Interrupt Source channel offline implicitly deasserts all the interrupts. Therefore, if there is an outstanding Resample when Quiesce is issued, Arm recommends that the Interrupt Source sends Resample Ack without sending any INT commands, which indicates that all interrupts are deasserted. It is, however, permitted for the Interrupt Source to send INT commands and then Resample Ack. |  |
| R <sub>YWLGB</sub> | If an Interrupt Signaling channel is offline, all of the following are true:                                                                                                                                                                                                                                                                                                                                |  |
|                    | <ul><li>The IRS sends no commands.</li><li>The Interrupt Source sends no commands, other than Reset to bring the channel online.</li><li>All interrupts are treated as de-asserted.</li></ul>                                                                                                                                                                                                               |  |

# Chapter A6 Alphabetical list of commands

This section contains the definition of each command for the GICv5 Stream Protocol.

Chapter A6. Alphabetical list of commands A6.1. Interrupt Handling channel

## A6.1 Interrupt Handling channel

This section contains the definition of each command for the Interrupt Handling channel for the GICv5 Stream Protocol.

## A6.1.1 Activate, Activate command (CPUIF -> IRS)

The Activate characteristics are:

#### Attributes

Activate is a 2-byte structure.

## **Field descriptions**

The Activate bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning  |  |
|--------|----------|--|
| 0b0010 | Activate |  |

### Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

### Bit [5]

Reserved, RESO.

#### Domain, bits [7:6]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

## Bits [15:8]

## A6.1.2 ActivateAck, Activate Acknowledge command (IRS -> CPUIF)

The ActivateAck characteristics are:

#### Attributes

ActivateAck is a 2-byte structure.

## **Field descriptions**

The ActivateAck bit assignments are:

| 15 | 4  | 3   | 0 |
|----|----|-----|---|
| RI | S0 | CMD |   |

### CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning      |  |
|--------|--------------|--|
| 0b0010 | Activate Ack |  |

## Bits [15:4]

## A6.1.3 Deactivate, Deactivate interrupt command (CPUIF -> IRS)

The Deactivate characteristics are:

#### Attributes

Deactivate is a 6-byte structure.

### **Field descriptions**

The Deactivate bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning    |  |
|--------|------------|--|
| 0b0110 | Deactivate |  |

## Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

## TYPE, bits [7:5]

The type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Domain, bits [9:8]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

## Bits [15:10]

Reserved, RESO.

ID, bits [39:16]

The ID of the interrupt.

Bits [47:40]

## A6.1.4 DeactivateAck, Deactivate interrupt Acknowledge command (IRS -> CPUIF)

The DeactivateAck characteristics are:

#### Attributes

DeactivateAck is a 2-byte structure.

## **Field descriptions**

The DeactivateAck bit assignments are:

| 15 | 4  | 3 | 0   |
|----|----|---|-----|
| RE | S0 |   | CMD |

### CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning        |
|--------|----------------|
| 0b0110 | Deactivate Ack |

## Bits [15:4]

## A6.1.5 DownstreamControl, Downstream Control (IRS -> CPUIF)

The DownstreamControl characteristics are:

#### Attributes

DownstreamControl is a 4-byte structure.

## **Field descriptions**

The DownstreamControl bit assignments are:

| 31 16  | 15 8 | 7 4         | 1 <sup>3</sup> 01 |
|--------|------|-------------|-------------------|
| IAFFID | RES0 |             | CMD               |
|        |      | LIdentifier |                   |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning           |  |
|--------|-------------------|--|
| 0b0100 | DownstreamControl |  |

## Identifier, bits [7:4]

Specifies the type of Downstream Control operation.

| Identifier | Meaning |  |
|------------|---------|--|
| 0b0001     | Flush   |  |
| 0b0010     | IAFFID  |  |

## Bits [15:8]

Reserved, RESO.

#### IAFFID, bits [31:16]

The PE interrupt affinity.

This field is RESO when Identifier is not 0b0010 (IAFFID).

## A6.1.6 DownstreamControlAck, Downstream Control Acknowledge command (CPUIF -> IRS)

The DownstreamControlAck characteristics are:

#### Attributes

DownstreamControlAck is a 2-byte structure.

#### **Field descriptions**

The DownstreamControlAck bit assignments are:



#### CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning               |  |
|--------|-----------------------|--|
| 0b0100 | DownstreamControl Ack |  |

#### Flush, bit [4]

Whether the operation being acknowledged is a Flush.

| Flush | Meaning                   |
|-------|---------------------------|
| 0b0   | Not acknowleding a Flush. |
| 0b1   | Acknowleding a Flush.     |

#### Bits [15:5]

## A6.1.7 Forward, Forward command (IRS -> CPUIF)

The Forward characteristics are:

#### Attributes

Forward is a 6-byte structure.

## **Field descriptions**

The Forward bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning |  |
|--------|---------|--|
| 0b0001 | Forward |  |

#### Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

## TYPE, bits [7:5]

The type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Domain, bits [9:8]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

#### ActivateAck, bit [10]

Whether the Forward also Acknowledges a previous Activate command.

| ActivateAck | Meaning                                                 |
|-------------|---------------------------------------------------------|
| 0b0         | The Forward does not acknowledge any previous Activate. |
| 0b1         | The Forward acknowledges a previous Activate.           |

When the Forward command acknowledges a previous Activate, it applies to an Activate for the same Domain and setting of Virtual.

#### Priority, bits [15:11]

The priority of the interrupt.

Lower numeric values are higher priority, meaning that 0b00000 is the highest supported priority and 0b11111 is the lowest priority.

The CPU interface treats priority bits it does not implement as RESO.

The IRS sets priority bits it does not implement to 0b0.

#### ID, bits [39:16]

The ID of the interrupt.

#### Bits [46:40]

Reserved, RESO.

#### Returnable, bit [47]

Indicates whether the CPU interface can choose to proactively return the interrupt.

| Returnable | Meaning                      |
|------------|------------------------------|
| 0b0        | Interrupt is not returnable. |
| 0b1        | Interrupt is returnable.     |

## A6.1.8 Recall, Recall command (IRS -> CPUIF)

The Recall characteristics are:

#### Attributes

Recall is a 2-byte structure.

## **Field descriptions**

The Recall bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning |  |
|--------|---------|--|
| 0b0011 | Recall  |  |

### Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

#### Bit [5]

Reserved, RESO.

#### Domain, bits [7:6]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

#### Bits [15:8]

## A6.1.9 Release, Release command (CPUIF -> IRS)

The Release characteristics are:

#### Attributes

Release is a 6-byte structure.

## **Field descriptions**

The Release bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning |  |
|--------|---------|--|
| 0b0011 | Release |  |

## Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

## TYPE, bits [7:5]

The type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Domain, bits [9:8]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0000   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

## Bits [15:10]

Reserved, RESO.

ID, bits [39:16]

The ID of the interrupt.

Bits [47:40]

## A6.1.10 RequestConfig, Request Interrupt Configuration command (CPUIF -> IRS)

The RequestConfig characteristics are:

#### Attributes

RequestConfig is a 6-byte structure.

### **Field descriptions**

The RequestConfig bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning       |  |
|--------|---------------|--|
| 0b1100 | RequestConfig |  |

### Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

## TYPE, bits [7:5]

The type of the interrupt.

| ТҮРЕ  | Meaning |
|-------|---------|
| 0b010 | LPI     |
| 0b011 | SPI     |

Values not defined above are reserved.

#### Domain, bits [9:8]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

## Bits [15:10]

Reserved, RESO.

ID, bits [39:16]

The ID of the interrupt.

Bits [47:40]

# A6.1.11 RequestConfigAck, Request Interrupt Configuration Acknowledge command (IRS -> CPUIF)

The RequestConfigAck characteristics are:

#### Attributes

RequestConfigAck is a 4-byte structure.

## **Field descriptions**

The RequestConfigAck bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning          |
|--------|------------------|
| 0b1100 | RequestConfigAck |

### Bit [4]

Reserved, RESO.

#### Active, bit [5]

Whether the interrupt is Active.

| Active | Meaning  |  |
|--------|----------|--|
| 0b0    | Inactive |  |
| 0b1    | Active   |  |

## Fault, bit [6]

Whether the IRS was able to retrieve the requested data.

| Fault | Meaning |  |
|-------|---------|--|
| 0b0   | Success |  |
| 0b1   | Fault   |  |

When this field is set to 1 it indicates the requested INTID was unreachable, the returned configuration is UNKNOWN.

## Enable, bit [7]

Whether the interrupt is individually enabled.

| Enable | Meaning  |  |
|--------|----------|--|
| 0b0    | Disabled |  |
| 0b1    | Enabled  |  |

## HM, bit [8]

Whether the interrupt is Level or Edge.

| HM  | Meaning |
|-----|---------|
| 000 | Edge    |
| 0b1 | Level   |

#### IRM, bit [9]

Interrupt routing mode

| IRM | Meaning                             |  |
|-----|-------------------------------------|--|
| 0b0 | Interrupt Routing mode is Targeted. |  |
| 0b1 | Interrupt Routing mode is 1ofN.     |  |

## Pending, bit [10]

Whether the interrupt is pending.

| Pending | Meaning      |  |
|---------|--------------|--|
| 0b0     | Not pending. |  |
| 0b1     | Pending.     |  |

#### Priority, bits [15:11]

The priority of the interrupt.

## IAFFID, bits [31:16]

The interrupt Affinity value.

When IRM is 1, this field is IMPLEMENTATION SPECIFIC.

## A6.1.12 SetAck, Set interrupt configuration acknowledge command (IRS -> CPUIF)

The SetAck characteristics are:

#### Attributes

SetAck is a 2-byte structure.

## **Field descriptions**

The SetAck bit assignments are:

| 15 | 4   | 3   | 0 |
|----|-----|-----|---|
| R  | ES0 | CMD | ) |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning |
|--------|---------|
| 0b1000 | Set Ack |

## Bits [15:4]

## A6.1.13 SetEnabled, Set interrupt Enabled command (CPUIF -> IRS)

The SetEnabled characteristics are:

#### Attributes

SetEnabled is a 6-byte structure.

## **Field descriptions**

The SetEnabled bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning    |  |
|--------|------------|--|
| 0b1000 | SetEnabled |  |

## Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

## TYPE, bits [7:5]

The type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Domain, bits [9:8]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

## EN, bit [10]

Whether the interrupt is Enabled.

| EN  | Meaning  |  |
|-----|----------|--|
| 0b0 | Disabled |  |
| 0b1 | Enabled  |  |

## Bits [15:11]

Reserved, RESO.

ID, bits [39:16]

The ID of the interrupt.

Bits [47:40]

## A6.1.14 SetHandling, Set Interrupt Handling Mode command (CPUIF -> IRS)

The SetHandling characteristics are:

#### Attributes

SetHandling is a 6-byte structure.

## **Field descriptions**

The SetHandling bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning     |  |
|--------|-------------|--|
| 0b1011 | SetHandling |  |

## Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

## TYPE, bits [7:5]

The type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Domain, bits [9:8]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

## HM, bit [10]

Interrupt Handling mode.

| HM  | Meaning |
|-----|---------|
| 0b0 | Edge    |
| 0b1 | Level   |

## Bits [15:11]

Reserved, RESO. *ID, bits [39:16]* 

The ID of the interrupt.

Bits [47:40]

## A6.1.15 SetPending, Set interrupt Pending command (CPUIF -> IRS)

The SetPending characteristics are:

#### Attributes

SetPending is a 8-byte structure.

## **Field descriptions**

The SetPending bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning    |  |
|--------|------------|--|
| 0b1110 | SetPending |  |

## Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

## TYPE, bits [7:5]

The type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Domain, bits [9:8]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

## Pending, bit [10]

Whether the interrupt is Pending.

| Pending | Meaning               |
|---------|-----------------------|
| 0b0     | Generate CLEAR event. |
| 0b1     | Generate SET event.   |

## Bits [15:11]

Reserved, RESO.

## ID, bits [39:16]

The ID of the interrupt.

#### Bits [47:40]

Reserved, RESO.

#### VM, bits [63:48]

The Virtual Machine identifier. This field is RESO when Virtual is 0.

## A6.1.16 SetPriority, Set Interrupt Priority command (CPUIF -> IRS)

The SetPriority characteristics are:

#### Attributes

SetPriority is a 6-byte structure.

## **Field descriptions**

The SetPriority bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning     |  |
|--------|-------------|--|
| 0b1010 | SetPriority |  |

## Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

## TYPE, bits [7:5]

The type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Domain, bits [9:8]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

## Bit [10]

Reserved, RESO.

#### Priority, bits [15:11]

The priority of the interrupt.

The CPU interface sets priority bits it does not implement to 0b0

The IRS treats priority bits it does not implement as 0b0.

## ID, bits [39:16]

The ID of the interrupt.

#### Bits [47:40]

## A6.1.17 SetResident, Set Resident command (CPUIF -> IRS)

The SetResident characteristics are:

#### Attributes

SetResident is a 6-byte structure.

## **Field descriptions**

The SetResident bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning     |  |
|--------|-------------|--|
| 0b1111 | SetResident |  |

## Virtual, bit [4]

Whether the operation is physical or virtual.

| Virtual | Meaning            |  |
|---------|--------------------|--|
| 0b1     | Virtual interrupt. |  |

## Bit [5]

Reserved, RESO.

#### Domain, bits [7:6]

The Interrupt Domain of the VPE being made resident or non-resident.

| Domain | Meaning    |  |
|--------|------------|--|
| 0b00   | Secure     |  |
| 0b01   | Non-secure |  |
| 0b11   | Realm      |  |

## Valid, bit [8]

Whether a VPE is resident or not.

| Valid | Meaning                                                                |  |  |
|-------|------------------------------------------------------------------------|--|--|
| 0b0   | The currently resident VPE is being cleared.                           |  |  |
| 0b1   | The VPE indicated by the Domain and VPE fields is being made resident. |  |  |

## VPE, bits [23:9]

The VPE identifier. This field is RESO when Valid is 0.

#### Bits [25:24]

Reserved, RESO.

#### DB, bit [26]

Doorbell Request.

| DB  | Meaning               |  |
|-----|-----------------------|--|
| 0b0 | No doorbell requested |  |
| 0b1 | Doorbell requested    |  |

This field is RESO when Valid is 1.

## DBPM, bits [31:27]

Doorbell Priority Mask.

This field is RESO when DB is 0.

#### VM, bits [47:32]

The Virtual Machine identifier. This field is RES0 when Valid is 0.

## A6.1.18 SetResidentAck, Set Resident acknowledge command (IRS -> CPUIF)

The SetResidentAck characteristics are:

#### Attributes

SetResidentAck is a 2-byte structure.

## **Field descriptions**

The SetResidentAck bit assignments are:

| 1 | 15   | 7 | 6 | 5   | 4   | 3 |     | Θ ι |
|---|------|---|---|-----|-----|---|-----|-----|
|   | RES0 |   |   | RE  | S0  |   | CMD |     |
|   |      |   | L | Fau | ılt |   |     |     |

#### CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning         |  |
|--------|-----------------|--|
| 0b1111 | SetResident Ack |  |

## Bits [5:4]

Reserved, RESO.

## Fault, bit [6]

Whether the requested VPE was made resident.

| Fault | Meaning                              |  |  |
|-------|--------------------------------------|--|--|
| 0b0   | Requested VPE was made resident.     |  |  |
| 0b1   | Requested VPE was not made resident. |  |  |

When acknowledging a SetResident with Valid set to 0, this field is RES0.

## Bits [15:7]

## A6.1.19 SetTarget, Set Interrupt Target command (CPUIF -> IRS)

The SetTarget characteristics are:

#### Attributes

SetTarget is a 8-byte structure.

## **Field descriptions**

The SetTarget bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning   |  |
|--------|-----------|--|
| 0b1001 | SetTarget |  |

## Virtual, bit [4]

Whether the operation is on a physical or virtual interrupt.

| Virtual | Meaning             |  |
|---------|---------------------|--|
| 0b0     | Physical interrupt. |  |
| 0b1     | Virtual interrupt.  |  |

## TYPE, bits [7:5]

The type of the interrupt.

| ТҮРЕ  | Meaning |  |
|-------|---------|--|
| 0b010 | LPI     |  |
| 0b011 | SPI     |  |

Values not defined above are reserved.

#### Domain, bits [9:8]

The Domain the operation affects.

| Domain | Meaning    |
|--------|------------|
| 0b00   | Secure     |
| 0b01   | Non-secure |
| 0b10   | EL3        |
| 0b11   | Realm      |

## IRM, bit [10]

Interrupt routing mode

| IRM | Meaning                                 |
|-----|-----------------------------------------|
| 0b0 | The interrupt Routing mode is Targeted. |
| 0b1 | The interrupt Routing mode is 1ofN.     |

## Bits [15:11]

Reserved, RESO.

## ID, bits [39:16]

The ID of the interrupt.

#### Bits [47:40]

Reserved, RESO.

## IAFFID, bits [63:48]

Target PE.

If IRM is 0, this field indicates the PE interrupt affinity of the target PE.

If IRM is 1, this field provides an IMPLEMENTATION DEFINED hint to 1ofN selection algorithm. A value of 0 means that no hint is provided.

## A6.1.20 Sync, synchronizes previously sent configuration changes (CPUIF -> IRS)

The Sync characteristics are:

#### Attributes

Sync is a 2-byte structure.

## **Field descriptions**

The Sync bit assignments are:

| 15 |      | 4 | 3 |     | 0 |
|----|------|---|---|-----|---|
|    | RES0 |   |   | CMD |   |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning |
|--------|---------|
| 0b1101 | Sync    |

## Bits [15:4]

## A6.1.21 SyncAck, synchronizes previously sent configuration changes (IRS -> CPUIF)

The SyncAck characteristics are:

#### Attributes

SyncAck is a 2-byte structure.

## **Field descriptions**

The SyncAck bit assignments are:

| 15 |      | 4 | 3 |     | Θι |
|----|------|---|---|-----|----|
|    | RES0 |   |   | CMD |    |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning  |  |
|--------|----------|--|
| 0b1101 | Sync Ack |  |

## Bits [15:4]

## A6.1.22 UpstreamControl, Upstream Control (CPUIF -> IRS)

The UpstreamControl characteristics are:

#### Attributes

UpstreamControl is a 2-byte structure.

## **Field descriptions**

The UpstreamControl bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning         |  |
|--------|-----------------|--|
| 060000 | UpstreamControl |  |

## Identifier, bits [7:4]

Specifies the type of Upstream Control operation.

| Identifier | Meaning                                                         |
|------------|-----------------------------------------------------------------|
| 000000     | Reset                                                           |
| 0b0001     | Quiesce                                                         |
| 0b0010     | Set 1ofN hints, Data specifies which hints are being set.       |
| 0b0011     | Clear 1ofN hints, Data specifies which hints are being cleared. |

## Data, bits [15:8]

Data associated with the Upstream Control operation.

When Identifier is 0b0010 or 0b00011, Data indicates which 1ofN hints are being set or cleared.

| Data      | Meaning                                                                                      |
|-----------|----------------------------------------------------------------------------------------------|
| 0bxxxxxx1 | Selecting this PE is likely to cause exit from a low power state.<br>Applies to all Domains. |

Values not defined above are reserved.

For all other values of Identifier, this field is RESO.

## A6.1.23 UpstreamControlAck, Upstream Control Acknowledge command (IRS -> CPUIF)

The UpstreamControlAck characteristics are:

#### Attributes

UpstreamControlAck is a 4-byte structure.

### **Field descriptions**

The UpstreamControlAck bit assignments are:

| 31 16  | 15 | 14 4  | 3 |     | 0 |
|--------|----|-------|---|-----|---|
| IAFFID |    | RES0  |   | CMD |   |
|        | L  | Reset |   |     |   |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning             |  |
|--------|---------------------|--|
| 0b0000 | UpstreamControl Ack |  |

#### Bits [14:4]

Reserved, RESO.

#### Reset, bit [15]

Whether a reset request is being acknowledged.

| Reset | Meaning                            |  |
|-------|------------------------------------|--|
| 0b0   | Not acknowledging a reset request. |  |
| 0b1   | Acknowledging a reset request.     |  |

#### IAFFID, bits [31:16]

The PE interrupt affinity.

This field is RESO when acknowledging an UpstreamControl with an Identifier that is not 0b0000 (Reset).

Chapter A6. Alphabetical list of commands A6.1. Interrupt Handling channel

## A6.1.24 WakeRequest, Wake request (IRS -> CPUIF)

The WakeRequest characteristics are:

#### Attributes

WakeRequest is a 2-byte structure.

## **Field descriptions**

The WakeRequest bit assignments are:

| 15 | 4   | 3   | 0 |
|----|-----|-----|---|
| R  | ES0 | CMD |   |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning     |
|--------|-------------|
| 0b0101 | WakeRequest |

## Bits [15:4]

Chapter A6. Alphabetical list of commands A6.2. Interrupt Signaling channel

# A6.2 Interrupt Signaling channel

This section contains the definition of each command for the Interrupt Signaling channel for the GICv5 Stream Protocol.

## A6.2.1 INT, Interrupt command (Interrupt Source -> IRS)

The INT characteristics are:

#### Attributes

INT is a 2-byte structure.

## **Field descriptions**

The INT bit assignments are:



#### CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning |  |
|--------|---------|--|
| 0b0001 | INT     |  |

Level, bit [4]

| Level | Meaning      |  |
|-------|--------------|--|
| 0b0   | De-asserted. |  |
| 0b1   | Asserted.    |  |

Edge, bit [5]

| Edge | Meaning                   |
|------|---------------------------|
| 0b0  | Falling-edge, or no edge. |
| 0b1  | Positive-edge.            |

## Bits [7:6]

Reserved, RESO.

## ID, bits [15:8]

The ID of the interrupt.

## A6.2.2 Flush, Flush command (IRS -> Interrupt Source)

The Flush characteristics are:

#### Attributes

Flush is a 2-byte structure.

## **Field descriptions**

The Flush bit assignments are:

| 15 |      | 4 | 3 |     | 0 |
|----|------|---|---|-----|---|
|    | RES0 |   |   | CMD |   |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning |
|--------|---------|
| 0b0100 | Flush   |

## Bits [15:4]

## A6.2.3 FlushAck, Flush acknowledge command (Interrupt Source -> IRS)

The FlushAck characteristics are:

#### Attributes

FlushAck is a 2-byte structure.

## **Field descriptions**

The FlushAck bit assignments are:

| 15 | 4   | 3   | 0 |
|----|-----|-----|---|
| R  | ES0 | CMD | ) |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning   |
|--------|-----------|
| 0b0100 | Flush Ack |

## Bits [15:4]

## A6.2.4 Quiesce, Quiesce command (Interrupt Source -> IRS)

The Quiesce characteristics are:

#### Attributes

Quiesce is a 2-byte structure.

## **Field descriptions**

The Quiesce bit assignments are:

| 15 |      | 4 | 3 |     | 0 |
|----|------|---|---|-----|---|
|    | RES0 |   |   | CMD |   |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning |
|--------|---------|
| 0b0011 | Quiesce |

## Bits [15:4]

## A6.2.5 QuiesceAck, Quiesce acknowledge command (IRS -> Interrupt Source)

The QuiesceAck characteristics are:

## Attributes

QuiesceAck is a 2-byte structure.

## **Field descriptions**

The QuiesceAck bit assignments are:

| 15   | 4 | 3 | 0   |
|------|---|---|-----|
| RES0 |   |   | CMD |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning     |
|--------|-------------|
| 0b0011 | Quiesce Ack |

## Bits [15:4]

## A6.2.6 Resample, Resample request command (IRS -> Interrupt Source)

The Resample characteristics are:

#### Attributes

Resample is a 2-byte structure.

## **Field descriptions**

The Resample bit assignments are:



## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning  |  |
|--------|----------|--|
| 0b0010 | Resample |  |

## IDV, bit [4]

| IDV | Meaning                                                    |
|-----|------------------------------------------------------------|
| 0b0 | Resample request for all asserted interrupts.              |
| 0b1 | Resample request for the interrupt identified by ID field. |

## Bits [7:5]

Reserved, RESO.

## ID, bits [15:8]

The ID of the interrupt. This field is RESO when IDV is 0.

## A6.2.7 ResampleAck, Resample request acknowledge command (Interrupt Source -> IRS)

The ResampleAck characteristics are:

#### Attributes

ResampleAck is a 2-byte structure.

## **Field descriptions**

The ResampleAck bit assignments are:

| 15 |      | 4 | 3 |     | 0 |
|----|------|---|---|-----|---|
|    | RES0 |   |   | CMD |   |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning      |
|--------|--------------|
| 0b0010 | Resample Ack |

## Bits [15:4]

## A6.2.8 Reset, Reset command (Interrupt Source -> IRS)

The Reset characteristics are:

#### Attributes

Reset is a 2-byte structure.

## **Field descriptions**

The Reset bit assignments are:

| 15 | 4   | 3   | 0 |
|----|-----|-----|---|
| R  | ES0 | CMD |   |

## CMD, bits [3:0]

Indicates the command type.

| CMD    | Meaning |
|--------|---------|
| 000000 | Reset   |

## Bits [15:4]

## A6.2.9 ResetAck, Reset acknowledge command (IRS -> Interrupt Source)

The ResetAck characteristics are:

#### Attributes

ResetAck is a 2-byte structure.

## **Field descriptions**

The ResetAck bit assignments are:

| 15 | 4   | 3   | 0 |
|----|-----|-----|---|
| R  | ES0 | CMD |   |

## CMD, bits [3:0]

Indicates the command type.

| CMD   | Meaning   |  |
|-------|-----------|--|
| 00000 | Reset Ack |  |

## Bits [15:4]

This section gives examples of typical sequences.

The flows given in this section are for illustration purposes only.

# A7.1 Bringing the Interrupt Handling channel online and taking it offline

If the Interrupt Handling channel between the CPU interface and IRS is offline, the first command that is sent is an UpstreamControl command. A two-phase reset process is used, as illustrated below:



The Interrupt Handling channel is taken offline by the CPU interface sending an UpstreamControl command with Identifier set to Quiesce. On receipt of the UpstreamControl command the IRS completes all outstanding commands, before sending a UpstreamControlAck. The IRS treats all outstanding Forward commands as being implicitly returned by the link that is taken offline. Once the UpstreamControlAck is received by the PE the Interrupt Handling channel is offline.

A7.1. Bringing the Interrupt Handling channel online and taking it offline



There may be cases where the Interrupt Handling channel is classed as online but needs to be reset. This can be achieved by the CPU interface sending an UpstreamControl command with Identifier set to Reset. Sending the UpstreamControl command with Identifier set to Reset returns any pending interrupts to the IRS and cancels outstanding commands. This process is illustrated below:

A7.1. Bringing the Interrupt Handling channel online and taking it offline



The CPU interface might need to restart the reset process part way through. To do this, the CPU interface sends a new Reset request.

A7.1. Bringing the Interrupt Handling channel online and taking it offline



Arm recommends that resetting an online connection is only used for recovery and not for normal operation.

A7.1. Bringing the Interrupt Handling channel online and taking it offline

If the Interrupt Handling channel is offline, the IRS can request that it is brought online by sending a wake request:



## A7.2 Simple interrupt life-cycle





The effect of acknowledging an interrupt is not guaranteed to have been observed by the IRS until after a GSB ACK or GSB SYS instruction has completed. With GICv5 Stream, a PE can determine the activation has been observed by waiting for an ActivateAck() before completing the barrier.

With edge-triggered interrupts, until the acknowledging of an instance of an interrupt is visible to the IRS, further edges from the interrupt source might continued to be merged.

## A7.3 Replacing the candidate HPPI for an Interrupt Domain, or resident VPE

The IRS forwards the candidate HPPI for a given Interrupt Domain, or resident VPE, to the CPU interface. The chosen candidate HPPI might change, for example due to another interrupt becoming pending or a change to interrupt configuration. In this case, the IRS can replace the candidate HPPI for the Interrupt Domain, or resident VPE, by sending another Forward. The CPU interface is required to either release or activate the replaced interrupt in finite time.



It is possible that the IRS again changes the candidate HPPI before the CPU interface has responded in finite time. The IRS can send further Forward commands, each replacing the previous. The CPU interface can return multiple pending interrupts for a given Interrupt Domain, or VPE, with a single Release command. The Release command releases the specified INTID, and all earlier outstanding Forward commands for that Interrupt Domain, or VPE.

Chapter A7. Example sequences A7.3. Replacing the candidate HPPI for an Interrupt Domain, or resident VPE



For a given Interrupt Domain, or the resident VPE, Forward commands are always acknowledged in the order they are received. In the above example, the CPU interface cannot issue an Activate for INTID C before INTIDs A and B are released.

In some cases the candidate HPPI might change due to GIC instructions executed on the PE that the interrupt has been forwarded to. In these cases the CPU interface communicates the change in configuration to the IRS and the IRS is responsible for recalling the interrupt if required. The CPU interface does not proactively issue a Release.

Chapter A7. Example sequences

A7.3. Replacing the candidate HPPI for an Interrupt Domain, or resident VPE



In the above example, the IRS acknowledges the SetEnabled command before the Interrupt Write effect of clearing the INTID Enable is visible. Acknowledging a SetEnabled, SetPending, SetPriority or SetTarget indicates that the IRS has observed the command and that the effects of the command will become visible in finite time. To guarantee that the effects of previous operations are complete, software must issue a GSB SYS barrier which results in a Sync command being sent to the IRS.

Another execution where the IRS sends the SetAck after the Interrupt Write effects are globally visible is also possible and permitted by the architecture.

## A7.4 Making a VPE resident

To set the resident VPE, the CPU interface sends a SetResident() command. The IRS responds with a SetResidentAck() to show that it has completed the operation. This is illustrated here:



Software can also configure the GIC so that there is no resident VPE, as illustrated here:

Chapter A7. Example sequences A7.4. Making a VPE resident



To change the resident VPE, the current resident VPE must first be made non-resident:

# Chapter A7. Example sequences A7.4. Making a VPE resident



If the CPU interface attempts to make an invalid VPE resident, the IRS acknowledges the command indicating that operation failed:



Chapter A7. Example sequences A7.5. Interrupt configuration

## A7.5 Interrupt configuration

The flow for updating the configuration of an LPI or SPI is illustrated below:



Chapter A7. Example sequences A7.6. Sending IPIs

## A7.6 Sending IPIs



The flow for generating a physical IPI is illustrated here:

For virtual IPIs, the VPE is taken from the previous SetResident() command, as illustrated here:



Chapter A7. Example sequences A7.7. 1 of N interrupts

## A7.7 1 of N interrupts

The following flow demonstrates how the Returnable argument to a Forward command can be used for lofN interrupts:



# Part B Litmus tests

# Chapter B1 Interrupt ordering litmus tests

This section gives examples of the use of GIC instructions with and without the use of the GIC specific barrier instructions introduced in this document.

The aim of these tests is to help programmers, hardware design engineers, and validation engineers understand the need for the different kinds of barriers and inherent ordering guarantees.

See also:

• 2.12 Interrupt ordering model and synchronization requirements

## **B1.1 Interrupt litmus test assumptions**

The litmus tests make the following assumptions related to GIC instructions, configuration of the GICv5 CPU interface, and interrupt state and configuration:

• We assume all interrupts are initialized with the following values:

- We assume no asynchronous events take place, including no interrupts become pending without explicit actions taken by one of the processes in the litmus test.
- We assume that ICC\_PCR\_EL1 and ICC\_HAPR\_EL1 are both set at the idle priority.
- We assume all GICv5 CPU interface and IRS controls are set to enable delivery of interrupts to PEs included in the litmus test.
- We assume that SCTLR\_ELx.NMI is 1.
- We assume interrupt exceptions are masked using PSTATE including interrupts with Superpriority.
- We assume all INTIDs referenced from the litmus tests are reachable from the PEs.
- We assume all PEs are executing in the same Interrupt Domain.
- Interrupts are delivered in finite time.
- Some litmus tests rely on a peripheral with the following properties:
  - The peripheral generates interrupt events to INTID(A) as a result of writing 1 to an MMIO register on the device.
  - A mapping to the interrupt generating MMIO register is annotated with //PERIP in the test.
  - The register initially has the value 0 when read back.
  - The register preserves the values written to it.
  - The peripheral generates a single edge event when there is a write to its MMIO register.
  - The interrupt is made Pending in finite time after the write to the peripheral's MMIO register.
- The WAIT (<instr>; <cond>) construct executes the instruction in a loop enough times that either <cond> is true, or any number of finite time periods have completed.
  - For example, a WAIT (GICR Xt, CDIA; Xt=(valid:1)) will eventually acknowledge an interrupt if all of the following are true:
    - \* The interrupt is Pending or becomes Pending in finite time.
    - \* The interrupt is Inactive, targeted to the PE, and of sufficient Priority to be acknowledged.

See the documentation of the hertools7 toolsuite (https://diy.inria.fr/) for more information about the syntax and use of litmus tests.

## B1.2 Atomicity of interrupt updates by GIC system instructions

## B1.2.1 Notes

A GIC system instruction generates a Successful Read-Modify-Write pair of INTID Effects to update an interrupt. The purpose of this section is to show that the Successful Read-Modify-Write pair is required to be atomic.

### B1.2.2 Litmus test

```
Arch64 gic.pri+gic.en
{
 [INTID(A)]=(priority:0,enabled:0);
 0:X1=(intid:A, priority:1);
 1:X1=(intid:A);
}
P0 | P1 ;
GIC CDPRI, X1 | GIC CDEN, X1 ;
exists(INTID(A)=(priority:0,enabled:1) \/ INTID(A)=(priority:1,enabled:0))
kinds: gic.pre+gic.en Forbid
```

## B1.2.2.1 Explanation

On P0, the GIC CDPRI, X1 system instruction updates the priority of the interrupt INTID (A):

- Generates an Interrupt Read Effect  $E_1$  to INTID (A).
- Modifies the priority field of the value read.
- Generates an Interrupt Write Effect  $E_2$  to INTID (A).

E<sub>1</sub> and E<sub>2</sub> are a Successful Read-Modify-Write pair of Interrupt Effects and have to be atomic.

On P1, the GIC CDEN, X1 system instruction enables the interrupt INTID (A):

- Generates an Interrupt Read Effect  $E_3$  to  $\mbox{intid}\ (\mbox{A})$  .
- Modifies the enabled field of the value read.
- Generates an Interrupt Write Effect  $E_4$  to  $\texttt{INTID}\left(\texttt{A}\right).$

E<sub>3</sub> and E<sub>4</sub> are a Successful Read-Modify-Write pair of Interrupt Effects and have to be atomic.

Therefore, an execution where  $E_1$  is Coherence-before  $E_4$ ,  $E_4$  is Coherence-before  $E_2$  and as a result INTID (A) has the final value (priority:1, enabled:0) is architecturally forbidden. Also, an execution where  $E_3$  is Coherence-before  $E_2$  and  $E_2$  is Coherence-before  $E_4$  and as a result INTID (A) has the final value (priority:0,  $\hookrightarrow$  enabled:1) is architecturally forbidden.

## **B1.3 Multiple updates of the same Interrupt Location**

### B1.3.1 Notes

The purpose of this test is to show that multiple upadtes to the same Interrupt Location by GIC system instructions with commands other than DI are observed in program order.

#### B1.3.2 Litmus test with two configuration updates

```
AArch64 coWW-gic
{
 [INTID(A)]=(priority:0);
 0:X1=(intid:A, priority:1);
 0:X2=(intid:A, priority:2);
}
PO ;
GIC CDPRI, X1 ;
GIC CDPRI, X2 ;
exists(INTID(A)=(priority:0) \/ INTID(A)=(priority:1))
kinds: coWW-gic Forbid
```

## B1.3.2.1 Explanation

On P0:

- The first GIC CDPRI, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$  that updates its priority.
- The second GIC CDPRI, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_2$  that updates its priority.

 $E_1$  and  $E_2$  are a Successful Read-Modify-Write pair of Interrupt Effects and are required to be atomic.

```
Therefore, an execution where E_1 is Coherence-before E_4, E_4 is Coherence-before E_2 and as a result INTID (A) has the final value (priority:1, enabled:0) is architecturally forbidden. Also, an execution where E_3 is Coherence-before E_2 and E_2 is Coherence-before E_4 and as a result INTID (A) has the final value (priority:0, \hookrightarrow enabled:1) is architecturally forbidden.
```

### B1.3.3 Litmus test with an interrupt disable and an interrupt deactivate

```
AArch64 coWR-gic+dis-di+rcfg
{
 [INTID(A)]=(enabled:1, active:1);
 0:X1=(intid:A);
 1:X1=(intid:A);
}
P0 | P1 ;
GIC CDDIS,X1 | GIC CDRCFG, X1 ;
GIC CDDI,X1 | ISB ;
 | MRS X3, ICC_ICSR_EL1 ;
exists(1:X3=(active:0,enabled:1))
kinds: coWR-gic+dis-di+rcfg Allowed
```

## B1.3.3.1 Explanation

On P0:

- GIC CDDIS, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$ .
- GIC CDDI, X1 generates an Implicit Interrupt Read Effect to INTID (A)  $E_3$  and an Implicit Interrupt Write Effect to INTID (A)  $E_4$ .

On P1:

• GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A) E5.

In the execution that satisfies the postcondition,  $E_5$  Reads-from  $E_4$  and  $E_4$  is Coherence-before  $E_1$ . This is architecturally allowed.

#### B1.3.4 Litmus test with an interrupt deactivate and an interrupt disable

```
AArch64 coWR-gic+dis-di+rcfg
{
  [INTID(A)]=(enabled:1, active:1);
  0:X1=(intid:A);
  1:X1=(intid:A);
}
P0 | P1 ;
GIC CDDI,X1 | GIC CDRCFG, X1 ;
GIC CDDIS,X1 | ISB ;
  | MRS X3, ICC_ICSR_EL1 ;
exists(1:X3=(active:1,enabled:0))
```

kinds: coWR-gic+di-dis+rcfg Allowed

## B1.3.4.1 Explanation

On P0:

- GIC CDDI, X1 generates an Implicit Interrupt Write Effect to INTID (A)  $E_1$  and an Implicit Interrupt Write Effect to INTID (A)  $E_2$ .
- GIC CDDIS, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$  and an Explicit Interrupt Write Effect to INTID (A)  $E_4$ .

On P1:

• GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_5$ .

In the execution that satisfies the postcondition,  $E_5$  Reads-from  $E_4$  and  $E_4$  is Coherence-before  $E_1$ . This is architecturally allowed.

## B1.4 Reading back interrupt writes on a single PE

## B1.4.1 Notes

The purpose of these tests is to show that writing the configuration of an interrupt or acknowledging an interrupt and reading back the configuration on the same PE guarantees that the written values are observed without the use of explicit synchronization.

### B1.4.2 Litmus test with a configuration update

```
AArch64 coWR-gic+en-rcfg
{
  [INTID(A)]=(enabled:0, affinity:P0);
  0:X1=(intid:A);
}
P0 ;
GIC CDEN, X1 ;
GIC CDRCFG, X1 ;
ISB ;
MRS X3, ICC_ICSR_EL1 ;
exists(0:X3=(affinity:P0,enabled:0))
kinds: coWR-gic+en-rcfg Forbid
```

## B1.4.2.1 Explanation

On P0:

- GIC CDEN, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$ .
- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_2$ .

In the execution that satisfies the postcondition,  $E_2$  Coherence-before  $E_1$ . This violates the architectural requirements of the Coherence-before relation and as a result, this execution is architecturally forbidden.

#### B1.4.3 Litmus test with deactivate

```
AArch64 coWR-gic+di-rcfg
{
  [INTID(A)]=(active:1);
  0:X1=(intid:A);
}
P0 ;
GIC CDDI, X1 ;
GIC CDRCFG, X1 ;
ISB ;
MRS X2, ICC_ICSR_EL1 ;
exists(0:X2=(active:1))
kinds: coWR-gic+di-rcfg Forbid
```

### B1.4.3.1 Explanation

On P0:

- GIC CDDI, X1 generates an Implicit Interrupt Write Effect to INTID (A) E1.
- + GIC CDRCFG, X1 generates an Interrupt Read Effect to INTID (A)  $E_2. \label{eq:constraint}$

In the execution that satisfies the postcondition,  $E_2$  Coherence-before  $E_1$ . This violates the architectural requirements of the Coherence-before relation and as a result, this execution is architecturally forbidden.

### B1.4.4 Litmus test with acknowledgement

```
AArch64 coWR-gic+ia-rcfg
{
 [INTID(A)]=(enabled:1, pending:1, affinity:P0);
 0:X1=(intid:A);
}
ΡO
                            ;
GICR
         X2, CDIA
                            ;
GIC
         CDRCFG, X1
                            ;
TSB
MRS
         X3, ICC_ICSR_EL1
                           ;
exists(0:X2=(valid:1) /\ 0:X3=(pending:1))
kinds: coWR-gic+ia-rcfg Forbid
```

## B1.4.4.1 Explanation

On P0:

- GIC X2, CDIA generates an Implicit Interrupt Write Effect to INTID (A)  $E_1$ .
- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_2$ .

In the execution that satisfies the postcondition,  $E_2$  is Coherence-before  $E_1$ . This violates the architectural requirements of the Coherence-before relation and as a result, this execution is architecturally forbidden.

#### B1.4.5 Litmus test with two configuration updates

```
AArch64 coWWR-gic+aff-en-rcfg
{
 [INTID(A)]=(enabled:0, affinity:P0);
0:X0=(intid:A, affinity:P1);
0:X1=(intid:A);
}
ΡO
GIC CDAFF, X0
                       ;
GIC CDEN, X1
                       ;
GIC CDRCFG, X1
                       ;
ISB
MRS X3, ICC_ICSR_EL1 ;
exists(0:X3=(affinity:P0,enabled:0) \/
       0:X3=(affinity:P1,enabled:0) \/
       0:X3=(affinity:P0,enabled:1))
```

### B1.4.5.1 Explanation

On P0:

- GIC CDAFF, X0 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$ .
- GIC CDEN, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_2$  and an Explicit Interrupt Write Effect to INTID (A)  $E_3$ .

kinds: coWWR-gic+aff-en-rcfg Forbid

• GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A) E4.

In the executions that satisfy the postcondition, any of the following applies:

- $E_4$  is Coherence-before  $E_1$ . This violates the architectural requirements of the Coherence-before relation and as a result, this execution is architecturally forbidden.
- E<sub>2</sub> is Coherence-before E<sub>1</sub> and E4~ Reads-from E<sub>3</sub>. This violates the architectural requirements of the Coherence-before relation and as a result, this execution is architecturally forbidden.

## **B1.5** Reading interrupt configurations and subsequent updates

### B1.5.1 Notes

The purpose of these tests is to show that when reading the configuration of an interrupt and then updating the configuration of that same interrupt, the value read is not affected by the updates.

### B1.5.2 Litmus test with update to priority

```
AArch64 coRW-gic+rcfg-pri
 [INTID(A)] = (priority:0);
 0:X0=(intid:A);
 0:X1=(intid:A, priority:1);
}
 ΡO
                        ;
 GIC CDRCFG, X0
                        ;
 GIC CDPRI, X1
                        :
 TSB
                        ;
 MRS X3, ICC_ICSR_EL1
                        :
exists(0:X3=(priority:1))
kinds: coRW-gic+rcfg-pri Forbid
```

## B1.5.2.1 Explanation

On P0:

- GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_1$ .
- GIC CDPRI, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_2$ .

It is architecturally required the Interrupt Read Effect generated by an GIC system instruction with the RCFG command  $E_1$  does not Read-from the Interrupt Write effect  $E_2$ .

Note that the ISB and MRS X3, ICC\_ICSR\_EL1 sequence can be placed before the GIC CDPRI, X1 instruction without changing the outcome of the test.

#### B1.5.3 Litmus test with deactivate

```
AArch64 coRW-gic+rcfg-di
{
 [INTID(A)] = (active:1);
0:X0=(intid:A);
0:X1=(intid:A);
1
ΡÛ
                        ;
GIC CDRCFG, X0
                        ;
GIC CDDI, X1
                        ;
ISB
MRS X3, ICC_ICSR_EL1
                        :
exists(0:X3=(active:0))
kinds: coRW-gic+rcfg-di Forbid
```

## B1.5.3.1 Explanation

On P0:

- GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_1$ .
- GIC CDDI, X1 generates an Implicit Interrupt Write Effect to INTID (A)  $E_2$ .

It is architecturally required the Interrupt Read Effect generated by an GIC system instruction with the RCFG command  $E_1$  does not Read-from the Interrupt Write effect  $E_2$ .

Note that the ISB and MRS X3, ICC\_ICSR\_EL1 sequence can be placed before the GIC CDDI, X1 instruction without changing the outcome of the test.

### B1.5.4 Litmus test with acknowledge

```
AArch64 coRW-gic+rcfg-ia
{
 [INTID(A)] = (priority:1, pending:1);
0:X0=(intid:A);
}
ΡO
                        ;
GIC CDRCFG, X0
                        ;
GICR X1, CDIA
                        ;
ISB
                        ;
MRS X3, ICC_ICSR_EL1
                        ;
exists(0:X3=(priority:1,pending:0,active:1))
kinds: coRW-gic+rcfg-ia Forbid
```

## B1.5.4.1 Explanation

On P0:

- GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_1$ .
- GICR X1, CDIA generates an Implicit Interrupt Write Effect to INTID (A) E2.

It is architecturally required the Interrupt Read Effect generated by an GIC system instruction with the RCFG command  $E_1$  does not Read-from the Interrupt Write effect  $E_2$ .

Note that the ISB and MRS X3, ICC\_ICSR\_EL1 sequence can be placed before the GICR X1, CDIA instruction without changing the outcome of the test.

## B1.6 Configuration and acknowledgement

#### B1.6.1 Notes

The purpose of this test is to show that disabling an interrupt is only required to be observed by an acknowledge when using explicit synchronization.

Illustrates a common principle of interrupt acknowledgement not being guaranteed to observe a preceding write in program order without either using explicit synchronization or observing the write through an explicit read.

See also:

- B1.11 IPI and acknowledgement
- B1.33 Reading interrupt configuration and exception status

#### B1.6.2 Litmus test using disable without explicit synchronization

```
AArch64 coWR-gic.dis.ack
{
  [INTID(A)]=(enabled:1, pending:1);
  0:X1=(intid:A);
}
P0 ;
GIC CDDIS, X1 ;
GICR X0, CDIA ;
exists(0:X0=(valid:1, intid:A))
kinds: coWR-gic.dis.ack Allow
```

#### B1.6.2.1 Explanation

In the execution that satisfies the postcondition, on PO:

- GIC CDDIS, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$ .
- GICR X0, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_2$ .

In the execution that satisfies the postcondition,  $E_2$  is Coherence-before  $E_1$ . This is permitted by the architecture.

#### B1.6.3 Litmus test using disable with explicit synchronization

```
AArch64 coWR-gic.dis.ack+gsb.sys
{
  [INTID(A)]=(enabled:1, pending:1);
  0:X1=(intid:A);
}
PO ;
GIC CDDIS, X1 ;
GSB SYS ;
GICR X0, CDIA ;
exists(0:X0=(valid:1, intid:A))
kinds: coWR-gic.dis.ack+gsb.sys Forbid
```

#### B1.6.3.1 Explanation

In the execution that satisfies the postcondition, on PO:

• GIC CDDIS, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$ .

- GSB SYS generates a GSB.SYS Effect E<sub>2</sub>.
- GICR X0, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_3$ .

Therefore,  $E_1$  is GSB-Ordered-before  $E_3$ . As per the postcondition,  $E_3$  is Coherence-before  $E_1$ . Consequently, this execution creates a cycle in the Ordered-before relation and as a result, violates the External visibility requirement.

#### B1.6.4 Litmus test with deactivate

```
kinds: coWW-gic+di-ia+rcfg
```

#### B1.6.4.1 Explanation

In the execution that satisfies the postcondition, on PO:

- GIC CDDI, X0 generates an Implicit Interrupt Write Effect to INTID (A)  $E_1$  and an Implicit Interrupt Write Effect to INTID (A)  $E_2$ .
- GICR X1, CDIA generates an Implicit Interrupt Read Effect to INTID (A) E<sub>3</sub> and an Implicit Interrupt Write Effect to INTID (A) E<sub>4</sub>.
- GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A) E5.

In the execution that satisfies the postcondition,  $E_4$  is Coherence-before  $E_2$  and  $E_5$  Reads-from  $E_2$ . This means that  $E_2$  is Coherence-before  $E_3$  and that violates the architectural requirements of the Coherence-before relation. As a result, this execution is architecturally forbidden.

#### B1.6.5 Litmus test using priority without explicit synchronization

```
AArch64 coWR-gic+pcr-isb-pri-ia
ł
 [INTID(A)]=(enabled:1, pending:1, priority:1);
 0:X1=(intid:A, priority:2);
 ΡÛ
 MOV X0, #1
                        ;
 MSR ICC_PCR_EL1, X0
                        ;
 TSB
 GIC CDPRI, X1
                        ;
 GICR X0, CDIA
exists(0:X0=(valid:1, intid:A))
kinds: coWR-gic+pcr-isb-pri-ia Allow
\sim \sim \sim
```

### B1.6.5.1 Explanation

In the execution that satisfies the postcondition, on PO:

- MSR ICC\_PCR\_EL1, X0 generates a Direct System Register Write Effect to ICC\_PCR\_EL1 E1.
- ISB generates a Instruction Fetch Barrier Effect  $E_2$ .
- GIC CDPRI, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_3$ .
- GICR X0, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_4$  and an Indirect System Register Read Effect to ICC\_PCR\_EL1  $E_5$ .

 $E_1$  is IFB-Ordered-before  $E_5$  and, consequently,  $E_5$  Reads-from-register  $E_1$ . This means that GICR X0, CDIA  $\hookrightarrow$  cannot acknowledge any interrupt with priority lower than 1. As per the postcondition, GICR X0, CDIA acknowledges interrupt INTID (A) and since the priority of INTID(A) cannot have been lower than 1,  $E_4$  is Coherence-before  $E_3$ . This is an architecturally allowed execution.

## B1.6.6 Litmus test using priority with explicit synchronization.

```
AArch64 coWR-gic+pcr-isb-pri-gsb.sys-ia
{
  [INTID(A)]=(enabled:1, pending:1, priority:1);
  0:X1=(intid:A, priority:2);
}
PO ;
MOV X0, #1 ;
MSR ICC_PCR_EL1, X0 ;
ISB ;
GIC CDPRI, X1 ;
GSB SYS ;
GICR X0, CDIA ;
exists(0:X0=(valid:1, intid:A))
kinds: coWR-gic+pcr-isb-pri-gsb.sys-ia Forbid
```

## B1.6.6.1 Explanation

In the execution that satisfies the postcondition, on PO:

- MSR ICC\_PCR\_EL1, X0 generates a Direct System Register Write Effect to ICC\_PCR\_EL1 E1.
- ISB generates a Instruction Fetch Barrier Effect E<sub>2</sub>.
- GIC CDPRI, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_3$ .
- GSB SYS generates a GSB.SYS Effect  $E_4$ .
- GICR X0, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_5$  and an Indirect System Register Read Effect to ICC\_PCR\_EL1  $E_6$ .

 $E_1$  is IFB-Ordered-before  $E_6$  and, consequently,  $E_6$  Reads-from-register  $E_1$ . This means that GICR X0, CDIA  $\hookrightarrow$  cannot acknowledge any interrupt with priority lower than 1. As per the postcondition, GICR X0, CDIA acknowledges interrupt INTID (A) and since the priority of INTID(A) cannot have been lower than 1,  $E_5$  is Coherence-before  $E_3$ . At the same time,  $E_3$  is GSB-Ordered-before  $E_5$ . This creates a cycle in the Ordered-before relation which violates the External visibility requirement.

## B1.7 Acknowledge followed by interrupt changes

#### B1.7.1 Notes

The update to an interrupt caused by an interrupt acknowledge is required to be ordered with respect to a deactivate but not with any other configuration update.

### B1.7.2 Litmus test with deactivate

```
AArch64 ack-deactivate
 [INTID(A)] = (enabled:1, affinity:P0, pending:1, active:0);
 0:X0=(intid:A);
}
 ΡO
                            ;
 GICR X1, CDIA
                            ;
 GIC
       CDDI, XO
                            ;
 GIC
       CDRCFG, X0
                            ;
 TSB
                            :
       X2, ICC_ICSR_EL1
 MRS
                            ;
exists (0:X1=(valid:1) / \ 0:X2=(pending:0, active:1))
kinds: ack-deactivate Forbid
```

## B1.7.2.1 Explanation

In the execution that satisfies the postcondition, on PO:

- GICR X1, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_1$ . As per the postcondition, the GICR system instruction acknowledges INTID (A) and, as a result, generates an Implicit Interrupt Write Effect  $E_2$  to INTID (A) that resets its pending state to 0 and sets its active state to 1.
- GIC CDDI, X0 generates an Implicit Interrupt Write Effect to INTID (A)  $E_3$ .
- GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A) E4.

As per the postcondition, the Explicit Interrupt Read Effect  $E_4$  observes that INTID (A) is active, and as a result,  $E_4$  Reads-from  $E_2$ . This means that either:

- $E_4$  is Coherence-before relation  $E_3$  which violates the architectural requirements of the Coherence-before relation, or
- $E_3$  is Coherence-before relation  $E_2$  and concequently  $E_1$  Reads-from  $E_3$  which violates the architectural requirements of the Reads-from relation.

#### B1.7.3 Litmus test with make pending

```
AArch64 edge-merging.ipi
{
 [INTID(A)]=(enabled:1, pending:1, affinity:P0);
 0:X0=(intid:A, pending:1); 0:X1=(intid:A);
}
P0
                            ;
         X2, CDIA
GTCR
                            ;
         CDPEND, X0
GTC
                            ;
         CDRCFG, X1
GTC
                            ;
 ISB
MRS
         X3, ICC_ICSR_EL1
                            ;
exists(0:X2=(valid:1, intid:A) /\
```

```
0:X3=(pending:0, active:1))
```

```
kinds: edge-merging.ipi Forbid
```

## B1.7.3.1 Explanation

On PO:

- GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_1$  and an Implicit Interrupt Write Effect to INTID (A)  $E_2$  that resets the pending state to 0 and sets the active state to 1.
- GIC CDPEND, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$  and an Explicit Interrupt Write Effect to INTID (A)  $E_4$  that sets the pending state to 1.
- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect  $E_5$  to INTID (A).

In the execution that satisfies the postcondition, E<sub>5</sub> Reads-from E<sub>2</sub>, and any of the following applies:

- $E_4$  is Coherence-before  $E_2$ . This violates the requirements of the Coherence-before and, as a result, is architecturally forbidden.
- $E_2$  is Coherence-before  $E_4$  and, consequently,  $E_5$  is Coherence-before  $E_4$ . This violates the requirements of the Coherence-before and, as a result, is architecturally forbidden.

Chapter B1. Interrupt ordering litmus tests B1.8. Multiple updates with interleaved read

## B1.8 Multiple updates with interleaved read

#### B1.8.1 Notes

The purpose of this test is to show that a write, followed by a read, followed by a write to the same interrupt location must result in the read observing the first write and not the second write.

#### B1.8.2 Litmus test

```
AArch64 coWRW-gic
 [INTID(A)] = (priority:0);
0:X0=(intid:A);
0:X1=(intid:A, priority:1);
0:X2=(intid:A, priority:2);
}
ΡO
                        ;
GIC CDPRI, X1
                        ;
GIC CDRCFG, X0
                        ;
GIC CDPRI, X2
                        ;
 TSB
                        ;
MRS X3, ICC_ICSR_EL1
                        ;
exists(0:X3=(priority:2) \/
       0:X3=(priority:0))
kinds: coWRW-gic Forbid
```

### B1.8.2.1 Explanation

On P0:

- The first GIC CDPRI, X1 generates an Explicit Interrupt Write Effect E1.
- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect  $E_2$ .
- The second GIC CDPRI, X2 generates an Explicit Interrupt Write Effect  $E_3$ .

It is architecturally required that:

- The Interrupt Read Effect generated by an GIC system instruction with the RCFG command  $E_2$  is Coherence-after the Interrupt Write effect  $E_1$ .
- The Interrupt Read Effect generated by an GIC system instruction with the RCFG command  $E_1$  does not Read-from the Interrupt Write effect  $E_3$ .

Note that the ISB and MRS X3, ICC\_ICSR\_EL1 sequence can be placed before the second GIC CDPRI, X2 instruction without changing the outcome of the test.

## B1.9 Configuration write and IRQ unmask in PSTATE

#### B1.9.1 Notes

The purpose of these tests is to show the required synchronization of to ensure that after disabling an pending interrupt there cannot be a IRQ exception when possible.

#### B1.9.2 Litmus test

```
AArch64 gic.cddis-gsb.sys-mrs.isr_ell
{
  [INTID(A)]=(enabled:1, pending:1);
  0:X1=(intid:A);
}
  P0 ;
  GIC CDDIS, X1 ;
  GSB SYS ;
  MRS X0, ISR_EL1 ;
  exists(0:X0=(I=1))
```

kinds: gic.cddis-gsb.sys-mrs.isr\_el1 Forbid

### B1.9.2.1 Explanation

For the execution that validates the postcondition:

- GIC CDDIS, X1 generates an Interrupt Write Effect  $E_1$  to Interrupt Location INTID (A).
- GSB SYS generates a GSB.SYS Effect E2.
- MRS X0, ISR\_EL1 generates a Direct System Register Read to ISR\_EL1  $E_3$ .

In the execution that satisfies the postcondition,  $E_3$  indicates that INTID (A) is still the HPPI. However because of  $E_2$  INTID (A) is disabled and cannot be the HPPI. As a result, this execution is architecturally forbidden.

### B1.9.3 Litmus test with initially masked IRQs

```
AArch64 coWex+gic.cddis-gsb.sys-clr.i
{
  [INTID(A)]=(enabled:1, pending:1);
  0:X1=(intid:A);
}
P0 ;
GIC CDDIS, X1 ;
GSB SYS ;
DAIFClr PSTATE.I ;
exists(async(P0, IRQ))
kinds: coWex+gic.cddis-gsb.sys-clr.i Forbid
```

### B1.9.3.1 Explanation

For the execution that validates the postcondition:

- GIC CDDIS, X1 generates an Interrupt Write Effect  $E_1$  to Interrupt Location INTID (A).
- GSB SYS generates a GSB.SYS Effect  $E_2$ .
- DAIFClr PSTATE.I generates a Direct System Register Write to PSTATE  $E_3$ .

In the execution that satisfies the postcondition, INTID(A) has become a pending IRQ. This execution is architectural forbidden as the GSB.SYS is required to have made the  $E_1$  observable before the IRQ was unmasked.

## B1.9.4 Litmus test with disable of a PPI

```
AArch64 ppi-disable-isb-clr.i
{
 0:[ppi(27)]=(enabled:1,pending:1,active:0);
}
 ΡO
 MOV
       X0, #0
                                  ;
 MSR
       ICC_PPI_ENABLER, X0
                                  ;
 ISB
                                  ;
 DAIFClr PSTATE.I
                                  ;
 exists(async(P0, IRQ)) Forbid
```

## B1.9.4.1 Explanation

The ISB guarantees completion of the MSR instructions and the effects of disabling the PPI which can no longer be the HPPI. As a result, this execution is architecturally forbidden.

## B1.10 Configuration write and exception status on a single PE

## B1.10.1 Notes

The purpose of this test is to show that an interrupt exception as a result of enabling a pending interrupt is not required to be observed even when explicit synchronization is used.

### B1.10.2 Litmus test without wait for IRQ exception to be signaled

```
AArch64 coWR+gic.cden-gsb.sys-isb-isr
 [INTID(A)]=(enabled:0, pending:1);
0:X1=(intid:A);
}
ΡO
                        ;
GIC CDEN, X1
                       ;
GSB SYS
                        ;
 ISB
                        ;
MRS X0, ISR_EL1
                        ;
exists(0:X0=(I=0))
kinds: coWR+gic.cden-gsb.sys-isb-isr Allow
```

## B1.10.2.1 Explanation

On P0:

- GIC CDEN, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$ .
- GSB SYS generates a GSB.SYS Effect E2.
- ISB generates a Instruction Fetch Barrier Effect E<sub>3</sub>.
- MRS X0, ISR\_EL1 generates a Direct System Register Read Effect to ISR\_EL1 E4.

 $E_1$  is IFB-Ordered-before  $E_1$ . As a result, INTID (A) is already a candidate HPPI when P0 generates  $E_4$ . However, the architecture does not guarantee that INTID(A) will be presented as the HPPI immediately. And as a result, the execution where reading ISR\_EL1 indicates there is no IRQ pending is architecturally allowed.

### B1.10.3 Litmus test with wait for IRQ exception to be signaled

```
AArch64 coWR+gic.cden-gsb.sys-isb-isr+wait
{
 [INTID(A)]=(enabled:0, pending:1);
 0:X1=(intid:A);
}
 ΡO
                                      ;
      GIC CDEN, X1
                                      ;
           SYS
      GSB
                                      ;
                                      ;
      ISB
 WAIT (MRS X0, ISR_EL1; X0=(I=1))
exists(0:X0=(I=0))
kinds: coWR+gic.cden-gsb.sys-isb-isr+wait Forbid
```

## B1.10.3.1 Explanation

On P0:

- GIC CDEN, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$ .
- GSB SYS generates a GSB.SYS Effect E2.
- ISB generates a Instruction Fetch Barrier Effect E<sub>3</sub>.
- The execution of MRS X0, ISR\_EL1 in a loop generates a Direct System Register Read Effect to ISR\_EL1  $E_4, E_5, \ldots, E_n$ .

 $E_1$  is IFB-Ordered-before  $E_1$ . As a result, INTID(A) is already a candidate HPPI when P0 generates  $E_4$ . The architecture does not guarantee that INTID(A) will be presented as the HPPI immediately. However, in finite time the GIC will presented INTID(A) as the HPPI, as a result,  $E_n$  where n is a finite number reads that the I field of ISR\_EL1 is set to 1 and an IRQ is pending.

## B1.11 IPI and acknowledgement

### B1.11.1 Notes

The purpose of these tests is to show that sending an IPI is only required to be observed by an acknowledge when using explicit synchronization.

Illustrates a common principle of interrupt acknowledgement not being guaranteed to observe a preceding write in program order without either using explicit synchronization or observing the write through an explicit read.

See also:

• B1.6 Configuration and acknowledgement

#### B1.11.2 Litmus test without explicit synchronization

```
AArch64 coWR-gic.ipi.ack
 [INTID(A)]=(enabled:1, pending:1, affinity:P0);
0:X0=(intid:A, pending:1); 0:X1=(intid:A);
}
ΡO
                            ;
         CDPEND, X0
GIC
                            ;
         X2, CDIA
GICR
                            ;
         CDRCFG, X1
GIC
TSB
         X3, ICC_ICSR_EL1
MRS
exists (0:X2=(valid:1) / \ 0:X3=(pending:1, active:1))
kinds: coWR-gic.ipi.ack Allow
```

## B1.11.2.1 Explanation

#### On P0:

- GIC CDPEND, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$  that sets the pending state to 1.
- GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_4$  and an Implicit Interrupt Write Effect to INTID (A)  $E_5$  that resets the pending state to 0 and sets the active state to 1.
- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_6$ .

In the execution that satisfies the postcondition, GICR X2, CDIA acknowledges INTID (A) and consecuently, either:

- $E_6$  Reads-from the initial value of INTID (A) and therefore  $E_6$  is Coherence-before  $E_2$ . This violates architectural requirements of the Coherence-before relation.
- E<sub>6</sub> Reads-from E<sub>2</sub>. This means that either:
  - E<sub>2</sub> is Coherence-before E<sub>5</sub> and E<sub>6</sub> is Coherence-before E<sub>5</sub>. This violates architectural requirements of the Coherence-before relation.
  - E<sub>5</sub> is Coherence-before E<sub>2</sub>. This execution is architecturally allowed.

#### B1.11.3 Litmus test with explicit synchronization

```
AArch64 coWR-gic.ipi.ack+gsb.sys
{
 [INTID(A)]=(enabled:1, pending:1, affinity:P0);
```

```
0:X0=(intid:A, pending:1); 0:X1=(intid:A);
}
ΡO
GIC
         CDPEND, X0
                            ;
GSB
         SYS
         X2, CDIA
GICR
         CDRCFG, X1
GIC
TSB
         X3, ICC_ICSR_EL1
MRS
                            ;
exists (0:X2=(valid:1) / \ 0:X3=(pending:1))
kinds: coWR-gic.ipi.ack+gsb.sys Forbid
```

## B1.11.3.1 Explanation

On PO:

- GIC CDPEND, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$  that sets the pending state to 1.
- GSB SYS generates a GSB.SYS Effect  $E_3$ .
- GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_4$  and an Implicit Interrupt Write Effect to INTID (A)  $E_5$  that resets the pending state to 0 and sets the active state to 1.
- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_6$ .

In the execution that satisfies the postcondition, GICR X2, CDIA acknowledges INTID (A) and consecuently, either:

- $E_6$  Reads-from the initial value of INTID (A) and therefore  $E_6$  is Coherence-before  $E_2$ . This violates architectural requirements of the Coherence-before relation.
- E<sub>6</sub> Reads-from E<sub>2</sub>. This means that either:
  - $E_2$  is Coherence-before  $E_5$  and  $E_6$  is Coherence-before  $E_5$ . This violates architectural requirements of the Coherence-before relation.
  - $E_5$  is Coherence-before  $E_2$  which would mean that  $E_1$  Reads-from  $E_5$  and as a result  $E_5$  is GIC-Observed-by  $E_1$ . At the same time,  $E_1$  is GSB-ordered-before  $E_5$ . This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

## B1.12 Observing multiple writes on a different PE

### B1.12.1 Notes

The purpose of this test is to show that the external observations of updates to the same interrupt location cannot contradict the Coherence order.

### B1.12.2 Litmus test

```
AArch64 coWW-gic+R
 [INTID(A)]=(enabled:0, affinity:P0);
 0:X1=(intid:A, affinity:P1);
 0:X2=(intid:A);
 1:X1=(intid:A);
}
 ΡO
                  | P1
                                          ;
 GIC CDAFF, X1
                  | GIC CDRCFG, X1
                                          :
 GIC CDEN, X2
                  | ISB
                  | MRS X0, ICC_ICSR_EL1 ;
exists(1:X0=(affinity:P0, enabled:1))
kinds: coWW-gic+R Forbid
```

## B1.12.2.1 Explanation

On P0:

- GIC CDAFF, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$ .
- GIC CDEN, X2 generates an Explicit Interrupt Read Effect to INTID (A)  $E_2$  and an Explicit Interrupt Write Effect to INTID (A)  $E_3$ .

#### On P1:

• GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_4$ .

For the execution that satisfies the post-condition,  $E_4$  Reads-from  $E_3$  and  $E_2$  is Coherence-before  $E_1$ . This violates the architectural requirement of the Reads-from relation.

## B1.13 Read of the configuration of an interrupt

### B1.13.1 Notes

The purpose of this section if to demonstrate the ordering properties of the Indirect System Register Write to ICC\_ICSR\_EL1 generated by the execution of a GIC system instruction with the RCFG command.

### B1.13.2 Litmus test without ISB

```
AArch64 gic.rcfg-mrs.icc_icsr_ell
{
  [INTID(A)]=(priority:5);
  0:X0=(intid:A);
}
P0 ;
GIC CDRCFG, X0 ;
MRS X1, ICC_ICSR_EL1 ;
exists(1:X1!=(priority:5))
kinds: gic.rcfg-mrs.icc_icsr_el1 Allow
```

## B1.13.2.1 Explanation

On PO:

- GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect  $E_1$  and an Indirect System Register Write Effect  $E_2$ .
- MRS X1, ICC\_ICSR\_EL1 generates a Direct System Register Read Effect to ICC\_ICSR\_EL1  $E_3$  and a Register Write Effect to X1  $E_4$ .

In the execution that satisfies the postcondition,  $E_1$  Reads-from the initial configuration of INTID(A) and consequently  $E_3$  is Coherence-before  $E_1$ . This is architecturally allowed.

## B1.13.3 Litmus test with ISB

```
AArch64 gic.rcfg-isb-mrs.icc_icsr_el1
{
  [INTID(A)]=(priority:5);
  0:X0=(intid:A);
}
P0 ;
GIC CDRCFG, X0 ;
ISB ;
MRS X1, ICC_ICSR_EL1 ;
exists(1:X1!=(priority:5))
kinds: gic.rcfg-isb-mrs.icc_icsr_el1 Forbid
```

## B1.13.3.1 Explanation

On P0:

- GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect  $E_1$  and an Indirect System Register Write Effect  $E_2$ .
- ISB generates an Instruction Fetch Barrier Effect  $E_2$  which is a Context Synchronization Event.

• MRS X1, ICC\_ICSR\_EL1 generates a Direct System Register Read Effect to ICC\_ICSR\_EL1  $E_3$  and a Register Write Effect to X1  $E_4$ .

In the execution that satisfies the postcondition,  $E_1$  Reads-from the initial configuration of INTID(A) and consequently  $E_3$  is Coherence-before  $E_1$ . This is architecturally forbidden.  $E_3$  is required to Read-from  $E_1$  because  $E_2$  is a Context Synchronization Event.

See also Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture[1] Table D24-1 Synchronization requirements' for more information.

# B1.14 Multiple reads of the same config

# B1.14.1 Notes

The purpose of this test is to show that if a read has observed a write to the same location, a second read must also have observed the same write.

The first litmus test uses an ISB after both GIC CDRCFG, X0 instructions to ensure that the implicit writes to ICC\_ICSR\_EL1 are observed by each MRS instruction after the ISB. The subsequent litmus tests illustrate the impact of omitting one or both ISBs.

# B1.14.2 Litmus test with ISBs

```
AArch64 coRR-gic+cdpri+cfg-isb-cfg-isb
 [INTID(A)] = (priority:0);
 0:X1=(intid:A, priority:1);
 1:X0=(intid:A);
}
 ΡO
               | P1
 GIC CDPRI, X1 | GIC CDRCFG, X0
               | ISB
               | MRS X1, ICC_ICSR_EL1 ;
               | GIC CDRCFG, X0
                                       ;
               | ISB
               | MRS X2, ICC_ICSR_EL1 ;
exists(1:X1=(priority:1) /\ 1:X2=(priority:0))
kinds: coRR-gic+cdpri+cfg-isb-cfg-isb Forbid
```

# B1.14.2.1 Explanation

#### On P0:

• GIC CDPRI, X1 generates an Explicit Interrupt Write Effect  $E_1$ .

On P1:

- The first GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect  $E_2$  and an Indirect System Register Write Effect to ICC\_ICSR\_EL1  $E_3$ .
- The first ISB generates an IFB Effect  $E_4$ .
- MSR C1, ICC\_ICSR\_EL1 generates a Direct System Register Read Effect E~5.
- The second GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect E<sub>6</sub> and an Indirect System Register Write Effect to ICC\_ICSR\_EL1 E<sub>7</sub>.
- The second ISB generates an IFB Effect  $E_8$ .
- MSR C1, ICC\_ICSR\_EL1 generates a Direct System Register Read Effect E~9.
- The first GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect  $E_{10}$  and an Indirect Write to System Register ICC\_ICSR\_EL1  $E_{11}$ .

In the execution that satisfies the postcondition,  $E_2$  Reads-from  $E_1$  and as a result  $E_2$ ,  $E_1$  is Observer-by  $E_2$  and one of the following applies:

 $E_3$  is Coherence-before  $E_1$  and as a result,  $E_2$  is GIC-Hazard-Ordered-before  $E_1$ . This creates a cycle in the Ordered-before relation which violates the External visibility requirement.

Chapter B1. Interrupt ordering litmus tests B1.15. GIC coherence order

# B1.15 GIC coherence order

### B1.15.1 Notes

The purpose of this test is to show that due to the total order on writes to an interrupt location, two reads of the same location by two separate observers must observe the same order on the writes.

#### B1.15.2 Litmus test

```
AArch64 IRIW-loc+gic.cdpri
 [INTID(A)] = (priority:0);
0:X1=(intid:A, priority:1);
1:X1=(intid:A, priority:2);
2:X0=(intid:A);
3:X0=(intid:A);
}
ΡO
               | P1
                                                       | P3
                               1 P2
GIC CDPRI, X1 | GIC CDPRI, X1 | GIC CDRCFG, X0
                                                       | GIC CDRCFG, X0
                                                                               :
                               | ISB
                                                       | ISB
                               | MRS X1, ICC_ICSR_EL1 | MRS X1, ICC_ICSR_EL1
                               | GIC CDRCFG, X0
                                                       | GIC CDRCFG, X0
                                | ISB
                                                       I TSB
                                | MRS X2, ICC_ICSR_EL1 | MRS X2, ICC_ICSR_EL1 ;
exists((2:X1=(priority:1) /\ 2:X2=(priority:2) /\
        3:X1=(priority:2) /\ 3:X2=(priority:1))
```

```
kinds: IRIW-loc+gic.cdpri Forbid
```

# B1.15.2.1 Explanation

In the execution that satisfies the postcondition:

- On P0, GIC CDPRI, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$  that sets its priority to 1.
- On P1, GIC CDPRI, X1 generates an Explicit Interrupt Write Effect to INTID (A) E<sub>2</sub> that sets its priority to 2.
- On P2:
  - The first GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$  that reads the priority as 1.
  - The second GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_4$  that reads the priority as 2.
- On P3:
  - The first GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_5$  that reads the priority as 2.
  - The second GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_6$  that reads the priority as 1.

Any of the following applies:

•  $E_1$  is Coherence-before  $E_2$ . In which case  $E_6$  is Coherence-before  $E_2$  and consecuently  $E_5$  is GIC-hazard-ordered-before  $E_2$ . At the same time,  $E_5$  [Reads-from](#def:cpuif:ordering\_model:rf]  $E_2$  and as a result  $E_2$  is [GIC-observed-by](#def:cpuif:ordering\_model:GIC-obs]  $E_5$ . This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

# Chapter B1. Interrupt ordering litmus tests B1.15. GIC coherence order

•  $E_2$  is Coherence-before  $E_1$ . In which case  $E_4$  is Coherence-before  $E_1$  and consecuently  $E_3$  is GIC-hazard-ordered-before  $E_1$ . At the same time,  $E_3$  [Reads-from](#def:cpuif:ordering\_model:rf]  $E_1$  and as a result  $E_1$  is [GIC-observed-by](#def:cpuif:ordering\_model:GIC-obs]  $E_3$ . This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

# B1.16 Independent reads of independent writes

## B1.16.1 Notes

The purpose of this test is to show that writes which can be observed by any observer must be observable by all observers.

In other words, the test shows that the interrupt ordering model has other multicopy atomicity.

### B1.16.2 Litmus test

```
AArch64 IRIW-2loc+gic.cdpri
{
 [INTID(A)] = (priority:0);
 [INTID(B)] = (priority:0);
0:X1=(intid:A, priority:1);
1:X1=(intid:B, priority:1);
2:X0=(intid:A); 2:X1=(intid:B);
3:X0=(intid:A); 3:X1=(intid:B);
}
               | P1
ΡÛ
                               | P2
                                                       | P.3
GIC CDPRI, X1 | GIC CDPRI, X1 | GIC CDRCFG, X0
                                                       | GIC CDRCFG, X1
                                                       | ISB
                               | ISB
               | MRS X2, ICC_ICSR_EL1 | MRS X2, ICC_ICSR_EL1 ;
               | GSB SYS
                                                       | GSB SYS
               ;
                               | GIC CDRCFG, X1
                                                       | GIC CDRCFG, X0
                                                                               ;
                                | ISB
                                                       | ISB
                                | MRS X3, ICC_ICSR_EL1 | MRS X3, ICC_ICSR_EL1 ;
exists(2:X2=(priority:1) /\ 2:X3=(priority:0) /\
        3:X2=(priority:1) /\ 3:X3=(priority:0))
```

kinds: IRIW-2loc+gic.cdpri Forbid

# B1.16.2.1 Explanation

In the execution that satisfies the postcondition:

- On P0, GIC CDPRI, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$ .
- On P1, GIC CDPRI, X1 generates an Explicit Interrupt Write Effect to INTID (B)  $E_2$ .
- On P2:
  - GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$ .
  - GSB SYS generates a GSB SYS Effect E4.
  - GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (B) E5.
- On P3:
  - GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (B)  $E_6$ .
  - GSB SYS generates a GSB SYS Effect E7.
  - GIC CDRCFG, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_8$ .

 $E_1$  is GIC-observed-by  $E_3$  as  $E_3$  Reads-from  $E_1$ .  $E_3$  is GSB-ordered-before  $E_5$ .  $E_5$  is GIC-observed-by  $E_2$  as  $E_5$  is Coherence-before  $E_2$ .  $E_2$  is GIC-observed-by  $E_6$  as  $E_6$  Reads-from  $E_2$ .  $E_6$  is GSB-ordered-before  $E_8$ .  $E_8$  is GIC-observed-by  $E_1$  as  $E_8$  is Coherence-before  $E_1$ . As a result, this execution creates a cycle in the Ordered-before relation and violates the External visibility requirement.

# B1.17 Message passing via flag in memory

# B1.17.1 Notes

The purpose of this test is to show the required barrier use when using a flag in memory to inform a different PE that an interrupt configuration has been updated.

# B1.17.2 Litmus test

```
AArch64 MP+gsb.sys+dsb.ld
[INTID(A)] = (affinity:P0);
0:X1=x;
0:X2=(intid:A, affinity:P1);
0:X3=(intid:A);
1:X1=x;
1:X2=(intid:A);
}
ΡO
                 | P1
GIC CDAFF, X2 | LDR X0, [X1]
GSB
     SYS
                | DSB
                       T,D
MOV X0, #1
                 | GIC
                       CDRCFG, X2
STR X0, [X1]
                 | ISB
                 | MRS X3, ICC_ICSR_EL1 ;
exists(1:X0=1 /\ 1:X3=(affinity:P0))
```

```
kinds: MP+gsb.sys+dsb.ld Forbid
```

# B1.17.2.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - GIC CDAFF, X2 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$  that sets its affinity to P1.
  - GSB SYS generates a GSB SYS Effect E2.
  - STR X0, [X1] generates an Explicit Write Memory Effect to  $\ge E_3.$
- On P1:
  - LDR X0, [X1] generates an Explicit Memory Read Effect to  $\times E_4$ .
  - DSB LD generates a DSB LD Effect  $E_5.$
  - GIC RCFG, X2 generates an Explicit Interrupt Effect E<sub>6</sub>.

In this execution:

- $E_4$  Reads-from-memory  $E_3$  and as a result  $E_3$  is Explicit-observed-by  $E_4$ .
- E<sub>4</sub> is DSB-ordered-before E<sub>6</sub>.
- E<sub>6</sub> is Coherence-before E<sub>1</sub>.
- E<sub>1</sub> is GSB-ordered-before E<sub>4</sub>.

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

# B1.18 Message passing via interrupt priority configuration

## B1.18.1 Notes

The purpose of this test is to show that writes to an interrupt configuration can be ordered with respect to an update of the interrupt Pending state such that observing the interrupt as Pending guarantees that the writes to the interrupt configuration are observed.

## B1.18.2 Litmus test

```
AArch64 MP-pri+gsb.sys+ack
 [INTID(A)]=(enabled:1, affinity:P1, priority:1, pending:0);
 [PTE(x)]=(oa:PA(x),attrs:(device-nGRE)); // PERIP
 0:X1=x;
 0:X2=(intid:A, priority:5);
 1:X1=(intid:A);
}
 ΡÛ
                 | P1
 GIC CDPRI, X2 | GICR X0, CDIA
                                          ;
 GSB SYS
                 | GIC CDRCFG, X1
                                          :
 STR X0, [X1]
                 | ISB
                 | MRS X1, ICC_ICSR_EL1 ;
exists(1:X0=(valid:1, intid:A) /\
       1:X1=(enabled:1, affinity:P1, priority:1, active:1))
```

```
kinds: MP-pri+gsb.sys+ack Forbid
```

# B1.18.2.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - GIC CDPRI, X2 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$  that sets its priority to 5.
  - GSB SYS generates a GSB SYS Effect  $E_2$ .
  - STR X0, [X1] generates an Explicit Write Memory Effect to x. When the Explicit Write Effect to Location x reaches its endpoint, the Peripheral device signals an interrupt event to the IRI which generates an Interrupt Read Effect  $E_3$  to INTID (A) and an Interrupt Write Effect to INTID (A)  $E_4$  which sets the pending state to 1.
- On P1:
  - GICR X0, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_5$  and an Implicit Interrupt Write Effect to INTID (A)  $E_6$  that resets the pending state to 0 and sets the active state to 1.
  - GIC CDRCFG, X2 generates an Explicit Interrupt Read Effect  $E_7$ .

#### In this execution:

- +  $E_7$  Reads-from  $E_6$  and as a result  $E_6$  and  $E_5$  are Coherence-before  $E_1$ .
- E<sub>1</sub> is GSB-ordered-before E<sub>4</sub>.
- $E_5$  Reads-from  $E_4$  and as a result,  $E_4$  is GIC-observed-by  $E_5$

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

# B1.19 Message passing with an LPI and a device read

## B1.19.1 Notes

The purpose of this test is to show that if a write to a peripheral has the side effect of making an interrupt pending, then observing that pending state on a different PE means that the write to the peripheral can also be observed.

## B1.19.2 Litmus test

```
AArch64 MP-fLPI+imp+gsb.ack
 [INTID(A)] = (enabled:1, affinity:P1, priority:1, pending:0);
 [PTE(x)]=(oa:PA(x),attrs:(device-nGRE)); // PERIP
0:X3=x;
1:X1=x;
}
ΡO
                 | P1
                                    ;
MOV W2, #1
                 | GICR X0, CDIA
                                    ;
STR W2, [X3]
                 | GSB ACK
                                    ;
                 | LDR W2, [X1]
                                    :
exists(1:X0=(valid:1, intid:A) /\ 1:X2=0);
kinds: MP-fLPI+imp+gsb.ack Forbid
```

# B1.19.2.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - STR W2, [X3] generates an Explicit Write Memory Effect to  $x E_1$ . When the Explicit Write Effect to Location x reaches its endpoint, the Peripheral device signals an interrupt event to the IRI which generates Interrupt Read Effect  $E_2$  to INTID (A) and an Interrupt Write Effect to INTID (A)  $E_3$  which sets the pending state to 1.
- On P1:
  - GICR X0, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_4$  and an Implicit Interrupt Write Effect to INTID (A)  $E_5$  that resets the pending state to 0 and sets the active state to 1.
  - GSB SYS generates a GSB SYS Effect E<sub>6</sub>.
  - LDR W2, [X1] generates an Explicit Memory Read Effect E<sub>7</sub>.

In this execution:

- $E_4$  Reads-from  $E_3$  and as a result  $E_3$  is GIC-observed-by  $E_4$
- E<sub>4</sub> is GSB-ordered-before E<sub>7</sub>.
- $E_7$  is Coherence-before  $E_1$  and as a result  $E_7$  is Explicit-observed-by  $E_1$ .
- E<sub>1</sub> is Ordered-before E<sub>3</sub>.

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

#### B1.19.3 Litmus test with address dependency

The GSB ACK can be omitted in favor of creating an address dependency on the result of the acknowledge.

This may provide performance benefits in some cases, however, an address dependency cannot always be used a replacement for the GSB ACK. For example, a store following LDR X2, [X1, X5] without any dependency on previous instructions can be re-ordered before the GICR X0, CDIA and the effects of the store can be observed before the effects of the GICR X0, CDIA on another PE.

```
AArch64 MP-fLPI+imp+addrpt
{
 [INTID(A)] = (enabled:1, affinity:P1, priority:1, pending:0);
 [PTE(x)]=(oa:PA(x),attrs:(device-nGRE)); // PERIP
 0:X1=x;
 1:X1=x;
 ΡO
                 I P1
                                      ;
 MOV W2, #1
                 | GICR X0, CDIA
                                      ;
 STR W2, [X1]
                 | EOR X5, X0, X0
                                      ;
                 | LDR W2, [X1, X5] ;
exists(1:X0=(valid:1, intid:A) /\ 1:X2=0);
kinds: MP-fLPI+imp+addrpt Forbid
```

# B1.19.3.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - STR W2, [X1] generates an Explicit Write Memory Effect to  $x E_1$ . When the Explicit Write Effect to Location x reaches its endpoint, the Peripheral device signals an interrupt event to the IRI which generates an Interrupt Read Effect  $E_2$  to INTID (A) and an Interrupt Write Effect to INTID (A)  $E_3$  which sets the pending state to 1.
- On P1:
  - GICR X0, CDIA generates an Implicit Interrupt Read Effect to INTID (A) E<sub>4</sub> and an Implicit Interrupt Write Effect to INTID (A) E<sub>5</sub> that resets the pending state to 0 and sets the active state to 1.
  - LDR W2, [X1, X5] generates an Explicit Memory Read Effect E7.

In this execution:

- +  $E_4$  Reads-from  $E_3$  and as a result  $E_3$  is GIC-observed-by  $E_4$
- There is an address dependency from  $E_4$  to  $E_7$  and, as a result,  $E_4$  is Dependency-ordered-before  $E_7$ .
- $E_7$  is Coherence-before  $E_1$  and as a result  $E_7$  is Explicit-observed-by  $E_1$ .
- E<sub>1</sub> is Ordered-before E<sub>3</sub>.

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

# B1.20 Message passing with an LPI and a GSB

### B1.20.1 Notes

The purpose of this test is to show that when a write to memory is ordered before a write which has the side effect of making an interrupt pending, then observing the interrupt being pending through acknowledgment on a different PE guarantees that the write is also observed.

If the peripheral generating an interrupt exists in the shared address space of P0 and P1, a the DSB ST on P0 can be relaxed to a DMB ST, but because the test makes no such assumptions, we must use a DSB ST.

# B1.20.2 Litmus test

```
AArch64 MP-fSPI+dsb.st+gsb.ack
 [INTID(A)]=(enabled:1, affinity:P1, priority:1, pending:0);
 [PTE(y)]=(oa:PA(y),attrs:(device-nGRE)); // PERIP
0:X1=x; 0:X3=y;
1:X1=x;
}
ΡO
                  | P1
                                     ;
MOV W0, #1
                  | GICR X0, CDIA
                                     ;
STR WO, [X1]
                  | GSB ACK
DSB ST
                  | LDR X2, [X1]
MOV W2, #1
                  STR W2, [X3]
                  exists(1:X0=(valid:1, intid:A) /\ 1:X2=0);
kinds: MP-fSPI+dsb.st+gsb.ack Forbid
```

# B1.20.2.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - STR W0, [X1] generates an Explicit Memory Write Effect to INTID (A)  $E_1$ .
  - DSB ST generates a DSB ST Effect E2.
  - STR W2, [X3] generates an Explicit Write Memory Effect to x. When the Explicit Write Effect to Location x reaches its endpoint, the Peripheral device signals an interrupt event to the IRI which generates an Interrupt Read Effect  $E_3$  to INTID (A) and an Interrupt Write Effect to INTID (A)  $E_4$  which sets the pending state to 1.
- On P1:
  - GICR X0, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_5$  and an Implicit Interrupt Write Effect to INTID (A)  $E_6$  that resets the pending state to 0 and sets the active state to 1.
  - GSB ACK generates a GSB ACK Effect E7.
  - LDR X2, [X1] generates an Explicit Memory Read Effect E<sub>8</sub>.

In this execution:

- $E_5$  Reads-from  $E_4$  and, as a result,  $E_4$  is GIC-observed-by  $E_5$ .
- E<sub>5</sub> is GSB-ordered-before E<sub>8</sub>.
- $E_8$  is Coherence-before  $E_1$  and, as a result,  $E_8$  is Explicit-observed-by  $E_1$ .

#### Chapter B1. Interrupt ordering litmus tests B1.20. Message passing with an LPI and a GSB

• E<sub>1</sub> is DSB-ordered-before E<sub>4</sub>.

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

# B1.21 Message passing with an IPI and a GSB

### B1.21.1 Notes

The purpose of this test is to show that a write to memory ordered before sending an IPI guarantees that the memory write is observed when the IPI is observed on another PE.

This is illustrating a commonly used pattern for cross-CPU communication by software.

# B1.21.2 Litmus test

```
AArch64 MP-fIPI+dsb.st+gsb.ack
[INTID(A)]=(enabled:1, pending:0, affinity:P1);
0:X1=x; 0:X2=(intid:A, pending:1);
1:X1=x;
}
ΡO
                 | P1
                                    ;
MOV W0, #1
               | GICR X0, CDIA
STR WO, [X1]
                | GSB ACK
                 | LDR W2, [X1]
DSB ST
                                    ;
GIC CDPEND, X2 |
                                    :
exists(1:X0=(valid:1, intid:A) /\ 1:X2=0)
kinds: MP-fIPI+dsb.st+gsb.ack Forbid
```

# B1.21.2.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - STR W0, [X1] generates an Explicit Memory Write Effect to INTID (A) E1.
  - DSB ST generates a DSB ST Effect E<sub>2</sub>.
  - GIC CDPEND, X2 generates an Explicit Interrupt Read Effect  $E_3$  to INTID (A) and an Explicit Interrupt Write Effect to INTID (A)  $E_4$  which sets the pending state to 1.
- On P1:
  - GICR X0, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_5$  and an Implicit Interrupt Write Effect to INTID (A)  $E_6$  that resets the pending state to 0 and sets the active state to 1.
  - GSB ACK generates a GSB ACK Effect E7.
  - LDR X2, [X1] generates an Explicit Memory Read Effect E<sub>8</sub>.

In this execution:

- +  $E_5$  Reads-from  $E_4$  and, as a result,  $E_4$  is GIC-observed-by  $E_5$ .
- $E_5$  is GSB-ordered-before  $E_8$ .
- $E_8$  is Coherence-before  $E_1$  and, as a result,  $E_8$  is Explicit-observed-by  $E_1$ .
- E<sub>1</sub> is DSB-ordered-before E<sub>4</sub>.

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

# B1.22 Message passing using deactivate

### B1.22.1 Notes

The purpose of these tests is to show that without explicit synchronization, or a combination of explicit synchronization and an address dependency, there is no ordering between writing to memory and deactivating an interrupt, or between reading interrupt configuration and reading from memory.

This test illustrates part of a real-world example in the following way. P0 illustrates the end of an interrupt handler sequence, which performs memory accesses as part of the handler logic and then finishes the handler by deactivating the interrupt. P1 reads the interrupt configuration and state and determines that the interrupt is no longer actively being handled, and therefore P1 expects to observe all memory accesses performed as part of the handler on P0.

# B1.22.2 Litmus test with explicit synchronization

```
AArch64 MP-fDI+W-dsb-W+R-gsb-R
{
 [INTID(A)] = (active:1);
 0:X0=x; 0:X1=(intid:A);
 1:X0=x; 1:X1=(intid:A);
 ΡÛ
                       | P1
                                                 ;
         X3, #1
 MOV
                       | GIC CDRCFG, X1
                                                 :
 STR
         X3, [X0]
                       | ISB
                                                 ;
 DSB
         ST
                       | MRS X2, ICC_ICSR_EL1
                                                 ;
 GTC
         CDDI, X1
                       | GSB SYS
                                                 ;
                        | LDR X3, [X0]
exists(1:X2=(active:0) /\ 1:X3=0)
kinds: MP-fDI+W-dsb-W+R-gsb-R Forbid
```

# B1.22.2.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - STR X3, [X0] generates an Explicit Memory Write Effect to INTID (A)  $E_1$ .
  - DSB ST generates a DSB ST Effect E<sub>2</sub>.
  - GIC CDDI, X1 generates an Implict Interrupt Read Effect  $E_3$  to INTID (A) and an Implicit Interrupt Write Effect to INTID (A)  $E_4$  which resets the active state to 0.
- On P1:
  - GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_5$ .
  - GSB SYS generates a GSB ACK Effect E<sub>6</sub>.
  - LDR X3, [X0] generates an Explicit Memory Read Effect E<sub>7</sub>.

In this execution:

- $E_5$  Reads-from  $E_4$  and, as a result,  $E_4$  is GIC-observed-by  $E_5$ .
- E<sub>5</sub> is GSB-ordered-before E<sub>7</sub>.
- $E_7$  is Coherence-before  $E_1$  and, as a result,  $E_7$  is Explicit-observed-by  $E_1$ .
- E<sub>1</sub> is DSB-ordered-before E<sub>4</sub>.

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

;

;

;

;

## B1.22.3 Litmus test with address dependency

```
AArch64 MP-fDI+W-dsb-W+R-addrpt-R
 [INTID(A)] = (active:1);
0:X0=x; 0:X1=(intid:A);
1:X0=x; 1:X1=(intid:A);
}
ΡO
                      | P1
         X3, #1
MOV
                      | GIC CDRCFG, X1
         X3, [X0]
STR
                      | ISB
DSB
         ST
                      | MRS X2, ICC_ICSR_EL1
         CDDI, X1
                      | EOR X5, X2, X2
GTC
                       | LDR X3, [X0, X5]
exists(1:X2=(active:0) /\ 1:X3=0)
```

kinds: MP-fDI+W-dsb-W+R-addrpt-R Forbid

# B1.22.3.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - STR X3, [X0] generates an Explicit Memory Write Effect to INTID (A)  $E_1$ .
  - DSB ST generates a DSB ST Effect E<sub>2</sub>.
  - GIC CDDI, X1 generates an Implict Interrupt Read Effect  $E_3$  to INTID (A) and an Implicit Interrupt Write Effect to INTID (A)  $E_4$  which resets the active state to 0.
- On P1:
  - GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_5$ .
  - LDR X3, [X0, X5] generates an Explicit Memory Read Effect E7.

In this execution:

- E<sub>5</sub> Reads-from E<sub>4</sub> and, as a result, E<sub>4</sub> is GIC-observed-by E<sub>5</sub>.
- There is an address dependency from  $E_5$  to  $E_7$  and, as a result,  $E_5$  is Dependency-ordered-before  $E_7$ .
- $E_7$  is Coherence-before  $E_1$  and, as a result,  $E_7$  is Explicit-observed-by  $E_1$ .
- E<sub>1</sub> is DSB-ordered-before E<sub>4</sub>.

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

;

#### B1.22.4 Litmus test with control dependency

```
STR
        X3, [X0]
                       | ISB
                       | MRS X2, ICC_ICSR_EL1
DSB
        ST
                                                  :
GIC
        CDDI, X1
                       | TST X2, X5
                       | B.NE LO
                                                  ;
                       | ISB
                                                   ;
                       | LDR X3, [X0]
                                                   ;
                       | L0:
                                                   ;
                       | NOP
                                                   ;
```

```
exists(1:X2=(active:0) /\ 1:X3=0)
```

```
kinds: MP-fDI+W-dsb-W+R-ctrlisb-R Forbid
```

# B1.22.4.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - STR X3, [X0] generates an Explicit Memory Write Effect to INTID (A) E1.
  - DSB ST generates a DSB ST Effect E<sub>2</sub>.
  - GIC CDDI, X1 generates an Implict Interrupt Read Effect  $E_3$  to INTID (A) and an Implicit Interrupt Write Effect to INTID (A)  $E_4$  which resets the active state to 0.
- On P1:
  - GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A) E5.
  - ISB (the second instance) generates an Instruction Fetch Barrier Effect  $E_6$ .
  - LDR X3, [X0] generates an Explicit Memory Read Effect E7.

In this execution:

- E<sub>5</sub> Reads-from E<sub>4</sub> and, as a result, E<sub>4</sub> is GIC-observed-by E<sub>5</sub>.
- There is a control dependency from  $E_5$  to  $E_6$  and as a result, because  $E_6$  is an Instruction Fetch Barrier Effect,  $E_5$  is IFB-ordered-before  $E_7$ .
- $E_7$  is Coherence-before  $E_1$  and, as a result,  $E_7$  is Explicit-observed-by  $E_1$ .
- E<sub>1</sub> is DSB-ordered-before E<sub>4</sub>.

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

#### B1.22.5 Litmus test without explicit synchronization

```
AArch64 MP-fDI+RR
{
 [INTID(A)] = (active:1);
0:X0=x; 0:X1=(intid:A);
1:X0=x; 1:X1=(intid:A);
}
ΡO
                       | P1
                                                ;
MOV
         X3, #1
                       | GIC CDRCFG, X1
                                                ;
         X3, [X0]
 STR
                       | ISB
                                                ;
         CDDI, X1
                       | MRS X2, ICC_ICSR_EL1 ;
 GIC
                        | LDR X3, [X0]
exists(1:X2=(active:0) /\ 1:X3=0)
```

kinds: MP-fDI+RR Allow

#### B1.22.5.1 Explanation

In the execution that satisfies the postcondition:

• On P0:

- STR X3, [X0] generates an Explicit Memory Write Effect to INTID (A) E1.
- GIC CDDI, X1 generates an Implict Interrupt Read Effect  $E_3$  to INTID (A) and an Implicit Interrupt Write Effect to INTID (A)  $E_4$  which resets the active state to 0.
- On P1:
  - GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A) E5.
  - LDR X3, [X0] generates an Explicit Memory Read Effect E<sub>7</sub>.

In this execution:

- E<sub>5</sub> Reads-from E<sub>4</sub> and, as a result, E<sub>4</sub> is GIC-observed-by E<sub>5</sub>.
- $E_7$  is Coherence-before  $E_1$  and, as a result,  $E_7$  is Explicit-observed-by  $E_1$ .

This means that there is no cycle in the Ordered-before relation and, as a result, this execution satisfies the External visibility requirement. This execution is architecturally allowed.

#### B1.22.6 Litmus test with a DSB but without a GSB

```
AArch64 MP-fDI+W-dsb-W+RR
 [INTID(A)] = (active:1);
 0:X0=x; 0:X1=(intid:A);
1:X0=x; 1:X1=(intid:A);
1
ΡÛ
                       | P1
         X3, #1
                       | GIC CDRCFG, X1
MOV
                                                ;
         X3, [X0]
STR
                       | ISB
DSB
         ST
                       | MRS X2, ICC_ICSR_EL1
                                               ;
GTC
         CDDI, X1
                        | LDR X3, [X0]
                                                ;
exists(1:X2=(active:0) /\ 1:X3=0)
```

kinds: MP-fDI+W-dsb-W+RR Allow

#### B1.22.6.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - STR X3, [X0] generates an Explicit Memory Write Effect to INTID (A)  $E_1$ .
  - DSB ST generates a DSB ST Effect  $E_2$ .
  - GIC CDDI, X1 generates an Implict Interrupt Read Effect E<sub>3</sub> to INTID (A) and an Implicit Interrupt Write Effect to INTID (A) E<sub>4</sub> which resets the active state to 0.
- On P1:
  - GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A) E5.
  - LDR X3, [X0] generates an Explicit Memory Read Effect E7.

In this execution:

- $E_5$  Reads-from  $E_4$  and, as a result,  $E_4$  is GIC-observed-by  $E_5$ .
- $E_7$  is Coherence-before  $E_1$  and, as a result,  $E_7$  is Explicit-observed-by  $E_1$ .
- E<sub>1</sub> is DSB-ordered-before E<sub>4</sub>.

This means that there is no cycle in the Ordered-before relation and, as a result, this execution satisfies the External visibility requirement. This execution is architecturally allowed.

# B1.22.7 Litmus test without a DSB but with a GSB

```
AArch64 MP-fDI+WW+R-gsb-R
 [INTID(A)] = (active:1);
0:X0=x; 0:X1=(intid:A);
1:X0=x; 1:X1=(intid:A);
1
ΡO
                       | P1
MOV
         X3, #1
                       | GIC CDRCFG, X1
 STR
         X3, [X0]
                       | ISB
GTC
         CDDI, X1
                       | MRS X2, ICC_ICSR_EL1 ;
                       | GSB SYS
                                                ;
                       | LDR X3, [X0]
                                                ;
exists(1:X2=(active:0) /\ 1:X3=0)
```

```
kinds: MP-fDI+WW+R-gsb-R Allow
```

# B1.22.7.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - STR X3, [X0] generates an Explicit Memory Write Effect to INTID (A) E1.
  - GIC CDDI, X1 generates an Implict Interrupt Read Effect  $E_3$  to INTID (A) and an Implicit Interrupt Write Effect to INTID (A)  $E_4$  which resets the active state to 0.
- On P1:
  - GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A) E5.
  - GSB SYS generates a GSB SYS Effect E<sub>6</sub>.
  - LDR X3, [X0] generates an Explicit Memory Read Effect E<sub>7</sub>.

In this execution:

- $E_5$  Reads-from  $E_4$  and, as a result,  $E_4$  is GIC-observed-by  $E_5$ .
- E<sub>5</sub> is GSB-ordered-before E<sub>7</sub>.
- $E_7$  is Coherence-before  $E_1$  and, as a result,  $E_7$  is Explicit-observed-by  $E_1$ .

This means that there is no cycle in the Ordered-before relation and, as a result, this execution satisfies the External visibility requirement. This execution is architecturally allowed.

# B1.23 IPI edge merging and message passing

### B1.23.1 Notes

The purpose of this test is to show that it is possible to inform a different PE that a GIC operation has completed by using a GSB SYS and a flag.

## B1.23.2 Litmus test

```
AArch64 edge-merging.ipi.MP
 [INTID(A)]=(enabled:1, pending:1, affinity:P1);
 0:X0=(intid:A, pending:1);
 0:X1=x;
 1:X1=x;
 1:X3=(intid:A);
}
 ΡO
                        | P1
                                                  ;
 GIC
         CDPEND, X0
                        | LDR W0, [X1]
                                                   ;
                        | DSB
 GSB
         SYS
                               ΤD
                                                   :
 MOV
         X2, #1
                        | GICR X2, CDIA
                                                  ;
 STR
         W2, [X1]
                         | GIC CDRCFG, X3
                         | ISB
                         | MRS X4, ICC_ICSR_EL1
exists(1:X0=1 /\ 1:X2=(valid:1, intid:A) /\
       1:X4=(pending:1, active:1, affinity:P1))
```

```
kinds: edge-merging.ipi.MP Forbid
```

# B1.23.2.1 Explanation

In the execution that satisfies the postcondition:

- On P0:
  - GIC CDPEND, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$  that sets the pending state to 1.
  - GSB SYS generates a GSB ACK Effect  $E_3$ .
  - STR W2, [X1] generates an Explicit Memory Write Effect E<sub>4</sub>.
- On P1:
  - LDR W0, [X1] generates an Explicit Memory Read Effect to INTID (A)  $E_5$ .
  - DSB LD generates a DSB LD Effect  $E_6$ .
  - GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_7$  and an Implicit Interrupt Write Effect to INTID (A)  $E_8$  that resets the pending state to 0 and sets the active state to 1.
  - GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect E9 to INTID (A).

In the execution that satisfies the postcondition:

- E<sub>9</sub> Reads-from E<sub>2</sub> and, as a result, E<sub>7</sub> is Coherence-before E<sub>2</sub> and E<sub>7</sub> is GIC-observed-by E<sub>2</sub>.
- E<sub>2</sub> GSB-ordered-before E<sub>4</sub>
- E<sub>5</sub> Reads-from-memory E<sub>4</sub> and, as a result, E<sub>4</sub> is Explicit-observed-by E<sub>5</sub>.
- E<sub>5</sub> is DSB-ordered-before E<sub>7</sub>.

#### Chapter B1. Interrupt ordering litmus tests B1.23. IPI edge merging and message passing

This creates a cycle in the Ordered-before relation and, as a result, the execution violates the External visibility requirement.

# B1.24 Device edge merging with GSB ACK

## B1.24.1 Notes

The purpose of this test is to show that two separate instances of an LPI being Pending are not allowed to be merged across an acknowledgement.

The LPI is initially Pending, it is then successfully acknowledged by GICR X1, CDIA which writes Pending = 0.

The STR has an implicit effect of writing Pending = 1, which happens in finite time, and the GIC will forward the Pending interrupt in finite time so that the second GICR X2, CDIA will return valid == 1 if not merged with the first instance.

Note that this test does not depend on the interrupt becoming Pending or being forwarded to the PE as a direct result of the write to the peripheral. The test relies solely on the finite time guarantees which are covered by the WAIT construct.

See also:

• B1.1 Interrupt litmus test assumptions

### B1.24.2 Litmus test

```
AArch64 edge-merging.LPI+gsb.ack
{
 [INTID(A)] = (enabled:1, pending:1, affinity:P0);
 [PTE(x)]=(oa:PA(x),attrs:(device-nGnRnE)); // PERIP
0:X0=x;
}
ΡO
      GICR X1, CDIA
                                     ;
      GSB
            ACK
                                     ;
      MOV
            X3, #1
                                     ;
      STR
            X3, [X0]
                                     ; trigger intid A via device
      GIC
            CDDI, X1
WAIT(GICR X2, CDIA; X2=(valid:1));
exists(0:X1=(valid:1) /\ 0:X2=(valid:0))
kinds: edge-merging.LPI+gsb.ack Forbid
```

# B1.24.2.1 Explanation

In the execution that satisfies the postcondition, on PO:

- GICR X1, CDIA generates an Implicit Interrupt Write Effect to INTID (A)  $E_1$  and an Implicit Interrupt Write Effect to INTID (A)  $E_2$  which resets the pending state to 0 and sets the active state to 1.
- GSB ACK generates a GSB ACK Effect  $E_3$ .
- STR X3, [X0] generates an Explicit Write Effect  $E_4$  to Location x. When the Explicit Write Effect to Location x reaches its endpoint, the Peripheral device signals an interrupt event to the IRI which generates Interrupt Read Effect  $E_4$  to INTID (A) and an Interrupt Write Effect to INTID (A)  $E_5$  which sets the pending state to 1.
- GIC CDDI, X1 generates Implicit Interrupt Write Effect to INTID (A)  $E_6$  and an Implicit Interrupt Write Effect to INTID (A)  $E_7$  which resets the pending state to 0.
- The repeated execution of GICR X2, CDIA generates Implicit Interrupt Read Effects  $E_8, E_9, \ldots, E_n$  where n is a finite number.

All Interupt Write Effects are required to complete in finite time and consequently, Interrupt Write Effects  $E_2$ ,  $E_5$  and  $E_7$  are Coherence-before  $E_n$ . In the execution that satisfies the postcondition, no interrupt is acknowledged and therefore INTID (A) does not become the HPPI. As a result one of the following has to be true:

- $E_5$  is Coherence-before  $E_2$  and consequently,  $E_1$  Reads-from  $E\sim5$  and  $E_5$  is GIC-observed-by  $E_1$ .  $E_1$  is GSB-ordered-before  $E_5$ . As a result, this execution violates the external visibility requirement as it creates a cycle in the Ordered-before relation.
- E<sub>7</sub> is Coherence-before E<sub>2</sub> and consequently, E<sub>1</sub> Reads-from E~7 and E<sub>7</sub> is GIC-observed-by E<sub>1</sub>. E<sub>1</sub> is GSB-ordered-before E<sub>7</sub>. As a result, this execution violates the external visibility requirement as it creates a cycle in the Ordered-before relation.

# B1.25 Configuration read and interrupt acknowledge

### B1.25.1 Notes

The purpose of these tests is to show that if an interrupt is disabled, and that disable is observed by a configuration read, then the interrupt cannot be acknowledged after observing the disable.

We show both a single-threaded and multi-threaded version of the test.

Illustrates a common principle of an interrupt acknowledge observing side effects of a write if that write can be observed via an explicit read.

#### B1.25.2 Single-threaded litmus test

```
AArch64 coRR.ack
{
  [INTID(A)]=(enabled:1,affinity:P0,pending:1);
  0:X1=(intid:A);
}
P0 ;
GIC CDDIS, X1 ;
GIC CDRCFG, X1 ;
ISB ;
MRS X2, ICC_ICSR_EL1 ;
GICR X0, CDIA ;
exists(0:X0=(valid:1, intid:A))
kinds: coRR.ack Forbid
```

# B1.25.2.1 Explanation

On P0:

- GIC CDDIS, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$  which sets the enabled state to 0
- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$ .
- GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_4$  and an Implicit Interrupt Write Effect to INTID (A)  $E_5$ .

In the execution that satisfies the postcondition:

- E<sub>4</sub> Reads-from the initial value of INTID (A) and, as a result, due to the atomicity requirement for successful pairs of Read Interrupt and Write Interrupt Effects, E<sub>5</sub> is Coherence-before E<sub>2</sub>.
- Any of the following applies:
  - $E_3$  Reads-from the initial state of INTID and, as a result,  $E_3$  is Coherence-before  $E_2$ . This violates the requirements of the Coherence-before relation. As a result, this execution is architecturally forbidden.
  - E<sub>3</sub> Reads-from E<sub>5</sub>. This violates the Reads-from relation. As a result, this execution is architecturally forbidden.

#### B1.25.3 Multi-threaded litmus test

```
AArch64 coRR.ack+dis+Rack
{
  [INTID(A)]=(enabled:1,affinity:P1,pending:1);
  0:X1=(intid:A);
  1:X1=(intid:A);
```

Chapter B1. Interrupt ordering litmus tests B1.25. Configuration read and interrupt acknowledge

```
}
P0 | P1 ;
GIC CDDIS, X1 | GIC CDRCFG, X1 ;
| ISB ;
| MRS X2, ICC_ICSR_EL1 ;
| GICR X0, CDIA ;
exists(1:X2=(enabled:0, affinity:P1, pending:1) /\
1:X0=(valid:1, intid:A))
```

## kinds: coRR.ack+dis+Rack Forbid

#### B1.25.3.1 Explanation

• GIC CDDIS, X1 generates an Explicit Interrupt Write Effect to INTID (A)  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$  which sets the enabled state to 0

On P1:

- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$ .
- GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A) E4 and an Implicit Interrupt Write Effect to INTID (A) E5.

In the execution that satisfies the postcondition:

- E<sub>3</sub> is in program order before E<sub>4</sub>.
- $E_3$  and  $E_4$  are to the same Interrupt Location INTID (A).
- $E_4$  Reads-from the initial state of INTID (A) and as a result  $E_4$  is Coherence-before  $E\sim2$ . This means that  $E_3$  is GIC-Hazard-Ordered-before  $E_2$
- E<sub>3</sub> Reads-from E<sub>2</sub> and as a result, E<sub>2</sub> is GIC-Observed-by E<sub>3</sub>.

This creates a cycle in the Ordered-before relation and as a result, the execution violates the External visibility requirement.

# B1.26 Atomicity of interrupt acknowledge

## B1.26.1 Notes

The purpose of this test is to show that the two interrupt write effects of acknowledging an interrupt are atomic with respect to any read effect to the interrupt.

## B1.26.2 Litmus test

```
AArch64 atomic-gic.ack
 [INTID(A)] = (enabled:1, affinity:P0, active:0, pending:1, handling_mode:edge);
1:X0=(intid:A)
}
ΡO
                  | P1
                                           ;
GICR X0, CDIA
                 | GIC
                        CDRCFG, X0
                                           ;
                  | ISB
                  | MRS
                        X1, ICC_ICSR_EL1 ;
exists(1:X1=(pending:1, active:1) \/
       1:X1=(pending:0, active:0))
kinds: atomic-gic.ack Forbid
```

# B1.26.2.1 Explanation

#### On P0:

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_1$  and an Implicit Interrupt Write Effect to INTID (A)  $E_2$  and atomically sets the pending state to 0 and the active state to 1.

#### On P1:

• GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$ .

In the execution that satisfies the postcondition,  $E_3$  reads that either the pending state is 1 and the active state is 1, or the pending state is 0 and the active state is 0. Both postconditions violate the atomicity requirement of  $E_2$ .

# B1.27 Atomicity of interrupt disable and acknowledge

# B1.27.1 Notes

This test demonstrates the interaction between disabling (clearing Enabled) and acknowledging an INTID from different PEs.

Illustrates a common principle of interrupt acknowledgement observing side effects of a write if that write can be observed via an explicit read.

;

;

;

;

# B1.27.2 Litmus test

```
AArch64 atomic.ack.dis.gic+W+R
 [INTID(A)] = (enabled:1, affinity:P0, pending:1, active:0);
 1:X1=(intid:A); 2:X1=(intid:A);
}
 P0
                    | P1
                                          | P2
 GICR X2, CDIA
                    | GIC CDDIS, X1
                                          | GIC CDRCFG, X1
                                          | ISB
                     | MRS X2, ICC_ICSR_EL1
exists(0:X2=(valid:1,intid:A) /\
       2:X2=(enabled:0, pending:1, active:0))
kinds: atomic.ack.dis.gic+W+R Forbid
```

# B1.27.2.1 Explanation

#### On P0:

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_1$  and an Implicit Interrupt Write Effect to INTID (A)  $E_2$  and atomically sets the pending state to 0 and the active state to 1.

#### On P1:

• GIC CDDIS, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$  and an Explicit Interrupt Write Effect to INTID (A)  $E_4$  and atomically sets the enabled state to 0.

#### On P2:

• GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_5$ .

In the execution that satisfies the postcondition,  $E_5$  Reads-from  $E_4$  and  $E_4$  is GIC-observed-by  $E_5$ . The postcondition also requires that  $E_3$  Reads-from the initial state of INTID (A). At the same time,  $E_1$  Reads-from the initial state of INTID (A). This violates the atomicity requirement for successful pairs of Read Interrupt and Write Interrupt Effects which should apply for the pairs of  $E_3$ ,  $E\sim4$  and  $E_1$ ,  $E_2$ .

# B1.28 Interrupt handler completion

### B1.28.1 Notes

The purpose of this test is to show that when an interrupt can be acknowledged on a PE, then disabling the interrupt on a different PE followed by reading back the interrupt configuration and state, exactly one of the following is true:

- The interrupt is observed as Active and P0 has acknowledged the interrupt.
- The interrupt is not observed as Active and P0 will not acknowledge the interrupt.

This illustrates a concept that operating systems would rely on, which is that if they've disabled the interrupt and observe an interrupt is not active, then that interrupt cannot be taken and become active without the interrupt being enabled again.

### B1.28.2 Litmus test

```
AArch64 atomic.ack.gic-ib+W-R-si-R
{
 [INTID(A)] = (enabled:1, affinity:P0, pending:1, active:0);
1:X1=(intid:A);
}
ΡO
                     | P1
                                               ;
GICR X2, CDIA
                     | GIC CDDIS, X1
                                               ;
                     | GIC CDRCFG, X1
                                               ;
                     | ISB
                                               ;
                     | MRS X2, ICC_ICSR_EL1
                                               ;
exists(0:X2=(valid:1, intid:A) /\
       1:X2=(enabled:0, affinity:P0, pending:1, active:0))
kinds: atomic.ack.gic-ib+W-R-si-R Forbid
```

# B1.28.2.1 Explanation

#### On P0:

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_1$  and an Implicit Interrupt Write Effect to INTID (A)  $E_2$  and atomically sets the pending state to 0 and the active state to 1.

#### On P1:

- GIC CDDIS, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$  and an Explicit Interrupt Write Effect to INTID (A)  $E_4$  and atomically sets the enabled state to 0.
- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_5$ .

In the execution that satisfies the postcondition:

- $E_1$  Reads-from the initial value of INTID (A) and, as a result,  $E_1$  is Coherence-before  $E_4$ .
- E-5~ Reads-from E<sub>3</sub>.
- $E_5$  is Coherence-before  $E_2$  and, as a result,  $E_4$  is also Coherence-before E~2.

This execution violates the atomicity requirement for the successful pair of Read Interrupt Effect  $E_1$  and Write Interrupt Effect  $E_2$ , as  $E_1$  is Coherence-before  $E_4$  and  $E_4$  is Coherence-before  $E_2$ .

# B1.29 Configuration update while disabled

### B1.29.1 Notes

The purpose of this test is to show that if multiple writes occur to the same interrupt while the interrupt is disabled, the interrupt will not be acknowledged and observe a partially updated interrupt.

### B1.29.2 Litmus test

```
AArch64 coWWW-gic.dis-en+ack+ack
 [INTID(A)]=(enabled:1, affinity:P1, active:0, pending:1, priority:5);
0:X0=(intid:A);
0:X1=(intid:A, priority:4);
0:X2=(intid:A, affinity:P2);
1:X1=(intid:A);
}
ΡO
                  | P1
                                           1 P2
GIC CDDIS, X0
                  | GICR X2, CDIA
                                           | GICR X2, CDIA
                                                                     ;
                                           | ISB
GIC CDPRI, X1
                  | ISB
                                                                     ;
GIC CDAFF, X2
                  | MRS X0, ICC_HAPR_EL1 | MRS X0, ICC_HAPR_EL1
                                                                     ;
GIC CDEN, XO
                  exists((1:X2=(valid:1, intid:A) /\ 1:X0=(priority:4)) \/
       (2:X2=(valid:1, intid:A) /\ 2:X0=(priority:5)))
kinds: coWWW-gic.dis-en+ack+ack Forbid
```

# B1.29.2.1 Explanation

#### On PO:

- GIC CDDIS, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$  and sets its enabled state to 0.
- GIC CDPRI, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$  and an Explicit Interrupt Write Effect to INTID (A)  $E_4$  and sets its priotity to 4.
- GIC CDAFF, X2 generates an Explicit Interrupt Read Effect to INTID (A)  $E_5$  and an Explicit Interrupt Write Effect to INTID (A)  $E_6$  and sets its affinity to P2.
- GIC CDEN, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_7$  and an Explicit Interrupt Write Effect to INTID (A)  $E_8$  and sets its enabled state to 1.

On P1:

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_9$ .

On P2:

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_{10}$ .

In the execution that satisfies the postcondition, any of the following applies:

- $E_4$  is Coherence-before  $E_2$ ,  $E_2$  is Coherence-before  $E_6$  and  $E \sim 8$ .  $E_9$  Reads-from  $E_4$ . In this execution,  $E_3$  is Coherence-before  $E_2$  which violates the requirements of the Coherence-before relation.
- $E_2$  is Coherence-before  $E_4$ ,  $E_4$  is Coherence-before  $E_8$ ,  $E_8$  is Coherence-before  $E_6$ .  $E_9$  Reads-from  $E_8$ . In this execution,  $E_7$  is Coherence-before  $E_6$  which violates the requirements of the Coherence-before relation.
- $E_6$  is Coherence-before  $E_2$ ,  $E_2$  is Coherence-before  $E_4$  and  $E \sim 8$ .  $E_{10}$  Reads-from  $E_6$ . In this execution,  $E_5$  is Coherence-before  $E_2$  which violates the requirements of the Coherence-before relation.

# Chapter B1. Interrupt ordering litmus tests B1.29. Configuration update while disabled

•  $E_2$  is Coherence-before  $E_6$ ,  $E_6$  is Coherence-before  $E_8$ ,  $E_8$  is Coherence-before  $E_4$ .  $E_{10}$  Reads-from  $E_8$ . In this execution,  $E_7$  is Coherence-before  $E_4$  which violates the requirements of the Coherence-before relation.

# B1.30 Atomicity of interrupt acknowledge and retarget

## B1.30.1 Notes

The purpose of this test is to show that even though an interrupt can be acknowledged and subsequently made pending, it cannot be acknowledged a second time without a deactivate of the interrupt taking place.

### B1.30.2 Litmus test

```
AArch64 co.ack-gic+WP+ack+ack
 [INTID(A)] = (enabled:1, affinity:P1, pending:1, active:0);
0:X0=(intid:A, pending:1);
0:X1=(intid:A, affinity:P2);
}
ΡO
                  | P1
                                     1 P2
                                                        ;
GIC CDAFF, X1
                 | GICR X2, CDIA
                                    | GICR X2, CDIA ;
GIC CDPEND, X0
                  exists(1:X2=(valid:1, intid:A) /\ 2:X2=(valid:1, intid:A))
kinds: co.ack-gic+WP+ack+ack Forbid
```

# B1.30.2.1 Explanation

#### On P0:

- GIC CDAFF, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$  that sets its affinity to P2.
- GIC CDPEND, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$  and an Explicit Interrupt Write Effect to INTID (A)  $E_4$  that set its pending state to 1.

#### On P1:

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_5$  and an Implicit Interrupt Read Effect to INTID (A)  $E_6$  thats resets its pending state to 0 and its active state to 1.

#### On P3:

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_7$  and an Implicit Interrupt Read Effect to INTID (A)  $E_8$  thats resets its pending state to 0 and its active state to 1.

In one of the possible executions that satisfies the postcondition:

- $E_5$  Reads-from the initial state of INTID (A) and as result  $E_5$  is Coherence-before  $E_2$ .
- E<sub>7</sub> Reads-from E<sub>2</sub>.
- E<sub>2</sub> is Coherence-before E<sub>6</sub>.

This execution violates the atomicity requirement for the successful pair of Read Interrupt Effect  $E_5$  and Write Interrupt Effect  $E_6$ , as  $E_5$  is Coherence-before  $E_2$  and  $E_2$  is Coherence-before  $E_6$ .

There are other executions that satisfy the postcondition all of which violate the atomicity requirement for a successful pair of Read Interrupt and Write Interrupt Effects.

Chapter B1. Interrupt ordering litmus tests B1.31. 1ofN interrupt acknowledge

# B1.31 1ofN interrupt acknowledge

## B1.31.1 Notes

The purpose of this test is to show that a 1ofN interrupt can only be acknowledged on a single PE.

# B1.31.2 Litmus test

```
AArch64 co.ack.lofN-gic
{
 [INTID(A)]=(enabled:1,affinity:lofN,pending:1,active:0);
}
 P0 | P1 ;
GICR X2, CDIA | GICR X2, CDIA ;
exists(0:X2=(valid:1,intid:A) /\ 1:X2=(valid:1,intid:A))
kinds: co.ack.lofN-gic Forbid
```

# B1.31.2.1 Explanation

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_1$  and an Implicit Interrupt Read Effect to INTID (A)  $E_2$  thats resets its pending state to 0 and its active state to 1.

On P3:

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_3$  and an Implicit Interrupt Read Effect to INTID (A)  $E_4$  thats resets its pending state to 0 and its active state to 1.

In one of the execution that satisfies the postcondition:

- $E_1$  Reads-from the initial state of INTID (A) and as result  $E_1$  and  $E_2$  are Coherence-before  $E_4$ .
- $E_3$  Reads-from the initial state of INTID (A) and as result  $E_3$  and  $E_4$  are Coherence-before  $E_2$ .

This execution violates the atomicity requirement for the successful pair of Read Interrupt Effect  $E_1$  and Write Interrupt Effect  $E_2$ , as  $E_1$  is Coherence-before  $E_4$  and  $E_4$  is Coherence-before  $E_2$ .

# B1.32 Retargeting interrupts without synchronization

# B1.32.1 Notes

The purpose of this test is to show that due to the total order on writes to the same interrupt location, a write to change an interrupt's Affinity followed by a write to make the interrupt Pending, results in an interrupt not being taken on the old PE.

## B1.32.2 Litmus test

```
AArch64 coWW.ack-gic+WP+ack
 [INTID(A)] = (enabled:1, affinity:P1, pending:0, active:0);
 0:X0=(intid:A, pending:1); 0:X1=(intid:A, affinity:P0);
 1:X0=x; 1:X1=(intid:A);
}
                   | P1
ΡÛ
                                       ;
GIC CDAFF, X1
                  | GICR X2, CDIA
                                       ;
GIC CDPEND, X0
                   ;
exists(1:X2=(valid:1, intid:A))
kinds: coWW.ack-gic+WP+ack Forbid
```

# B1.32.2.1 Explanation

On P0:

- GIC CDAFF, X1 generates an Explicit Interrupt Read Effect to INTID (A)  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$  that sets its affinity to P0.
- GIC CDPEND, X0 generates an Explicit Interrupt Read Effect to INTID (A)  $E_3$  and an Explicit Interrupt Write Effect to INTID (A)  $E_4$  that set its pending state to 0.

#### On P1:

• GICR X2, CDIA generates an Implicit Interrupt Read Effect to INTID (A)  $E_5$ .

In the execution that satisfies the postcondition:

- E<sub>5</sub> Reads-from E<sub>4</sub>.
- $E_4$  is Coherence-before  $E_2$  and, as a result,  $E_3$  is also Coherence-before  $E\sim2$ . This violates the requirements of the Coherence-before relation and, as a result, this is an architecturally forbidden execution.

# **B1.33 Reading interrupt configuration and exception status**

# B1.33.1 Notes

The purpose of these tests is to show the interaction between observing a change to an interrupt configuration and observing a corresponding change in the interrupt exception pending status.

See also:

• B1.6 Configuration and acknowledgement

#### B1.33.2 Litmus test with ISB before reading IRQ pending status

```
AArch64 coRex-gic+dis+RisbR
 [INTID(A)]=(enabled:1, pending:1, affinity:P1);
0:X1=(intid:A);
1:X1=(intid:A);
1
ΡO
                        I P1
GIC CDDIS, X1
                        | GIC
                              CDRCFG, X1
                        | ISB
                        | MRS
                              X2, ICC_ICSR_EL1 ;
                        | MRS
                              X0, ISR_EL1
exists(1:X2=(enabled:0) /\ 1:X0=(I:1))
```

```
kinds: coRex-gic+dis+RisbR Forbid
```

# B1.33.2.1 Explanation

For the execution that validates the postcondition:

On P0:

• GIC CDDIS, X1 generates an Explicit Interrupt Write Effect  $E_1$  to INTID (A).

On P1:

- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect  $E_2$  to INTID (A).
- ISB generates an Instruction Fetch Barrier Effect  $E_3$ .
- MRS X0, ISR\_EL1 generates a Direct System Register Read Effect to ISR\_EL1 E4.

In the execution that satisfies the postcondition,  $E_2$  Reads-from  $E_1$ . But  $E_4$  indicates that INTID(A) is still the HPPI. However because of  $E_3$  INTID(A) is disabled and cannot be the HPPI. As a result, this execution is architecturally forbidden.

# B1.33.3 Litmus test with ISB after reading IRQ pending status

```
exists(1:X2=(enabled:0) /\ 1:X0=(I:1))
```

```
kinds: coRex-gic+dis+RR Allow
```

# B1.33.3.1 Explanation

For the execution that validates the postcondition:

On P0:

• GIC CDDIS, X1 generates an Explicit Interrupt Write Effect  $E_1$  to INTID (A).

On P1:

- GIC CDRCFG, X1 generates an Explicit Interrupt Read Effect  $E_2$  to INTID (A).
- MRS X0, ISR\_EL1 generates a Direct System Register Read Effect to ISR\_EL1 E4.

In the execution that satisfies the postcondition,  $E_2$  Reads-from  $E_1$ . But  $E_4$  indicates that INTID (A) is still the HPPI. This execution is architecturally allowed.

# B1.34 Reading interrupt configuration and IRQ unmask in PSTATE

### B1.34.1 Notes

The purpose of these tests is to show the interaction between observing a change to an interrupt configuration and observing the corresponding interrupt exception.

See also:

• B1.9 Configuration write and IRQ unmask in PSTATE

### B1.34.2 Explanation

The interrupt read effect R1 of GIC CDRCFG, X1 on P1 may or may not observe the interrupt write effect W2 of GIC CDDIS, X1 on P0, but if it does, it means that the interrupt has been recalled from P1 on completion of W2.

If R1 from GIC CDRCFG, X1 observes W2 from GIC CDDIS, X1, then effects of W2 on the execution context (whether an IRQ exception is pending) must be observed by the instructions following the ISB. This means that when DAIFClr PSTATE.I is executed, the IRQ interrupt exception will not be taken.

#### B1.34.3 Litmus test with ISB before unmasking IRQ in PSTATE

```
AArch64 coRR+gic.cddis+gic.cdrcfg-isb-clr.i
{
 [INTID(A)]=(enabled:1, pending:1, affinity:P1);
 0:X1=(intid:A);
 1:X1=(intid:A);
}
 ΡÛ
                       | P1
                                                ;
 GIC CDDIS, X1
                       | GIC
                             CDRCFG, X1
                                                ;
                       | ISB
                       | MRS X2, ICC_ICSR_EL1 ;
                       | DAIFClr PSTATE.I
exists(1:X2=(enabled:0) /\ async(P1, IRQ)
kinds: coRR+gic.cddis+gic.cdrcfg-isb-clr.i Forbid
```

# B1.34.4 Litmus test with ISB after unmasking IRQ in PSTATE

```
AArch64 coRR+gic.cddis+gic.cdrcfg-clr.i-isb
{
 [INTID(A)]=(enabled:1, pending:1, affinity:P1);
0:X1=(intid:A);
1:X1=(intid:A);
}
ΡÛ
                       | P1
                                                ;
                       | GIC CDRCFG, X1
GIC CDDIS, X1
                                                :
                       | DAIFClr PSTATE.I
                       | ISB
                       | MRS X2, ICC_ICSR_EL1 ;
exists(1:X2=(enabled:0) /\ async(P1, IRQ)
kinds: coRR+gic.cddis+gic.cdrcfg-clr.i-isb Allow
```

Chapter B1. Interrupt ordering litmus tests B1.35. PPI activate and system register read

# B1.35 PPI activate and system register read

#### B1.35.1 Notes

The PPI active state is stored in system registers.

These tests show that an ISB is required to guarantee the updates to the system registers from acknowledge interrupts are visible to a system register read.

Illustrates a common principle that any instruction with effects to state held in system registers, including GICR and GIC instructions affecting PPI state, can be observed following an ISB.

#### B1.35.2 Litmus test without ISB

```
AArch64 coWmrs.ack
{
    0:[ppi(0)]=(enabled:1,pending:1,active:0);
}
P0
GICR X0, CDIA ;
MRS X1, ICC_PPI_SACTIVER0_EL1 ;
exists(0:X0=(valid:1, initd:ppi0) /\ 0:X1=0)
kinds: coWmrs.ack Allow
```

# B1.35.2.1 Explanation

On P0:

- GICR X0, CDIA acknowleges ppi (0) and as a result generates an Indirect System Register Write Effect to ICC\_PPI\_SACTIVER0\_EL1 E<sub>1</sub>.
- MRS X1, ICC\_PPI\_SACTIVER0\_EL1 generates a Direct System Register Read Effect to ICC\_PPI\_SACTIVER0\_EL1 E<sub>2</sub>.

As per the postcondition,  $E_2$  is Coherence-before  $E_1$  which is architecturally allowed. See 'Table D24-1 Synchronization requirements' in the Architecture Reference Manual for A-profile [1] for more information.

# B1.35.3 Litmus test with GSB

```
AArch64 coWmrs.ack+gsb
{
    0:[ppi(0)]=(enabled:1,pending:1,active:0);
}
P0
GICR X0, CDIA ;
GSB ACK ;
MRS X1, ICC_PPI_SACTIVER0_EL1 ;
exists(0:X0=(valid:1, initd:ppi0) /\ 0:X1=0)
kinds: coWmrs.ack+gsb Allow
```

# B1.35.3.1 Explanation

On P0:

• GICR X0, CDIA acknowleges ppi (0) and as a result generates an Indirect System Register Write Effect to ICC\_PPI\_SACTIVER0\_EL1 E<sub>1</sub>.

- GSB ACK generates a GSB ACK Effect  $E_2$ .
- MRS X1, ICC\_PPI\_SACTIVER0\_EL1 generates a Direct System Register Read Effect to ICC\_PPI\_SACTIVER0\_EL1 E<sub>3</sub>.

As per the postcondition,  $E_3$  is Coherence-before  $E_1$  which is architecturally allowed. See 'Table D24-1 Synchronization requirements' in the Architecture Reference Manual for A-profile [1] for more information.

### B1.35.4 Litmus test with ISB

```
AArch64 coWmrs.ack+isb
{
    0:[ppi(0)]=(enabled:1,pending:1,active:0);
}
P0
GICR X0, CDIA ;
ISB ;
MRS X1, ICC_PPI_SACTIVER0_EL1 ;
exists(0:X0=(valid:1, initd:ppi0) /\ 0:X1=0)
kinds: coWmrs.ack+isb Forbid
```

# B1.35.4.1 Explanation

On P0:

- GICR X0, CDIA acknowleges ppi(0) and as a result generates an Indirect System Register Write Effect to ICC\_PPI\_SACTIVER0\_EL1 E<sub>1</sub>.
- ISB generates an Instruction Fetch Barrier Effect E<sub>2</sub> which is a Context Synchronization Event.
- MRS X1, ICC\_PPI\_SACTIVER0\_EL1 generates a Direct System Register Read Effect to ICC\_PPI\_SACTIVER0\_EL1 E<sub>3</sub>.

As per the postcondition,  $E_3$  is Coherence-before  $E_1$ . This violates the requirements of the Coherence-before definition. As a result this execution is architecturally forbidden.

See also 'Table D24-1 Synchronization requirements' in the Architecture Reference Manual for A-profile [1] for more information.

Chapter B1. Interrupt ordering litmus tests B1.36. PPI disable and acknowledge

# B1.36 PPI disable and acknowledge

## B1.36.1 Notes

The PPI configuration is stored in system registers.

The purpose of the test is to show that the effects of updates to the execution context are completed by the ISB, including which PPIs can be the HPPI.

Illustrates a common principle that any instruction with effects to state held in system registers, including GICR and GIC instructions affecting PPI state, can be observed following an ISB.

### B1.36.2 Litmus test with ISB

```
AArch64 comsrR.ack+isb
{
    0:[ppi(0)]=(enabled:1,pending:1,active:0);
    0:X1=(ppi0:1);
}
P0
MSR ICC_PPI_CENABLER0_EL1, X1 ;
ISB ;
GICR X0, CDIA ;
exists(0:X0=(valid:1, initd:ppi0))
kinds: comsrR.ack+isb Forbid
```

# B1.36.2.1 Explanation

On P0:

- MSR ICC\_PPI\_CENABLER0\_EL1, X1 generates a Direct System Register Write Effect to ICC\_PPI\_CENABLER0\_EL1  $E_1$  and disables ppi(0).
- ISB generates an Instruction Fetch Barrier Effect E2 which is a Context Synchronization Event.
- GICR X0, CDIA acknowleges ppi(0) and as a result generates an Indirect System Register Read Effect to ICC\_PPI\_CENABLER0\_EL1 E<sub>3</sub>.

As per the postcondition,  $E_3$  is Coherence-before  $E_1$  as  $E_3$  finds ppi (0) still enabled. This violates the requirements of the Coherence-before definition. As a result this execution is architecturally forbidden.

See also 'Table D24-1 Synchronization requirements' in the Architecture Reference Manual for A-profile [1] for more information.

Chapter B1. Interrupt ordering litmus tests B1.37. PPI acknowledgement

# B1.37 PPI acknowledgement

#### B1.37.1 Notes

The PPI active state is stored in system registers.

The purpose of the test is to show that a GICR instruction that acknowledges a PPI generates an Indirect System Register Write to ICC\_PPI\_SPEND<n>\_EL1.

#### B1.37.2 Litmus test

```
AArch64 coWR-ppi+ia-isb-mrs.sprendr1
{
    0:[ppi(64)]=(enabled:1,pending:1,active:0); // Edge-triggered IMPDEF PPI 64
    0:X1=1;
}
PO
GICR X0, CDIA ;
ISB ;
MRS ICC_PPI_SPENDR1_EL1, X2 ;
exists(0:X2=1)
kinds: coWR-ppi+ia-isb-mrs.sprendr1 Forbid
```

# B1.37.2.1 Explanation

In the execution that satisfies the postcondition, on PO:

- GICR X1, CDIA acknowledges ppi(64) and generates an Indirect System Register Write to ICC\_PPI\_SPEND1\_EL1  $E_1$  and sets Pend0 to 0.
- ISB generates an Instruction Fetch Barrier Effect E<sub>2</sub> which is a Context Synchronization Event.
- MRS ICC\_PPI\_SPEND1\_EL1, X2 generates a Direct System Register Read to ICC\_PPI\_SPEND1\_EL1 E3.

As per the postcondition,  $E_3$  is Coherence-before  $E_1$ . This violates the requirements of the Coherence-before definition. As a result this execution is architecturally forbidden. See 'Table D24-1 Synchronization requirements' in the Architecture Reference Manual for A-profile [1] for more information.

# B1.37.3 Litmus test

```
AArch64 edge-merging.ppi
{
    0:[ppi(64)]=(enabled:1,pending:1,active:0); // Edge-triggered IMPDEF PPI 64
    0:X1=1;
}
P0
GICR X0, CDIA ;
MSR ICC_PPI_SPENDR1_EL1, X1 ;
MRS ICC_PPI_SPENDR1_EL1, X2 ;
exists(0:X2=0)
kinds: edge-merging.ppi Forbid
```

## B1.37.3.1 Explanation

In the execution that satisfies the postcondition, on PO:

- GICR X1, CDIA acknowledges ppi(64) and generates an Indirect System Register Write to ICC\_PPI\_SPEND1\_EL1  $E_1$  and sets Pend0 to 0.
- MSR ICC\_PPI\_SPEND1\_EL1, X1 generates a Direct System Register Write to ICC\_PPI\_SPEND1\_EL1 E<sub>2</sub> and sets Pend0 to 1.
- MRS ICC\_PPI\_SPEND1\_EL1, X2 generates a Direct System Register Read to ICC\_PPI\_SPEND1\_EL1 E<sub>3</sub>.

As per the postcondition,  $E_3$  Reads-from  $E_1$ . This is architecturally forbidden as  $E_1$  and  $E_2$  are ordered without the need of synchronization, and  $E_3$  has to Read-from  $E_2$  as both are Direct System Register Effects.

See also Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture[1] Table D24-1 Synchronization requirements' for more information.

# B1.38 Write after changing resident VM

## B1.38.1 Notes

The purpose of this test is to show that an ISB is required to change the resident VM on a PE so that interrupt write effects are made to the expected interrupts.

Illustrates a common principle that any instruction with effects to state held in system registers, including GICR and GIC instructions affecting PPI state, can be observed following an ISB.

# B1.38.2 Litmus test

```
AArch64 vmW-gic+R
 [VM0:INTID(A)] = (enabled:0);
 [VM1:INTID(A)] = (enabled:0);
 0:ICH_CONTEXTR_EL2=(VM1, VPE0, VALID);
 0:X0=(intid:A); 0:X1=(VM0, VPE0, VALID);
 1:ICH_CONTEXTR_EL2=(VM1, VPE1, VALID);
 1:X0=(intid:A);
}
 ΡO
                            | P1
                                                       ;
 MSR ICH_CONTEXTR_EL2, XZR | GIC VDRCFG, X0
                                                       ;
 MSR ICH_CONTEXTR_EL2, X1 | ISB
                                                       ;
 TSB
                            | MRS X2, ICC_ICSR_EL1
                                                       ;
 GIC VDEN, XO
                            ;
exists(1:X2=(enabled:1))
kinds: vmW-gic+R Forbid
```

# B1.38.2.1 Explanation

#### On P0:

- MSR ICH\_CONTEXTR\_EL2, XZR generates a Direct System Register Write Effect to ICH\_CONTEXTR\_EL2  $E_1$  and ensures that there is no resident VPE.
- MSR ICH\_CONTEXTR\_EL2, X1 generates a Direct System Register Write Effect to ICH\_CONTEXTR\_EL2  $E_2$  and makes VPE 0 of VM 0 resident.
- ISB generates an Instruction Fetch Barrier Effect E<sub>3</sub> which is a Context Synchronization Event.
- GIC VDEN, X0 generates an Indirect System Register Read to ICH\_CONTEXTR\_EL2  $E_4$  and an Explicit Interrupt Write Effect to INTID (A)  $E_5$  enabling INTID (A).

#### On P1:

• GIC VDRCFG, X0 generates an Indirect System Register Read to ICH\_CONTEXTR\_EL2 E<sub>6</sub> and an Explicit Interrupt Read Effect to INTID (A) E<sub>7</sub>.

As per the postcondition,  $E_7$  reads that INTID (A) is enabled which could only have happened if  $E_7$  Reads-from  $E_5$ . This in turn means that  $E_5$  was to VM1:INTID (A) and as a result,  $E_4$  Reads-from the initial value of ICH\_CONTEXTR\_EL2 and  $E_4$  is Coherence-before  $E_2$ . This violates the requirements of the Coherence-before definition and this execution is architecturally forbidden.

See 'Table D24-1 Synchronization requirements' in the Architecture Reference Manual for A-profile [1] for more information.

# B1.39 Write before changing resident VM

## B1.39.1 Notes

The purpose of this test is to show that an ISB is not needed to ensure that interrupt write effects are made to the resident VM when an instruction to change the resident VM occurs in program order after the instruction causing the interrupt write effect.

## B1.39.2 Litmus test

```
AArch64 Wvm-gic+R
 [VM0:INTID(A)] = (enabled:0);
 [VM1:INTID(A)] = (enabled:0);
 0:ICH_CONTEXTR_EL2=(VM0, VPE0);
 0:X0=(intid:A); 0:X1=(VM1, VPE0);
 1:ICH_CONTEXTR_EL2=(VM1, VPE0);
 1:X0=(intid:A);
}
РO
                           I P1
                                                       ;
GIC VDEN, X0
                           | GIC VDRCFG, X0
                                                       ;
MSR ICH_CONTEXTR_EL2, XZR | ISB
                                                       ;
MSR ICH_CONTEXTR_EL2, X1 | MRS X2, ICC_ICSR_EL1
                                                       ;
exists(1:X2=(enabled:1))
kinds: Wvm-gic+R Forbid
```

# B1.39.2.1 Explanation

#### On P0:

- GIC VDEN, X0 generates an Indirect System Register Read to ICH\_CONTEXTR\_EL2  $E_1$  and an Explicit Interrupt Write Effect to INTID (A)  $E_2$  enabling INTID (A).
- MSR ICH\_CONTEXTR\_EL2, XZR generates a Direct System Register Write Effect to ICH\_CONTEXTR\_EL2  $E_3$  and ensures that there is no resident VPE.
- MSR ICH\_CONTEXTR\_EL2, X1 generates a Direct System Register Write Effect to ICH\_CONTEXTR\_EL2  $E_4$  and makes VPE 0 of VM 0 resident.

On P1:

• GIC VDRCFG, X0 generates an Indirect System Register Read to ICH\_CONTEXTR\_EL2  $E_5$  and an Explicit Interrupt Read Effect to INTID (A)  $E_6$ .

As per the postcondition,  $E_6$  reads that INTID (A) is enabled which could only have happened if  $E_6$  Reads-from  $E_2$ . This in turn means that  $E_2$  was to VM1:INTID (A) and as a result,  $E_1$  Reads-from  $E_4$ . This violates the requirements of the Reads-from definition and this execution is architecturally forbidden.

See 'Table D24-1 Synchronization requirements' in the Architecture Reference Manual for A-profile [1] for more information.

# B1.40 Completion of GIC and GICR instructions in finite time

## B1.40.1 Notes

The purpose of this test is to show that writes to Interrupt Locations are required to become visible to observers in finite time.

## B1.40.2 Litmus test with a priority update observed by a configuration read

```
AArch64 gic.pri+gic.rcfg-wait
 [INTID(A)] = (priority:0);
 0:X1=(intid:A, priority:1);
 1:X0=(intid:A); 1:X2=(priority:1);
}
 ΡO
               | P1
                                        ;
 GIC CDPRI, X1 |L0:
               | GIC CDRCFG, X0
               | ISB
               | MRS X1, ICC_ICSR_EL1 ;
               | CMP X1, X2
                                        ;
                | B.NE LO
                                        ;
existsN(1:X1=(priority:1))
```

```
kinds: gic.pri+gic.rcfg-wait Require
```

## B1.40.2.1 Explanation

On P0:

• GIC CDPRI, X1 generates an Explicit Interrupt Write Effect  $E_1$  to <code>INTID(A)</code>.

On P1:

• GIC CDRCFG, X0 generates Explicit Interrupt Read Effects  $E_2, E_3, \ldots E_n$  to INTID (A).

It is architecturally required that there is a finite number n for which  $E_n$  Reads-from  $E_1$ .

## B1.40.3 Litmus test with an interrupt acknowledge observed by a configuration read

```
AArch64 gic.ia+gic.rcfg-wait
 [INTID(A)]=(enabled:1, pending:1, active:0, priority:1, affinity:P0);
 1:X0=gicarg:(intid:A);
 1:X2=(enabled:1, pending:0, active:1, priority:1, affinity:P0);
}
 ΡO
               | P1
                                       ;
 GICR X1, CDIA |LO:
               | GIC CDRCFG, X0
               | ISB
               | MRS X1, ICC_ICSR_EL1 ;
               | CMP X1, X2
               | B.NE LO
existsN(0:X1=(valid:1, intid:A) /\ 1:X1=(priority:1))
kinds: gic.ia+gic.rcfg-wait Require
```

# B1.40.3.1 Explanation

On P0:

• GICR X1, CDIA generates an Implicit Interrupt Write Effect  $E_1$  to INTID (A).

On P1:

• GIC CDRCFG, X0 generates Explicit Interrupt Read Effects  $E_2, E_3, \ldots E_n$  to INTID (A).

It is architecturally required that there is a finite number n for which  $E_n$  Reads-from  $E_1$ .

# B1.40.4 Litmus test with an interrupt becoming pending and then acknowledged

```
AArch64 gic.pend1+gic.ia-wait
{
 [INTID(A)]=(enabled:1, pending:0, active:0, priority:1, affinity:P1);
 0:X0=(intid:A,pending:1);
 1:X2=(valid:1, intid:A);
}
 ΡO
               | P1
                                        ;
 GIC CDPEND, X0 |L0:
                                        ;
               | GICR X1,CDIA
                                        ;
               | CMP X1, X2
                                        ;
               | B.NE LO
                                        ;
existsN(1:X1=(valid:1, intid:A))
kinds: gic.pend1+gic.ia-wait Require
```

# B1.40.4.1 Explanation

On P0:

• GIC CDPEND, X0 generates an Explicit Interrupt Write Effect  $E_1$  to INTID (A).

On P1:

• GICR X1, CDIA generates Implicit Interrupt Read Effects  $E_2, E_3, \ldots E_n$  to INTID (A).

It is architecturally required that there is a finite number n for which  $E_n$  Reads-from  $E_1$ .

# Chapter B2 Effects of disabling a PPI source on the PPI Pending state

#### B2.0.1 Notes

The purpose of this test is to show that updates to a PPI Pending state can not be synchronized by any instruction.

## B2.0.2 Litmus test with disable of the timer state

```
AArch64 timer-disable-isb-ppi-read
{
 0:[ppi(27)]=(enabled:1,pending:1,active:0);
}
 ΡO
 MRS
      X0, CNTV_CTL_ELO
                                  ;
 MOV
      X1, #0
                                  ;
      CNTV_CTL_ELO, X1
 MSR
                                  ;
 ISB
                                  ;
 MRS
       X2, ICC_PPI_SPENDR0
                                  ;
exists(0:X0=(ISTATUS=1,IMASK=0,ENABLE=1) /\ 0:X2=0x00020000)
kinds: timer-disable-isb-ppi-read Allow
```

## B2.0.2.1 Explanation

Updates from a PPI source to the PPI Pending state is an autonomous asynchronous event. Even though the PPI Pending state can be observed by reading the ICC\_PPI\_SPENDCR0 System register, the update to the PPI Pending state is not an indirect System register write to ICC\_PPI\_SPENDRR0 caused by the direct System register write to CNTV\_CTL\_EL0. Instead, the write to CNTV\_CTL\_EL0 is observed by the autonomous asynchronous event that causes the EL1 Virtual Timer to evaluate its state and update the Pending state of the PPI.

Part C Model

# Chapter C1 Operational model

I<sub>QZJCC</sub>

The following code is an operational model of the GIC, written in Arm Specification Language (ASL). This section is is at Alpha quality. Alpha quality means that most major features of the specification are described in this release, but some features and details might be missing.

See also:

• Arm Specification Language Reference Manual [14].

```
// exceptions.asl
//
// This is the pseudocode implementing the exceptions signaling logic.
INTID GetHPPI(bits(2) domain)
return DOMAIN_HPPIS[UInt(domain)].intid;
boolean HasHPPI(bits(2) domain)
return DOMAIN_HPPIS[UInt(domain)].valid;
boolean DomainEnabled(bits(2) domain)
if domain == DOM_EL3 then
return ICC_CR0_EL3.EN == '1';
else
return BankedICC_CR0_EL1(domain).EN == '1';
bits(2) PhysicalIRQTarget()
route_to_el2 = (PSTATE.EL IN {EL0, EL1} && EL2Enabled() &&
(HCR_EL2.TGE == '1' || HCR_EL2.IMO == '1'));
```

```
if PSTATE.EL == EL2 || route_to_el2 then
        assert PSTATE.EL != EL3;
        return EL2;
    else
        assert PSTATE.EL IN {EL0, EL1};
        return EL1;
boolean NMIEnabled()
    if PhysicalIRQTarget() == EL2 then
        return SCTLR_EL2.NMI == '1';
    if PhysicalIRQTarget() == EL1 then
        return SCTLR_EL1.NMI == '1';
    return FALSE;
integer GetRunningPriority(bits(2) domain)
    return 31; // Should return the running priority based on the value in the
       →banked ICC_APR_EL1 or ICC_APR_EL3
integer GetPriorityMask(bits(2) domain)
    case domain of
        when DOM_EL3 return UInt(ICC_PCR_EL3.Priority);
        when DOM_S return UInt(ICC_PCR_EL1[0].Priority);
        when DOM_NS return UInt(ICC_PCR_EL1[1].Priority);
        when DOM_RL return UInt(ICC_PCR_EL1[2].Priority);
boolean HPPIAvailable(bits(2) domain)
    if !DomainEnabled(domain) then
        return FALSE;
    hppi = GetHPPI(domain);
    hppi_priority = UInt(hppi.Priority);
    running_priority = GetRunningPriority(domain);
    priority_mask = GetPriorityMask(domain);
    return hppi_priority < running_priority && hppi_priority <= priority_mask;
bits(2) PreemptiveDomain()
    return ICC_CR0_EL3.PID;
boolean PreemptiveHPPIAvailable(bits(2) domain)
    if domain == DOM_EL3 then
        return FALSE; // Ob10 in ICC_CR0_EL3.PID encodes no preemptive domain
    if PreemptiveDomain() != domain then
        return FALSE;
    return HPPIAvailable(domain) && UInt(GetHPPI(domain).Priority) < UInt(
       ←BankedICC_CR0_EL1(domain).IPPT);
// GICSignalException()
// Signal CPU interrupt exception based on HPPI availability in the Interrupt
// Domains.
GICPhysicalExceptions()
    if CurrentDomain() == DOM_EL3 then
        if HPPIAvailable(DOM_EL3) ||
           HPPIAvailable(DOM_S) ||
           HPPIAvailable(DOM_NS) ||
```

```
HPPIAvailable (DOM_RL) then
           FIQ();
    else // Non-EL3 Domain
        if HPPIAvailable(EL3) || PreemptiveHPPIAvailable(PreemptiveDomain()) then
           FIO();
        elsif HPPIAvailable(CurrentDomain()) then
           IRQ();
    return;
// gic_shared_functions.asl
sysreg_ICC_CR0_EL1 BankedICC_CR0_EL1(bits(2) domain)
    case domain of
        when DOM_EL3 assert FALSE;
        when DOM_S return ICC_CR0_EL1[0];
        when DOM_NS return ICC_CR0_EL1[1];
        when DOM_RL return ICC_CR0_EL1[2];
bits(2) CurrentDomain()
    if PSTATE.EL == EL3 then
       return DOM_EL3;
    else
       bits(2) state_bits;
        if HaveRME() then
           state_bits = SCR_EL3.<NSE,NS>;
        else
           state_bits = '0' : SCR_EL3.NS;
        case state_bits of
           when '00' return DOM_S;
           when '01' return DOM_NS;
           when '10' Unreachable();
           when '11' return DOM_RL;
// HavePreemptiveDomain()
// Returns TRUE when the Domain selected by ICC_CR0_EL3 is implemented, FALSE
   →otherwise
// MostPrivilegedSecurityState()
// Returns the most privileged Security state
SecurityState MostPrivilegedSecurityState()
    // We can always ask SecurityStateAtEL with 'EL3' to get the right answer even
       \hookrightarrow if EL3 is not implemented
    return SecurityStateAtEL(EL3)
// IsAccessMPPAS()
// Returns TRUE when an access is made with the Most Privileged PAS
boolean IsAccessMPPAS();
    mpss = MostPrivilegedSecurityState()
    case mpss of
        when SS_Root return IsAccessRoot();
        when SS_Secure return IsAccessSecure();
```

```
when SS_NonSecure return IsAccessNonSecure();
        when SS_Realm Unreachable();
// IsAccessIWBMPPAS()
// Returns TRUE when an access is made with the Most Privileged PAS of the IWB
boolean IsAccessIWBMPPAS();
    iwb_mppas = IWBMPPAS()
    case iwb_mppas of
        when PAS_Root return IsAccessRoot();
        when PAS_Secure return IsAccessSecure();
        when PAS_NonSecure return IsAccessNonSecure();
        otherwise Unreachable();
bits(2) IWBMPPAS()
    domains = IWB_IDR0.INT_DOMS
    case domains of
        when '0001' return PAS_Secure;
        when '0010' return PAS_NonSecure;
        when '0111' return PAS_Secure;
        when '1110' return PAS_Root;
        when '1111' return PAS_Root;
        otherwise Unreachable();
// IsWireAccessible()
// Returns TRUE when a wire can be configured on an IWB for a given access PAS
boolean IsWireAccessible(bits(11) n, bits(5) x)
    // IWB MPPAS can access state of all wires
    if IsAccessIWBMPPAS() then
        return TRUE;
    reg_index = (n * 2) + (x / 16);
    wire_index = x MOD 16;
    wire_domain = IWB_WDOMAINR[reg_index].WDOM[wire_index];
    if IsAccessRoot() then
        // If PAS is Root and it is not the IWB MPPAS, then either EL3 Domain is
        // not supported or it is associated with the Secure PAS.
        return FALSE;
    if IsAccessSecure() then
        // Wire cannot be accessed if Secure Interrupt Domain is not implemented.
        if IWB_IDR0.INT_DOMS[0] == 0 then
            return FALSE;
        if wire_domain == DOM_S then
               return TRUE;
    if IsAccessRealm() then
        // Wire cannot be accessed if Realm Interrupt Domain is not implemented.
        if IWB_IDR0.INT_DOMS[3] == 0 then
            return FALSE;
        if wire_domain == DOM_RL then
            return TRUE;
```

```
if IsAccessNonSecure() then
       // Wire cannot be accessed if Non-secure Interrupt Domain is not
           \hookrightarrow implemented.
       if IWB_IDR0.INT_DOMS[1] == 0 then
           return FALSE;
       if wire_domain == DOM_NS then
           return TRUE;
    Unreachable();
// IsWireDomainRO()
// Returns TRUE if the Interrupt Domain assignment of an IWB input wire is fixed
boolean IsWireDomainRO(bits(16) wire_idx)
    return IMPLEMENTATION_DEFINED "Whether the Interrupt Domain assignment of a
       \hookrightarrowwire is fixed.";
// IsWireConfigRO()
// Returns TRUE if the Trigger mode of an IWB input wire is read-only
boolean IsWireConfigRO(bits(16) wire_idx)
    return IMPLEMENTATION_DEFINED "Whether an IWB input wire Trigger mode is read-

→only";

// IsPPIAssignedToCurrentDomain()
// Returns TRUE when a physial PPI is assigned to the Current Physical Interrupt
    →Domain
boolean IsPPIAssignedToCurrentDomain(bits(7) PPI_ID)
    n = PPI_ID DIV 32;
    x = PPI_ID MOD 32;
    if !HaveEL(EL3) then
       return TRUE;
    return ICC_PPI_DOMAINR_EL3[n] <x + 1:x> == CurrentDomain();
// IsSPIAssignedToDomain()
// Returns TRUE if the SPI is assigned to the specified domain.
// This would be correctly modeled by accessing the internal SPI Domain assignment
   ↔ state that is exposed via IRS_SPI_DOMAINR.
boolean IsSPIDVISupported(bits(29) spi_id, bits(2) domain);
// IsSPIDVISupported()
// Returns TRUE if the SPI supports being assigned to a VM.
// Arm strongly recommends that an SPI that can be driven by a signal external to
```

```
\hookrightarrowthe IRS supports assignment to a VM.
```

boolean IsSPIDVISupported(bits(29) spi\_id)
 return IMPLEMENTATION\_DEFINED "Whether the SPI can be assigned to a VM.";

# Glossary

#### Abort

Any situation where the memory system returns an error response to a memory access by the GIC. Examples of error responses could include GPF faults returned by an SMMU[5] or DECERR in AMBA AXI[7] systems.

#### Accepted

An event has been Accepted by a GICv5 system component when it has sent a reply to the sender of the event. See 3.2 *Communication between GIC system components* for more information.

#### **Application PE**

A PE used by the operating system or hypervisor to execute user application or kernel threads.

#### ASL

Arm Specification Language Language used to express pseudocode implementations. Formal language definition can be found in the *Arm<sup>®</sup> Specification Language Reference Manual*[14].

#### **Candidate HPPI**

An interrupt identified among a subset of all interrupts as a candidate for the HPPI. See 2.7 *Interrupt Prioritization* for more information.

#### **Doorbell PPI**

A PPI used to signal to an Interrupt Domain that there is an interrupt pending for another Interrupt Domain. See 2.9.6 *Doorbell PPIs* for more information.

#### Downstream

An interrupt signal flows downstream from the interrupt source through the ITS, IRS, and is presented to PEs.

Where two components are involved, *upstream* is the component farthest away from the PE, and *downstream* is the component closest to the PE.

This also applies to the GICv5 Stream protocol where downstream packets flow from the IRS to the PE, and upstream packets flow from the PE to the IRS.

#### GPC

Granule Protection Check. The process of checking whether an access to a Location is permitted by the Granule Protection Table. This term is also used to refer to an MMU-attached or SMMU-attached Granular PAS filter that implements the Granule Protection Check. See *Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture*[1] for more information.

#### HPPI

| <b>Highest Priorit</b> | y Pending Interru | pt. See | 2.7 In | terrunt l | <b>Prioritization</b> | for more | information. |
|------------------------|-------------------|---------|--------|-----------|-----------------------|----------|--------------|
| inghest i norn         | y ronang monu     |         | 2.1 11 | acrapi 1  | i nonniganon          | ior more | mormation.   |

IPI

Inter-processor Interrupt. See 2.5 Inter-Processor Interrupts for more information.

#### IRI

Interrupt Routing Infrastructure. See Chapter 1 Introduction and Chapter 3 GICv5 system architecture for more information.

#### IRS

#### Glossary

|                  | Interrupt Routing Service. See Chapter 4 Interrupt routing service (IRS) for more information.                                                                                                                                                                                     |  |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| ITS              | Interrupt Translation Service. See Chapter 5 Interrupt translation service (ITS) for more information.                                                                                                                                                                             |  |  |  |  |  |
| IWB              | Interrupt Wire Bridge. See Chapter 6 Interrupt Wire Bridge (IWB) for more information.                                                                                                                                                                                             |  |  |  |  |  |
| LPI              | Logical Peripheral Interrupt. See 2.4 Interrupt types and identifiers for more information.                                                                                                                                                                                        |  |  |  |  |  |
| MPPAS            | Most Privileged PAS. See 3.1 Interrupt Domains for more information.                                                                                                                                                                                                               |  |  |  |  |  |
| MPSS             | Most Privileged Security State. See 3.1 Interrupt Domains for more information.                                                                                                                                                                                                    |  |  |  |  |  |
| NMI              | Non-maskable Interrupt. See 2.9 The physical CPU interface for more information.                                                                                                                                                                                                   |  |  |  |  |  |
| PAS              | Physical Address Space. See Arm <sup>®</sup> Architecture Reference Manual, for A-profile architecture[1] for more information.                                                                                                                                                    |  |  |  |  |  |
| PPI              | PE-Private Peripheral Interrupt. See 2.4 Interrupt types and identifiers for more information.                                                                                                                                                                                     |  |  |  |  |  |
| Processed        |                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                  | An interrupt event has been processed by an IRS when the interrupt effects of an interrupt event can be observed by PEs. See 4.5 <i>IRS synchronization requests</i> for more information.                                                                                         |  |  |  |  |  |
| RAS              |                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                  | Reliability, Availability, and Serviceability. See Arm <sup>®</sup> Architecture Reference Manual, for A-profile architecture[1] and Arm <sup>®</sup> Reliability, Availability, and Serviceability (RAS) System Architecture for A-profile architecture[15] for more information. |  |  |  |  |  |
| Reachable        |                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                  | An INTID is reachable from a PE if the PE can access the configuration and state of the interrupt. See 2.6 <i>GIC System instructions</i> and 4.6 <i>Interrupt configuration and state</i> for more information.                                                                   |  |  |  |  |  |
| Running priority |                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                  | The highest active priority on an Interrupt Domain. See 2.8 Interrupt handling for more information.                                                                                                                                                                               |  |  |  |  |  |
| SGI              |                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                  | Software Generated Interrupt. A dedicated interrupt type for IPIs in GIC version 3 and version 4. See <i>Arm</i> <sup>®</sup> <i>Generic Interrupt Controller Architecture Specification, GIC architecture version 3 and version 4</i> [3] for more information.                   |  |  |  |  |  |
| SPI              |                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                  | Shared Peripheral Interrupt. See 2.4 Interrupt types and identifiers for more information.                                                                                                                                                                                         |  |  |  |  |  |
| Unreachable      |                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|                  | See Reachable.                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| Upstream         |                                                                                                                                                                                                                                                                                    |  |  |  |  |  |

#### Glossary

See Downstream

#### VM

Virtual machine.

#### VMSA

Virtual Memory System Architecture defined in Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture[1].

#### VPE

Virtual PE.

#### **VPE doorbell**

An LPI which is signaled when a non-resident VPE receives an interrupt. See 4.10.7 *VPE doorbells* for more information.

#### Write-One-to-Clear (W1C)

Writes of 0 to the bit are ignored. A write of 1 clears the bit to 0. See *Arm<sup>®</sup> Architecture Reference Manual, for A-profile architecture*[1] for more information.