# TLBIP VALE2, TLBIP VALE2NXS, TLB Invalidate Pair by VA, Last level, EL2

The TLBIP VALE2, TLBIP VALE2NXS characteristics are:

# **Purpose**

When EL2 is implemented and enabled in the current Security state, 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.
  - Or the entry is a 64-bit stage 1 translation table entry, if TTL[3:2] is 0b00.
- The entry would be used to translate the specified VA using the EL2 or EL2&0 translation regime, as determined by the current value of the HCR EL2.E2H bit, for the Security state.
- If <u>HCR\_EL2</u>.E2H == 0, the entry is from the final level of the translation table walk.
- If <u>HCR\_EL2</u>.E2H == 1, one of the following applies:
  - The entry is a global entry from the final level of the translation table walk.
  - The entry is a non-global entry from the final level of the translation table walk that matches the specified ASID.

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 the PE that executes this System instruction.

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 VALE2, TLBIP VALE2NXS are undefined.

#### **Attributes**

TLBIP VALE2, TLBIP VALE2NXS is a 128-bit System instruction.

## Field descriptions

| 127  | 126           | 125 | 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 | )99 | 989 | 9796 |
|------|---------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|
|      | 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  | 67  | 666 | 6564 |
|      | 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  | 35  | 343 | 3332 |
|      | ASID 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 0  |
| RES0 |               |     |     |     |     |     |     |     |     |     |     |     |           |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |      |

#### 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 ASID value (if appropriate) and VA will be affected by this System instruction.

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.

#### ASID, bits [63:48] When HCR EL2.E2H == 1:

ASID value to match. Any TLB entries that match the ASID value and VA value will be affected by this System instruction.

Global TLB entries that match the VA value will be affected by this System instruction, regardless of the value of the ASID field.

If the implementation supports 16 bits of ASID, then the upper 8 bits of the ASID must be written to 0 by software when the context being invalidated only uses 8 bits.

#### Otherwise:

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.

| Meaning                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| No information supplied as to the 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 translation granule. The level of walk for the leaf level 0bxx 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. |
|                                                                                                                                                                                                                                            |

Obloxx The entry comes from a 16KB

translation granule. The level of walk for the leaf level <code>Obxx</code> 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.

0b11xx The entry comes from a 64KB

translation granule. The level of walk for the leaf level <code>Obxx</code> 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.

#### Bits [43:0]

Reserved, res0.

# **Executing TLBIP VALE2, TLBIP VALE2NXS**

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

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

| op0  | op1   | CRn    | CRm    | op2   |  |  |  |
|------|-------|--------|--------|-------|--|--|--|
| 0b01 | 0b100 | 0b1000 | 0b0111 | 0b101 |  |  |  |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR EL2.NV == '1' then
        AArch64.SystemAccessTrap(EL2, 0x14);
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if HCR EL2.E2H == '1' then
        AArch64.TLBIP_VA(SecurityStateAtEL(EL2),
Regime_EL20, VMID_NONE, Shareability_NSH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
        AArch64.TLBIP_VA(SecurityStateAtEL(EL2),
Regime_EL2, VMID_NONE, Shareability_NSH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
elsif PSTATE.EL == EL3 then
    if !EL2Enabled() then
        UNDEFINED;
    elsif HCR_EL2.E2H == '1' then
        AArch64.TLBIP_VA(SecurityStateAtEL(EL2),
Regime_EL20, VMID_NONE, Shareability_NSH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
    else
        AArch64.TLBIP_VA(SecurityStateAtEL(EL2),
Regime_EL2, VMID_NONE, Shareability_NSH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
```

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

| op0  | op1   | CRn    | CRm    | op2   |  |  |  |  |
|------|-------|--------|--------|-------|--|--|--|--|
| 0b01 | 0b100 | 0b1001 | 0b0111 | 0b101 |  |  |  |  |

```
if !IsFeatureImplemented(FEAT_XS) then
    UNDEFINED;
elsif PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.NV == '1' then
        AArch64.SystemAccessTrap(EL2, 0x14);
    else
        UNDEFINED;
elsif PSTATE.EL == EL2 then
    if HCR\_EL2.E2H == '1' then
        AArch64.TLBIP_VA(SecurityStateAtEL(EL2),
Regime_EL20, VMID_NONE, Shareability_NSH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
    else
        AArch64.TLBIP_VA(SecurityStateAtEL(EL2),
Regime_EL2, VMID_NONE, Shareability_NSH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
elsif PSTATE.EL == EL3 then
```

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.