# TLBIP IPAS2LE1IS, TLBIP IPAS2LE1ISNXS, TLB Invalidate Pair by Intermediate Physical Address, Stage 2, Last level, EL1, Inner Shareable

The TLBIP IPAS2LE1IS, TLBIP IPAS2LE1ISNXS characteristics are:

## **Purpose**

If 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 2 only translation table entry, from the final level of the translation table walk.
  - Or the entry is a 64-bit stage 2 only translation table entry, from the final level of the translation table walk, if TTL[3:2] is 0b00.
- If FEAT RME is implemented, one of the following applies:
  - <u>SCR\_EL3</u>.{NSE, NS} is {0, 0} and the entry would be required to translate the specified IPA using the Secure EL1&0 translation regime.
  - <u>SCR\_EL3</u>.{NSE, NS} is {0, 1} and the entry would be required to translate the specified IPA using the Non-secure EL1&0 translation regime.
  - <u>SCR\_EL3</u>.{NSE, NS} is {1, 1} and the entry would be required to translate the specified IPA using the Realm EL1&0 translation regime.
- If FEAT RME is not implemented, one of the following applies:
  - <u>SCR\_EL3</u>.NS is 0 and the entry would be required to translate the specified IPA using the Secure EL1&0 translation regime.
  - <u>SCR\_EL3</u>.NS is 1 and the entry would be required to translate the specified IPA using the Non-secure EL1&0 translation regime.
- The entry would be used with the current VMID.

The invalidation is not required to apply to caching structures that combine stage 1 and stage 2 translation table entries.

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

For more information about the architectural requirements for this System instruction, see 'Invalidation of TLB entries from stage 2 translations'.

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 IPAS2LE1IS, TLBIP IPAS2LE1ISNXS are undefined.

#### **Attributes**

TLBIP IPAS2LE1IS, TLBIP IPAS2LE1ISNXS is a 128-bit System instruction.

## Field descriptions

| 127  | 12712612512412312212112011911811711611511411311211111010910810710610510410310210110099989796 |    |    |    |    |    |    |    |    |    |    |     |     |      |     |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |
|------|----------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|-----|-----|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|
|      | RES0                                                                                         |    |    |    |    |    |    |    |    |    |    |     | PA[ | 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 | 5564 |
|      | IPA[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 |
| NS   | NS RESO TTL                                                                                  |    |    |    |    |    |    |    |    |    | R  | ESC | )   |      |     |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |
| 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.

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

Bits[55:12] of the intermediate physical address to match.

### NS, bit [63]

#### When FEAT\_RME is implemented:

When the instruction is executed and  $\underline{SCR\_EL3}$ .{NSE, NS} == {0, 0}, NS selects the IPA space.

| NS  | Meaning                             |  |  |  |  |  |  |
|-----|-------------------------------------|--|--|--|--|--|--|
| 0b0 | IPA is in the Secure IPA space.     |  |  |  |  |  |  |
| 0b1 | IPA is in the Non-secure IPA space. |  |  |  |  |  |  |

When the instruction is executed and  $SCR\_EL3.{NSE, NS} == \{1, 1\}$ , this field is res0, and the instruction applies only to the Realm IPA space.

When the instruction is executed and SCR\_EL3.{NSE, NS} == {0, 1}, this field is res0, and the instruction applies only to the Nonsecure IPA space.

#### When FEAT SEL2 is implemented and FEAT RME is not implemented:

Not Secure. Specifies the IPA space.

| NS  | Meaning                             |
|-----|-------------------------------------|
| 0b0 | IPA is in the Secure IPA space.     |
| 0b1 | IPA is in the Non-secure IPA space. |

When the instruction is executed in Non-secure state, this field is res0, and the instruction applies only to the Non-secure IPA space.

When FEAT\_SEL2 is not implemented, or if EL2 is disabled in the current Security state, this field is res0.

#### Otherwise:

Reserved, res0.

#### Bits [62: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.

| TTI. | Meaning    |  |
|------|------------|--|
|      | 1-10411119 |  |

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 IPAS2LE1IS, TLBIP IPAS2LE1ISNXS**

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

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

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

```
if 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
    AArch64.TLBIP_IPAS2 (SecurityStateAtEL (EL1),
Regime_EL10, VMID[], Shareability_ISH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
elsif PSTATE.EL == EL3 then
    if !EL2Enabled() then
         return;
         AArch64.TLBIP_IPAS2 (SecurityStateAtEL(EL1),
Regime_EL10, VMID[], Shareability_ISH,
TLBILevel_Last, TLBI_AllAttr, X[t2, 64]:X[t, 64]);
```

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

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

```
if !IsFeatureImplemented(FEAT_XS) then
    UNDEFINED;
elsif PSTATE.EL == EL0 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
    AArch64.TLBIP_IPAS2(SecurityStateAtEL(EL1),
Regime_EL10, VMID[], Shareability_ISH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
elsif PSTATE.EL == EL3 then
    if !EL2Enabled() then
        return;
else
        AArch64.TLBIP_IPAS2(SecurityStateAtEL(EL1),
Regime_EL10, VMID[], Shareability_ISH,
TLBILevel_Last, TLBI_ExcludeXS, X[t2, 64]:X[t, 64]);
```

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

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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