# TLBIP VAALE1OS, TLBIP VAALE1OSNXS, TLB Invalidate Pair by VA, All ASID, Last Level, EL1, Outer Shareable

The TLBIP VAALE1OS, TLBIP VAALE1OSNXS characteristics are:

## **Purpose**

Invalidates cached copies of translation table entries from TLBs that meet all the following requirements:

- The entry is a 128-bit stage 1 translation table entry, from the final level of the translation table walk.
  - Or the entry is a 64-bit stage 1 translation table entry, from the final level of the translation table walk, if TTL[3:2] is 0b00.
- When EL2 is implemented and enabled in the current Security state:
  - If <u>HCR\_EL2</u>.{E2H, TGE} is not {1, 1}, the entry would be used with the current VMID and would be required to translate the specified VA using the EL1&0 translation regime for the Security state.
  - If <u>HCR\_EL2</u>.{E2H, TGE} is {1, 1}, the entry would be required to translate the specified VA using the EL2&0 translation regime for the Security state.
- When EL2 is not implemented or is disabled in the current Security state, the entry would be required to translate the specified VA using the EL1&0 translation regime for the Security state.

The Security state is indicated by the value of <u>SCR\_EL3</u>.NS if FEAT\_RME is not implemented, or <u>SCR\_EL3</u>.{NSE, NS} if FEAT\_RME is implemented.

The invalidation applies to all PEs in the same Outer Shareable shareability domain as the PE that executes this System instruction.

### **Note**

When a TLB maintenance instruction is generated to the Secure EL1&0 translation regime and is defined to pass a VMID

argument, or would be defined to pass a VMID argument if <u>SCR\_EL3</u>.EEL2==1, then:

- A PE with <u>SCR\_EL3</u>.EEL2==1 is not architecturally required to invalidate any entries in the Secure EL1&0 translation of a PE in the same required shareability domain with <u>SCR\_EL3</u>.EEL2==0.
- A PE with <u>SCR\_EL3</u>.EEL2==0 is not architecturally required to invalidate any entries in the Secure EL1&0 translation of a PE in the same required shareability domain with <u>SCR\_EL3</u>.EEL2==1.
- A PE is architecturally required to invalidate all relevant entries in the Secure EL1&0 translation of a System MMU in the same required shareability domain with a VMID of 0.

## **Note**

For the EL1&0 and EL2&0 translation regimes, the invalidation applies to both global entries and non-global entries with any ASID.

If FEAT\_XS is implemented, the nXS variant of this System instruction is defined.

Both variants perform the same invalidation, but the TLBI System instruction without the nXS qualifier waits for all memory accesses using in-scope old translation information to complete before it is considered complete.

The TLBI System instruction with the nXS qualifier is considered complete when the subset of these memory accesses with XS attribute set to 0 are complete.

# **Configuration**

This instruction is present only when FEAT\_D128 is implemented. Otherwise, direct accesses to TLBIP VAALE1OS, TLBIP VAALE1OSNXS are undefined.

# **Attributes**

TLBIP VAALE1OS, TLBIP VAALE1OSNXS is a 128-bit System instruction.

## Field descriptions

| 12   | 7126          | 5125 | 124 | 123 | 122 | 121 | 120 | 119 | 118 | 117       | 116 | 115 | 114 | 113 | 112 | 111 | 110 | 109 | 108 | 107 | 106 | 105 | 104 | 103 | 102 | 101 | 100 | )999 | 89  | 796 |
|------|---------------|------|-----|-----|-----|-----|-----|-----|-----|-----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|-----|-----|
|      | RES0          |      |     |     |     |     |     |     |     | VA[55:12] |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |      |     |     |
| 95   | 94            | 93   | 92  | 91  | 90  | 89  | 88  | 87  | 86  | 85        | 84  | 83  | 82  | 81  | 80  | 79  | 78  | 77  | 76  | 75  | 74  | 73  | 72  | 71  | 70  | 69  | 68  | 676  | 666 | 564 |
|      | VA[55:12]     |      |     |     |     |     |     |     |     |           |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |      |     |     |
| 63   | 62            | 61   | 60  | 59  | 58  | 57  | 56  | 55  | 54  | 53        | 52  | 51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 43  | 42  | 41  | 40  | 39  | 38  | 37  | 36  | 353  | 343 | 332 |
|      | RESO TTL RESO |      |     |     |     |     |     |     |     |           |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |      |     |     |
| 31   | . 30          | 29   | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21        | 20  | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3    | 2 1 | L 0 |
| RESO |               |      |     |     |     |     |     |     |     |           |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |      |     |     |

## Bits [127:108]

Reserved, res0.

## VA[55:12], bits [107:64]

Bits[55:12] of the virtual address to match. Any appropriate TLB entries that match the VA will be affected by this System instruction, regardless of the ASID.

If the TLB maintenance instructions are targeting a translation regime that is using AArch32, and so has a VA of only 32 bits, then the software must treat bits[55:32] as res0.

The treatment of the low-order bits of this field depends on the translation granule size, as follows:

- Where a 4KB translation granule is being used, all bits are valid and used for the invalidation.
- Where a 16KB translation granule is being used, bits [1:0] of this field are res0 and ignored when the instruction is executed, because VA[13:12] have no effect on the operation of the instruction.
- Where a 64KB translation granule is being used, bits [3:0] of this field are res0 and ignored when the instruction is executed, because VA[15:12] have no effect on the operation of the instruction.

### Bits [63:48]

Reserved, res0.

