# PIR\_EL3, Permission Indirection Register 3 (EL3)

The PIR EL3 characteristics are:

#### **Purpose**

Stage 1 Permission Indirection Register for privileged access of the EL3 translation regime.

### **Configuration**

This register is present only when FEAT\_S1PIE is implemented. Otherwise, direct accesses to PIR EL3 are undefined.

#### **Attributes**

PIR EL3 is a 64-bit register.

## Field descriptions

#### Perm<m>, bits [4m+3:4m], for m = 15 to 0

Represents Stage 1 Base Permissions.

| Perm <m></m> | Meaning                                           |
|--------------|---------------------------------------------------|
| 000000       | No access, Overlay applied.                       |
| 0b0001       | Read, Overlay applied.                            |
| 0b0010       | Execute, Overlay applied.                         |
| 0b0011       | Read and Execute, Overlay applied.                |
| 0b0100       | Reserved - treated as No access, Overlay applied. |
| 0b0101       | Read and Write, Overlay applied.                  |
| 0b0110       | Read, Write and Execute,<br>Overlay applied.      |
| 0b0111       | Read, Write and Execute,<br>Overlay applied.      |

| 0b1000 | Read, Overlay not applied.                            |
|--------|-------------------------------------------------------|
| 0b1001 | Read, GCS Read and GCS Write, Overlay not applied.    |
| 0b1010 | Read and Execute, Overlay not applied.                |
| 0b1011 | Reserved - treated as No access, Overlay not applied. |
| 0b1100 | Read and Write, Overlay not applied.                  |
| 0b1101 | Reserved - treated as No access, Overlay not applied. |
| 0b1110 | Read, Write and Execute,<br>Overlay not applied.      |
| 0b1111 | Reserved - treated as No access, Overlay not applied. |

This field is permitted to be cached in a TLB.

When Stage 1 Indirect Permission mechanism is disabled, this register is ignored.

The reset behavior of this field is:

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

#### **Accessing PIR\_EL3**

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

# MRS <Xt>, PIR\_EL3

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b1010 | 0b0010 | 0b011 |

```
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] = PIR_EL3;
```

## MSR PIR\_EL3, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b1010 | 0b0010 | 0b011 |

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

AArch32 Registers AArch64 Registers AArch32 Instructions AArch64 Instructions Index by Encoding External Registers

28/03/2023 16:01; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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