UMOV

Unsigned move vector element to general-purpose register

This instruction reads the unsigned integer from the source SIMD&FP register, zero-extends it to form a 32-bit or 64-bit value, and writes the result to the destination general-purpose register.

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.

This instruction is used by the alias MOV (to general).

Advanced SIMD
(FEAT_AdvSIMD)

313029282726252423222120191817161514131211109876543210
0Q001110000imm5001111RnRd
opimm4

Encoding for the 32-bit variant

Applies when (Q == 0)

UMOV <Wd>, <Vn>.<Ts>[<index>]

Encoding for the 64-bit variant

Applies when (Q == 1 && imm5 == x1000)

UMOV <Xd>, <Vn>.D[<index>]

Decode for all variants of this encoding

if !IsFeatureImplemented(FEAT_AdvSIMD) then EndOfDecode(Decode_UNDEF); if imm5 IN 'x0000' then EndOfDecode(Decode_UNDEF); constant integer size = LowestSetBitNZ(imm5<3:0>); constant integer d = UInt(Rd); constant integer n = UInt(Rn); constant integer esize = 8 << size; constant integer datasize = 32 << UInt(Q); if datasize == 64 && esize < 64 then EndOfDecode(Decode_UNDEF); if datasize == 32 && esize >= 64 then EndOfDecode(Decode_UNDEF); constant integer index = UInt(imm5<4:size+1>); constant integer idxdsize = 64 << UInt(imm5<4>);

Assembler Symbols

<Wd>

Is the 32-bit name of the general-purpose destination register, encoded in the "Rd" field.

<Vn>

Is the name of the SIMD&FP source register, encoded in the "Rn" field.

<Ts>

Is an element size specifier, encoded in imm5:

imm5 <Ts>
xx000 RESERVED
xxxx1 B
xxx10 H
xx100 S
<index>

For the "32-bit" variant: is the element index encoded in imm5:

imm5 <index>
xx000 RESERVED
xxxx1 UInt(imm5<4:1>)
xxx10 UInt(imm5<4:2>)
xx100 UInt(imm5<4:3>)

For the "64-bit" variant: is the element index encoded in "imm5<4>".

<Xd>

Is the 64-bit name of the general-purpose destination register, encoded in the "Rd" field.

Alias Conditions

AliasOf variantIs preferred when
MOV (to general)32-bitimm5 IN {'xx100'}
MOV (to general)64-bitimm5 IN {'x1000'}

Operation

if index == 0 then CheckFPEnabled64(); else CheckFPAdvSIMDEnabled64(); constant bits(idxdsize) operand = V[n, idxdsize]; X[d, datasize] = ZeroExtend(Elem[operand, index, esize], datasize);

Operational information

If PSTATE.DIT is 1:


Internal version only: aarchmrs v2024-12_rel, pseudocode v2024-12_rel ; Build timestamp: 2024-12-15T22:18

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