# **GITS\_CTLR, ITS Control Register**

The GITS CTLR characteristics are:

### **Purpose**

Controls the operation of an ITS.

## **Configuration**

The ITS\_Number (bits [7:4]) and bit [1] fields apply only in FEAT\_GICv4 implementations, and are res0 in FEAT\_GICv3 implementations.

### **Attributes**

GITS CTLR is a 32-bit register.

## **Field descriptions**

| 31        | 3029282726252423222120191817161514131211109 | 8              | 7   | 6        | 5  | 4   | 3  | 2  | 1    | 0       |
|-----------|---------------------------------------------|----------------|-----|----------|----|-----|----|----|------|---------|
| Quiescent | RES0                                        | <b>UMSlirq</b> | ITS | <u>N</u> | um | nbe | ЯE | SO | ImDe | Enabled |

#### Quiescent, bit [31]

Read-only. Indicates completion of all ITS operations when GITS CTLR. Enabled == 0.

| Quiescent | Meaning                  |
|-----------|--------------------------|
| 0b0       | The ITS is not quiescent |
|           | and cannot be powered    |
|           | down.                    |
| 0b1       | The ITS is quiescent and |
|           | can be powered down.     |

For the ITS to be considered inactive, there must be no transactions in progress. In addition, all operations required to ensure that mapping data is consistent with external memory must be complete.

#### **Note**

In distributed GIC implementations, this bit is set to 1 only after the ITS forwards any operations that have not yet been completed to the Redistributors and receives confirmation that all such operations have reached the appropriate Redistributor.

In FEAT\_GICv3, FEAT\_GICv3p1, and FEAT\_GICv4, when GITS\_CTLR.Enabled == 1, the value of GITS\_CTLR.Quiescent is unknown.

In FEAT\_GICv4p1, when GITS\_CTLR.Enabled == 1, the value of GITS\_CTLR.Quiescent reads as 1 until the write to Enabled has taken effect and then reads as 0.

The reset behavior of this field is:

• On a GIC reset, this field resets to 1.

#### Bits [30:9]

Reserved, res0.

#### UMSIirq, bit [8]

Unmapped MSI reporting interrupt enable.

| UMSIirq | Meaning                         |
|---------|---------------------------------|
| 0b0     | The ITS does not assert an      |
|         | interrupt signal when           |
|         | <b>GITS_STATUSR</b> .UMSI is 1. |
| 0b1     | The ITS asserts an interrupt    |
|         | signal when                     |
|         | GITS_STATUSR.UMSI is 1.         |

If GITS TYPER.UMSIirq is 0, this field is res0.

The reset behavior of this field is:

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

#### ITS Number, bits [7:4]

In FEAT GICv3 implementations this field is res0.

In FEAT\_GICv4 implementations with more than one ITS instance, this field indicates the ITS number for use with 'VMOVP GICv4.0' in ARM® Generic Interrupt Controller Architecture Specification, GIC architecture version 3.0 and version 4.0 (ARM IHI 0069).

When <u>GITS\_TYPER</u>.VMOVP is 1, this field may be implemented as res0.

It is implementation defined whether this field is programmable or RO.

If this field is programmable, changing this field when GITS\_CTLR.Quiescent == 0 or GITS\_CTLR.Enabled == 1 is unpredictable.

The reset behavior of this field is:

• On a GIC reset, this field resets to an architecturally unknown value.

#### Bits [3:2]

Reserved, res0.

#### ImDe, bit [1]

In GICv3 implementations, this bit is res0.

In GICv4 implementations, this bit is implementation defined.

The reset behavior of this field is:

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

#### Enabled, bit [0]

Controls whether the ITS is enabled:

| Enabled | Meaning                        |
|---------|--------------------------------|
| 0b0     | The ITS is not enabled. Writes |
|         | to <u>GITS_TRANSLATER</u> are  |
|         | ignored and no further         |
|         | command queue entries are      |
|         | processed.                     |
| 0b1     | The ITS is enabled. Writes to  |
|         | GITS TRANSLATER result in      |
|         | interrupt translations and the |
|         | command queue is processed.    |

If a write to this register changes this field from 1 to 0, the ITS must ensure that both:

- Any caches containing mapping data are made consistent with external memory.
- GITS\_CTLR.Quiescent == 0 until all caches are consistent with external memory.

Changing GITS\_CTLR.Enabled from 0 to 1 when GITS CTLR.Quiescent is 0 results in unpredictable behavior.

The reset behavior of this field is:

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

# **Accessing GITS\_CTLR**

## **GITS\_CTLR** can be accessed through the memory-mapped interfaces:

| Component       | Offset | Instance  |  |  |
|-----------------|--------|-----------|--|--|
| GIC ITS control | 0x0000 | GITS_CTLR |  |  |

Accesses on this interface are RW.

| AArch32          | AArch64          | AArch32             | AArch64             | Index by        | <u>External</u> |
|------------------|------------------|---------------------|---------------------|-----------------|-----------------|
| <u>Registers</u> | <u>Registers</u> | <u>Instructions</u> | <u>Instructions</u> | <b>Encoding</b> | Registers       |

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

Copyright © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.