### **MOVN**

Move wide with NOT moves the inverse of an optionally-shifted 16-bit immediate value to a register.

This instruction is used by the alias MOV (inverted wide immediate).

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 

sf 0 0 1 0 0 1 0 1 hw | imm16 Rd

opc

```
32-bit (sf == 0 \&\& hw == 0x)
```

```
MOVN <Wd>>, #<imm>{, LSL #<shift>}
64-bit (sf == 1)
```

```
MOVN <Xd>, #<imm>{, LSL #<shift>}

if sf == '0' && hw<1> == '1' then UNDEFINED;

integer d = <u>UInt(Rd);</u>
constant integer datasize = 32 << <u>UInt(sf);</u>
constant integer pos = <u>UInt(hw:'0000');</u>
```

### **Assembler Symbols**

| <wd></wd> | Is the 32-bit name of the general-purpose destination |
|-----------|-------------------------------------------------------|
|           |                                                       |

register, encoded in the "Rd" field.

<Xd> Is the 64-bit name of the general-purpose destination

register, encoded in the "Rd" field.

<imm> Is the 16-bit unsigned immediate, in the range 0 to 65535,

encoded in the "imm16" field.

<shift> For the 32-bit variant: is the amount by which to shift the

immediate left, either 0 (the default) or 16, encoded in the

"hw" field as <shift>/16.

For the 64-bit variant: is the amount by which to shift the immediate left, either 0 (the default), 16, 32 or 48, encoded in the "hw" field as <shift>/16.

#### **Alias Conditions**

| Alias                             | Of<br>variant | Is p | preferred when          |     |    |     |       |     |   |                           |
|-----------------------------------|---------------|------|-------------------------|-----|----|-----|-------|-----|---|---------------------------|
| MOV                               | 64-bit        | !    | ( <u>IsZero</u> (imm16) | & & | hw | ! = | '00') |     |   |                           |
| (inverted wide                    |               |      |                         |     |    |     |       |     |   |                           |
| immediate)                        |               |      |                         |     |    |     |       |     |   |                           |
| MOV                               | 32-bit        | !    | ( <u>IsZero</u> (imm16) | & & | hw | !=  | '00') | & & | ! | <pre>IsOnes (imm16)</pre> |
| (inverted                         |               |      |                         |     |    |     |       |     |   |                           |
| <u>wide</u><br><u>immediate</u> ) |               |      |                         |     |    |     |       |     |   |                           |

# **Operation**

```
bits(datasize) result;

result = Zeros(datasize);

result<pos+15:pos> = imm16;
result = NOT(result);
X[d, datasize] = 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.

| <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> | <b>Encoding</b> |

 $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