# TTL, bits [47:44]

## When FEAT TTL is implemented:

Translation Table Level. Indicates the level of the translation table walk that holds the leaf entry for the address being invalidated.

| TTL | Meaning |  |
|-----|---------|--|
|     |         |  |

No information supplied as to 0b00xxthe translation table level. Hardware must assume that the entry can be from any level. In this case, TTL<1:0> is res0. The entry comes from a 4KB 0b01xx translation granule. The level of walk for the leaf level Obxx is encoded as: 0b00: If FEAT LPA2 is implemented, level 0. Otherwise, treat as if TTL<3:2> is 0b00. 0b01: Level 1. 0b10: Level 2. 0b11: Level 3. The entry comes from a 16KB 0b10xxtranslation granule. The level of walk for the leaf level Obxx is encoded as: 0b00: Reserved. Treat as if TTL < 3:2 > is 0b00.0b01: If FEAT LPA2 is implemented, level 1. Otherwise, treat as if TTL<3:2> is 0b00. 0b10: Level 2. 0b11 : Level 3. The entry comes from a 64KB 0b11xxtranslation granule. The level of walk for the leaf level Obxx is encoded as: 0b00: Reserved. Treat as if TTL < 3:2 > is 0b00.0b01: Level 1. 0b10: Level 2. 0b11: Level 3.

If an incorrect value of the TTL field is specified for the entry being invalidated by the instruction, then no entries are required by the architecture to be invalidated from the TLB.

## Otherwise:

Reserved, res0.

Reserved, res0.

# **Executing TLBIP VAALE1OS, TLBIP VAALE1OSNXS**

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

# TLBIP VAALE10S{, <Xt>, <Xt2>}

| op0  | op1   | CRn    | CRm    | op2   |  |  |
|------|-------|--------|--------|-------|--|--|
| 0b01 | 0b000 | 0b1000 | 0b0001 | 0b111 |  |  |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.TTLB == '1' then
        AArch64.SystemAccessTrap(EL2, 0x14);
    elsif EL2Enabled() && HCR_EL2.TTLBOS == '1' then
        AArch64.SystemAccessTrap(EL2, 0x14);
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3) | |
SCR_EL3.FGTEn == '1') && HFGITR_EL2.TLBIVAALE1OS ==
'1' then
        AArch64.SystemAccessTrap(EL2, 0x14);
    else
        if IsFeatureImplemented(FEAT XS) &&
IsFeatureImplemented(FEAT HCX) && IsHCRXEL2Enabled()
&& HCRX EL2.FnXS == '1' then
AArch64.TLBIP_VAA(SecurityStateAtEL(EL1),
Regime_EL10, VMID[], Shareability_OSH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
        else
AArch64.TLBIP_VAA(SecurityStateAtEL(EL1),
Regime_EL10, VMID[], Shareability_OSH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
elsif PSTATE.EL == EL2 then
    if HCR_EL2.<E2H, TGE> == '11' then
        AArch64.TLBIP_VAA(SecurityStateAtEL(EL2),
Regime EL20, VMID NONE, Shareability OSH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
    else
        AArch64.TLBIP_VAA(SecurityStateAtEL(EL1),
Regime_EL10, VMID[], Shareability_OSH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
elsif PSTATE.EL == EL3 then
    if HCR_EL2.<E2H, TGE> == '11' then
        AArch64.TLBIP_VAA(SecurityStateAtEL(EL2),
Regime_EL20, VMID_NONE, Shareability_OSH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
```

# TLBIP VAALE10SNXS{, <Xt>, <Xt2>}

| op0  | op1   | CRn    | CRm    | op2   |  |  |  |
|------|-------|--------|--------|-------|--|--|--|
| 0b01 | 0b000 | 0b1001 | 0b0001 | 0b111 |  |  |  |

```
if !IsFeatureImplemented(FEAT_XS) then
    UNDEFINED;
elsif PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.TTLB == '1' then
        AArch64.SystemAccessTrap(EL2, 0x14);
    elsif EL2Enabled() && HCR_EL2.TTLBOS == '1' then
        AArch64.SystemAccessTrap(EL2, 0x14);
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3) | |
SCR\_EL3.FGTEn == '1') &&
IsFeatureImplemented(FEAT_HCX) && (!
IsHCRXEL2Enabled() | HCRX_EL2.FGTnXS == '0') &&
HFGITR_EL2.TLBIVAALE1OS == '1' then
        AArch64.SystemAccessTrap(EL2, 0x14);
        AArch64.TLBIP_VAA(SecurityStateAtEL(EL1),
Regime_EL10, VMID[], Shareability_OSH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
elsif PSTATE.EL == EL2 then
    if HCR_EL2.<E2H, TGE> == '11' then
        AArch64.TLBIP_VAA (SecurityStateAtEL (EL2),
Regime_EL20, VMID_NONE, Shareability_OSH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
    else
        AArch64.TLBIP_VAA(SecurityStateAtEL(EL1),
Regime_EL10, VMID[], Shareability_OSH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
elsif PSTATE.EL == EL3 then
    if HCR_EL2.<E2H, TGE> == '11' then
        AArch64.TLBIP_VAA(SecurityStateAtEL(EL2),
Regime_EL20, VMID_NONE, Shareability_OSH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
    else
        AArch64.TLBIP_VAA(SecurityStateAtEL(EL1),
Regime_EL10, VMID[], Shareability_OSH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
```

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:01; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

Copyright  $\hat{A}$  © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.