## MOV (immediate, predicated, zeroing)

Move signed integer immediate to vector elements (zeroing)

Move a signed integer immediate to each active element in the destination vector. Inactive elements in the destination vector register are set to zero.

The immediate operand is a signed value in the range -128 to +127, and for element widths of 16 bits or higher it may also be a signed multiple of 256 in the range -32768 to +32512 (excluding 0).

The immediate is encoded in 8 bits with an optional left shift by 8. The preferred disassembly when the shift option is specified is "#<simm8>, LSL #8". However an assembler and disassembler may also allow use of the shifted 16-bit value unless the immediate is 0 and the shift amount is 8, which must be unambiguously described as "#0, LSL #8".

This is an alias of <u>CPY (immediate, zeroing)</u>. This means:

- The encodings in this description are named to match the encodings of CPY (immediate, zeroing).
- The description of <u>CPY (immediate, zeroing)</u> gives the operational pseudocode, any constrained unpredictable behavior, and any operational information for this instruction.

is equivalent to

and is always the preferred disassembly.

## **Assembler Symbols**

<Zd>

Is the name of the destination scalable vector register, encoded in the "Zd" field.

<T>

Is the size specifier, encoded in "size":

| size | <t></t> |
|------|---------|
| 0.0  | В       |
| 01   | Н       |
| 10   | S       |
| 11   | D       |

| <pg></pg>       | Is the name of the governing scalable predicate register, encoded in the "Pg" field. |
|-----------------|--------------------------------------------------------------------------------------|
| <imm></imm>     | Is a signed immediate in the range -128 to 127, encoded in the "imm8" field.         |
| <shift></shift> |                                                                                      |

Is the optional left shift to apply to the immediate, defaulting to LSL #0 and encoded in "sh":

| sh | <shift></shift> |  |  |
|----|-----------------|--|--|
| 0  | LSL #0          |  |  |
| 1  | LSL #8          |  |  |

## **Operation**

The description of <u>CPY (immediate, zeroing)</u> gives the operational pseudocode for this instruction.

## **Operational information**

If FEAT\_SVE2 is implemented or FEAT\_SME is implemented, then if PSTATE.DIT is 1:

- The execution time of this instruction is independent of:
  - The values of the data supplied in any of its operand registers when its governing predicate register contains the same value for each execution.
  - 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 operand registers when its governing predicate register contains the same value for each execution.
  - The values of the NZCV flags.

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

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

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

Sn Pseu