## **MOVT** (scalar to ZT0)

Move 8 bytes from general-purpose register to ZT0

Move 8 bytes to the ZT0 register at the byte offset specified by the immediate index from a general-purpose register. This instruction is UNDEFINED in Non-debug state.

# SME2 (FEAT SME2)

```
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 1 0 0 0 0 0 0 1 1 0 0 1 1 1 0 0 off3 0 0 1 1 1 1 1 | Rt
```

```
MOVT ZT0[<offs>], <Xt>
if !HaveSME2() |  !Halted() then UNDEFINED;
integer t = UInt(Rt);
integer offset = UInt(off3);
```

### **Assembler Symbols**

<offs> Is the immediate byte offset, a multiple of 8 in the range of

0 to 56, encoded in the "off3" field as <offs>/8.

<Xt> Is the 64-bit name of the general-purpose register to be

transferred, encoded in the "Rt" field.

### **Operation**

```
CheckSMEEnabled();
CheckSMEZT0Enabled();
bits(512) result = ZT0[512];

Elem[result, offset, 64] = X[t, 64];
ZT0[512] = result;
```

#### **Operational information**

If PSTATE.DIT is 1:

- The execution time of this instruction is independent of:
  - The values of the data supplied in any of its registers.
  - The values of the NZCV flags.
- The response of this instruction to asynchronous exceptions does not vary based on:
  - The values of the data supplied in any of its registers.
  - The values of the NZCV flags.

Sh Pseu BaseSIMD&FPSVESMEIndex byInstructionsInstructionsInstructionsInstructions

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

Sh Pseu

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