External

Registers

# ICC\_SRE\_EL3, Interrupt Controller System Register Enable Register (EL3)

The ICC SRE EL3 characteristics are:

## **Purpose**

Controls whether the System register interface or the memory-mapped interface to the GIC CPU interface is used for EL3.

## **Configuration**

This register is present only when FEAT\_GICv3 is implemented and EL3 is implemented. Otherwise, direct accesses to ICC\_SRE\_EL3 are undefined.

#### **Attributes**

ICC SRE EL3 is a 64-bit register.

# Field descriptions

| 636261605958575655545352515049484746454443424140393837369434444342414039383736944444444444444444444444444444444444 | 35     | 34  | 33  | 32  |
|--------------------------------------------------------------------------------------------------------------------|--------|-----|-----|-----|
| RES0                                                                                                               |        |     |     |     |
| RES0                                                                                                               | Enable | DIB | DFB | SRE |
| 31302928272625242322212019181716151413121110 9 8 7 6 5 4                                                           | 3      | 7   | 1   | 0   |

#### Bits [63:4]

Reserved, res0.

#### Enable, bit [3]

Enable. Enables lower Exception level access to <a href="ICC\_SRE\_EL1">ICC\_SRE\_EL1</a> and <a href="ICC\_SRE\_EL2">ICC\_SRE\_EL2</a>.

| Enable | Meaning                                                |
|--------|--------------------------------------------------------|
| 0b0    | EL1 accesses to <u>ICC_SRE_EL1</u>                     |
|        | trap to EL3, unless these                              |
|        | accesses are trapped to EL2 as                         |
|        | a result of                                            |
|        | $ICC\_SRE\_EL2.Enable == 0.$                           |
|        | EL2 accesses to ICC SRE EL1                            |
|        | and <a href="ICC_SRE_EL2">ICC_SRE_EL2</a> trap to EL3. |

| 0b1 | EL1 accesses to <u>ICC SRE EL1</u> |
|-----|------------------------------------|
|     | do not trap to EL3.                |
|     | EL2 accesses to <u>ICC_SRE_EL1</u> |
|     | and ICC SRE EL2 do not trap        |
|     | to EL3.                            |

If ICC\_SRE\_EL3.SRE is RAO/WI, an implementation is permitted to make the Enable bit RAO/WI.

If ICC\_SRE\_EL3.SRE is 0, the Enable bit behaves as 1 for all purposes other than reading the value of the bit.

The reset behavior of this field is:

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

#### **DIB**, bit [2]

Disable IRQ bypass.

| DIB | Meaning              |
|-----|----------------------|
| 0b0 | IRQ bypass enabled.  |
| 0b1 | IRQ bypass disabled. |

In systems that do not support IRQ bypass, this bit is RAO/WI.

The reset behavior of this field is:

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

#### DFB, bit [1]

Disable FIQ bypass.

| DFB | Meaning              |
|-----|----------------------|
| 0b0 | FIQ bypass enabled.  |
| 0b1 | FIQ bypass disabled. |

In systems that do not support FIQ bypass, this bit is RAO/WI.

The reset behavior of this field is:

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

#### SRE, bit [0]

System Register Enable.

| SRE | Meaning |
|-----|---------|
|     |         |

| 0b0 | The memory-mapped interface must be used. Access at EL3 to any ICH * or ICC * register other |
|-----|----------------------------------------------------------------------------------------------|
|     | than <u>ICC_SRE_EL1</u> ,<br><u>ICC_SRE_EL2</u> , or ICC_SRE_EL3 is                          |
|     | trapped to EL3                                                                               |
|     | <b>-</b> -                                                                                   |
| 0b1 | The System register interface to                                                             |
|     | the ICH_* registers and the EL1,                                                             |
|     | EL2, and EL3 ICC_* registers is                                                              |
|     | enabled for EL3.                                                                             |

If software changes this bit from 1 to 0, the results are unpredictable.

If Realm Management Extension is implemented, this field is RAO/WI.

FEAT\_GICv3 implementations that do not require GICv2 compatibility might choose to make this bit RAO/WI.

The reset behavior of this field is:

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

# **Accessing ICC\_SRE\_EL3**

This register is always System register accessible.

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, ICC\_SRE\_EL3

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b1100 | 0b1100 | 0b101 |

```
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_SRE_EL3;
```

# MSR ICC\_SRE\_EL3, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b1100 | 0b1100 | 0b101 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    UNDEFINED;
elsif PSTATE.EL == EL2 then
    UNDEFINED;
elsif PSTATE.EL == EL3 then
    ICC_SRE_EL3 = X[t, 64];
```

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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