| dex by | <u>S</u> ] |
|--------|------------|
| coding | Pseu       |

# LDNP (SIMD&FP)

Load Pair of SIMD&FP registers, with Non-temporal hint. This instruction loads a pair of SIMD&FP registers from memory, issuing a hint to the memory system that the access is non-temporal. The address that is used for the load is calculated from a base register value and an optional immediate offset.

For information about non-temporal pair instructions, see *Load/Store SIMD* and *Floating-point Non-temporal pair*.

Depending on the settings in the *CPACR\_EL1*, *CPTR\_EL2*, and *CPTR\_EL3* registers, and the current Security state and Exception level, an attempt to execute the instruction might be trapped.

| 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 |
|-------|----|----|----|----|----|----|----|---------------|----------------------|----------------|---|---|----|---|---|---|---|----|---|---|
| орс   | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 1             | imm7                 | Rt2            |   |   | Rn |   |   |   |   | Rt |   |   |
|       | _  |    |    |    |    |    |    | $\overline{}$ |                      | -              |   |   |    |   |   |   |   |    |   |   |

```
32-bit (opc == 00)
```

```
LDNP <St1>, <St2>, [<Xn | SP>{, #<imm>}]

64-bit (opc == 01)

LDNP <Dt1>, <Dt2>, [<Xn | SP>{, #<imm>}]

128-bit (opc == 10)

LDNP <Qt1>, <Qt2>, [<Xn | SP>{, #<imm>}]

// Empty.
```

For information about the constrained unpredictable behavior of this instruction, see *Architectural Constraints on UNPREDICTABLE behaviors*, and particularly *LDNP* (*SIMD&FP*).

### **Assembler Symbols**

| <dt1></dt1> | Is the 64-bit name of the first SIMD&FP register to be transferred, encoded in the "Rt" field.    |
|-------------|---------------------------------------------------------------------------------------------------|
| <dt2></dt2> | Is the 64-bit name of the second SIMD&FP register to be transferred, encoded in the "Rt2" field.  |
| <qt1></qt1> | Is the 128-bit name of the first SIMD&FP register to be transferred, encoded in the "Rt" field.   |
| <qt2></qt2> | Is the 128-bit name of the second SIMD&FP register to be transferred, encoded in the "Rt2" field. |

<St1> Is the 32-bit name of the first SIMD&FP register to be transferred, encoded in the "Rt" field. <St2> Is the 32-bit name of the second SIMD&FP register to be transferred, encoded in the "Rt2" field. <Xn|SP>Is the 64-bit name of the general-purpose base register or stack pointer, encoded in the "Rn" field. <imm> For the 32-bit variant: is the optional signed immediate byte offset, a multiple of 4 in the range -256 to 252, defaulting to 0 and encoded in the "imm7" field as <imm>/4. For the 64-bit variant: is the optional signed immediate byte offset, a multiple of 8 in the range -512 to 504, defaulting to 0 and encoded in the "imm7" field as <imm>/8. For the 128-bit variant: is the optional signed immediate byte offset, a multiple of 16 in the range -1024 to 1008, defaulting to 0 and encoded in the "imm7" field as <imm>/ 16

#### **Shared Decode**

```
integer n = UInt(Rn);
integer t = UInt(Rt);
integer t2 = UInt(Rt2);
if opc == '11' then UNDEFINED;
integer scale = 2 + UInt(opc);
constant integer datasize = 8 << scale;</pre>
bits (64) offset = LSL (SignExtend (imm7, 64), scale);
boolean tagchecked = n != 31;
boolean rt_unknown = FALSE;
if t == t2 then
    Constraint c = ConstrainUnpredictable(Unpredictable_LDPOVERLAP);
    assert c IN {Constraint_UNKNOWN, Constraint_UNDEF, Constraint_NOP};
    case c of
        when Constraint_UNKNOWN rt_unknown = TRUE; // result is UNKN
        when <a href="Constraint_UNDEF">Constraint_UNDEF</a> UNDEFINED;
```

## **Operation**

```
else
    address = X[n, 64];

address = address + offset;

data1 = Mem[address, dbytes, accdesc];
data2 = Mem[address+dbytes, dbytes, accdesc];
if rt_unknown then
    data1 = bits(datasize) UNKNOWN;
    data2 = bits(datasize) UNKNOWN;
    V[t, datasize] = data1;
V[t2, datasize] = data2;
```

# **Operational information**

If PSTATE.DIT is 1, the timing of this instruction is insensitive to the value of the data being loaded or stored.

| <u>Base</u>         | SIMD&FP             | <u>SVE</u>          | <u>SME</u>          | Index by |
|---------------------|---------------------|---------------------|---------------------|----------|
| <u>Instructions</u> | <u>Instructions</u> | <u>Instructions</u> | <u>Instructions</u> | Encoding |

Internal version only: is a v33.64, AdvSIMD v29.12, pseudocode no\_diffs\_2023\_09\_RC2, sve v2023-06\_rel ; Build timestamp: 2023-09-18T17:56

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

Sh Pseu