Top-level encodings for A64

313029282726252423222120191817161514131211109876543210
op0op1
Decode fields Instruction details
op0op1
0 0000 Reserved
1 0000 SME encodings
0001 UNALLOCATED
0010 SVE encodings
0011 UNALLOCATED
100x Data Processing -- Immediate
101x Branches, Exception Generating and System instructions
x1x0 Loads and Stores
x101 Data Processing -- Register
x111 Data Processing -- Scalar Floating-Point and Advanced SIMD

Reserved

These instructions are under the top-level.

313029282726252423222120191817161514131211109876543210
op00000op1
Decode fields Instruction details
op0op1
00 000000000 UDF
!= 000000000 UNALLOCATED
!= 00 UNALLOCATED

SME encodings

These instructions are under the top-level.

313029282726252423222120191817161514131211109876543210
1op00000op1op2op3op4
Decode fields Instruction details
op0op1op2op3op4
0x x0xxxx UNALLOCATED
0x x10xxx xx0 SME Outer Product - 32 bit
0x x10xxx xx1 UNALLOCATED
0x x11xxx x0x SME Outer Product - 64 bit
0x x11xxx x1x UNALLOCATED
10 0xx000 0 0xx SME Move into Array
10 0xx000 0 1xx UNALLOCATED
10 0xx000 1 0 SME Move from Array
10 0xx000 1 1 UNALLOCATED
10 0xx001 SME Misc
10 0xx010 x0x SME Add Vector to Array
10 0xx010 x1x UNALLOCATED
10 0xx011 UNALLOCATED
10 0xx1xx UNALLOCATED
10 1xxxxx UNALLOCATED
11 SME Memory

SME Outer Product - 32 bit

These instructions are under SME encodings.

313029282726252423222120191817161514131211109876543210
10op00000op110op2op30
Decode fields Instruction details
op0op1op2op3
0 0 0 0 SME FP32 outer product
0 0 0 1 UNALLOCATED
0 0 1 UNALLOCATED
0 1 0 0 SME BF16 outer product
0 1 1 0 SME FP16 outer product
0 1 1 UNALLOCATED
1 0 SME Int8 outer product
1 1 UNALLOCATED

SME FP32 outer product

These instructions are under SME Outer Product - 32 bit.

313029282726252423222120191817161514131211109876543210
10000000100ZmPmPnZnS00ZAda
Decode fields Instruction Details Feature
S
0 FMOPA (non-widening)FEAT_SME
1 FMOPS (non-widening)FEAT_SME

SME BF16 outer product

These instructions are under SME Outer Product - 32 bit.

313029282726252423222120191817161514131211109876543210
10000001100ZmPmPnZnS00ZAda
Decode fields Instruction Details Feature
S
0 BFMOPAFEAT_SME
1 BFMOPSFEAT_SME

SME FP16 outer product

These instructions are under SME Outer Product - 32 bit.

313029282726252423222120191817161514131211109876543210
10000001101ZmPmPnZnS00ZAda
Decode fields Instruction Details Feature
S
0 FMOPA (widening)FEAT_SME
1 FMOPS (widening)FEAT_SME

SME Int8 outer product

These instructions are under SME Outer Product - 32 bit.

313029282726252423222120191817161514131211109876543210
1010000u010u1ZmPmPnZnS00ZAda
Decode fields Instruction Details Feature
u0 u1 S
0 0 0 SMOPAFEAT_SME
0 0 1 SMOPSFEAT_SME
0 1 0 SUMOPAFEAT_SME
0 1 1 SUMOPSFEAT_SME
1 0 0 USMOPAFEAT_SME
1 0 1 USMOPSFEAT_SME
1 1 0 UMOPAFEAT_SME
1 1 1 UMOPSFEAT_SME

SME Outer Product - 64 bit

These instructions are under SME encodings.

313029282726252423222120191817161514131211109876543210
10op00000op111op20
Decode fields Instruction details
op0op1op2
0 0 0 SME FP64 outer product
0 0 1 UNALLOCATED
0 1 UNALLOCATED
1 SME Int16 outer product

SME FP64 outer product

These instructions are under SME Outer Product - 64 bit.

313029282726252423222120191817161514131211109876543210
10000000110ZmPmPnZnS0ZAda
Decode fields Instruction Details Feature
S
0 FMOPA (non-widening)FEAT_SME_F64F64
1 FMOPS (non-widening)FEAT_SME_F64F64

SME Int16 outer product

These instructions are under SME Outer Product - 64 bit.

313029282726252423222120191817161514131211109876543210
1010000u011u1ZmPmPnZnS0ZAda
Decode fields Instruction Details Feature
u0 u1 S
0 0 0 SMOPAFEAT_SME_I16I64
0 0 1 SMOPSFEAT_SME_I16I64
0 1 0 SUMOPAFEAT_SME_I16I64
0 1 1 SUMOPSFEAT_SME_I16I64
1 0 0 USMOPAFEAT_SME_I16I64
1 0 1 USMOPSFEAT_SME_I16I64
1 1 0 UMOPAFEAT_SME_I16I64
1 1 1 UMOPSFEAT_SME_I16I64

SME Move into Array

These instructions are under SME encodings.

313029282726252423222120191817161514131211109876543210
11000000000op000
Decode fields Instruction details
op0
0 SME move vector to array
1 UNALLOCATED

SME move vector to array

These instructions are under SME Move into Array.

313029282726252423222120191817161514131211109876543210
11000000size00000QVRsPgZn0opc
Decode fields Instruction Details Feature
size Q
0x 1 UNALLOCATED-
00 0 MOVA (vector to tile)8-bitFEAT_SME
01 0 MOVA (vector to tile)16-bitFEAT_SME
10 0 MOVA (vector to tile)32-bitFEAT_SME
10 1 UNALLOCATED-
11 0 MOVA (vector to tile)64-bitFEAT_SME
11 1 MOVA (vector to tile)128-bitFEAT_SME

SME Move from Array

These instructions are under SME encodings.

313029282726252423222120191817161514131211109876543210
11000000000op010
Decode fields Instruction details
op0
0 SME move array to vector
1 UNALLOCATED

SME move array to vector

These instructions are under SME Move from Array.

313029282726252423222120191817161514131211109876543210
11000000size00001QVRsPg0opcZd
Decode fields Instruction Details Feature
size Q
0x 1 UNALLOCATED-
00 0 MOVA (tile to vector)8-bitFEAT_SME
01 0 MOVA (tile to vector)16-bitFEAT_SME
10 0 MOVA (tile to vector)32-bitFEAT_SME
10 1 UNALLOCATED-
11 0 MOVA (tile to vector)64-bitFEAT_SME
11 1 MOVA (tile to vector)128-bitFEAT_SME

SME Misc

These instructions are under SME encodings.

313029282726252423222120191817161514131211109876543210
11000000op0001op1
Decode fields Instruction details Architecture version
op0op1
00 00000000000 ZEROFEAT_SME
00 != 00000000000 UNALLOCATED-
!= 00 UNALLOCATED-

SME Add Vector to Array

These instructions are under SME encodings.

313029282726252423222120191817161514131211109876543210
11000000op0010op1op20
Decode fields Instruction details
op0op1op2
0 UNALLOCATED
1 00 0 SME add vector to array
1 00 1 UNALLOCATED
1 != 00 UNALLOCATED

SME add vector to array

These instructions are under SME Add Vector to Array.

313029282726252423222120191817161514131211109876543210
110000001op01000VPmPnZn00opc2
Decode fields Instruction Details Feature
op V opc2
0 1xx UNALLOCATED-
0 0 0xx ADDHA32-bitFEAT_SME
0 1 0xx ADDVA32-bitFEAT_SME
1 0 ADDHA64-bitFEAT_SME_I16I64
1 1 ADDVA64-bitFEAT_SME_I16I64

SME Memory

These instructions are under SME encodings.

313029282726252423222120191817161514131211109876543210
1110000op0op1op2op3
Decode fields Instruction details Architecture version
op0op1op2op3
0xx0 0 SME load array vector (elements)-
0xx1 0 SME store array vector (elements)-
0xxx 1 UNALLOCATED-
100x 000000 000 0 SME save and restore array-
100x 000000 000 1 UNALLOCATED-
100x 000000 != 000 UNALLOCATED-
100x != 000000 UNALLOCATED-
101x UNALLOCATED-
110x UNALLOCATED-
1110 0 LD1QFEAT_SME
1111 0 ST1QFEAT_SME
111x 1 UNALLOCATED-

SME load array vector (elements)

These instructions are under SME Memory.

313029282726252423222120191817161514131211109876543210
11100000msz0RmVRsPgRn0opc
Decode fields Instruction Details Feature
msz
00 LD1BFEAT_SME
01 LD1HFEAT_SME
10 LD1WFEAT_SME
11 LD1DFEAT_SME

SME store array vector (elements)

These instructions are under SME Memory.

313029282726252423222120191817161514131211109876543210
11100000msz1RmVRsPgRn0opc
Decode fields Instruction Details Feature
msz
00 ST1BFEAT_SME
01 ST1HFEAT_SME
10 ST1WFEAT_SME
11 ST1DFEAT_SME

SME save and restore array

These instructions are under SME Memory.

313029282726252423222120191817161514131211109876543210
1110000100op000000Rv000Rn0imm4
Decode fields Instruction Details Feature
op
0 LDRFEAT_SME
1 STRFEAT_SME

SVE encodings

These instructions are under the top-level.

313029282726252423222120191817161514131211109876543210
op00010op1op2op3op4
Decode fields Instruction details
op0op1op2op3op4
000 0x 0xxxx x1xxxx SVE Integer Multiply-Add - Predicated
000 0x 0xxxx 000xxx SVE Integer Binary Arithmetic - Predicated
000 0x 0xxxx 001xxx SVE Integer Reduction
000 0x 0xxxx 100xxx SVE Bitwise Shift - Predicated
000 0x 0xxxx 101xxx SVE Integer Unary Arithmetic - Predicated
000 0x 1xxxx 000xxx SVE integer add/subtract vectors (unpredicated)
000 0x 1xxxx 001xxx SVE Bitwise Logical - Unpredicated
000 0x 1xxxx 0100xx SVE Index Generation
000 0x 1xxxx 0101xx SVE Stack Allocation
000 0x 1xxxx 011xxx SVE2 Integer Multiply - Unpredicated
000 0x 1xxxx 100xxx SVE Bitwise Shift - Unpredicated
000 0x 1xxxx 1010xx SVE address generation
000 0x 1xxxx 1011xx SVE Integer Misc - Unpredicated
000 0x 1xxxx 11xxxx SVE Element Count
000 1x 00xxx SVE Bitwise Immediate
000 1x 01xxx SVE Integer Wide Immediate - Predicated
000 1x 1xxxx 001000 DUP (indexed)
000 1x 1xxxx 001001 UNALLOCATED
000 1x 1xxxx 00101x SVE table lookup (three sources)
000 1x 1xxxx 0011x1 UNALLOCATED
000 1x 1xxxx 001100 TBLSVE
000 1x 1xxxx 001110 SVE Permute Vector - Unpredicated
000 1x 1xxxx 010xxx SVE Permute Predicate
000 1x 1xxxx 011xxx SVE permute vector elements
000 1x 1xxxx 10xxxx SVE Permute Vector - Predicated
000 1x 1xxxx 11xxxx SEL (vectors)
000 10 1xxxx 000xxx SVE Permute Vector - Extract
000 11 1xxxx 000xxx sve_perm_inter_long
001 0x 0xxxx SVE Integer Compare - Vectors
001 0x 1xxxx SVE integer compare with unsigned immediate
001 1x 0xxxx x0xxxx SVE integer compare with signed immediate
001 1x 00xxx 01xxxx SVE predicate logical operations
001 1x 00xxx 11xxxx SVE Propagate Break
001 1x 01xxx 01xxxx SVE Partition Break
001 1x 01xxx 11xxxx SVE Predicate Misc
001 1x 1xxxx 00xxxx SVE Integer Compare - Scalars
001 1x 1xxxx 01xxxx 0 SVE broadcast predicate element
001 1x 1xxxx 01xxxx 1 UNALLOCATED
001 1x 1xxxx 11xxxx SVE Integer Wide Immediate - Unpredicated
001 1x 100xx 10xxxx SVE Predicate Count
001 1x 101xx 1000xx SVE Inc/Dec by Predicate Count
001 1x 101xx 1001xx SVE Write FFR
001 1x 101xx 101xxx UNALLOCATED
001 1x 11xxx 10xxxx UNALLOCATED
010 0x 0xxxx 0xxxxx SVE Integer Multiply-Add - Unpredicated
010 0x 0xxxx 10xxxx SVE2 Integer - Predicated
010 0x 0xxxx 11000x SVE clamp
010 0x 0xxxx 11001x UNALLOCATED
010 0x 0xxxx 1101xx UNALLOCATED
010 0x 0xxxx 111xxx UNALLOCATED
010 0x 1xxxx SVE Multiply - Indexed
010 1x 0xxxx 0xxxxx SVE2 Widening Integer Arithmetic
010 1x 0xxxx 10xxxx SVE Misc
010 1x 0xxxx 11xxxx SVE2 Accumulate
010 1x 1xxxx 0xxxxx SVE2 Narrowing
010 1x 1xxxx 100xxx SVE2 character match
010 1x 1xxxx 101xxx SVE2 Histogram Computation - Segment
010 1x 1xxxx 110xxx HISTCNT
010 1x 1xxxx 111xxx SVE2 Crypto Extensions
011 0x 0xxxx 0xxxxx FCMLA (vectors)
011 0x 00x1x 1xxxxx UNALLOCATED
011 0x 00000 100xxx FCADD
011 0x 00000 101xxx UNALLOCATED
011 0x 00000 11xxxx UNALLOCATED
011 0x 00001 1xxxxx UNALLOCATED
011 0x 0010x 100xxx UNALLOCATED
011 0x 0010x 101xxx SVE floating-point convert precision odd elements
011 0x 0010x 11xxxx UNALLOCATED
011 0x 010xx 100xxx SVE2 floating-point pairwise operations
011 0x 010xx 101xxx UNALLOCATED
011 0x 010xx 11xxxx UNALLOCATED
011 0x 011xx 1xxxxx UNALLOCATED
011 0x 1xxxx x0x01x UNALLOCATED
011 0x 1xxxx 00000x SVE floating-point multiply-add (indexed)
011 0x 1xxxx 0001xx SVE floating-point complex multiply-add (indexed)
011 0x 1xxxx 001000 SVE floating-point multiply (indexed)
011 0x 1xxxx 001001 UNALLOCATED
011 0x 1xxxx 0011xx UNALLOCATED
011 0x 1xxxx 01x0xx SVE Floating Point Widening Multiply-Add - Indexed
011 0x 1xxxx 01x1xx UNALLOCATED
011 0x 1xxxx 10x00x SVE Floating Point Widening Multiply-Add
011 0x 1xxxx 10x1xx UNALLOCATED
011 0x 1xxxx 110xxx UNALLOCATED
011 0x 1xxxx 111000 UNALLOCATED
011 0x 1xxxx 111001 SVE floating point matrix multiply accumulate
011 0x 1xxxx 11101x UNALLOCATED
011 0x 1xxxx 1111xx UNALLOCATED
011 1x 0xxxx x1xxxx SVE floating-point compare vectors
011 1x 0xxxx 000xxx SVE floating-point arithmetic (unpredicated)
011 1x 0xxxx 100xxx SVE Floating Point Arithmetic - Predicated
011 1x 0xxxx 101xxx SVE Floating Point Unary Operations - Predicated
011 1x 000xx 001xxx SVE floating-point recursive reduction
011 1x 001xx 0010xx UNALLOCATED
011 1x 001xx 0011xx SVE Floating Point Unary Operations - Unpredicated
011 1x 010xx 001xxx SVE Floating Point Compare - with Zero
011 1x 011xx 001xxx SVE Floating Point Accumulating Reduction
011 1x 1xxxx SVE Floating Point Multiply-Add
100 SVE Memory - 32-bit Gather and Unsized Contiguous
101 SVE Memory - Contiguous Load
110 SVE Memory - 64-bit Gather
111 0x0xxx SVE Memory - Contiguous Store and Unsized Contiguous
111 0x1xxx SVE Memory - Non-temporal and Multi-register Store
111 1x0xxx SVE Memory - Scatter with Optional Sign Extend
111 101xxx SVE Memory - Scatter
111 111xxx SVE Memory - Contiguous Store with Immediate Offset

SVE Integer Multiply-Add - Predicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001000op01
Decode fields Instruction details
op0
0 SVE integer multiply-accumulate writing addend (predicated)
1 SVE integer multiply-add writing multiplicand (predicated)

SVE integer multiply-accumulate writing addend (predicated)

These instructions are under SVE Integer Multiply-Add - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size0Zm01opPgZnZda
Decode fields Instruction Details
op
0 MLA (vectors)
1 MLS (vectors)

SVE integer multiply-add writing multiplicand (predicated)

These instructions are under SVE Integer Multiply-Add - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size0Zm11opPgZaZdn
Decode fields Instruction Details
op
0 MAD
1 MSB

SVE Integer Binary Arithmetic - Predicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001000op0000
Decode fields Instruction details
op0
00x SVE integer add/subtract vectors (predicated)
01x SVE integer min/max/difference (predicated)
100 SVE integer multiply vectors (predicated)
101 SVE integer divide vectors (predicated)
11x SVE bitwise logical operations (predicated)

SVE integer add/subtract vectors (predicated)

These instructions are under SVE Integer Binary Arithmetic - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size000opc000PgZmZdn
Decode fields Instruction Details
opc
000 ADD (vectors, predicated)
001 SUB (vectors, predicated)
010 UNALLOCATED
011 SUBR (vectors)
1xx UNALLOCATED

SVE integer min/max/difference (predicated)

These instructions are under SVE Integer Binary Arithmetic - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size001opcU000PgZmZdn
Decode fields Instruction Details
opc U
00 0 SMAX (vectors)
00 1 UMAX (vectors)
01 0 SMIN (vectors)
01 1 UMIN (vectors)
10 0 SABD
10 1 UABD
11 UNALLOCATED

SVE integer multiply vectors (predicated)

These instructions are under SVE Integer Binary Arithmetic - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size0100HU000PgZmZdn
Decode fields Instruction Details
H U
0 0 MUL (vectors, predicated)
0 1 UNALLOCATED
1 0 SMULH (predicated)
1 1 UMULH (predicated)

SVE integer divide vectors (predicated)

These instructions are under SVE Integer Binary Arithmetic - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size0101RU000PgZmZdn
Decode fields Instruction Details
R U
0 0 SDIV
0 1 UDIV
1 0 SDIVR
1 1 UDIVR

SVE bitwise logical operations (predicated)

These instructions are under SVE Integer Binary Arithmetic - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size011opc000PgZmZdn
Decode fields Instruction Details
opc
000 ORR (vectors, predicated)
001 EOR (vectors, predicated)
010 AND (vectors, predicated)
011 BIC (vectors, predicated)
1xx UNALLOCATED

SVE Integer Reduction

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001000op0001
Decode fields Instruction details
op0
000 SVE integer add reduction (predicated)
010 SVE integer min/max reduction (predicated)
0x1 UNALLOCATED
10x SVE constructive prefix (predicated)
110 SVE bitwise logical reduction (predicated)
111 UNALLOCATED

SVE integer add reduction (predicated)

These instructions are under SVE Integer Reduction.

313029282726252423222120191817161514131211109876543210
00000100size0000opU001PgZnVd
Decode fields Instruction Details
op U
0 0 SADDV
0 1 UADDV
1 UNALLOCATED

SVE integer min/max reduction (predicated)

These instructions are under SVE Integer Reduction.

313029282726252423222120191817161514131211109876543210
00000100size0010opU001PgZnVd
Decode fields Instruction Details
op U
0 0 SMAXV
0 1 UMAXV
1 0 SMINV
1 1 UMINV

SVE constructive prefix (predicated)

These instructions are under SVE Integer Reduction.

313029282726252423222120191817161514131211109876543210
00000100size010opcM001PgZnZd
Decode fields Instruction Details
opc
00 MOVPRFX (predicated)
01 UNALLOCATED
1x UNALLOCATED

SVE bitwise logical reduction (predicated)

These instructions are under SVE Integer Reduction.

313029282726252423222120191817161514131211109876543210
00000100size0110opc001PgZnVd
Decode fields Instruction Details
opc
00 ORV
01 EORV
10 ANDV
11 UNALLOCATED

SVE Bitwise Shift - Predicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001000op0100
Decode fields Instruction details
op0
0x SVE bitwise shift by immediate (predicated)
10 SVE bitwise shift by vector (predicated)
11 SVE bitwise shift by wide elements (predicated)

SVE bitwise shift by immediate (predicated)

These instructions are under SVE Bitwise Shift - Predicated.

313029282726252423222120191817161514131211109876543210
00000100tszh00opcLU100Pgtszlimm3Zdn
Decode fields Instruction Details
opc L U
00 0 0 ASR (immediate, predicated)
00 0 1 LSR (immediate, predicated)
00 1 0 UNALLOCATED
00 1 1 LSL (immediate, predicated)
01 0 0 ASRD
01 0 1 UNALLOCATED
01 1 0 SQSHL (immediate)
01 1 1 UQSHL (immediate)
10 UNALLOCATED
11 0 0 SRSHR
11 0 1 URSHR
11 1 0 UNALLOCATED
11 1 1 SQSHLU

SVE bitwise shift by vector (predicated)

These instructions are under SVE Bitwise Shift - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size010RLU100PgZmZdn
Decode fields Instruction Details
R L U
1 0 UNALLOCATED
0 0 0 ASR (vectors)
0 0 1 LSR (vectors)
0 1 1 LSL (vectors)
1 0 0 ASRR
1 0 1 LSRR
1 1 1 LSLR

SVE bitwise shift by wide elements (predicated)

These instructions are under SVE Bitwise Shift - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size011RLU100PgZmZdn
Decode fields Instruction Details
R L U
0 0 0 ASR (wide elements, predicated)
0 0 1 LSR (wide elements, predicated)
0 1 0 UNALLOCATED
0 1 1 LSL (wide elements, predicated)
1 UNALLOCATED

SVE Integer Unary Arithmetic - Predicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001000op0101
Decode fields Instruction details
op0
0x UNALLOCATED
10 SVE integer unary operations (predicated)
11 SVE bitwise unary operations (predicated)

SVE integer unary operations (predicated)

These instructions are under SVE Integer Unary Arithmetic - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size010opc101PgZnZd
Decode fields Instruction Details
opc
000 SXTB, SXTH, SXTWSXTB
001 UXTB, UXTH, UXTWUXTB
010 SXTB, SXTH, SXTWSXTH
011 UXTB, UXTH, UXTWUXTH
100 SXTB, SXTH, SXTWSXTW
101 UXTB, UXTH, UXTWUXTW
110 ABS
111 NEG

SVE bitwise unary operations (predicated)

These instructions are under SVE Integer Unary Arithmetic - Predicated.

313029282726252423222120191817161514131211109876543210
00000100size011opc101PgZnZd
Decode fields Instruction Details
opc
000 CLS
001 CLZ
010 CNT
011 CNOT
100 FABS
101 FNEG
110 NOT (vector)
111 UNALLOCATED

SVE integer add/subtract vectors (unpredicated)

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00000100size1Zm000opcZnZd
Decode fields Instruction Details
opc
000 ADD (vectors, unpredicated)
001 SUB (vectors, unpredicated)
01x UNALLOCATED
100 SQADD (vectors, unpredicated)
101 UQADD (vectors, unpredicated)
110 SQSUB (vectors, unpredicated)
111 UQSUB (vectors, unpredicated)

SVE Bitwise Logical - Unpredicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001001001op0
Decode fields Instruction details
op0
0xx UNALLOCATED
100 SVE bitwise logical operations (unpredicated)
101 XAR
11x SVE2 bitwise ternary operations

SVE bitwise logical operations (unpredicated)

These instructions are under SVE Bitwise Logical - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000100opc1Zm001100ZnZd
Decode fields Instruction Details
opc
00 AND (vectors, unpredicated)
01 ORR (vectors, unpredicated)
10 EOR (vectors, unpredicated)
11 BIC (vectors, unpredicated)

SVE2 bitwise ternary operations

These instructions are under SVE Bitwise Logical - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000100opc1Zm00111o2ZkZdn
Decode fields Instruction Details
opc o2
00 0 EOR3
00 1 BSL
01 0 BCAX
01 1 BSL1N
1x 0 UNALLOCATED
10 1 BSL2N
11 1 NBSL

SVE Index Generation

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
0000010010100op0
Decode fields Instruction details
op0
00 INDEX (immediates)
01 INDEX (scalar, immediate)
10 INDEX (immediate, scalar)
11 INDEX (scalars)

SVE Stack Allocation

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00000100op010101op1
Decode fields Instruction details
op0op1
0 0 SVE stack frame adjustment
1 0 SVE stack frame size
1 UNALLOCATED

SVE stack frame adjustment

These instructions are under SVE Stack Allocation.

313029282726252423222120191817161514131211109876543210
000001000op1Rn01010imm6Rd
Decode fields Instruction Details
op
0 ADDVL
1 ADDPL

SVE stack frame size

These instructions are under SVE Stack Allocation.

313029282726252423222120191817161514131211109876543210
000001001op1opc201010imm6Rd
Decode fields Instruction Details
op opc2
0 0xxxx UNALLOCATED
0 10xxx UNALLOCATED
0 110xx UNALLOCATED
0 1110x UNALLOCATED
0 11110 UNALLOCATED
0 11111 RDVL
1 UNALLOCATED

SVE2 Integer Multiply - Unpredicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001001011op0
Decode fields Instruction details
op0
0x SVE2 integer multiply vectors (unpredicated)
10 SVE2 signed saturating doubling multiply high (unpredicated)
11 UNALLOCATED

SVE2 integer multiply vectors (unpredicated)

These instructions are under SVE2 Integer Multiply - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000100size1Zm0110opcZnZd
Decode fields Instruction Details
size opc
00 MUL (vectors, unpredicated)
10 SMULH (unpredicated)
11 UMULH (unpredicated)
00 01 PMUL
01 01 UNALLOCATED
1x 01 UNALLOCATED

SVE2 signed saturating doubling multiply high (unpredicated)

These instructions are under SVE2 Integer Multiply - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000100size1Zm01110RZnZd
Decode fields Instruction Details
R
0 SQDMULH (vectors)
1 SQRDMULH (vectors)

SVE Bitwise Shift - Unpredicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001001100op0
Decode fields Instruction details
op0
0 SVE bitwise shift by wide elements (unpredicated)
1 SVE bitwise shift by immediate (unpredicated)

SVE bitwise shift by wide elements (unpredicated)

These instructions are under SVE Bitwise Shift - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000100size1Zm1000opcZnZd
Decode fields Instruction Details
opc
00 ASR (wide elements, unpredicated)
01 LSR (wide elements, unpredicated)
10 UNALLOCATED
11 LSL (wide elements, unpredicated)

SVE bitwise shift by immediate (unpredicated)

These instructions are under SVE Bitwise Shift - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000100tszh1tszlimm31001opcZnZd
Decode fields Instruction Details
opc
00 ASR (immediate, unpredicated)
01 LSR (immediate, unpredicated)
10 UNALLOCATED
11 LSL (immediate, unpredicated)

SVE address generation

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00000100opc1Zm1010mszZnZd
Decode fields Instruction Details
opc
00 ADRUnpacked 32-bit signed offsets
01 ADRUnpacked 32-bit unsigned offsets
1x ADRPacked offsets

SVE Integer Misc - Unpredicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
0000010011011op0
Decode fields Instruction details
op0
0x SVE floating-point trig select coefficient
10 SVE floating-point exponential accelerator
11 SVE constructive prefix (unpredicated)

SVE floating-point trig select coefficient

These instructions are under SVE Integer Misc - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000100size1Zm10110opZnZd
Decode fields Instruction Details
op
0 FTSSEL
1 UNALLOCATED

SVE floating-point exponential accelerator

These instructions are under SVE Integer Misc - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000100size1opc101110ZnZd
Decode fields Instruction Details
opc
00000 FEXPA
00001 UNALLOCATED
0001x UNALLOCATED
001xx UNALLOCATED
01xxx UNALLOCATED
1xxxx UNALLOCATED

SVE constructive prefix (unpredicated)

These instructions are under SVE Integer Misc - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000100opc1opc2101111ZnZd
Decode fields Instruction Details
opc opc2
00 00000 MOVPRFX (unpredicated)
00 00001 UNALLOCATED
00 0001x UNALLOCATED
00 001xx UNALLOCATED
00 01xxx UNALLOCATED
00 1xxxx UNALLOCATED
01 UNALLOCATED
1x UNALLOCATED

SVE Element Count

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001001op011op1
Decode fields Instruction details
op0op1
0 00x SVE saturating inc/dec vector by element count
0 100 SVE element count
0 101 UNALLOCATED
1 000 SVE inc/dec vector by element count
1 100 SVE inc/dec register by element count
1 x01 UNALLOCATED
01x UNALLOCATED
11x SVE saturating inc/dec register by element count

SVE saturating inc/dec vector by element count

These instructions are under SVE Element Count.

313029282726252423222120191817161514131211109876543210
00000100size10imm41100DUpatternZdn
Decode fields Instruction Details
size D U
00 UNALLOCATED
01 0 0 SQINCH (vector)
01 0 1 UQINCH (vector)
01 1 0 SQDECH (vector)
01 1 1 UQDECH (vector)
10 0 0 SQINCW (vector)
10 0 1 UQINCW (vector)
10 1 0 SQDECW (vector)
10 1 1 UQDECW (vector)
11 0 0 SQINCD (vector)
11 0 1 UQINCD (vector)
11 1 0 SQDECD (vector)
11 1 1 UQDECD (vector)

SVE element count

These instructions are under SVE Element Count.

313029282726252423222120191817161514131211109876543210
00000100size10imm411100oppatternRd
Decode fields Instruction Details
size op
1 UNALLOCATED
00 0 CNTB, CNTD, CNTH, CNTWCNTB
01 0 CNTB, CNTD, CNTH, CNTWCNTH
10 0 CNTB, CNTD, CNTH, CNTWCNTW
11 0 CNTB, CNTD, CNTH, CNTWCNTD

SVE inc/dec vector by element count

These instructions are under SVE Element Count.

313029282726252423222120191817161514131211109876543210
00000100size11imm411000DpatternZdn
Decode fields Instruction Details
size D
00 UNALLOCATED
01 0 INCD, INCH, INCW (vector)INCH
01 1 DECD, DECH, DECW (vector)DECH
10 0 INCD, INCH, INCW (vector)INCW
10 1 DECD, DECH, DECW (vector)DECW
11 0 INCD, INCH, INCW (vector)INCD
11 1 DECD, DECH, DECW (vector)DECD

SVE inc/dec register by element count

These instructions are under SVE Element Count.

313029282726252423222120191817161514131211109876543210
00000100size11imm411100DpatternRdn
Decode fields Instruction Details
size D
00 0 INCB, INCD, INCH, INCW (scalar)INCB
00 1 DECB, DECD, DECH, DECW (scalar)DECB
01 0 INCB, INCD, INCH, INCW (scalar)INCH
01 1 DECB, DECD, DECH, DECW (scalar)DECH
10 0 INCB, INCD, INCH, INCW (scalar)INCW
10 1 DECB, DECD, DECH, DECW (scalar)DECW
11 0 INCB, INCD, INCH, INCW (scalar)INCD
11 1 DECB, DECD, DECH, DECW (scalar)DECD

SVE saturating inc/dec register by element count

These instructions are under SVE Element Count.

313029282726252423222120191817161514131211109876543210
00000100size1sfimm41111DUpatternRdn
Decode fields Instruction Details
size sf D U
00 0 0 0 SQINCB32-bit
00 0 0 1 UQINCB32-bit
00 0 1 0 SQDECB32-bit
00 0 1 1 UQDECB32-bit
00 1 0 0 SQINCB64-bit
00 1 0 1 UQINCB64-bit
00 1 1 0 SQDECB64-bit
00 1 1 1 UQDECB64-bit
01 0 0 0 SQINCH (scalar)32-bit
01 0 0 1 UQINCH (scalar)32-bit
01 0 1 0 SQDECH (scalar)32-bit
01 0 1 1 UQDECH (scalar)32-bit
01 1 0 0 SQINCH (scalar)64-bit
01 1 0 1 UQINCH (scalar)64-bit
01 1 1 0 SQDECH (scalar)64-bit
01 1 1 1 UQDECH (scalar)64-bit
10 0 0 0 SQINCW (scalar)32-bit
10 0 0 1 UQINCW (scalar)32-bit
10 0 1 0 SQDECW (scalar)32-bit
10 0 1 1 UQDECW (scalar)32-bit
10 1 0 0 SQINCW (scalar)64-bit
10 1 0 1 UQINCW (scalar)64-bit
10 1 1 0 SQDECW (scalar)64-bit
10 1 1 1 UQDECW (scalar)64-bit
11 0 0 0 SQINCD (scalar)32-bit
11 0 0 1 UQINCD (scalar)32-bit
11 0 1 0 SQDECD (scalar)32-bit
11 0 1 1 UQDECD (scalar)32-bit
11 1 0 0 SQINCD (scalar)64-bit
11 1 0 1 UQINCD (scalar)64-bit
11 1 1 0 SQDECD (scalar)64-bit
11 1 1 1 UQDECD (scalar)64-bit

SVE Bitwise Immediate

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00000101op000op1
Decode fields Instruction details
op0op1
11 00 DUPM
!= 11 00 SVE bitwise logical with immediate (unpredicated)
!= 00 UNALLOCATED

SVE bitwise logical with immediate (unpredicated)

These instructions are under SVE Bitwise Immediate.

313029282726252423222120191817161514131211109876543210
00000101!= 110000imm13Zdn
opc

The following constraints also apply to this encoding: opc != 11 && opc != 11

Decode fields Instruction Details
opc
00 ORR (immediate)
01 EOR (immediate)
10 AND (immediate)

SVE Integer Wide Immediate - Predicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
0000010101op0
Decode fields Instruction details
op0
0xx SVE copy integer immediate (predicated)
10x UNALLOCATED
110 FCPY
111 UNALLOCATED

SVE copy integer immediate (predicated)

These instructions are under SVE Integer Wide Immediate - Predicated.

313029282726252423222120191817161514131211109876543210
00000101size01Pg0Mshimm8Zd
Decode fields Instruction Details
M
0 CPY (immediate, zeroing)
1 CPY (immediate, merging)

SVE table lookup (three sources)

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00000101size1Zm00101opZnZd
Decode fields Instruction Details
op
0 TBL
1 TBX

SVE Permute Vector - Unpredicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001011op0op1001110
Decode fields Instruction details
op0op1
00 000 DUP (scalar)
00 100 INSR (scalar)
00 x10 UNALLOCATED
00 xx1 UNALLOCATED
01 UNALLOCATED
10 0xx SVE unpack vector elements
10 100 INSR (SIMD&FP scalar)
10 110 UNALLOCATED
10 1x1 UNALLOCATED
11 000 REV (vector)
11 != 000 UNALLOCATED

SVE unpack vector elements

These instructions are under SVE Permute Vector - Unpredicated.

313029282726252423222120191817161514131211109876543210
00000101size1100UH001110ZnZd
Decode fields Instruction Details
U H
0 0 SUNPKHI, SUNPKLOSUNPKLO
0 1 SUNPKHI, SUNPKLOSUNPKHI
1 0 UUNPKHI, UUNPKLOUUNPKLO
1 1 UUNPKHI, UUNPKLOUUNPKHI

SVE Permute Predicate

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00000101op01op1010op2op3
Decode fields Instruction details
op0op1op2op3
00 1000x 0000 0 SVE unpack predicate elements
01 1000x 0000 0 UNALLOCATED
10 1000x 0000 0 UNALLOCATED
11 1000x 0000 0 UNALLOCATED
0xxxx xxx0 0 SVE permute predicate elements
0xxxx xxx1 0 UNALLOCATED
10100 0000 0 REV (predicate)
10101 0000 0 UNALLOCATED
10x0x 1000 0 UNALLOCATED
10x0x x100 0 UNALLOCATED
10x0x xx10 0 UNALLOCATED
10x0x xxx1 0 UNALLOCATED
10x1x 0 UNALLOCATED
11xxx 0 UNALLOCATED
1 UNALLOCATED

SVE unpack predicate elements

These instructions are under SVE Permute Predicate.

313029282726252423222120191817161514131211109876543210
000001010011000H0100000Pn0Pd
Decode fields Instruction Details
H
0 PUNPKHI, PUNPKLOPUNPKLO
1 PUNPKHI, PUNPKLOPUNPKHI

SVE permute predicate elements

These instructions are under SVE Permute Predicate.

313029282726252423222120191817161514131211109876543210
00000101size10Pm010opcH0Pn0Pd
Decode fields Instruction Details
opc H
00 0 ZIP1, ZIP2 (predicates)ZIP1
00 1 ZIP1, ZIP2 (predicates)ZIP2
01 0 UZP1, UZP2 (predicates)UZP1
01 1 UZP1, UZP2 (predicates)UZP2
10 0 TRN1, TRN2 (predicates)TRN1
10 1 TRN1, TRN2 (predicates)TRN2
11 UNALLOCATED

SVE permute vector elements

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00000101size1Zm011opcZnZd
Decode fields Instruction Details
opc
000 ZIP1, ZIP2 (vectors)ZIP1
001 ZIP1, ZIP2 (vectors)ZIP2
010 UZP1, UZP2 (vectors)UZP1
011 UZP1, UZP2 (vectors)UZP2
100 TRN1, TRN2 (vectors)TRN1
101 TRN1, TRN2 (vectors)TRN2
11x UNALLOCATED

SVE Permute Vector - Predicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001011op0op1op210op3
Decode fields Instruction details
op0op1op2op3
0 000 0 0 CPY (SIMD&FP scalar)
0 000 1 0 COMPACT
0 000 1 SVE extract element to general register
0 001 0 SVE extract element to SIMD&FP scalar register
0 01x 0 SVE reverse within elements
0 01x 1 UNALLOCATED
0 100 0 1 CPY (scalar)
0 100 1 1 UNALLOCATED
0 100 0 SVE conditionally broadcast element to vector
0 101 0 SVE conditionally extract element to SIMD&FP scalar
0 110 0 0 SPLICEDestructive
0 110 1 0 SPLICEConstructive
0 110 1 UNALLOCATED
0 111 0 0 SVE reverse doublewords
0 111 0 1 UNALLOCATED
0 111 1 UNALLOCATED
0 x01 1 UNALLOCATED
1 000 0 UNALLOCATED
1 000 1 SVE conditionally extract element to general register
1 != 000 UNALLOCATED

SVE extract element to general register

These instructions are under SVE Permute Vector - Predicated.

313029282726252423222120191817161514131211109876543210
00000101size10000B101PgZnRd
Decode fields Instruction Details
B
0 LASTA (scalar)
1 LASTB (scalar)

SVE extract element to SIMD&FP scalar register

These instructions are under SVE Permute Vector - Predicated.

313029282726252423222120191817161514131211109876543210
00000101size10001B100PgZnVd
Decode fields Instruction Details
B
0 LASTA (SIMD&FP scalar)
1 LASTB (SIMD&FP scalar)

SVE reverse within elements

These instructions are under SVE Permute Vector - Predicated.

313029282726252423222120191817161514131211109876543210
00000101size1001opc100PgZnZd
Decode fields Instruction Details
opc
00 REVB, REVH, REVWREVB
01 REVB, REVH, REVWREVH
10 REVB, REVH, REVWREVW
11 RBIT

SVE conditionally broadcast element to vector

These instructions are under SVE Permute Vector - Predicated.

313029282726252423222120191817161514131211109876543210
00000101size10100B100PgZmZdn
Decode fields Instruction Details
B
0 CLASTA (vectors)
1 CLASTB (vectors)

SVE conditionally extract element to SIMD&FP scalar

These instructions are under SVE Permute Vector - Predicated.

313029282726252423222120191817161514131211109876543210
00000101size10101B100PgZmVdn
Decode fields Instruction Details
B
0 CLASTA (SIMD&FP scalar)
1 CLASTB (SIMD&FP scalar)

SVE reverse doublewords

These instructions are under SVE Permute Vector - Predicated.

313029282726252423222120191817161514131211109876543210
00000101size101110100PgZnZd
Decode fields Instruction Details Feature
size
00 REVDFEAT_SME
01 UNALLOCATED-
1x UNALLOCATED-

SVE conditionally extract element to general register

These instructions are under SVE Permute Vector - Predicated.

313029282726252423222120191817161514131211109876543210
00000101size11000B101PgZmRdn
Decode fields Instruction Details
B
0 CLASTA (scalar)
1 CLASTB (scalar)

SVE Permute Vector - Extract

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001010op01000
Decode fields Instruction details
op0
0 EXTDestructive
1 EXTConstructive

sve_perm_inter_long

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
000001011op01000
Decode fields Instruction details
op0
0 SVE permute vector segments
1 UNALLOCATED

SVE permute vector segments

These instructions are under sve_perm_inter_long.

313029282726252423222120191817161514131211109876543210
00000101101Zm000opcHZnZd
Decode fields Instruction Details Feature
opc H
00 0 ZIP1, ZIP2 (vectors)ZIP1FEAT_F64MM
00 1 ZIP1, ZIP2 (vectors)ZIP2FEAT_F64MM
01 0 UZP1, UZP2 (vectors)UZP1FEAT_F64MM
01 1 UZP1, UZP2 (vectors)UZP2FEAT_F64MM
10 UNALLOCATED-
11 0 TRN1, TRN2 (vectors)TRN1FEAT_F64MM
11 1 TRN1, TRN2 (vectors)TRN2FEAT_F64MM

SVE Integer Compare - Vectors

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
001001000op0
Decode fields Instruction details
op0
0 SVE integer compare vectors
1 SVE integer compare with wide elements

SVE integer compare vectors

These instructions are under SVE Integer Compare - Vectors.

313029282726252423222120191817161514131211109876543210
00100100size0Zmop0o2PgZnnePd
Decode fields Instruction Details
op o2 ne
0 0 0 CMP<cc> (vectors)CMPHS
0 0 1 CMP<cc> (vectors)CMPHI
0 1 0 CMP<cc> (wide elements)CMPEQ
0 1 1 CMP<cc> (wide elements)CMPNE
1 0 0 CMP<cc> (vectors)CMPGE
1 0 1 CMP<cc> (vectors)CMPGT
1 1 0 CMP<cc> (vectors)CMPEQ
1 1 1 CMP<cc> (vectors)CMPNE

SVE integer compare with wide elements

These instructions are under SVE Integer Compare - Vectors.

313029282726252423222120191817161514131211109876543210
00100100size0ZmU1ltPgZnnePd
Decode fields Instruction Details
U lt ne
0 0 0 CMP<cc> (wide elements)CMPGE
0 0 1 CMP<cc> (wide elements)CMPGT
0 1 0 CMP<cc> (wide elements)CMPLT
0 1 1 CMP<cc> (wide elements)CMPLE
1 0 0 CMP<cc> (wide elements)CMPHS
1 0 1 CMP<cc> (wide elements)CMPHI
1 1 0 CMP<cc> (wide elements)CMPLO
1 1 1 CMP<cc> (wide elements)CMPLS

SVE integer compare with unsigned immediate

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00100100size1imm7ltPgZnnePd
Decode fields Instruction Details
lt ne
0 0 CMP<cc> (immediate)CMPHS
0 1 CMP<cc> (immediate)CMPHI
1 0 CMP<cc> (immediate)CMPLO
1 1 CMP<cc> (immediate)CMPLS

SVE integer compare with signed immediate

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00100101size0imm5op0o2PgZnnePd
Decode fields Instruction Details
op o2 ne
0 0 0 CMP<cc> (immediate)CMPGE
0 0 1 CMP<cc> (immediate)CMPGT
0 1 0 CMP<cc> (immediate)CMPLT
0 1 1 CMP<cc> (immediate)CMPLE
1 0 0 CMP<cc> (immediate)CMPEQ
1 0 1 CMP<cc> (immediate)CMPNE
1 1 UNALLOCATED

SVE predicate logical operations

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00100101opS00Pm01Pgo2Pno3Pd
Decode fields Instruction Details
op S o2 o3
0 0 0 0 AND (predicates)
0 0 0 1 BIC (predicates)
0 0 1 0 EOR (predicates)
0 0 1 1 SEL (predicates)
0 1 0 0 ANDS
0 1 0 1 BICS
0 1 1 0 EORS
0 1 1 1 UNALLOCATED
1 0 0 0 ORR (predicates)
1 0 0 1 ORN (predicates)
1 0 1 0 NOR
1 0 1 1 NAND
1 1 0 0 ORRS
1 1 0 1 ORNS
1 1 1 0 NORS
1 1 1 1 NANDS

SVE Propagate Break

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
001001010011op0
Decode fields Instruction details
op0
0 SVE propagate break from previous partition
1 UNALLOCATED

SVE propagate break from previous partition

These instructions are under SVE Propagate Break.

313029282726252423222120191817161514131211109876543210
00100101opS00Pm11Pg0PnBPd
Decode fields Instruction Details
op S B
0 0 0 BRKPA
0 0 1 BRKPB
0 1 0 BRKPAS
0 1 1 BRKPBS
1 UNALLOCATED

SVE Partition Break

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00100101op001op101op2op3
Decode fields Instruction details
op0op1op2op3
0 1000 0 0 SVE propagate break to next partition
0 1000 0 1 UNALLOCATED
0 x000 1 UNALLOCATED
0 x1xx UNALLOCATED
0 xx1x UNALLOCATED
0 xxx1 UNALLOCATED
1 0000 1 UNALLOCATED
1 != 0000 UNALLOCATED
0000 0 SVE partition break condition

SVE propagate break to next partition

These instructions are under SVE Partition Break.

313029282726252423222120191817161514131211109876543210
001001010S01100001Pg0Pn0Pdm
Decode fields Instruction Details
S
0 BRKN
1 BRKNS

SVE partition break condition

These instructions are under SVE Partition Break.

313029282726252423222120191817161514131211109876543210
00100101BS01000001Pg0PnMPd
Decode fields Instruction Details
B S M
1 1 UNALLOCATED
0 0 BRKA
0 1 0 BRKAS
1 0 BRKB
1 1 0 BRKBS

SVE Predicate Misc

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
0010010101op011op1op2op3op4
Decode fields Instruction details
op0op1op2op3op4
0000 x0 0 SVE predicate test
0100 x0 0 UNALLOCATED
0x10 x0 0 UNALLOCATED
0xx1 x0 0 UNALLOCATED
0xxx x1 0 UNALLOCATED
1000 000 00 0 SVE predicate first active
1000 000 != 00 0 UNALLOCATED
1000 100 10 0000 0 SVE predicate zero
1000 100 10 != 0000 0 UNALLOCATED
1000 110 00 0 SVE predicate read from FFR (predicated)
1001 000 0x 0 UNALLOCATED
1001 000 10 0 PNEXT
1001 000 11 0 UNALLOCATED
1001 100 10 0 UNALLOCATED
1001 110 00 0000 0 SVE predicate read from FFR (unpredicated)
1001 110 00 != 0000 0 UNALLOCATED
100x 010 0 UNALLOCATED
100x 100 0x 0 SVE predicate initialize
100x 100 11 0 UNALLOCATED
100x 110 != 00 0 UNALLOCATED
100x xx1 0 UNALLOCATED
110x 0 UNALLOCATED
1x1x 0 UNALLOCATED
1 UNALLOCATED

SVE predicate test

These instructions are under SVE Predicate Misc.

313029282726252423222120191817161514131211109876543210
00100101opS01000011Pg0Pn0opc2
Decode fields Instruction Details
op S opc2
0 0 UNALLOCATED
0 1 0000 PTEST
0 1 0001 UNALLOCATED
0 1 001x UNALLOCATED
0 1 01xx UNALLOCATED
0 1 1xxx UNALLOCATED
1 UNALLOCATED

SVE predicate first active

These instructions are under SVE Predicate Misc.

313029282726252423222120191817161514131211109876543210
00100101opS0110001100000Pg0Pdn
Decode fields Instruction Details
op S
0 0 UNALLOCATED
0 1 PFIRST
1 UNALLOCATED

SVE predicate zero

These instructions are under SVE Predicate Misc.

313029282726252423222120191817161514131211109876543210
00100101opS011000111001000000Pd
Decode fields Instruction Details
op S
0 0 PFALSE
0 1 UNALLOCATED
1 UNALLOCATED

SVE predicate read from FFR (predicated)

These instructions are under SVE Predicate Misc.

313029282726252423222120191817161514131211109876543210
00100101opS0110001111000Pg0Pd
Decode fields Instruction Details
op S
0 0 RDFFR (predicated)
0 1 RDFFRS
1 UNALLOCATED

SVE predicate read from FFR (unpredicated)

These instructions are under SVE Predicate Misc.

313029282726252423222120191817161514131211109876543210
00100101opS011001111100000000Pd
Decode fields Instruction Details
op S
0 0 RDFFR (unpredicated)
0 1 UNALLOCATED
1 UNALLOCATED

SVE predicate initialize

These instructions are under SVE Predicate Misc.

313029282726252423222120191817161514131211109876543210
00100101size01100S111000pattern0Pd
Decode fields Instruction Details
S
0 PTRUE
1 PTRUES

SVE Integer Compare - Scalars

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00100101100op0op1op2
Decode fields Instruction details
op0op1op2
0x SVE integer compare scalar count and limit
10 00 0000 SVE conditionally terminate scalars
10 00 != 0000 UNALLOCATED
11 00 SVE pointer conflict compare
1x != 00 UNALLOCATED

SVE integer compare scalar count and limit

These instructions are under SVE Integer Compare - Scalars.

313029282726252423222120191817161514131211109876543210
00100101size1Rm000sfUltRneqPd
Decode fields Instruction Details
U lt eq
0 0 0 WHILEGE
0 0 1 WHILEGT
0 1 0 WHILELT
0 1 1 WHILELE
1 0 0 WHILEHS
1 0 1 WHILEHI
1 1 0 WHILELO
1 1 1 WHILELS

SVE conditionally terminate scalars

These instructions are under SVE Integer Compare - Scalars.

313029282726252423222120191817161514131211109876543210
00100101opsz1Rm001000Rnne0000
Decode fields Instruction Details
op ne
0 UNALLOCATED
1 0 CTERMEQ, CTERMNECTERMEQ
1 1 CTERMEQ, CTERMNECTERMNE

SVE pointer conflict compare

These instructions are under SVE Integer Compare - Scalars.

313029282726252423222120191817161514131211109876543210
00100101size1Rm001100RnrwPd
Decode fields Instruction Details
rw
0 WHILEWR
1 WHILERW

SVE broadcast predicate element

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00100101i1tszh1tszlRv01PnSPm0Pd
Decode fields Instruction Details Feature
S
0 PSELFEAT_SME
1 UNALLOCATED-

SVE Integer Wide Immediate - Unpredicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
001001011op0op111
Decode fields Instruction details
op0op1
00 SVE integer add/subtract immediate (unpredicated)
01 SVE integer min/max immediate (unpredicated)
10 SVE integer multiply immediate (unpredicated)
11 0 SVE broadcast integer immediate (unpredicated)
11 1 SVE broadcast floating-point immediate (unpredicated)

SVE integer add/subtract immediate (unpredicated)

These instructions are under SVE Integer Wide Immediate - Unpredicated.

313029282726252423222120191817161514131211109876543210
00100101size100opc11shimm8Zdn
Decode fields Instruction Details
opc
000 ADD (immediate)
001 SUB (immediate)
010 UNALLOCATED
011 SUBR (immediate)
100 SQADD (immediate)
101 UQADD (immediate)
110 SQSUB (immediate)
111 UQSUB (immediate)

SVE integer min/max immediate (unpredicated)

These instructions are under SVE Integer Wide Immediate - Unpredicated.

313029282726252423222120191817161514131211109876543210
00100101size101opc11o2imm8Zdn
Decode fields Instruction Details
opc o2
0xx 1 UNALLOCATED
000 0 SMAX (immediate)
001 0 UMAX (immediate)
010 0 SMIN (immediate)
011 0 UMIN (immediate)
1xx UNALLOCATED

SVE integer multiply immediate (unpredicated)

These instructions are under SVE Integer Wide Immediate - Unpredicated.

313029282726252423222120191817161514131211109876543210
00100101size110opc11o2imm8Zdn
Decode fields Instruction Details
opc o2
000 0 MUL (immediate)
000 1 UNALLOCATED
001 UNALLOCATED
01x UNALLOCATED
1xx UNALLOCATED

SVE broadcast integer immediate (unpredicated)

These instructions are under SVE Integer Wide Immediate - Unpredicated.

313029282726252423222120191817161514131211109876543210
00100101size111opc011shimm8Zd
Decode fields Instruction Details
opc
00 DUP (immediate)
01 UNALLOCATED
1x UNALLOCATED

SVE broadcast floating-point immediate (unpredicated)

These instructions are under SVE Integer Wide Immediate - Unpredicated.

313029282726252423222120191817161514131211109876543210
00100101size111opc111o2imm8Zd
Decode fields Instruction Details
opc o2
00 0 FDUP
00 1 UNALLOCATED
01 UNALLOCATED
1x UNALLOCATED

SVE Predicate Count

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
0010010110010op0
Decode fields Instruction details
op0
0 SVE predicate count
1 UNALLOCATED

SVE predicate count

These instructions are under SVE Predicate Count.

313029282726252423222120191817161514131211109876543210
00100101size100opc10Pg0PnRd
Decode fields Instruction Details
opc
000 CNTP
001 UNALLOCATED
01x UNALLOCATED
1xx UNALLOCATED

SVE Inc/Dec by Predicate Count

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00100101101op01000op1
Decode fields Instruction details
op0op1
0 0 SVE saturating inc/dec vector by predicate count
0 1 SVE saturating inc/dec register by predicate count
1 0 SVE inc/dec vector by predicate count
1 1 SVE inc/dec register by predicate count

SVE saturating inc/dec vector by predicate count

These instructions are under SVE Inc/Dec by Predicate Count.

313029282726252423222120191817161514131211109876543210
00100101size1010DU10000opcPmZdn
Decode fields Instruction Details
D U opc
01 UNALLOCATED
1x UNALLOCATED
0 0 00 SQINCP (vector)
0 1 00 UQINCP (vector)
1 0 00 SQDECP (vector)
1 1 00 UQDECP (vector)

SVE saturating inc/dec register by predicate count

These instructions are under SVE Inc/Dec by Predicate Count.

313029282726252423222120191817161514131211109876543210
00100101size1010DU10001sfopPmRdn
Decode fields Instruction Details
D U sf op
1 UNALLOCATED
0 0 0 0 SQINCP (scalar)32-bit
0 0 1 0 SQINCP (scalar)64-bit
0 1 0 0 UQINCP (scalar)32-bit
0 1 1 0 UQINCP (scalar)64-bit
1 0 0 0 SQDECP (scalar)32-bit
1 0 1 0 SQDECP (scalar)64-bit
1 1 0 0 UQDECP (scalar)32-bit
1 1 1 0 UQDECP (scalar)64-bit

SVE inc/dec vector by predicate count

These instructions are under SVE Inc/Dec by Predicate Count.

313029282726252423222120191817161514131211109876543210
00100101size1011opD10000opc2PmZdn
Decode fields Instruction Details
op D opc2
0 01 UNALLOCATED
0 1x UNALLOCATED
0 0 00 INCP (vector)
0 1 00 DECP (vector)
1 UNALLOCATED

SVE inc/dec register by predicate count

These instructions are under SVE Inc/Dec by Predicate Count.

313029282726252423222120191817161514131211109876543210
00100101size1011opD10001opc2PmRdn
Decode fields Instruction Details
op D opc2
0 01 UNALLOCATED
0 1x UNALLOCATED
0 0 00 INCP (scalar)
0 1 00 DECP (scalar)
1 UNALLOCATED

SVE Write FFR

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
00100101101op0op11001op2op3op4
Decode fields Instruction details
op0op1op2op3op4
0 00 000 00000 SVE FFR write from predicate
1 00 000 0000 00000 SVE FFR initialise
1 00 000 1xxx 00000 UNALLOCATED
1 00 000 x1xx 00000 UNALLOCATED
1 00 000 xx1x 00000 UNALLOCATED
1 00 000 xxx1 00000 UNALLOCATED
00 000 != 00000 UNALLOCATED
00 != 000 UNALLOCATED
!= 00 UNALLOCATED

SVE FFR write from predicate

These instructions are under SVE Write FFR.

313029282726252423222120191817161514131211109876543210
00100101opc1010001001000Pn00000
Decode fields Instruction Details
opc
00 WRFFR
01 UNALLOCATED
1x UNALLOCATED

SVE FFR initialise

These instructions are under SVE Write FFR.

313029282726252423222120191817161514131211109876543210
00100101opc1011001001000000000000
Decode fields Instruction Details
opc
00 SETFFR
01 UNALLOCATED
1x UNALLOCATED

SVE Integer Multiply-Add - Unpredicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
0100010000op0
Decode fields Instruction details
op0
0000x SVE integer dot product (unpredicated)
0001x SVE2 saturating multiply-add interleaved long
001xx CDOT (vectors)
01xxx SVE2 complex integer multiply-add
10xxx SVE2 integer multiply-add long
110xx SVE2 saturating multiply-add long
1110x SVE2 saturating multiply-add high
11110 SVE mixed sign dot product
11111 UNALLOCATED

SVE integer dot product (unpredicated)

These instructions are under SVE Integer Multiply-Add - Unpredicated.

313029282726252423222120191817161514131211109876543210
01000100size0Zm00000UZnZda
Decode fields Instruction Details
U
0 SDOT (vectors)
1 UDOT (vectors)

SVE2 saturating multiply-add interleaved long

These instructions are under SVE Integer Multiply-Add - Unpredicated.

313029282726252423222120191817161514131211109876543210
01000100size0Zm00001SZnZda
Decode fields Instruction Details
S
0 SQDMLALBT
1 SQDMLSLBT

SVE2 complex integer multiply-add

These instructions are under SVE Integer Multiply-Add - Unpredicated.

313029282726252423222120191817161514131211109876543210
01000100size0Zm001oprotZnZda
Decode fields Instruction Details
op
0 CMLA (vectors)
1 SQRDCMLAH (vectors)

SVE2 integer multiply-add long

These instructions are under SVE Integer Multiply-Add - Unpredicated.

313029282726252423222120191817161514131211109876543210
01000100size0Zm010SUTZnZda
Decode fields Instruction Details
S U T
0 0 0 SMLALB (vectors)
0 0 1 SMLALT (vectors)
0 1 0 UMLALB (vectors)
0 1 1 UMLALT (vectors)
1 0 0 SMLSLB (vectors)
1 0 1 SMLSLT (vectors)
1 1 0 UMLSLB (vectors)
1 1 1 UMLSLT (vectors)

SVE2 saturating multiply-add long

These instructions are under SVE Integer Multiply-Add - Unpredicated.

313029282726252423222120191817161514131211109876543210
01000100size0Zm0110STZnZda
Decode fields Instruction Details
S T
0 0 SQDMLALB (vectors)
0 1 SQDMLALT (vectors)
1 0 SQDMLSLB (vectors)
1 1 SQDMLSLT (vectors)

SVE2 saturating multiply-add high

These instructions are under SVE Integer Multiply-Add - Unpredicated.

313029282726252423222120191817161514131211109876543210
01000100size0Zm01110SZnZda
Decode fields Instruction Details
S
0 SQRDMLAH (vectors)
1 SQRDMLSH (vectors)

SVE mixed sign dot product

These instructions are under SVE Integer Multiply-Add - Unpredicated.

313029282726252423222120191817161514131211109876543210
01000100size0Zm011110ZnZda
Decode fields Instruction Details Feature
size
0x UNALLOCATED-
10 USDOT (vectors)FEAT_I8MM
11 UNALLOCATED-

SVE2 Integer - Predicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
010001000op010op1
Decode fields Instruction details
op0op1
0010 1 SVE2 integer pairwise add and accumulate long
0011 1 UNALLOCATED
011x 1 UNALLOCATED
0x0x 1 SVE2 integer unary operations (predicated)
0xxx 0 SVE2 saturating/rounding bitwise shift left (predicated)
10xx 0 SVE2 integer halving add/subtract (predicated)
10xx 1 SVE2 integer pairwise arithmetic
11xx 0 SVE2 saturating add/subtract
11xx 1 UNALLOCATED

SVE2 integer pairwise add and accumulate long

These instructions are under SVE2 Integer - Predicated.

313029282726252423222120191817161514131211109876543210
01000100size00010U101PgZnZda
Decode fields Instruction Details
U
0 SADALP
1 UADALP

SVE2 integer unary operations (predicated)

These instructions are under SVE2 Integer - Predicated.

313029282726252423222120191817161514131211109876543210
01000100size00Q0opc101PgZnZd
Decode fields Instruction Details
Q opc
1x UNALLOCATED
0 00 URECPE
0 01 URSQRTE
1 00 SQABS
1 01 SQNEG

SVE2 saturating/rounding bitwise shift left (predicated)

These instructions are under SVE2 Integer - Predicated.

313029282726252423222120191817161514131211109876543210
01000100size00QRNU100PgZmZdn
Decode fields Instruction Details
Q R N U
0 0 UNALLOCATED
0 0 1 0 SRSHL
0 0 1 1 URSHL
0 1 1 0 SRSHLR
0 1 1 1 URSHLR
1 0 0 0 SQSHL (vectors)
1 0 0 1 UQSHL (vectors)
1 0 1 0 SQRSHL
1 0 1 1 UQRSHL
1 1 0 0 SQSHLR
1 1 0 1 UQSHLR
1 1 1 0 SQRSHLR
1 1 1 1 UQRSHLR

SVE2 integer halving add/subtract (predicated)

These instructions are under SVE2 Integer - Predicated.

313029282726252423222120191817161514131211109876543210
01000100size010RSU100PgZmZdn
Decode fields Instruction Details
R S U
0 0 0 SHADD
0 0 1 UHADD
0 1 0 SHSUB
0 1 1 UHSUB
1 0 0 SRHADD
1 0 1 URHADD
1 1 0 SHSUBR
1 1 1 UHSUBR

SVE2 integer pairwise arithmetic

These instructions are under SVE2 Integer - Predicated.

313029282726252423222120191817161514131211109876543210
01000100size010opcU101PgZmZdn
Decode fields Instruction Details
opc U
00 0 UNALLOCATED
00 1 ADDP
01 UNALLOCATED
10 0 SMAXP
10 1 UMAXP
11 0 SMINP
11 1 UMINP

SVE2 saturating add/subtract

These instructions are under SVE2 Integer - Predicated.

313029282726252423222120191817161514131211109876543210
01000100size011opSU100PgZmZdn
Decode fields Instruction Details
op S U
0 0 0 SQADD (vectors, predicated)
0 0 1 UQADD (vectors, predicated)
0 1 0 SQSUB (vectors, predicated)
0 1 1 UQSUB (vectors, predicated)
1 0 0 SUQADD
1 0 1 USQADD
1 1 0 SQSUBR
1 1 1 UQSUBR

SVE clamp

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01000100size0Zm11000UZnZd
Decode fields Instruction Details Feature
U
0 SCLAMPFEAT_SME
1 UCLAMPFEAT_SME

SVE Multiply - Indexed

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
010001001op0
Decode fields Instruction details
op0
00000x SVE integer dot product (indexed)
00001x SVE2 integer multiply-add (indexed)
00010x SVE2 saturating multiply-add high (indexed)
00011x SVE mixed sign dot product (indexed)
001xxx SVE2 saturating multiply-add (indexed)
0100xx SVE2 complex integer dot product (indexed)
0101xx UNALLOCATED
0110xx SVE2 complex integer multiply-add (indexed)
0111xx SVE2 complex saturating multiply-add (indexed)
10xxxx SVE2 integer multiply-add long (indexed)
110xxx SVE2 integer multiply long (indexed)
1110xx SVE2 saturating multiply (indexed)
11110x SVE2 saturating multiply high (indexed)
111110 SVE2 integer multiply (indexed)
111111 UNALLOCATED

SVE integer dot product (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc00000UZnZda
Decode fields Instruction Details
size U
0x UNALLOCATED
10 0 SDOT (indexed)32-bit
10 1 UDOT (indexed)32-bit
11 0 SDOT (indexed)64-bit
11 1 UDOT (indexed)64-bit

SVE2 integer multiply-add (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc00001SZnZda
Decode fields Instruction Details
size S
0x 0 MLA (indexed)16-bit
0x 1 MLS (indexed)16-bit
10 0 MLA (indexed)32-bit
10 1 MLS (indexed)32-bit
11 0 MLA (indexed)64-bit
11 1 MLS (indexed)64-bit

SVE2 saturating multiply-add high (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc00010SZnZda
Decode fields Instruction Details
size S
0x 0 SQRDMLAH (indexed)16-bit
0x 1 SQRDMLSH (indexed)16-bit
10 0 SQRDMLAH (indexed)32-bit
10 1 SQRDMLSH (indexed)32-bit
11 0 SQRDMLAH (indexed)64-bit
11 1 SQRDMLSH (indexed)64-bit

SVE mixed sign dot product (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc00011UZnZda
Decode fields Instruction Details Feature
size U
0x UNALLOCATED-
10 0 USDOT (indexed)FEAT_I8MM
10 1 SUDOTFEAT_I8MM
11 UNALLOCATED-

SVE2 saturating multiply-add (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc001SilTZnZda
Decode fields Instruction Details
size S T
0x UNALLOCATED
10 0 0 SQDMLALB (indexed)32-bit
10 0 1 SQDMLALT (indexed)32-bit
10 1 0 SQDMLSLB (indexed)32-bit
10 1 1 SQDMLSLT (indexed)32-bit
11 0 0 SQDMLALB (indexed)64-bit
11 0 1 SQDMLALT (indexed)64-bit
11 1 0 SQDMLSLB (indexed)64-bit
11 1 1 SQDMLSLT (indexed)64-bit

SVE2 complex integer dot product (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc0100rotZnZda
Decode fields Instruction Details
size
0x UNALLOCATED
10 CDOT (indexed)32-bit
11 CDOT (indexed)64-bit

SVE2 complex integer multiply-add (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc0110rotZnZda
Decode fields Instruction Details
size
0x UNALLOCATED
10 CMLA (indexed)16-bit
11 CMLA (indexed)32-bit

SVE2 complex saturating multiply-add (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc0111rotZnZda
Decode fields Instruction Details
size
0x UNALLOCATED
10 SQRDCMLAH (indexed)16-bit
11 SQRDCMLAH (indexed)32-bit

SVE2 integer multiply-add long (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc10SUilTZnZda
Decode fields Instruction Details
size S U T
0x UNALLOCATED
10 0 0 0 SMLALB (indexed)32-bit
10 0 0 1 SMLALT (indexed)32-bit
10 0 1 0 UMLALB (indexed)32-bit
10 0 1 1 UMLALT (indexed)32-bit
10 1 0 0 SMLSLB (indexed)32-bit
10 1 0 1 SMLSLT (indexed)32-bit
10 1 1 0 UMLSLB (indexed)32-bit
10 1 1 1 UMLSLT (indexed)32-bit
11 0 0 0 SMLALB (indexed)64-bit
11 0 0 1 SMLALT (indexed)64-bit
11 0 1 0 UMLALB (indexed)64-bit
11 0 1 1 UMLALT (indexed)64-bit
11 1 0 0 SMLSLB (indexed)64-bit
11 1 0 1 SMLSLT (indexed)64-bit
11 1 1 0 UMLSLB (indexed)64-bit
11 1 1 1 UMLSLT (indexed)64-bit

SVE2 integer multiply long (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc110UilTZnZd
Decode fields Instruction Details
size U T
0x UNALLOCATED
10 0 0 SMULLB (indexed)32-bit
10 0 1 SMULLT (indexed)32-bit
10 1 0 UMULLB (indexed)32-bit
10 1 1 UMULLT (indexed)32-bit
11 0 0 SMULLB (indexed)64-bit
11 0 1 SMULLT (indexed)64-bit
11 1 0 UMULLB (indexed)64-bit
11 1 1 UMULLT (indexed)64-bit

SVE2 saturating multiply (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc1110ilTZnZd
Decode fields Instruction Details
size T
0x UNALLOCATED
10 0 SQDMULLB (indexed)32-bit
10 1 SQDMULLT (indexed)32-bit
11 0 SQDMULLB (indexed)64-bit
11 1 SQDMULLT (indexed)64-bit

SVE2 saturating multiply high (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc11110RZnZd
Decode fields Instruction Details
size R
0x 0 SQDMULH (indexed)16-bit
0x 1 SQRDMULH (indexed)16-bit
10 0 SQDMULH (indexed)32-bit
10 1 SQRDMULH (indexed)32-bit
11 0 SQDMULH (indexed)64-bit
11 1 SQRDMULH (indexed)64-bit

SVE2 integer multiply (indexed)

These instructions are under SVE Multiply - Indexed.

313029282726252423222120191817161514131211109876543210
01000100size1opc111110ZnZd
Decode fields Instruction Details
size
0x MUL (indexed)16-bit
10 MUL (indexed)32-bit
11 MUL (indexed)64-bit

SVE2 Widening Integer Arithmetic

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
0100010100op0
Decode fields Instruction details
op0
0x SVE2 integer add/subtract long
10 SVE2 integer add/subtract wide
11 SVE2 integer multiply long

SVE2 integer add/subtract long

These instructions are under SVE2 Widening Integer Arithmetic.

313029282726252423222120191817161514131211109876543210
01000101size0Zm00opSUTZnZd
Decode fields Instruction Details
op S U T
0 0 0 0 SADDLB
0 0 0 1 SADDLT
0 0 1 0 UADDLB
0 0 1 1 UADDLT
0 1 0 0 SSUBLB
0 1 0 1 SSUBLT
0 1 1 0 USUBLB
0 1 1 1 USUBLT
1 0 UNALLOCATED
1 1 0 0 SABDLB
1 1 0 1 SABDLT
1 1 1 0 UABDLB
1 1 1 1 UABDLT

SVE2 integer add/subtract wide

These instructions are under SVE2 Widening Integer Arithmetic.

313029282726252423222120191817161514131211109876543210
01000101size0Zm010SUTZnZd
Decode fields Instruction Details
S U T
0 0 0 SADDWB
0 0 1 SADDWT
0 1 0 UADDWB
0 1 1 UADDWT
1 0 0 SSUBWB
1 0 1 SSUBWT
1 1 0 USUBWB
1 1 1 USUBWT

SVE2 integer multiply long

These instructions are under SVE2 Widening Integer Arithmetic.

313029282726252423222120191817161514131211109876543210
01000101size0Zm011opUTZnZd
Decode fields Instruction Details
op U T
0 0 0 SQDMULLB (vectors)
0 0 1 SQDMULLT (vectors)
0 1 0 PMULLB
0 1 1 PMULLT
1 0 0 SMULLB (vectors)
1 0 1 SMULLT (vectors)
1 1 0 UMULLB (vectors)
1 1 1 UMULLT (vectors)

SVE Misc

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01000101op0010op1
Decode fields Instruction details
op0op1
0 10xx SVE2 bitwise shift left long
1 10xx UNALLOCATED
00xx SVE2 integer add/subtract interleaved long
010x SVE2 bitwise exclusive-or interleaved
0110 SVE integer matrix multiply accumulate
0111 UNALLOCATED
11xx SVE2 bitwise permute

SVE2 bitwise shift left long

These instructions are under SVE Misc.

313029282726252423222120191817161514131211109876543210
010001010tszh0tszlimm31010UTZnZd
Decode fields Instruction Details
U T
0 0 SSHLLB
0 1 SSHLLT
1 0 USHLLB
1 1 USHLLT

SVE2 integer add/subtract interleaved long

These instructions are under SVE Misc.

313029282726252423222120191817161514131211109876543210
01000101size0Zm1000StbZnZd
Decode fields Instruction Details
S tb
0 0 SADDLBT
0 1 UNALLOCATED
1 0 SSUBLBT
1 1 SSUBLTB

SVE2 bitwise exclusive-or interleaved

These instructions are under SVE Misc.

313029282726252423222120191817161514131211109876543210
01000101size0Zm10010tbZnZd
Decode fields Instruction Details
tb
0 EORBT
1 EORTB

SVE integer matrix multiply accumulate

These instructions are under SVE Misc.

313029282726252423222120191817161514131211109876543210
01000101uns0Zm100110ZnZd
Decode fields Instruction Details Feature
uns
00 SMMLAFEAT_I8MM
01 UNALLOCATED-
10 USMMLAFEAT_I8MM
11 UMMLAFEAT_I8MM

SVE2 bitwise permute

These instructions are under SVE Misc.

313029282726252423222120191817161514131211109876543210
01000101size0Zm1011opcZnZd
Decode fields Instruction Details Feature
opc
00 BEXTFEAT_SVE_BitPerm
01 BDEPFEAT_SVE_BitPerm
10 BGRPFEAT_SVE_BitPerm
11 UNALLOCATED-

SVE2 Accumulate

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
010001010op011op1
Decode fields Instruction details
op0op1
0000 011 SVE2 complex integer add
!= 0000 011 UNALLOCATED
00x SVE2 integer absolute difference and accumulate long
010 SVE2 integer add/subtract long with carry
10x SVE2 bitwise shift right and accumulate
110 SVE2 bitwise shift and insert
111 SVE2 integer absolute difference and accumulate

SVE2 complex integer add

These instructions are under SVE2 Accumulate.

313029282726252423222120191817161514131211109876543210
01000101size00000op11011rotZmZdn
Decode fields Instruction Details
op
0 CADD
1 SQCADD

SVE2 integer absolute difference and accumulate long

These instructions are under SVE2 Accumulate.

313029282726252423222120191817161514131211109876543210
01000101size0Zm1100UTZnZda
Decode fields Instruction Details
U T
0 0 SABALB
0 1 SABALT
1 0 UABALB
1 1 UABALT

SVE2 integer add/subtract long with carry

These instructions are under SVE2 Accumulate.

313029282726252423222120191817161514131211109876543210
01000101size0Zm11010TZnZda
Decode fields Instruction Details
size T
0x 0 ADCLB
0x 1 ADCLT
1x 0 SBCLB
1x 1 SBCLT

SVE2 bitwise shift right and accumulate

These instructions are under SVE2 Accumulate.

313029282726252423222120191817161514131211109876543210
01000101tszh0tszlimm31110RUZnZda
Decode fields Instruction Details
R U
0 0 SSRA
0 1 USRA
1 0 SRSRA
1 1 URSRA

SVE2 bitwise shift and insert

These instructions are under SVE2 Accumulate.

313029282726252423222120191817161514131211109876543210
01000101tszh0tszlimm311110opZnZd
Decode fields Instruction Details
op
0 SRI
1 SLI

SVE2 integer absolute difference and accumulate

These instructions are under SVE2 Accumulate.

313029282726252423222120191817161514131211109876543210
01000101size0Zm11111UZnZda
Decode fields Instruction Details
U
0 SABA
1 UABA

SVE2 Narrowing

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01000101op01op10op2
Decode fields Instruction details
op0op1op2
0 000 10 SVE2 saturating extract narrow
0 != 000 10 UNALLOCATED
0 0x SVE2 bitwise shift right narrow
1 0x UNALLOCATED
1 10 UNALLOCATED
11 SVE2 integer add/subtract narrow high part

SVE2 saturating extract narrow

These instructions are under SVE2 Narrowing.

313029282726252423222120191817161514131211109876543210
010001010tszh1tszl000010opcTZnZd
Decode fields Instruction Details
opc T
00 0 SQXTNB
00 1 SQXTNT
01 0 UQXTNB
01 1 UQXTNT
10 0 SQXTUNB
10 1 SQXTUNT
11 UNALLOCATED

SVE2 bitwise shift right narrow

These instructions are under SVE2 Narrowing.

313029282726252423222120191817161514131211109876543210
010001010tszh1tszlimm300opURTZnZd
Decode fields Instruction Details
op U R T
0 0 0 0 SQSHRUNB
0 0 0 1 SQSHRUNT
0 0 1 0 SQRSHRUNB
0 0 1 1 SQRSHRUNT
0 1 0 0 SHRNB
0 1 0 1 SHRNT
0 1 1 0 RSHRNB
0 1 1 1 RSHRNT
1 0 0 0 SQSHRNB
1 0 0 1 SQSHRNT
1 0 1 0 SQRSHRNB
1 0 1 1 SQRSHRNT
1 1 0 0 UQSHRNB
1 1 0 1 UQSHRNT
1 1 1 0 UQRSHRNB
1 1 1 1 UQRSHRNT

SVE2 integer add/subtract narrow high part

These instructions are under SVE2 Narrowing.

313029282726252423222120191817161514131211109876543210
01000101size1Zm011SRTZnZd
Decode fields Instruction Details
S R T
0 0 0 ADDHNB
0 0 1 ADDHNT
0 1 0 RADDHNB
0 1 1 RADDHNT
1 0 0 SUBHNB
1 0 1 SUBHNT
1 1 0 RSUBHNB
1 1 1 RSUBHNT

SVE2 character match

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01000101size1Zm100PgZnopPd
Decode fields Instruction Details
op
0 MATCH
1 NMATCH

SVE2 Histogram Computation - Segment

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
010001011101op0
Decode fields Instruction details
op0
000 HISTSEG
!= 000 UNALLOCATED

SVE2 Crypto Extensions

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
010001011op0op1111op2op3
Decode fields Instruction details
op0op1op2op3
000 00 00 00000 SVE2 crypto unary operations
000 00 00 != 00000 UNALLOCATED
000 00 x1 UNALLOCATED
000 01 0x UNALLOCATED
000 01 11 UNALLOCATED
000 1x 00 SVE2 crypto destructive binary operations
000 1x x1 UNALLOCATED
!= 000 0x UNALLOCATED
!= 000 11 UNALLOCATED
10 SVE2 crypto constructive binary operations

SVE2 crypto unary operations

These instructions are under SVE2 Crypto Extensions.

313029282726252423222120191817161514131211109876543210
01000101size10000011100op00000Zdn
Decode fields Instruction Details Feature
size op
00 0 AESMCFEAT_SVE_AES
00 1 AESIMCFEAT_SVE_AES
01 UNALLOCATED-
1x UNALLOCATED-

SVE2 crypto destructive binary operations

These instructions are under SVE2 Crypto Extensions.

313029282726252423222120191817161514131211109876543210
01000101size10001op11100o2ZmZdn
Decode fields Instruction Details Feature
size op o2
00 0 0 AESEFEAT_SVE_AES
00 0 1 AESDFEAT_SVE_AES
00 1 0 SM4EFEAT_SVE_SM4
00 1 1 UNALLOCATED-
01 UNALLOCATED-
1x UNALLOCATED-

SVE2 crypto constructive binary operations

These instructions are under SVE2 Crypto Extensions.

313029282726252423222120191817161514131211109876543210
01000101size1Zm11110opZnZd
Decode fields Instruction Details Feature
size op
00 0 SM4EKEYFEAT_SVE_SM4
00 1 RAX1FEAT_SVE_SHA3
01 UNALLOCATED-
1x UNALLOCATED-

SVE floating-point convert precision odd elements

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100100opc0010opc2101PgZnZd
Decode fields Instruction Details Feature
opc opc2
x0 11 UNALLOCATED-
00 0x UNALLOCATED-
00 10 FCVTXNT-
01 UNALLOCATED-
10 00 FCVTNTsingle-precision to half-precision-
10 01 FCVTLThalf-precision to single-precision-
10 10 BFCVTNTFEAT_BF16
11 0x UNALLOCATED-
11 10 FCVTNTdouble-precision to single-precision-
11 11 FCVTLTsingle-precision to double-precision-

SVE2 floating-point pairwise operations

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100100size010opc100PgZmZdn
Decode fields Instruction Details
opc
000 FADDP
001 UNALLOCATED
01x UNALLOCATED
100 FMAXNMP
101 FMINNMP
110 FMAXP
111 FMINP

SVE floating-point multiply-add (indexed)

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100100size1opc00000opZnZda
Decode fields Instruction Details
size op
0x 0 FMLA (indexed)half-precision
0x 1 FMLS (indexed)half-precision
10 0 FMLA (indexed)single-precision
10 1 FMLS (indexed)single-precision
11 0 FMLA (indexed)double-precision
11 1 FMLS (indexed)double-precision

SVE floating-point complex multiply-add (indexed)

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100100size1opc0001rotZnZda
Decode fields Instruction Details
size
0x UNALLOCATED
10 FCMLA (indexed)half-precision
11 FCMLA (indexed)single-precision

SVE floating-point multiply (indexed)

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100100size1opc001000ZnZd
Decode fields Instruction Details
size
0x FMUL (indexed)half-precision
10 FMUL (indexed)single-precision
11 FMUL (indexed)double-precision

SVE Floating Point Widening Multiply-Add - Indexed

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100100op0101op10op2
Decode fields Instruction details
op0op1op2
0 0 00 SVE BFloat16 floating-point dot product (indexed)
0 0 != 00 UNALLOCATED
0 1 UNALLOCATED
1 SVE floating-point multiply-add long (indexed)

SVE BFloat16 floating-point dot product (indexed)

These instructions are under SVE Floating Point Widening Multiply-Add - Indexed.

313029282726252423222120191817161514131211109876543210
011001000op1i2Zm010000ZnZda
Decode fields Instruction Details Feature
op
0 UNALLOCATED-
1 BFDOT (indexed)FEAT_BF16

SVE floating-point multiply-add long (indexed)

These instructions are under SVE Floating Point Widening Multiply-Add - Indexed.

313029282726252423222120191817161514131211109876543210
011001001o21i3hZm01op0i3lTZnZda
Decode fields Instruction Details Feature
o2 op T
0 0 0 FMLALB (indexed)-
0 0 1 FMLALT (indexed)-
0 1 0 FMLSLB (indexed)-
0 1 1 FMLSLT (indexed)-
1 0 0 BFMLALB (indexed)FEAT_BF16
1 0 1 BFMLALT (indexed)FEAT_BF16
1 1 UNALLOCATED-

SVE Floating Point Widening Multiply-Add

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100100op0110op100op2
Decode fields Instruction details
op0op1op2
0 0 0 SVE BFloat16 floating-point dot product
0 0 1 UNALLOCATED
0 1 UNALLOCATED
1 SVE floating-point multiply-add long

SVE BFloat16 floating-point dot product

These instructions are under SVE Floating Point Widening Multiply-Add.

313029282726252423222120191817161514131211109876543210
011001000op1Zm100000ZnZda
Decode fields Instruction Details Feature
op
0 UNALLOCATED-
1 BFDOT (vectors)FEAT_BF16

SVE floating-point multiply-add long

These instructions are under SVE Floating Point Widening Multiply-Add.

313029282726252423222120191817161514131211109876543210
011001001o21Zm10op00TZnZda
Decode fields Instruction Details Feature
o2 op T
0 0 0 FMLALB (vectors)-
0 0 1 FMLALT (vectors)-
0 1 0 FMLSLB (vectors)-
0 1 1 FMLSLT (vectors)-
1 0 0 BFMLALB (vectors)FEAT_BF16
1 0 1 BFMLALT (vectors)FEAT_BF16
1 1 UNALLOCATED-

SVE floating point matrix multiply accumulate

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100100opc1Zm111001ZnZda
Decode fields Instruction Details Feature
opc
00 UNALLOCATED-
01 BFMMLAFEAT_BF16
10 FMMLA32-bit elementFEAT_F32MM
11 FMMLA64-bit elementFEAT_F64MM

SVE floating-point compare vectors

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100101size0Zmop1o2PgZno3Pd
Decode fields Instruction Details
op o2 o3
0 0 0 FCM<cc> (vectors)FCMGE
0 0 1 FCM<cc> (vectors)FCMGT
0 1 0 FCM<cc> (vectors)FCMEQ
0 1 1 FCM<cc> (vectors)FCMNE
1 0 0 FCM<cc> (vectors)FCMUO
1 0 1 FAC<cc>FACGE
1 1 0 UNALLOCATED
1 1 1 FAC<cc>FACGT

SVE floating-point arithmetic (unpredicated)

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100101size0Zm000opcZnZd
Decode fields Instruction Details
opc
000 FADD (vectors, unpredicated)
001 FSUB (vectors, unpredicated)
010 FMUL (vectors, unpredicated)
011 FTSMUL
10x UNALLOCATED
110 FRECPS
111 FRSQRTS

SVE Floating Point Arithmetic - Predicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
011001010op0100op1op2
Decode fields Instruction details
op0op1op2
0x SVE floating-point arithmetic (predicated)
10 000 FTMAD
10 != 000 UNALLOCATED
11 0000 SVE floating-point arithmetic with immediate (predicated)
11 != 0000 UNALLOCATED

SVE floating-point arithmetic (predicated)

These instructions are under SVE Floating Point Arithmetic - Predicated.

313029282726252423222120191817161514131211109876543210
01100101size00opc100PgZmZdn
Decode fields Instruction Details
opc
0000 FADD (vectors, predicated)
0001 FSUB (vectors, predicated)
0010 FMUL (vectors, predicated)
0011 FSUBR (vectors)
0100 FMAXNM (vectors)
0101 FMINNM (vectors)
0110 FMAX (vectors)
0111 FMIN (vectors)
1000 FABD
1001 FSCALE
1010 FMULX
1011 UNALLOCATED
1100 FDIVR
1101 FDIV
111x UNALLOCATED

SVE floating-point arithmetic with immediate (predicated)

These instructions are under SVE Floating Point Arithmetic - Predicated.

313029282726252423222120191817161514131211109876543210
01100101size011opc100Pg0000i1Zdn
Decode fields Instruction Details
opc
000 FADD (immediate)
001 FSUB (immediate)
010 FMUL (immediate)
011 FSUBR (immediate)
100 FMAXNM (immediate)
101 FMINNM (immediate)
110 FMAX (immediate)
111 FMIN (immediate)

SVE Floating Point Unary Operations - Predicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
011001010op0101
Decode fields Instruction details
op0
00x SVE floating-point round to integral value
010 SVE floating-point convert precision
011 SVE floating-point unary operations
10x SVE integer convert to floating-point
11x SVE floating-point convert to integer

SVE floating-point round to integral value

These instructions are under SVE Floating Point Unary Operations - Predicated.

313029282726252423222120191817161514131211109876543210
01100101size000opc101PgZnZd
Decode fields Instruction Details
opc
000 FRINT<r>nearest with ties to even
001 FRINT<r>toward plus infinity
010 FRINT<r>toward minus infinity
011 FRINT<r>toward zero
100 FRINT<r>nearest with ties to away
101 UNALLOCATED
110 FRINT<r>current mode signalling inexact
111 FRINT<r>current mode

SVE floating-point convert precision

These instructions are under SVE Floating Point Unary Operations - Predicated.

313029282726252423222120191817161514131211109876543210
01100101opc0010opc2101PgZnZd
Decode fields Instruction Details Feature
opc opc2
x0 11 UNALLOCATED-
00 0x UNALLOCATED-
00 10 FCVTX-
01 UNALLOCATED-
10 00 FCVTsingle-precision to half-precision-
10 01 FCVThalf-precision to single-precision-
10 10 BFCVTFEAT_BF16
11 00 FCVTdouble-precision to half-precision-
11 01 FCVThalf-precision to double-precision-
11 10 FCVTdouble-precision to single-precision-
11 11 FCVTsingle-precision to double-precision-

SVE floating-point unary operations

These instructions are under SVE Floating Point Unary Operations - Predicated.

313029282726252423222120191817161514131211109876543210
01100101size0011opc101PgZnZd
Decode fields Instruction Details
opc
00 FRECPX
01 FSQRT
1x UNALLOCATED

SVE integer convert to floating-point

These instructions are under SVE Floating Point Unary Operations - Predicated.

313029282726252423222120191817161514131211109876543210
01100101opc010opc2U101PgZnZd
Decode fields Instruction Details
opc opc2 U
00 UNALLOCATED
01 00 UNALLOCATED
01 01 0 SCVTF16-bit to half-precision
01 01 1 UCVTF16-bit to half-precision
01 10 0 SCVTF32-bit to half-precision
01 10 1 UCVTF32-bit to half-precision
01 11 0 SCVTF64-bit to half-precision
01 11 1 UCVTF64-bit to half-precision
10 0x UNALLOCATED
10 10 0 SCVTF32-bit to single-precision
10 10 1 UCVTF32-bit to single-precision
10 11 UNALLOCATED
11 00 0 SCVTF32-bit to double-precision
11 00 1 UCVTF32-bit to double-precision
11 01 UNALLOCATED
11 10 0 SCVTF64-bit to single-precision
11 10 1 UCVTF64-bit to single-precision
11 11 0 SCVTF64-bit to double-precision
11 11 1 UCVTF64-bit to double-precision

SVE floating-point convert to integer

These instructions are under SVE Floating Point Unary Operations - Predicated.

313029282726252423222120191817161514131211109876543210
01100101opc011opc2U101PgZnZd
Decode fields Instruction Details
opc opc2 U
00 0 FLOGB
00 1 UNALLOCATED
01 00 UNALLOCATED
01 01 0 FCVTZShalf-precision to 16-bit
01 01 1 FCVTZUhalf-precision to 16-bit
01 10 0 FCVTZShalf-precision to 32-bit
01 10 1 FCVTZUhalf-precision to 32-bit
01 11 0 FCVTZShalf-precision to 64-bit
01 11 1 FCVTZUhalf-precision to 64-bit
10 0x UNALLOCATED
10 10 0 FCVTZSsingle-precision to 32-bit
10 10 1 FCVTZUsingle-precision to 32-bit
10 11 UNALLOCATED
11 00 0 FCVTZSdouble-precision to 32-bit
11 00 1 FCVTZUdouble-precision to 32-bit
11 01 UNALLOCATED
11 10 0 FCVTZSsingle-precision to 64-bit
11 10 1 FCVTZUsingle-precision to 64-bit
11 11 0 FCVTZSdouble-precision to 64-bit
11 11 1 FCVTZUdouble-precision to 64-bit

SVE floating-point recursive reduction

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100101size000opc001PgZnVd
Decode fields Instruction Details
opc
000 FADDV
001 UNALLOCATED
01x UNALLOCATED
100 FMAXNMV
101 FMINNMV
110 FMAXV
111 FMINV

SVE Floating Point Unary Operations - Unpredicated

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
011001010010011op0
Decode fields Instruction details
op0
00 SVE floating-point reciprocal estimate (unpredicated)
!= 00 UNALLOCATED

SVE floating-point reciprocal estimate (unpredicated)

These instructions are under SVE Floating Point Unary Operations - Unpredicated.

313029282726252423222120191817161514131211109876543210
01100101size001opc001100ZnZd
Decode fields Instruction Details
opc
0xx UNALLOCATED
10x UNALLOCATED
110 FRECPE
111 FRSQRTE

SVE Floating Point Compare - with Zero

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100101010op0001
Decode fields Instruction details
op0
0 SVE floating-point compare with zero
1 UNALLOCATED

SVE floating-point compare with zero

These instructions are under SVE Floating Point Compare - with Zero.

313029282726252423222120191817161514131211109876543210
01100101size0100eqlt001PgZnnePd
Decode fields Instruction Details
eq lt ne
0 0 0 FCM<cc> (zero)FCMGE
0 0 1 FCM<cc> (zero)FCMGT
0 1 0 FCM<cc> (zero)FCMLT
0 1 1 FCM<cc> (zero)FCMLE
1 1 UNALLOCATED
1 0 0 FCM<cc> (zero)FCMEQ
1 1 0 FCM<cc> (zero)FCMNE

SVE Floating Point Accumulating Reduction

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
01100101011op0001
Decode fields Instruction details
op0
0 SVE floating-point serial reduction (predicated)
1 UNALLOCATED

SVE floating-point serial reduction (predicated)

These instructions are under SVE Floating Point Accumulating Reduction.

313029282726252423222120191817161514131211109876543210
01100101size0110opc001PgZmVdn
Decode fields Instruction Details
opc
00 FADDA
01 UNALLOCATED
1x UNALLOCATED

SVE Floating Point Multiply-Add

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
011001011op0
Decode fields Instruction details
op0
0 SVE floating-point multiply-accumulate writing addend
1 SVE floating-point multiply-accumulate writing multiplicand

SVE floating-point multiply-accumulate writing addend

These instructions are under SVE Floating Point Multiply-Add.

313029282726252423222120191817161514131211109876543210
01100101size1Zm0opcPgZnZda
Decode fields Instruction Details
opc
00 FMLA (vectors)
01 FMLS (vectors)
10 FNMLA
11 FNMLS

SVE floating-point multiply-accumulate writing multiplicand

These instructions are under SVE Floating Point Multiply-Add.

313029282726252423222120191817161514131211109876543210
01100101size1Za1opcPgZmZdn
Decode fields Instruction Details
opc
00 FMAD
01 FMSB
10 FNMAD
11 FNMSB

SVE Memory - 32-bit Gather and Unsized Contiguous

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
1000010op0op1op2op3
Decode fields Instruction details
op0op1op2op3
00 x1 0xx 0 SVE 32-bit gather prefetch (scalar plus 32-bit scaled offsets)
00 x1 0xx 1 UNALLOCATED
01 x1 0xx SVE 32-bit gather load halfwords (scalar plus 32-bit scaled offsets)
10 x1 0xx SVE 32-bit gather load words (scalar plus 32-bit scaled offsets)
11 0x 000 0 LDR (predicate)
11 0x 000 1 UNALLOCATED
11 0x 010 LDR (vector)
11 0x 0x1 UNALLOCATED
11 1x 0xx 0 SVE contiguous prefetch (scalar plus immediate)
11 1x 0xx 1 UNALLOCATED
!= 11 x0 0xx SVE 32-bit gather load (scalar plus 32-bit unscaled offsets)
00 10x SVE2 32-bit gather non-temporal load (scalar plus 32-bit unscaled offsets)
00 110 0 SVE contiguous prefetch (scalar plus scalar)
00 111 0 SVE 32-bit gather prefetch (vector plus immediate)
00 11x 1 UNALLOCATED
01 1xx SVE 32-bit gather load (vector plus immediate)
1x 1xx SVE load and broadcast element

SVE 32-bit gather prefetch (scalar plus 32-bit scaled offsets)

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
100001000xs1Zm0mszPgRn0prfop
Decode fields Instruction Details
msz
00 PRFB (scalar plus vector)
01 PRFH (scalar plus vector)
10 PRFW (scalar plus vector)
11 PRFD (scalar plus vector)

SVE 32-bit gather load halfwords (scalar plus 32-bit scaled offsets)

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
100001001xs1Zm0UffPgRnZt
Decode fields Instruction Details
U ff
0 0 LD1SH (scalar plus vector)
0 1 LDFF1SH (scalar plus vector)
1 0 LD1H (scalar plus vector)
1 1 LDFF1H (scalar plus vector)

SVE 32-bit gather load words (scalar plus 32-bit scaled offsets)

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
100001010xs1Zm0UffPgRnZt
Decode fields Instruction Details
U ff
0 UNALLOCATED
1 0 LD1W (scalar plus vector)
1 1 LDFF1W (scalar plus vector)

SVE contiguous prefetch (scalar plus immediate)

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
1000010111imm60mszPgRn0prfop
Decode fields Instruction Details
msz
00 PRFB (scalar plus immediate)
01 PRFH (scalar plus immediate)
10 PRFW (scalar plus immediate)
11 PRFD (scalar plus immediate)

SVE 32-bit gather load (scalar plus 32-bit unscaled offsets)

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
1000010!= 11xs0Zm0UffPgRnZt
opc

The following constraints also apply to this encoding: opc != 11 && opc != 11

Decode fields Instruction Details
opc U ff
00 0 0 LD1SB (scalar plus vector)
00 0 1 LDFF1SB (scalar plus vector)
00 1 0 LD1B (scalar plus vector)
00 1 1 LDFF1B (scalar plus vector)
01 0 0 LD1SH (scalar plus vector)
01 0 1 LDFF1SH (scalar plus vector)
01 1 0 LD1H (scalar plus vector)
01 1 1 LDFF1H (scalar plus vector)
10 0 UNALLOCATED
10 1 0 LD1W (scalar plus vector)
10 1 1 LDFF1W (scalar plus vector)

SVE2 32-bit gather non-temporal load (scalar plus 32-bit unscaled offsets)

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
1000010msz00Rm10UPgZnZt
Decode fields Instruction Details
msz U
00 0 LDNT1SB
00 1 LDNT1B (vector plus scalar)
01 0 LDNT1SH
01 1 LDNT1H (vector plus scalar)
10 0 UNALLOCATED
10 1 LDNT1W (vector plus scalar)
11 UNALLOCATED

SVE contiguous prefetch (scalar plus scalar)

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
1000010msz00Rm110PgRn0prfop
Decode fields Instruction Details
msz
00 PRFB (scalar plus scalar)
01 PRFH (scalar plus scalar)
10 PRFW (scalar plus scalar)
11 PRFD (scalar plus scalar)

SVE 32-bit gather prefetch (vector plus immediate)

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
1000010msz00imm5111PgZn0prfop
Decode fields Instruction Details
msz
00 PRFB (vector plus immediate)
01 PRFH (vector plus immediate)
10 PRFW (vector plus immediate)
11 PRFD (vector plus immediate)

SVE 32-bit gather load (vector plus immediate)

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
1000010msz01imm51UffPgZnZt
Decode fields Instruction Details
msz U ff
00 0 0 LD1SB (vector plus immediate)
00 0 1 LDFF1SB (vector plus immediate)
00 1 0 LD1B (vector plus immediate)
00 1 1 LDFF1B (vector plus immediate)
01 0 0 LD1SH (vector plus immediate)
01 0 1 LDFF1SH (vector plus immediate)
01 1 0 LD1H (vector plus immediate)
01 1 1 LDFF1H (vector plus immediate)
10 0 UNALLOCATED
10 1 0 LD1W (vector plus immediate)
10 1 1 LDFF1W (vector plus immediate)
11 UNALLOCATED

SVE load and broadcast element

These instructions are under SVE Memory - 32-bit Gather and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
1000010dtypeh1imm61dtypelPgRnZt
Decode fields Instruction Details
dtypeh dtypel
00 00 LD1RB8-bit element
00 01 LD1RB16-bit element
00 10 LD1RB32-bit element
00 11 LD1RB64-bit element
01 00 LD1RSW
01 01 LD1RH16-bit element
01 10 LD1RH32-bit element
01 11 LD1RH64-bit element
10 00 LD1RSH64-bit element
10 01 LD1RSH32-bit element
10 10 LD1RW32-bit element
10 11 LD1RW64-bit element
11 00 LD1RSB64-bit element
11 01 LD1RSB32-bit element
11 10 LD1RSB16-bit element
11 11 LD1RD

SVE Memory - Contiguous Load

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
1010010op0op1op2
Decode fields Instruction details
op0op1op2
00 0 111 SVE contiguous non-temporal load (scalar plus immediate)
00 110 SVE contiguous non-temporal load (scalar plus scalar)
!= 00 0 111 SVE load multiple structures (scalar plus immediate)
!= 00 110 SVE load multiple structures (scalar plus scalar)
0 001 SVE load and broadcast quadword (scalar plus immediate)
0 101 SVE contiguous load (scalar plus immediate)
1 001 UNALLOCATED
1 101 SVE contiguous non-fault load (scalar plus immediate)
1 111 UNALLOCATED
000 SVE load and broadcast quadword (scalar plus scalar)
010 SVE contiguous load (scalar plus scalar)
011 SVE contiguous first-fault load (scalar plus scalar)
100 UNALLOCATED

SVE contiguous non-temporal load (scalar plus immediate)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010msz000imm4111PgRnZt
Decode fields Instruction Details
msz
00 LDNT1B (scalar plus immediate)
01 LDNT1H (scalar plus immediate)
10 LDNT1W (scalar plus immediate)
11 LDNT1D (scalar plus immediate)

SVE contiguous non-temporal load (scalar plus scalar)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010msz00Rm110PgRnZt
Decode fields Instruction Details
msz
00 LDNT1B (scalar plus scalar)
01 LDNT1H (scalar plus scalar)
10 LDNT1W (scalar plus scalar)
11 LDNT1D (scalar plus scalar)

SVE load multiple structures (scalar plus immediate)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010msz!= 000imm4111PgRnZt
opc

The following constraints also apply to this encoding: opc != 00 && opc != 00

Decode fields Instruction Details
msz opc
00 01 LD2B (scalar plus immediate)
00 10 LD3B (scalar plus immediate)
00 11 LD4B (scalar plus immediate)
01 01 LD2H (scalar plus immediate)
01 10 LD3H (scalar plus immediate)
01 11 LD4H (scalar plus immediate)
10 01 LD2W (scalar plus immediate)
10 10 LD3W (scalar plus immediate)
10 11 LD4W (scalar plus immediate)
11 01 LD2D (scalar plus immediate)
11 10 LD3D (scalar plus immediate)
11 11 LD4D (scalar plus immediate)

SVE load multiple structures (scalar plus scalar)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010msz!= 00Rm110PgRnZt
opc

The following constraints also apply to this encoding: opc != 00 && opc != 00

Decode fields Instruction Details
msz opc
00 01 LD2B (scalar plus scalar)
00 10 LD3B (scalar plus scalar)
00 11 LD4B (scalar plus scalar)
01 01 LD2H (scalar plus scalar)
01 10 LD3H (scalar plus scalar)
01 11 LD4H (scalar plus scalar)
10 01 LD2W (scalar plus scalar)
10 10 LD3W (scalar plus scalar)
10 11 LD4W (scalar plus scalar)
11 01 LD2D (scalar plus scalar)
11 10 LD3D (scalar plus scalar)
11 11 LD4D (scalar plus scalar)

SVE load and broadcast quadword (scalar plus immediate)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010mszssz0imm4001PgRnZt
Decode fields Instruction Details Feature
msz ssz
1x UNALLOCATED-
00 00 LD1RQB (scalar plus immediate)-
00 01 LD1ROB (scalar plus immediate)FEAT_F64MM
01 00 LD1RQH (scalar plus immediate)-
01 01 LD1ROH (scalar plus immediate)FEAT_F64MM
10 00 LD1RQW (scalar plus immediate)-
10 01 LD1ROW (scalar plus immediate)FEAT_F64MM
11 00 LD1RQD (scalar plus immediate)-
11 01 LD1ROD (scalar plus immediate)FEAT_F64MM

SVE contiguous load (scalar plus immediate)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010dtype0imm4101PgRnZt
Decode fields Instruction Details
dtype
0000 LD1B (scalar plus immediate)8-bit element
0001 LD1B (scalar plus immediate)16-bit element
0010 LD1B (scalar plus immediate)32-bit element
0011 LD1B (scalar plus immediate)64-bit element
0100 LD1SW (scalar plus immediate)
0101 LD1H (scalar plus immediate)16-bit element
0110 LD1H (scalar plus immediate)32-bit element
0111 LD1H (scalar plus immediate)64-bit element
1000 LD1SH (scalar plus immediate)64-bit element
1001 LD1SH (scalar plus immediate)32-bit element
1010 LD1W (scalar plus immediate)32-bit element
1011 LD1W (scalar plus immediate)64-bit element
1100 LD1SB (scalar plus immediate)64-bit element
1101 LD1SB (scalar plus immediate)32-bit element
1110 LD1SB (scalar plus immediate)16-bit element
1111 LD1D (scalar plus immediate)

SVE contiguous non-fault load (scalar plus immediate)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010dtype1imm4101PgRnZt
Decode fields Instruction Details
dtype
0000 LDNF1B8-bit element
0001 LDNF1B16-bit element
0010 LDNF1B32-bit element
0011 LDNF1B64-bit element
0100 LDNF1SW
0101 LDNF1H16-bit element
0110 LDNF1H32-bit element
0111 LDNF1H64-bit element
1000 LDNF1SH64-bit element
1001 LDNF1SH32-bit element
1010 LDNF1W32-bit element
1011 LDNF1W64-bit element
1100 LDNF1SB64-bit element
1101 LDNF1SB32-bit element
1110 LDNF1SB16-bit element
1111 LDNF1D

SVE load and broadcast quadword (scalar plus scalar)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010mszsszRm000PgRnZt
Decode fields Instruction Details Feature
msz ssz
1x UNALLOCATED-
00 00 LD1RQB (scalar plus scalar)-
00 01 LD1ROB (scalar plus scalar)FEAT_F64MM
01 00 LD1RQH (scalar plus scalar)-
01 01 LD1ROH (scalar plus scalar)FEAT_F64MM
10 00 LD1RQW (scalar plus scalar)-
10 01 LD1ROW (scalar plus scalar)FEAT_F64MM
11 00 LD1RQD (scalar plus scalar)-
11 01 LD1ROD (scalar plus scalar)FEAT_F64MM

SVE contiguous load (scalar plus scalar)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010dtypeRm010PgRnZt
Decode fields Instruction Details
dtype
0000 LD1B (scalar plus scalar)8-bit element
0001 LD1B (scalar plus scalar)16-bit element
0010 LD1B (scalar plus scalar)32-bit element
0011 LD1B (scalar plus scalar)64-bit element
0100 LD1SW (scalar plus scalar)
0101 LD1H (scalar plus scalar)16-bit element
0110 LD1H (scalar plus scalar)32-bit element
0111 LD1H (scalar plus scalar)64-bit element
1000 LD1SH (scalar plus scalar)64-bit element
1001 LD1SH (scalar plus scalar)32-bit element
1010 LD1W (scalar plus scalar)32-bit element
1011 LD1W (scalar plus scalar)64-bit element
1100 LD1SB (scalar plus scalar)64-bit element
1101 LD1SB (scalar plus scalar)32-bit element
1110 LD1SB (scalar plus scalar)16-bit element
1111 LD1D (scalar plus scalar)

SVE contiguous first-fault load (scalar plus scalar)

These instructions are under SVE Memory - Contiguous Load.

313029282726252423222120191817161514131211109876543210
1010010dtypeRm011PgRnZt
Decode fields Instruction Details
dtype
0000 LDFF1B (scalar plus scalar)8-bit element
0001 LDFF1B (scalar plus scalar)16-bit element
0010 LDFF1B (scalar plus scalar)32-bit element
0011 LDFF1B (scalar plus scalar)64-bit element
0100 LDFF1SW (scalar plus scalar)
0101 LDFF1H (scalar plus scalar)16-bit element
0110 LDFF1H (scalar plus scalar)32-bit element
0111 LDFF1H (scalar plus scalar)64-bit element
1000 LDFF1SH (scalar plus scalar)64-bit element
1001 LDFF1SH (scalar plus scalar)32-bit element
1010 LDFF1W (scalar plus scalar)32-bit element
1011 LDFF1W (scalar plus scalar)64-bit element
1100 LDFF1SB (scalar plus scalar)64-bit element
1101 LDFF1SB (scalar plus scalar)32-bit element
1110 LDFF1SB (scalar plus scalar)16-bit element
1111 LDFF1D (scalar plus scalar)

SVE Memory - 64-bit Gather

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
1100010op0op1op2op3
Decode fields Instruction details
op0op1op2op3
00 01 0xx 1 UNALLOCATED
00 11 1xx 0 SVE 64-bit gather prefetch (scalar plus 64-bit scaled offsets)
00 11 1 UNALLOCATED
00 x1 0xx 0 SVE 64-bit gather prefetch (scalar plus unpacked 32-bit scaled offsets)
!= 00 11 1xx SVE 64-bit gather load (scalar plus 64-bit scaled offsets)
!= 00 x1 0xx SVE 64-bit gather load (scalar plus 32-bit unpacked scaled offsets)
00 101 UNALLOCATED
00 111 0 SVE 64-bit gather prefetch (vector plus immediate)
00 111 1 UNALLOCATED
00 1x0 SVE2 64-bit gather non-temporal load (scalar plus unpacked 32-bit unscaled offsets)
01 1xx SVE 64-bit gather load (vector plus immediate)
10 1xx SVE 64-bit gather load (scalar plus 64-bit unscaled offsets)
x0 0xx SVE 64-bit gather load (scalar plus unpacked 32-bit unscaled offsets)

SVE 64-bit gather prefetch (scalar plus 64-bit scaled offsets)

These instructions are under SVE Memory - 64-bit Gather.

313029282726252423222120191817161514131211109876543210
11000100011Zm1mszPgRn0prfop
Decode fields Instruction Details
msz
00 PRFB (scalar plus vector)
01 PRFH (scalar plus vector)
10 PRFW (scalar plus vector)
11 PRFD (scalar plus vector)

SVE 64-bit gather prefetch (scalar plus unpacked 32-bit scaled offsets)

These instructions are under SVE Memory - 64-bit Gather.

313029282726252423222120191817161514131211109876543210
110001000xs1Zm0mszPgRn0prfop
Decode fields Instruction Details
msz
00 PRFB (scalar plus vector)
01 PRFH (scalar plus vector)
10 PRFW (scalar plus vector)
11 PRFD (scalar plus vector)

SVE 64-bit gather load (scalar plus 64-bit scaled offsets)

These instructions are under SVE Memory - 64-bit Gather.

313029282726252423222120191817161514131211109876543210
1100010!= 0011Zm1UffPgRnZt
opc

The following constraints also apply to this encoding: opc != 00 && opc != 00

Decode fields Instruction Details
opc U ff
01 0 0 LD1SH (scalar plus vector)
01 0 1 LDFF1SH (scalar plus vector)
01 1 0 LD1H (scalar plus vector)
01 1 1 LDFF1H (scalar plus vector)
10 0 0 LD1SW (scalar plus vector)
10 0 1 LDFF1SW (scalar plus vector)
10 1 0 LD1W (scalar plus vector)
10 1 1 LDFF1W (scalar plus vector)
11 0 UNALLOCATED
11 1 0 LD1D (scalar plus vector)
11 1 1 LDFF1D (scalar plus vector)

SVE 64-bit gather load (scalar plus 32-bit unpacked scaled offsets)

These instructions are under SVE Memory - 64-bit Gather.

313029282726252423222120191817161514131211109876543210
1100010!= 00xs1Zm0UffPgRnZt
opc

The following constraints also apply to this encoding: opc != 00 && opc != 00

Decode fields Instruction Details
opc U ff
01 0 0 LD1SH (scalar plus vector)
01 0 1 LDFF1SH (scalar plus vector)
01 1 0 LD1H (scalar plus vector)
01 1 1 LDFF1H (scalar plus vector)
10 0 0 LD1SW (scalar plus vector)
10 0 1 LDFF1SW (scalar plus vector)
10 1 0 LD1W (scalar plus vector)
10 1 1 LDFF1W (scalar plus vector)
11 0 UNALLOCATED
11 1 0 LD1D (scalar plus vector)
11 1 1 LDFF1D (scalar plus vector)

SVE 64-bit gather prefetch (vector plus immediate)

These instructions are under SVE Memory - 64-bit Gather.

313029282726252423222120191817161514131211109876543210
1100010msz00imm5111PgZn0prfop
Decode fields Instruction Details
msz
00 PRFB (vector plus immediate)
01 PRFH (vector plus immediate)
10 PRFW (vector plus immediate)
11 PRFD (vector plus immediate)

SVE2 64-bit gather non-temporal load (scalar plus unpacked 32-bit unscaled offsets)

These instructions are under SVE Memory - 64-bit Gather.

313029282726252423222120191817161514131211109876543210
1100010msz00Rm1U0PgZnZt
Decode fields Instruction Details
msz U
00 0 LDNT1SB
00 1 LDNT1B (vector plus scalar)
01 0 LDNT1SH
01 1 LDNT1H (vector plus scalar)
10 0 LDNT1SW
10 1 LDNT1W (vector plus scalar)
11 0 UNALLOCATED
11 1 LDNT1D (vector plus scalar)

SVE 64-bit gather load (vector plus immediate)

These instructions are under SVE Memory - 64-bit Gather.

313029282726252423222120191817161514131211109876543210
1100010msz01imm51UffPgZnZt
Decode fields Instruction Details
msz U ff
00 0 0 LD1SB (vector plus immediate)
00 0 1 LDFF1SB (vector plus immediate)
00 1 0 LD1B (vector plus immediate)
00 1 1 LDFF1B (vector plus immediate)
01 0 0 LD1SH (vector plus immediate)
01 0 1 LDFF1SH (vector plus immediate)
01 1 0 LD1H (vector plus immediate)
01 1 1 LDFF1H (vector plus immediate)
10 0 0 LD1SW (vector plus immediate)
10 0 1 LDFF1SW (vector plus immediate)
10 1 0 LD1W (vector plus immediate)
10 1 1 LDFF1W (vector plus immediate)
11 0 UNALLOCATED
11 1 0 LD1D (vector plus immediate)
11 1 1 LDFF1D (vector plus immediate)

SVE 64-bit gather load (scalar plus 64-bit unscaled offsets)

These instructions are under SVE Memory - 64-bit Gather.

313029282726252423222120191817161514131211109876543210
1100010msz10Zm1UffPgRnZt
Decode fields Instruction Details
msz U ff
00 0 0 LD1SB (scalar plus vector)
00 0 1 LDFF1SB (scalar plus vector)
00 1 0 LD1B (scalar plus vector)
00 1 1 LDFF1B (scalar plus vector)
01 0 0 LD1SH (scalar plus vector)
01 0 1 LDFF1SH (scalar plus vector)
01 1 0 LD1H (scalar plus vector)
01 1 1 LDFF1H (scalar plus vector)
10 0 0 LD1SW (scalar plus vector)
10 0 1 LDFF1SW (scalar plus vector)
10 1 0 LD1W (scalar plus vector)
10 1 1 LDFF1W (scalar plus vector)
11 0 UNALLOCATED
11 1 0 LD1D (scalar plus vector)
11 1 1 LDFF1D (scalar plus vector)

SVE 64-bit gather load (scalar plus unpacked 32-bit unscaled offsets)

These instructions are under SVE Memory - 64-bit Gather.

313029282726252423222120191817161514131211109876543210
1100010mszxs0Zm0UffPgRnZt
Decode fields Instruction Details
msz U ff
00 0 0 LD1SB (scalar plus vector)
00 0 1 LDFF1SB (scalar plus vector)
00 1 0 LD1B (scalar plus vector)
00 1 1 LDFF1B (scalar plus vector)
01 0 0 LD1SH (scalar plus vector)
01 0 1 LDFF1SH (scalar plus vector)
01 1 0 LD1H (scalar plus vector)
01 1 1 LDFF1H (scalar plus vector)
10 0 0 LD1SW (scalar plus vector)
10 0 1 LDFF1SW (scalar plus vector)
10 1 0 LD1W (scalar plus vector)
10 1 1 LDFF1W (scalar plus vector)
11 0 UNALLOCATED
11 1 0 LD1D (scalar plus vector)
11 1 1 LDFF1D (scalar plus vector)

SVE Memory - Contiguous Store and Unsized Contiguous

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
1110010op00op10op2
Decode fields Instruction details
op0op1op2
0xx 0 UNALLOCATED
10x 0 UNALLOCATED
110 0 0 STR (predicate)
110 0 1 UNALLOCATED
110 1 STR (vector)
111 0 UNALLOCATED
!= 110 1 SVE contiguous store (scalar plus scalar)

SVE contiguous store (scalar plus scalar)

These instructions are under SVE Memory - Contiguous Store and Unsized Contiguous.

313029282726252423222120191817161514131211109876543210
1110010!= 110o2Rm010PgRnZt
opc

The following constraints also apply to this encoding: opc != 110 && opc != 110

Decode fields Instruction Details
opc o2
00x ST1B (scalar plus scalar)
01x ST1H (scalar plus scalar)
10x ST1W (scalar plus scalar)
111 0 UNALLOCATED
111 1 ST1D (scalar plus scalar)

SVE Memory - Non-temporal and Multi-register Store

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
1110010op00op11
Decode fields Instruction details
op0op1
00 0 SVE2 64-bit scatter non-temporal store (vector plus scalar)
00 1 SVE contiguous non-temporal store (scalar plus scalar)
10 0 SVE2 32-bit scatter non-temporal store (vector plus scalar)
!= 00 1 SVE store multiple structures (scalar plus scalar)
x1 0 UNALLOCATED

SVE2 64-bit scatter non-temporal store (vector plus scalar)

These instructions are under SVE Memory - Non-temporal and Multi-register Store.

313029282726252423222120191817161514131211109876543210
1110010msz00Rm001PgZnZt
Decode fields Instruction Details
msz
00 STNT1B (vector plus scalar)
01 STNT1H (vector plus scalar)
10 STNT1W (vector plus scalar)
11 STNT1D (vector plus scalar)

SVE contiguous non-temporal store (scalar plus scalar)

These instructions are under SVE Memory - Non-temporal and Multi-register Store.

313029282726252423222120191817161514131211109876543210
1110010msz00Rm011PgRnZt
Decode fields Instruction Details
msz
00 STNT1B (scalar plus scalar)
01 STNT1H (scalar plus scalar)
10 STNT1W (scalar plus scalar)
11 STNT1D (scalar plus scalar)

SVE2 32-bit scatter non-temporal store (vector plus scalar)

These instructions are under SVE Memory - Non-temporal and Multi-register Store.

313029282726252423222120191817161514131211109876543210
1110010msz10Rm001PgZnZt
Decode fields Instruction Details
msz
00 STNT1B (vector plus scalar)
01 STNT1H (vector plus scalar)
10 STNT1W (vector plus scalar)
11 UNALLOCATED

SVE store multiple structures (scalar plus scalar)

These instructions are under SVE Memory - Non-temporal and Multi-register Store.

313029282726252423222120191817161514131211109876543210
1110010msz!= 00Rm011PgRnZt
opc

The following constraints also apply to this encoding: opc != 00 && opc != 00

Decode fields Instruction Details
msz opc
00 01 ST2B (scalar plus scalar)
00 10 ST3B (scalar plus scalar)
00 11 ST4B (scalar plus scalar)
01 01 ST2H (scalar plus scalar)
01 10 ST3H (scalar plus scalar)
01 11 ST4H (scalar plus scalar)
10 01 ST2W (scalar plus scalar)
10 10 ST3W (scalar plus scalar)
10 11 ST4W (scalar plus scalar)
11 01 ST2D (scalar plus scalar)
11 10 ST3D (scalar plus scalar)
11 11 ST4D (scalar plus scalar)

SVE Memory - Scatter with Optional Sign Extend

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
1110010op010
Decode fields Instruction details
op0
00 SVE 64-bit scatter store (scalar plus unpacked 32-bit unscaled offsets)
01 SVE 64-bit scatter store (scalar plus unpacked 32-bit scaled offsets)
10 SVE 32-bit scatter store (scalar plus 32-bit unscaled offsets)
11 SVE 32-bit scatter store (scalar plus 32-bit scaled offsets)

SVE 64-bit scatter store (scalar plus unpacked 32-bit unscaled offsets)

These instructions are under SVE Memory - Scatter with Optional Sign Extend.

313029282726252423222120191817161514131211109876543210
1110010msz00Zm1xs0PgRnZt
Decode fields Instruction Details
msz
00 ST1B (scalar plus vector)
01 ST1H (scalar plus vector)
10 ST1W (scalar plus vector)
11 ST1D (scalar plus vector)

SVE 64-bit scatter store (scalar plus unpacked 32-bit scaled offsets)

These instructions are under SVE Memory - Scatter with Optional Sign Extend.

313029282726252423222120191817161514131211109876543210
1110010msz01Zm1xs0PgRnZt
Decode fields Instruction Details
msz
00 UNALLOCATED
01 ST1H (scalar plus vector)
10 ST1W (scalar plus vector)
11 ST1D (scalar plus vector)

SVE 32-bit scatter store (scalar plus 32-bit unscaled offsets)

These instructions are under SVE Memory - Scatter with Optional Sign Extend.

313029282726252423222120191817161514131211109876543210
1110010msz10Zm1xs0PgRnZt
Decode fields Instruction Details
msz
00 ST1B (scalar plus vector)
01 ST1H (scalar plus vector)
10 ST1W (scalar plus vector)
11 UNALLOCATED

SVE 32-bit scatter store (scalar plus 32-bit scaled offsets)

These instructions are under SVE Memory - Scatter with Optional Sign Extend.

313029282726252423222120191817161514131211109876543210
1110010msz11Zm1xs0PgRnZt
Decode fields Instruction Details
msz
00 UNALLOCATED
01 ST1H (scalar plus vector)
10 ST1W (scalar plus vector)
11 UNALLOCATED

SVE Memory - Scatter

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
1110010op0101
Decode fields Instruction details
op0
00 SVE 64-bit scatter store (scalar plus 64-bit unscaled offsets)
01 SVE 64-bit scatter store (scalar plus 64-bit scaled offsets)
10 SVE 64-bit scatter store (vector plus immediate)
11 SVE 32-bit scatter store (vector plus immediate)

SVE 64-bit scatter store (scalar plus 64-bit unscaled offsets)

These instructions are under SVE Memory - Scatter.

313029282726252423222120191817161514131211109876543210
1110010msz00Zm101PgRnZt
Decode fields Instruction Details
msz
00 ST1B (scalar plus vector)
01 ST1H (scalar plus vector)
10 ST1W (scalar plus vector)
11 ST1D (scalar plus vector)

SVE 64-bit scatter store (scalar plus 64-bit scaled offsets)

These instructions are under SVE Memory - Scatter.

313029282726252423222120191817161514131211109876543210
1110010msz01Zm101PgRnZt
Decode fields Instruction Details
msz
00 UNALLOCATED
01 ST1H (scalar plus vector)
10 ST1W (scalar plus vector)
11 ST1D (scalar plus vector)

SVE 64-bit scatter store (vector plus immediate)

These instructions are under SVE Memory - Scatter.

313029282726252423222120191817161514131211109876543210
1110010msz10imm5101PgZnZt
Decode fields Instruction Details
msz
00 ST1B (vector plus immediate)
01 ST1H (vector plus immediate)
10 ST1W (vector plus immediate)
11 ST1D (vector plus immediate)

SVE 32-bit scatter store (vector plus immediate)

These instructions are under SVE Memory - Scatter.

313029282726252423222120191817161514131211109876543210
1110010msz11imm5101PgZnZt
Decode fields Instruction Details
msz
00 ST1B (vector plus immediate)
01 ST1H (vector plus immediate)
10 ST1W (vector plus immediate)
11 UNALLOCATED

SVE Memory - Contiguous Store with Immediate Offset

These instructions are under SVE encodings.

313029282726252423222120191817161514131211109876543210
1110010op0op1111
Decode fields Instruction details
op0op1
00 1 SVE contiguous non-temporal store (scalar plus immediate)
!= 00 1 SVE store multiple structures (scalar plus immediate)
0 SVE contiguous store (scalar plus immediate)

SVE contiguous non-temporal store (scalar plus immediate)

These instructions are under SVE Memory - Contiguous Store with Immediate Offset.

313029282726252423222120191817161514131211109876543210
1110010msz001imm4111PgRnZt
Decode fields Instruction Details
msz
00 STNT1B (scalar plus immediate)
01 STNT1H (scalar plus immediate)
10 STNT1W (scalar plus immediate)
11 STNT1D (scalar plus immediate)

SVE store multiple structures (scalar plus immediate)

These instructions are under SVE Memory - Contiguous Store with Immediate Offset.

313029282726252423222120191817161514131211109876543210
1110010msz!= 001imm4111PgRnZt
opc

The following constraints also apply to this encoding: opc != 00 && opc != 00

Decode fields Instruction Details
msz opc
00 01 ST2B (scalar plus immediate)
00 10 ST3B (scalar plus immediate)
00 11 ST4B (scalar plus immediate)
01 01 ST2H (scalar plus immediate)
01 10 ST3H (scalar plus immediate)
01 11 ST4H (scalar plus immediate)
10 01 ST2W (scalar plus immediate)
10 10 ST3W (scalar plus immediate)
10 11 ST4W (scalar plus immediate)
11 01 ST2D (scalar plus immediate)
11 10 ST3D (scalar plus immediate)
11 11 ST4D (scalar plus immediate)

SVE contiguous store (scalar plus immediate)

These instructions are under SVE Memory - Contiguous Store with Immediate Offset.

313029282726252423222120191817161514131211109876543210
1110010mszsize0imm4111PgRnZt
Decode fields Instruction Details
msz
00 ST1B (scalar plus immediate)
01 ST1H (scalar plus immediate)
10 ST1W (scalar plus immediate)
11 ST1D (scalar plus immediate)

Data Processing -- Immediate

These instructions are under the top-level.

313029282726252423222120191817161514131211109876543210
100op0
Decode fields Instruction details
op0
00x PC-rel. addressing
010 Add/subtract (immediate)
011 Add/subtract (immediate, with tags)
100 Logical (immediate)
101 Move wide (immediate)
110 Bitfield
111 Extract

PC-rel. addressing

These instructions are under Data Processing -- Immediate.

313029282726252423222120191817161514131211109876543210
opimmlo10000immhiRd
Decode fields Instruction Details
op
0 ADR
1 ADRP

Add/subtract (immediate)

These instructions are under Data Processing -- Immediate.

313029282726252423222120191817161514131211109876543210
sfopS100010shimm12RnRd
Decode fields Instruction Details
sf op S
0 0 0 ADD (immediate)32-bit
0 0 1 ADDS (immediate)32-bit
0 1 0 SUB (immediate)32-bit
0 1 1 SUBS (immediate)32-bit
1 0 0 ADD (immediate)64-bit
1 0 1 ADDS (immediate)64-bit
1 1 0 SUB (immediate)64-bit
1 1 1 SUBS (immediate)64-bit

Add/subtract (immediate, with tags)

These instructions are under Data Processing -- Immediate.

313029282726252423222120191817161514131211109876543210
sfopS100011o2uimm6op3uimm4RnRd
Decode fields Instruction Details Feature
sf op S o2
1 UNALLOCATED-
0 0 UNALLOCATED-
1 1 0 UNALLOCATED-
1 0 0 0 ADDGFEAT_MTE
1 1 0 0 SUBGFEAT_MTE

Logical (immediate)

These instructions are under Data Processing -- Immediate.

313029282726252423222120191817161514131211109876543210
sfopc100100NimmrimmsRnRd
Decode fields Instruction Details
sf opc N
0 1 UNALLOCATED
0 00 0 AND (immediate)32-bit
0 01 0 ORR (immediate)32-bit
0 10 0 EOR (immediate)32-bit
0 11 0 ANDS (immediate)32-bit
1 00 AND (immediate)64-bit
1 01 ORR (immediate)64-bit
1 10 EOR (immediate)64-bit
1 11 ANDS (immediate)64-bit

Move wide (immediate)

These instructions are under Data Processing -- Immediate.

313029282726252423222120191817161514131211109876543210
sfopc100101hwimm16Rd
Decode fields Instruction Details
sf opc hw
01 UNALLOCATED
0 1x UNALLOCATED
0 00 0x MOVN32-bit
0 10 0x MOVZ32-bit
0 11 0x MOVK32-bit
1 00 MOVN64-bit
1 10 MOVZ64-bit
1 11 MOVK64-bit

Bitfield

These instructions are under Data Processing -- Immediate.

313029282726252423222120191817161514131211109876543210
sfopc100110NimmrimmsRnRd
Decode fields Instruction Details
sf opc N
11 UNALLOCATED
0 1 UNALLOCATED
0 00 0 SBFM32-bit
0 01 0 BFM32-bit
0 10 0 UBFM32-bit
1 0 UNALLOCATED
1 00 1 SBFM64-bit
1 01 1 BFM64-bit
1 10 1 UBFM64-bit

Extract

These instructions are under Data Processing -- Immediate.

313029282726252423222120191817161514131211109876543210
sfop21100111No0RmimmsRnRd
Decode fields Instruction Details
sf op21 N o0 imms
x1 UNALLOCATED
00 1 UNALLOCATED
1x UNALLOCATED
0 1xxxxx UNALLOCATED
0 1 UNALLOCATED
0 00 0 0 0xxxxx EXTR32-bit
1 0 UNALLOCATED
1 00 1 0 EXTR64-bit

Branches, Exception Generating and System instructions

These instructions are under the top-level.

313029282726252423222120191817161514131211109876543210
op0101op1op2
Decode fields Instruction details
op0op1op2
010 0xxxxxxxxxxxxx Conditional branch (immediate)
110 00xxxxxxxxxxxx Exception generation
110 01000000110001 System instructions with register argument
110 01000000110010 11111 Hints
110 01000000110011 Barriers
110 0100000xxx0100 PSTATE
110 0100100xxxxxxx System with result
110 0100x01xxxxxxx System instructions
110 0100x1xxxxxxxx System register move
110 1xxxxxxxxxxxxx Unconditional branch (register)
x00 Unconditional branch (immediate)
x01 0xxxxxxxxxxxxx Compare and branch (immediate)
x01 1xxxxxxxxxxxxx Test and branch (immediate)

Conditional branch (immediate)

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
0101010o1imm19o0cond
Decode fields Instruction Details Feature
o1 o0
0 0 B.cond-
0 1 BC.condFEAT_HBC
1 UNALLOCATED-

Exception generation

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
11010100opcimm16op2LL
Decode fields Instruction Details Feature
opc op2 LL
001 UNALLOCATED-
01x UNALLOCATED-
1xx UNALLOCATED-
000 000 00 UNALLOCATED-
000 000 01 SVC-
000 000 10 HVC-
000 000 11 SMC-
001 000 x1 UNALLOCATED-
001 000 00 BRK-
001 000 1x UNALLOCATED-
010 000 x1 UNALLOCATED-
010 000 00 HLT-
010 000 1x UNALLOCATED-
011 000 00 TCANCELFEAT_TME
011 000 01 UNALLOCATED-
011 000 1x UNALLOCATED-
100 000 UNALLOCATED-
101 000 00 UNALLOCATED-
101 000 01 DCPS1-
101 000 10 DCPS2-
101 000 11 DCPS3-
110 000 UNALLOCATED-
111 000 UNALLOCATED-

System instructions with register argument

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
11010101000000110001CRmop2Rt
Decode fields Instruction Details Feature
CRm op2
!= 0000 UNALLOCATED-
0000 000 WFETFEAT_WFxT
0000 001 WFITFEAT_WFxT
0000 01x UNALLOCATED-
0000 1xx UNALLOCATED-

Hints

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
11010101000000110010CRmop211111
Decode fields Instruction Details Feature
CRm op2
HINT-
0000 000 NOP-
0000 001 YIELD-
0000 010 WFE-
0000 011 WFI-
0000 100 SEV-
0000 101 SEVL-
0000 110 DGH-
0000 111 XPACD, XPACI, XPACLRIFEAT_PAuth
0001 000 PACIA, PACIA1716, PACIASP, PACIAZ, PACIZAPACIA1716FEAT_PAuth
0001 010 PACIB, PACIB1716, PACIBSP, PACIBZ, PACIZBPACIB1716FEAT_PAuth
0001 100 AUTIA, AUTIA1716, AUTIASP, AUTIAZ, AUTIZAAUTIA1716FEAT_PAuth
0001 110 AUTIB, AUTIB1716, AUTIBSP, AUTIBZ, AUTIZBAUTIB1716FEAT_PAuth
0010 000 ESBFEAT_RAS
0010 001 PSB CSYNCFEAT_SPE
0010 010 TSB CSYNCFEAT_TRF
0010 100 CSDB-
0011 000 PACIA, PACIA1716, PACIASP, PACIAZ, PACIZAPACIAZFEAT_PAuth
0011 001 PACIA, PACIA1716, PACIASP, PACIAZ, PACIZAPACIASPFEAT_PAuth
0011 010 PACIB, PACIB1716, PACIBSP, PACIBZ, PACIZBPACIBZFEAT_PAuth
0011 011 PACIB, PACIB1716, PACIBSP, PACIBZ, PACIZBPACIBSPFEAT_PAuth
0011 100 AUTIA, AUTIA1716, AUTIASP, AUTIAZ, AUTIZAAUTIAZFEAT_PAuth
0011 101 AUTIA, AUTIA1716, AUTIASP, AUTIAZ, AUTIZAAUTIASPFEAT_PAuth
0011 110 AUTIB, AUTIB1716, AUTIBSP, AUTIBZ, AUTIZBAUTIBZFEAT_PAuth
0011 111 AUTIB, AUTIB1716, AUTIBSP, AUTIBZ, AUTIZBAUTIBSPFEAT_PAuth
0100 xx0 BTIFEAT_BTI

Barriers

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
11010101000000110011CRmop2Rt
Decode fields Instruction Details Feature
CRm op2 Rt
000 UNALLOCATED-
001 != 11111 UNALLOCATED-
010 11111 CLREX-
100 11111 DSBmemory barrier-
101 11111 DMB-
110 11111 ISB-
111 != 11111 UNALLOCATED-
111 11111 SB-
xx0x 001 11111 UNALLOCATED-
xx10 001 11111 DSBMemory nXS barrierFEAT_XS
xx11 001 11111 UNALLOCATED-
0000 011 11111 TCOMMITFEAT_TME
0001 011 UNALLOCATED-
001x 011 UNALLOCATED-
01xx 011 UNALLOCATED-
1xxx 011 UNALLOCATED-

PSTATE

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
1101010100000op10100CRmop2Rt
Decode fields Instruction Details Feature
op1 op2 Rt
!= 11111 UNALLOCATED-
11111 MSR (immediate)-
000 000 11111 CFINVFEAT_FlagM
000 001 11111 XAFLAGFEAT_FlagM2
000 010 11111 AXFLAGFEAT_FlagM2

System with result

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
1101010100100op1CRnCRmop2Rt
Decode fields Instruction Details Feature
op1 CRn CRm op2
!= 011 UNALLOCATED-
011 != 0011 UNALLOCATED-
011 0011 != 011 UNALLOCATED-
011 0011 != 000x 011 UNALLOCATED-
011 0011 0000 011 TSTARTFEAT_TME
011 0011 0001 011 TTESTFEAT_TME

System instructions

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
1101010100L01op1CRnCRmop2Rt
Decode fields Instruction Details
L
0 SYS
1 SYSL

System register move

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
1101010100L1o0op1CRnCRmop2Rt
Decode fields Instruction Details
L
0 MSR (register)
1 MRS

Unconditional branch (register)

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
1101011opcop2op3Rnop4
Decode fields Instruction Details Feature
opc op2 op3 Rn op4
!= 11111 UNALLOCATED-
0000 11111 000000 != 00000 UNALLOCATED-
0000 11111 000000 00000 BR-
0000 11111 000001 UNALLOCATED-
0000 11111 000010 != 11111 UNALLOCATED-
0000 11111 000010 11111 BRAA, BRAAZ, BRAB, BRABZkey A, zero modifierFEAT_PAuth
0000 11111 000011 != 11111 UNALLOCATED-
0000 11111 000011 11111 BRAA, BRAAZ, BRAB, BRABZkey B, zero modifierFEAT_PAuth
0000 11111 0001xx UNALLOCATED-
0000 11111 001xxx UNALLOCATED-
0000 11111 01xxxx UNALLOCATED-
0000 11111 1xxxxx UNALLOCATED-
0001 11111 000000 != 00000 UNALLOCATED-
0001 11111 000000 00000 BLR-
0001 11111 000001 UNALLOCATED-
0001 11111 000010 != 11111 UNALLOCATED-
0001 11111 000010 11111 BLRAA, BLRAAZ, BLRAB, BLRABZkey A, zero modifierFEAT_PAuth
0001 11111 000011 != 11111 UNALLOCATED-
0001 11111 000011 11111 BLRAA, BLRAAZ, BLRAB, BLRABZkey B, zero modifierFEAT_PAuth
0001 11111 0001xx UNALLOCATED-
0001 11111 001xxx UNALLOCATED-
0001 11111 01xxxx UNALLOCATED-
0001 11111 1xxxxx UNALLOCATED-
0010 11111 000000 != 00000 UNALLOCATED-
0010 11111 000000 00000 RET-
0010 11111 000001 UNALLOCATED-
0010 11111 000010 != 11111 != 11111 UNALLOCATED-
0010 11111 000010 11111 11111 RETAA, RETABRETAAFEAT_PAuth
0010 11111 000011 != 11111 != 11111 UNALLOCATED-
0010 11111 000011 11111 11111 RETAA, RETABRETABFEAT_PAuth
0010 11111 0001xx UNALLOCATED-
0010 11111 001xxx UNALLOCATED-
0010 11111 01xxxx UNALLOCATED-
0010 11111 1xxxxx UNALLOCATED-
0011 11111 UNALLOCATED-
0100 11111 000000 != 11111 != 00000 UNALLOCATED-
0100 11111 000000 != 11111 00000 UNALLOCATED-
0100 11111 000000 11111 != 00000 UNALLOCATED-
0100 11111 000000 11111 00000 ERET-
0100 11111 000001 UNALLOCATED-
0100 11111 000010 != 11111 != 11111 UNALLOCATED-
0100 11111 000010 != 11111 11111 UNALLOCATED-
0100 11111 000010 11111 != 11111 UNALLOCATED-
0100 11111 000010 11111 11111 ERETAA, ERETABERETAAFEAT_PAuth
0100 11111 000011 != 11111 != 11111 UNALLOCATED-
0100 11111 000011 != 11111 11111 UNALLOCATED-
0100 11111 000011 11111 != 11111 UNALLOCATED-
0100 11111 000011 11111 11111 ERETAA, ERETABERETABFEAT_PAuth
0100 11111 0001xx UNALLOCATED-
0100 11111 001xxx UNALLOCATED-
0100 11111 01xxxx UNALLOCATED-
0100 11111 1xxxxx UNALLOCATED-
0101 11111 != 000000 UNALLOCATED-
0101 11111 000000 != 11111 != 00000 UNALLOCATED-
0101 11111 000000 != 11111 00000 UNALLOCATED-
0101 11111 000000 11111 != 00000 UNALLOCATED-
0101 11111 000000 11111 00000 DRPS-
011x 11111 UNALLOCATED-
1000 11111 00000x UNALLOCATED-
1000 11111 000010 BRAA, BRAAZ, BRAB, BRABZkey A, register modifierFEAT_PAuth
1000 11111 000011 BRAA, BRAAZ, BRAB, BRABZkey B, register modifierFEAT_PAuth
1000 11111 0001xx UNALLOCATED-
1000 11111 001xxx UNALLOCATED-
1000 11111 01xxxx UNALLOCATED-
1000 11111 1xxxxx UNALLOCATED-
1001 11111 00000x UNALLOCATED-
1001 11111 000010 BLRAA, BLRAAZ, BLRAB, BLRABZkey A, register modifierFEAT_PAuth
1001 11111 000011 BLRAA, BLRAAZ, BLRAB, BLRABZkey B, register modifierFEAT_PAuth
1001 11111 0001xx UNALLOCATED-
1001 11111 001xxx UNALLOCATED-
1001 11111 01xxxx UNALLOCATED-
1001 11111 1xxxxx UNALLOCATED-
101x 11111 UNALLOCATED-
11xx 11111 UNALLOCATED-

Unconditional branch (immediate)

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
op00101imm26
Decode fields Instruction Details
op
0 B
1 BL

Compare and branch (immediate)

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
sf011010opimm19Rt
Decode fields Instruction Details
sf op
0 0 CBZ32-bit
0 1 CBNZ32-bit
1 0 CBZ64-bit
1 1 CBNZ64-bit

Test and branch (immediate)

These instructions are under Branches, Exception Generating and System instructions.

313029282726252423222120191817161514131211109876543210
b5011011opb40imm14Rt
Decode fields Instruction Details
op
0 TBZ
1 TBNZ

Loads and Stores

These instructions are under the top-level.

313029282726252423222120191817161514131211109876543210
op01op10op2op3op4
Decode fields Instruction details
op0op1op2op3op4
0x00 0 00 1xxxxx Compare and swap pair
0x00 1 00 000000 Advanced SIMD load/store multiple structures
0x00 1 01 0xxxxx Advanced SIMD load/store multiple structures (post-indexed)
0x00 1 0x 1xxxxx UNALLOCATED
0x00 1 10 x00000 Advanced SIMD load/store single structure
0x00 1 11 Advanced SIMD load/store single structure (post-indexed)
0x00 1 x0 x1xxxx UNALLOCATED
0x00 1 x0 xx1xxx UNALLOCATED
0x00 1 x0 xxx1xx UNALLOCATED
0x00 1 x0 xxxx1x UNALLOCATED
0x00 1 x0 xxxxx1 UNALLOCATED
1101 0 1x 1xxxxx Load/store memory tags
1x00 0 00 1xxxxx Load/store exclusive pair
1x00 1 UNALLOCATED
xx00 0 00 0xxxxx Load/store exclusive register
xx00 0 01 0xxxxx Load/store ordered
xx00 0 01 1xxxxx Compare and swap
xx01 0 1x 0xxxxx 00 LDAPR/STLR (unscaled immediate)
xx01 0x Load register (literal)
xx01 1x 0xxxxx 01 Memory Copy and Memory Set
xx10 00 Load/store no-allocate pair (offset)
xx10 01 Load/store register pair (post-indexed)
xx10 10 Load/store register pair (offset)
xx10 11 Load/store register pair (pre-indexed)
xx11 0x 0xxxxx 00 Load/store register (unscaled immediate)
xx11 0x 0xxxxx 01 Load/store register (immediate post-indexed)
xx11 0x 0xxxxx 10 Load/store register (unprivileged)
xx11 0x 0xxxxx 11 Load/store register (immediate pre-indexed)
xx11 0x 1xxxxx 00 Atomic memory operations
xx11 0x 1xxxxx 10 Load/store register (register offset)
xx11 0x 1xxxxx x1 Load/store register (pac)
xx11 1x Load/store register (unsigned immediate)

Compare and swap pair

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
0sz0010000L1Rso0Rt2RnRt
Decode fields Instruction Details Feature
sz L o0 Rt2
!= 11111 UNALLOCATED-
0 0 0 11111 CASP, CASPA, CASPAL, CASPL32-bit CASPFEAT_LSE
0 0 1 11111 CASP, CASPA, CASPAL, CASPL32-bit CASPLFEAT_LSE
0 1 0 11111 CASP, CASPA, CASPAL, CASPL32-bit CASPAFEAT_LSE
0 1 1 11111 CASP, CASPA, CASPAL, CASPL32-bit CASPALFEAT_LSE
1 0 0 11111 CASP, CASPA, CASPAL, CASPL64-bit CASPFEAT_LSE
1 0 1 11111 CASP, CASPA, CASPAL, CASPL64-bit CASPLFEAT_LSE
1 1 0 11111 CASP, CASPA, CASPAL, CASPL64-bit CASPAFEAT_LSE
1 1 1 11111 CASP, CASPA, CASPAL, CASPL64-bit CASPALFEAT_LSE

Advanced SIMD load/store multiple structures

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
0Q0011000L000000opcodesizeRnRt
Decode fields Instruction Details
L opcode
0 0000 ST4 (multiple structures)
0 0001 UNALLOCATED
0 0010 ST1 (multiple structures)four registers
0 0011 UNALLOCATED
0 0100 ST3 (multiple structures)
0 0101 UNALLOCATED
0 0110 ST1 (multiple structures)three registers
0 0111 ST1 (multiple structures)one register
0 1000 ST2 (multiple structures)
0 1001 UNALLOCATED
0 1010 ST1 (multiple structures)two registers
0 1011 UNALLOCATED
0 11xx UNALLOCATED
1 0000 LD4 (multiple structures)
1 0001 UNALLOCATED
1 0010 LD1 (multiple structures)four registers
1 0011 UNALLOCATED
1 0100 LD3 (multiple structures)
1 0101 UNALLOCATED
1 0110 LD1 (multiple structures)three registers
1 0111 LD1 (multiple structures)one register
1 1000 LD2 (multiple structures)
1 1001 UNALLOCATED
1 1010 LD1 (multiple structures)two registers
1 1011 UNALLOCATED
1 11xx UNALLOCATED

Advanced SIMD load/store multiple structures (post-indexed)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
0Q0011001L0RmopcodesizeRnRt
Decode fields Instruction Details
L Rm opcode
0 0001 UNALLOCATED
0 0011 UNALLOCATED
0 0101 UNALLOCATED
0 1001 UNALLOCATED
0 1011 UNALLOCATED
0 11xx UNALLOCATED
0 != 11111 0000 ST4 (multiple structures)register offset
0 != 11111 0010 ST1 (multiple structures)four registers, register offset
0 != 11111 0100 ST3 (multiple structures)register offset
0 != 11111 0110 ST1 (multiple structures)three registers, register offset
0 != 11111 0111 ST1 (multiple structures)one register, register offset
0 != 11111 1000 ST2 (multiple structures)register offset
0 != 11111 1010 ST1 (multiple structures)two registers, register offset
0 11111 0000 ST4 (multiple structures)immediate offset
0 11111 0010 ST1 (multiple structures)four registers, immediate offset
0 11111 0100 ST3 (multiple structures)immediate offset
0 11111 0110 ST1 (multiple structures)three registers, immediate offset
0 11111 0111 ST1 (multiple structures)one register, immediate offset
0 11111 1000 ST2 (multiple structures)immediate offset
0 11111 1010 ST1 (multiple structures)two registers, immediate offset
1 0001 UNALLOCATED
1 0011 UNALLOCATED
1 0101 UNALLOCATED
1 1001 UNALLOCATED
1 1011 UNALLOCATED
1 11xx UNALLOCATED
1 != 11111 0000 LD4 (multiple structures)register offset
1 != 11111 0010 LD1 (multiple structures)four registers, register offset
1 != 11111 0100 LD3 (multiple structures)register offset
1 != 11111 0110 LD1 (multiple structures)three registers, register offset
1 != 11111 0111 LD1 (multiple structures)one register, register offset
1 != 11111 1000 LD2 (multiple structures)register offset
1 != 11111 1010 LD1 (multiple structures)two registers, register offset
1 11111 0000 LD4 (multiple structures)immediate offset
1 11111 0010 LD1 (multiple structures)four registers, immediate offset
1 11111 0100 LD3 (multiple structures)immediate offset
1 11111 0110 LD1 (multiple structures)three registers, immediate offset
1 11111 0111 LD1 (multiple structures)one register, immediate offset
1 11111 1000 LD2 (multiple structures)immediate offset
1 11111 1010 LD1 (multiple structures)two registers, immediate offset

Advanced SIMD load/store single structure

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
0Q0011010LR00000opcodeSsizeRnRt
Decode fields Instruction Details
L R opcode S size
0 11x UNALLOCATED
0 0 000 ST1 (single structure)8-bit
0 0 001 ST3 (single structure)8-bit
0 0 010 x0 ST1 (single structure)16-bit
0 0 010 x1 UNALLOCATED
0 0 011 x0 ST3 (single structure)16-bit
0 0 011 x1 UNALLOCATED
0 0 100 00 ST1 (single structure)32-bit
0 0 100 1x UNALLOCATED
0 0 100 0 01 ST1 (single structure)64-bit
0 0 100 1 01 UNALLOCATED
0 0 101 00 ST3 (single structure)32-bit
0 0 101 10 UNALLOCATED
0 0 101 0 01 ST3 (single structure)64-bit
0 0 101 0 11 UNALLOCATED
0 0 101 1 x1 UNALLOCATED
0 1 000 ST2 (single structure)8-bit
0 1 001 ST4 (single structure)8-bit
0 1 010 x0 ST2 (single structure)16-bit
0 1 010 x1 UNALLOCATED
0 1 011 x0 ST4 (single structure)16-bit
0 1 011 x1 UNALLOCATED
0 1 100 00 ST2 (single structure)32-bit
0 1 100 10 UNALLOCATED
0 1 100 0 01 ST2 (single structure)64-bit
0 1 100 0 11 UNALLOCATED
0 1 100 1 x1 UNALLOCATED
0 1 101 00 ST4 (single structure)32-bit
0 1 101 10 UNALLOCATED
0 1 101 0 01 ST4 (single structure)64-bit
0 1 101 0 11 UNALLOCATED
0 1 101 1 x1 UNALLOCATED
1 0 000 LD1 (single structure)8-bit
1 0 001 LD3 (single structure)8-bit
1 0 010 x0 LD1 (single structure)16-bit
1 0 010 x1 UNALLOCATED
1 0 011 x0 LD3 (single structure)16-bit
1 0 011 x1 UNALLOCATED
1 0 100 00 LD1 (single structure)32-bit
1 0 100 1x UNALLOCATED
1 0 100 0 01 LD1 (single structure)64-bit
1 0 100 1 01 UNALLOCATED
1 0 101 00 LD3 (single structure)32-bit
1 0 101 10 UNALLOCATED
1 0 101 0 01 LD3 (single structure)64-bit
1 0 101 0 11 UNALLOCATED
1 0 101 1 x1 UNALLOCATED
1 0 110 0 LD1R
1 0 110 1 UNALLOCATED
1 0 111 0 LD3R
1 0 111 1 UNALLOCATED
1 1 000 LD2 (single structure)8-bit
1 1 001 LD4 (single structure)8-bit
1 1 010 x0 LD2 (single structure)16-bit
1 1 010 x1 UNALLOCATED
1 1 011 x0 LD4 (single structure)16-bit
1 1 011 x1 UNALLOCATED
1 1 100 00 LD2 (single structure)32-bit
1 1 100 10 UNALLOCATED
1 1 100 0 01 LD2 (single structure)64-bit
1 1 100 0 11 UNALLOCATED
1 1 100 1 x1 UNALLOCATED
1 1 101 00 LD4 (single structure)32-bit
1 1 101 10 UNALLOCATED
1 1 101 0 01 LD4 (single structure)64-bit
1 1 101 0 11 UNALLOCATED
1 1 101 1 x1 UNALLOCATED
1 1 110 0 LD2R
1 1 110 1 UNALLOCATED
1 1 111 0 LD4R
1 1 111 1 UNALLOCATED

Advanced SIMD load/store single structure (post-indexed)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
0Q0011011LRRmopcodeSsizeRnRt
Decode fields Instruction Details
L R Rm opcode S size
0 11x UNALLOCATED
0 0 010 x1 UNALLOCATED
0 0 011 x1 UNALLOCATED
0 0 100 1x UNALLOCATED
0 0 100 1 01 UNALLOCATED
0 0 101 10 UNALLOCATED
0 0 101 0 11 UNALLOCATED
0 0 101 1 x1 UNALLOCATED
0 0 != 11111 000 ST1 (single structure)8-bit, register offset
0 0 != 11111 001 ST3 (single structure)8-bit, register offset
0 0 != 11111 010 x0 ST1 (single structure)16-bit, register offset
0 0 != 11111 011 x0 ST3 (single structure)16-bit, register offset
0 0 != 11111 100 00 ST1 (single structure)32-bit, register offset
0 0 != 11111 100 0 01 ST1 (single structure)64-bit, register offset
0 0 != 11111 101 00 ST3 (single structure)32-bit, register offset
0 0 != 11111 101 0 01 ST3 (single structure)64-bit, register offset
0 0 11111 000 ST1 (single structure)8-bit, immediate offset
0 0 11111 001 ST3 (single structure)8-bit, immediate offset
0 0 11111 010 x0 ST1 (single structure)16-bit, immediate offset
0 0 11111 011 x0 ST3 (single structure)16-bit, immediate offset
0 0 11111 100 00 ST1 (single structure)32-bit, immediate offset
0 0 11111 100 0 01 ST1 (single structure)64-bit, immediate offset
0 0 11111 101 00 ST3 (single structure)32-bit, immediate offset
0 0 11111 101 0 01 ST3 (single structure)64-bit, immediate offset
0 1 010 x1 UNALLOCATED
0 1 011 x1 UNALLOCATED
0 1 100 10 UNALLOCATED
0 1 100 0 11 UNALLOCATED
0 1 100 1 x1 UNALLOCATED
0 1 101 10 UNALLOCATED
0 1 101 0 11 UNALLOCATED
0 1 101 1 x1 UNALLOCATED
0 1 != 11111 000 ST2 (single structure)8-bit, register offset
0 1 != 11111 001 ST4 (single structure)8-bit, register offset
0 1 != 11111 010 x0 ST2 (single structure)16-bit, register offset
0 1 != 11111 011 x0 ST4 (single structure)16-bit, register offset
0 1 != 11111 100 00 ST2 (single structure)32-bit, register offset
0 1 != 11111 100 0 01 ST2 (single structure)64-bit, register offset
0 1 != 11111 101 00 ST4 (single structure)32-bit, register offset
0 1 != 11111 101 0 01 ST4 (single structure)64-bit, register offset
0 1 11111 000 ST2 (single structure)8-bit, immediate offset
0 1 11111 001 ST4 (single structure)8-bit, immediate offset
0 1 11111 010 x0 ST2 (single structure)16-bit, immediate offset
0 1 11111 011 x0 ST4 (single structure)16-bit, immediate offset
0 1 11111 100 00 ST2 (single structure)32-bit, immediate offset
0 1 11111 100 0 01 ST2 (single structure)64-bit, immediate offset
0 1 11111 101 00 ST4 (single structure)32-bit, immediate offset
0 1 11111 101 0 01 ST4 (single structure)64-bit, immediate offset
1 0 010 x1 UNALLOCATED
1 0 011 x1 UNALLOCATED
1 0 100 1x UNALLOCATED
1 0 100 1 01 UNALLOCATED
1 0 101 10 UNALLOCATED
1 0 101 0 11 UNALLOCATED
1 0 101 1 x1 UNALLOCATED
1 0 110 1 UNALLOCATED
1 0 111 1 UNALLOCATED
1 0 != 11111 000 LD1 (single structure)8-bit, register offset
1 0 != 11111 001 LD3 (single structure)8-bit, register offset
1 0 != 11111 010 x0 LD1 (single structure)16-bit, register offset
1 0 != 11111 011 x0 LD3 (single structure)16-bit, register offset
1 0 != 11111 100 00 LD1 (single structure)32-bit, register offset
1 0 != 11111 100 0 01 LD1 (single structure)64-bit, register offset
1 0 != 11111 101 00 LD3 (single structure)32-bit, register offset
1 0 != 11111 101 0 01 LD3 (single structure)64-bit, register offset
1 0 != 11111 110 0 LD1Rregister offset
1 0 != 11111 111 0 LD3Rregister offset
1 0 11111 000 LD1 (single structure)8-bit, immediate offset
1 0 11111 001 LD3 (single structure)8-bit, immediate offset
1 0 11111 010 x0 LD1 (single structure)16-bit, immediate offset
1 0 11111 011 x0 LD3 (single structure)16-bit, immediate offset
1 0 11111 100 00 LD1 (single structure)32-bit, immediate offset
1 0 11111 100 0 01 LD1 (single structure)64-bit, immediate offset
1 0 11111 101 00 LD3 (single structure)32-bit, immediate offset
1 0 11111 101 0 01 LD3 (single structure)64-bit, immediate offset
1 0 11111 110 0 LD1Rimmediate offset
1 0 11111 111 0 LD3Rimmediate offset
1 1 010 x1 UNALLOCATED
1 1 011 x1 UNALLOCATED
1 1 100 10 UNALLOCATED
1 1 100 0 11 UNALLOCATED
1 1 100 1 x1 UNALLOCATED
1 1 101 10 UNALLOCATED
1 1 101 0 11 UNALLOCATED
1 1 101 1 x1 UNALLOCATED
1 1 110 1 UNALLOCATED
1 1 111 1 UNALLOCATED
1 1 != 11111 000 LD2 (single structure)8-bit, register offset
1 1 != 11111 001 LD4 (single structure)8-bit, register offset
1 1 != 11111 010 x0 LD2 (single structure)16-bit, register offset
1 1 != 11111 011 x0 LD4 (single structure)16-bit, register offset
1 1 != 11111 100 00 LD2 (single structure)32-bit, register offset
1 1 != 11111 100 0 01 LD2 (single structure)64-bit, register offset
1 1 != 11111 101 00 LD4 (single structure)32-bit, register offset
1 1 != 11111 101 0 01 LD4 (single structure)64-bit, register offset
1 1 != 11111 110 0 LD2Rregister offset
1 1 != 11111 111 0 LD4Rregister offset
1 1 11111 000 LD2 (single structure)8-bit, immediate offset
1 1 11111 001 LD4 (single structure)8-bit, immediate offset
1 1 11111 010 x0 LD2 (single structure)16-bit, immediate offset
1 1 11111 011 x0 LD4 (single structure)16-bit, immediate offset
1 1 11111 100 00 LD2 (single structure)32-bit, immediate offset
1 1 11111 100 0 01 LD2 (single structure)64-bit, immediate offset
1 1 11111 101 00 LD4 (single structure)32-bit, immediate offset
1 1 11111 101 0 01 LD4 (single structure)64-bit, immediate offset
1 1 11111 110 0 LD2Rimmediate offset
1 1 11111 111 0 LD4Rimmediate offset

Load/store memory tags

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
11011001opc1imm9op2RnRt
Decode fields Instruction Details Feature
opc imm9 op2
00 01 STGpost-indexFEAT_MTE
00 10 STGsigned offsetFEAT_MTE
00 11 STGpre-indexFEAT_MTE
00 000000000 00 STZGMFEAT_MTE2
01 00 LDGFEAT_MTE
01 01 STZGpost-indexFEAT_MTE
01 10 STZGsigned offsetFEAT_MTE
01 11 STZGpre-indexFEAT_MTE
10 01 ST2Gpost-indexFEAT_MTE
10 10 ST2Gsigned offsetFEAT_MTE
10 11 ST2Gpre-indexFEAT_MTE
10 != 000000000 00 UNALLOCATED-
10 000000000 00 STGMFEAT_MTE2
11 01 STZ2Gpost-indexFEAT_MTE
11 10 STZ2Gsigned offsetFEAT_MTE
11 11 STZ2Gpre-indexFEAT_MTE
11 != 000000000 00 UNALLOCATED-
11 000000000 00 LDGMFEAT_MTE2

Load/store exclusive pair

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
1sz0010000L1Rso0Rt2RnRt
Decode fields Instruction Details
sz L o0
0 0 0 STXP32-bit
0 0 1 STLXP32-bit
0 1 0 LDXP32-bit
0 1 1 LDAXP32-bit
1 0 0 STXP64-bit
1 0 1 STLXP64-bit
1 1 0 LDXP64-bit
1 1 1 LDAXP64-bit

Load/store exclusive register

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size0010000L0Rso0Rt2RnRt
Decode fields Instruction Details
size L o0
00 0 0 STXRB
00 0 1 STLXRB
00 1 0 LDXRB
00 1 1 LDAXRB
01 0 0 STXRH
01 0 1 STLXRH
01 1 0 LDXRH
01 1 1 LDAXRH
10 0 0 STXR32-bit
10 0 1 STLXR32-bit
10 1 0 LDXR32-bit
10 1 1 LDAXR32-bit
11 0 0 STXR64-bit
11 0 1 STLXR64-bit
11 1 0 LDXR64-bit
11 1 1 LDAXR64-bit

Load/store ordered

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size0010001L0Rso0Rt2RnRt
Decode fields Instruction Details Feature
size L o0
00 0 0 STLLRBFEAT_LOR
00 0 1 STLRB-
00 1 0 LDLARBFEAT_LOR
00 1 1 LDARB-
01 0 0 STLLRHFEAT_LOR
01 0 1 STLRH-
01 1 0 LDLARHFEAT_LOR
01 1 1 LDARH-
10 0 0 STLLR32-bitFEAT_LOR
10 0 1 STLR32-bit-
10 1 0 LDLAR32-bitFEAT_LOR
10 1 1 LDAR32-bit-
11 0 0 STLLR64-bitFEAT_LOR
11 0 1 STLR64-bit-
11 1 0 LDLAR64-bitFEAT_LOR
11 1 1 LDAR64-bit-

Compare and swap

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size0010001L1Rso0Rt2RnRt
Decode fields Instruction Details Feature
size L o0 Rt2
!= 11111 UNALLOCATED-
00 0 0 11111 CASB, CASAB, CASALB, CASLBCASBFEAT_LSE
00 0 1 11111 CASB, CASAB, CASALB, CASLBCASLBFEAT_LSE
00 1 0 11111 CASB, CASAB, CASALB, CASLBCASABFEAT_LSE
00 1 1 11111 CASB, CASAB, CASALB, CASLBCASALBFEAT_LSE
01 0 0 11111 CASH, CASAH, CASALH, CASLHCASHFEAT_LSE
01 0 1 11111 CASH, CASAH, CASALH, CASLHCASLHFEAT_LSE
01 1 0 11111 CASH, CASAH, CASALH, CASLHCASAHFEAT_LSE
01 1 1 11111 CASH, CASAH, CASALH, CASLHCASALHFEAT_LSE
10 0 0 11111 CAS, CASA, CASAL, CASL32-bit CASFEAT_LSE
10 0 1 11111 CAS, CASA, CASAL, CASL32-bit CASLFEAT_LSE
10 1 0 11111 CAS, CASA, CASAL, CASL32-bit CASAFEAT_LSE
10 1 1 11111 CAS, CASA, CASAL, CASL32-bit CASALFEAT_LSE
11 0 0 11111 CAS, CASA, CASAL, CASL64-bit CASFEAT_LSE
11 0 1 11111 CAS, CASA, CASAL, CASL64-bit CASLFEAT_LSE
11 1 0 11111 CAS, CASA, CASAL, CASL64-bit CASAFEAT_LSE
11 1 1 11111 CAS, CASA, CASAL, CASL64-bit CASALFEAT_LSE

LDAPR/STLR (unscaled immediate)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size011001opc0imm900RnRt
Decode fields Instruction Details Feature
size opc
00 00 STLURBFEAT_LRCPC2
00 01 LDAPURBFEAT_LRCPC2
00 10 LDAPURSB64-bitFEAT_LRCPC2
00 11 LDAPURSB32-bitFEAT_LRCPC2
01 00 STLURHFEAT_LRCPC2
01 01 LDAPURHFEAT_LRCPC2
01 10 LDAPURSH64-bitFEAT_LRCPC2
01 11 LDAPURSH32-bitFEAT_LRCPC2
10 00 STLUR32-bitFEAT_LRCPC2
10 01 LDAPUR32-bitFEAT_LRCPC2
10 10 LDAPURSWFEAT_LRCPC2
10 11 UNALLOCATED-
11 00 STLUR64-bitFEAT_LRCPC2
11 01 LDAPUR64-bitFEAT_LRCPC2
11 10 UNALLOCATED-
11 11 UNALLOCATED-

Load register (literal)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
opc011V00imm19Rt
Decode fields Instruction Details
opc V
00 0 LDR (literal)32-bit
00 1 LDR (literal, SIMD&FP)32-bit
01 0 LDR (literal)64-bit
01 1 LDR (literal, SIMD&FP)64-bit
10 0 LDRSW (literal)
10 1 LDR (literal, SIMD&FP)128-bit
11 0 PRFM (literal)
11 1 UNALLOCATED

Memory Copy and Memory Set

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size011o001op10Rsop201RnRd
Decode fields Instruction Details Feature
o0 op1 op2
0 00 0000 CPYFP, CPYFM, CPYFECPYFPFEAT_MOPS
0 00 0001 CPYFPWT, CPYFMWT, CPYFEWTCPYFPWTFEAT_MOPS
0 00 0010 CPYFPRT, CPYFMRT, CPYFERTCPYFPRTFEAT_MOPS
0 00 0011 CPYFPT, CPYFMT, CPYFETCPYFPTFEAT_MOPS
0 00 0100 CPYFPWN, CPYFMWN, CPYFEWNCPYFPWNFEAT_MOPS
0 00 0101 CPYFPWTWN, CPYFMWTWN, CPYFEWTWNCPYFPWTWNFEAT_MOPS
0 00 0110 CPYFPRTWN, CPYFMRTWN, CPYFERTWNCPYFPRTWNFEAT_MOPS
0 00 0111 CPYFPTWN, CPYFMTWN, CPYFETWNCPYFPTWNFEAT_MOPS
0 00 1000 CPYFPRN, CPYFMRN, CPYFERNCPYFPRNFEAT_MOPS
0 00 1001 CPYFPWTRN, CPYFMWTRN, CPYFEWTRNCPYFPWTRNFEAT_MOPS
0 00 1010 CPYFPRTRN, CPYFMRTRN, CPYFERTRNCPYFPRTRNFEAT_MOPS
0 00 1011 CPYFPTRN, CPYFMTRN, CPYFETRNCPYFPTRNFEAT_MOPS
0 00 1100 CPYFPN, CPYFMN, CPYFENCPYFPNFEAT_MOPS
0 00 1101 CPYFPWTN, CPYFMWTN, CPYFEWTNCPYFPWTNFEAT_MOPS
0 00 1110 CPYFPRTN, CPYFMRTN, CPYFERTNCPYFPRTNFEAT_MOPS
0 00 1111 CPYFPTN, CPYFMTN, CPYFETNCPYFPTNFEAT_MOPS
0 01 0000 CPYFP, CPYFM, CPYFECPYFMFEAT_MOPS
0 01 0001 CPYFPWT, CPYFMWT, CPYFEWTCPYFMWTFEAT_MOPS
0 01 0010 CPYFPRT, CPYFMRT, CPYFERTCPYFMRTFEAT_MOPS
0 01 0011 CPYFPT, CPYFMT, CPYFETCPYFMTFEAT_MOPS
0 01 0100 CPYFPWN, CPYFMWN, CPYFEWNCPYFMWNFEAT_MOPS
0 01 0101 CPYFPWTWN, CPYFMWTWN, CPYFEWTWNCPYFMWTWNFEAT_MOPS
0 01 0110 CPYFPRTWN, CPYFMRTWN, CPYFERTWNCPYFMRTWNFEAT_MOPS
0 01 0111 CPYFPTWN, CPYFMTWN, CPYFETWNCPYFMTWNFEAT_MOPS
0 01 1000 CPYFPRN, CPYFMRN, CPYFERNCPYFMRNFEAT_MOPS
0 01 1001 CPYFPWTRN, CPYFMWTRN, CPYFEWTRNCPYFMWTRNFEAT_MOPS
0 01 1010 CPYFPRTRN, CPYFMRTRN, CPYFERTRNCPYFMRTRNFEAT_MOPS
0 01 1011 CPYFPTRN, CPYFMTRN, CPYFETRNCPYFMTRNFEAT_MOPS
0 01 1100 CPYFPN, CPYFMN, CPYFENCPYFMNFEAT_MOPS
0 01 1101 CPYFPWTN, CPYFMWTN, CPYFEWTNCPYFMWTNFEAT_MOPS
0 01 1110 CPYFPRTN, CPYFMRTN, CPYFERTNCPYFMRTNFEAT_MOPS
0 01 1111 CPYFPTN, CPYFMTN, CPYFETNCPYFMTNFEAT_MOPS
0 10 0000 CPYFP, CPYFM, CPYFECPYFEFEAT_MOPS
0 10 0001 CPYFPWT, CPYFMWT, CPYFEWTCPYFEWTFEAT_MOPS
0 10 0010 CPYFPRT, CPYFMRT, CPYFERTCPYFERTFEAT_MOPS
0 10 0011 CPYFPT, CPYFMT, CPYFETCPYFETFEAT_MOPS
0 10 0100 CPYFPWN, CPYFMWN, CPYFEWNCPYFEWNFEAT_MOPS
0 10 0101 CPYFPWTWN, CPYFMWTWN, CPYFEWTWNCPYFEWTWNFEAT_MOPS
0 10 0110 CPYFPRTWN, CPYFMRTWN, CPYFERTWNCPYFERTWNFEAT_MOPS
0 10 0111 CPYFPTWN, CPYFMTWN, CPYFETWNCPYFETWNFEAT_MOPS
0 10 1000 CPYFPRN, CPYFMRN, CPYFERNCPYFERNFEAT_MOPS
0 10 1001 CPYFPWTRN, CPYFMWTRN, CPYFEWTRNCPYFEWTRNFEAT_MOPS
0 10 1010 CPYFPRTRN, CPYFMRTRN, CPYFERTRNCPYFERTRNFEAT_MOPS
0 10 1011 CPYFPTRN, CPYFMTRN, CPYFETRNCPYFETRNFEAT_MOPS
0 10 1100 CPYFPN, CPYFMN, CPYFENCPYFENFEAT_MOPS
0 10 1101 CPYFPWTN, CPYFMWTN, CPYFEWTNCPYFEWTNFEAT_MOPS
0 10 1110 CPYFPRTN, CPYFMRTN, CPYFERTNCPYFERTNFEAT_MOPS
0 10 1111 CPYFPTN, CPYFMTN, CPYFETNCPYFETNFEAT_MOPS
0 11 0000 SETP, SETM, SETESETPFEAT_MOPS
0 11 0001 SETPT, SETMT, SETETSETPTFEAT_MOPS
0 11 0010 SETPN, SETMN, SETENSETPNFEAT_MOPS
0 11 0011 SETPTN, SETMTN, SETETNSETPTNFEAT_MOPS
0 11 0100 SETP, SETM, SETESETMFEAT_MOPS
0 11 0101 SETPT, SETMT, SETETSETMTFEAT_MOPS
0 11 0110 SETPN, SETMN, SETENSETMNFEAT_MOPS
0 11 0111 SETPTN, SETMTN, SETETNSETMTNFEAT_MOPS
0 11 1000 SETP, SETM, SETESETEFEAT_MOPS
0 11 1001 SETPT, SETMT, SETETSETETFEAT_MOPS
0 11 1010 SETPN, SETMN, SETENSETENFEAT_MOPS
0 11 1011 SETPTN, SETMTN, SETETNSETETNFEAT_MOPS
0 11 11xx UNALLOCATED-
1 00 0000 CPYP, CPYM, CPYECPYPFEAT_MOPS
1 00 0001 CPYPWT, CPYMWT, CPYEWTCPYPWTFEAT_MOPS
1 00 0010 CPYPRT, CPYMRT, CPYERTCPYPRTFEAT_MOPS
1 00 0011 CPYPT, CPYMT, CPYETCPYPTFEAT_MOPS
1 00 0100 CPYPWN, CPYMWN, CPYEWNCPYPWNFEAT_MOPS
1 00 0101 CPYPWTWN, CPYMWTWN, CPYEWTWNCPYPWTWNFEAT_MOPS
1 00 0110 CPYPRTWN, CPYMRTWN, CPYERTWNCPYPRTWNFEAT_MOPS
1 00 0111 CPYPTWN, CPYMTWN, CPYETWNCPYPTWNFEAT_MOPS
1 00 1000 CPYPRN, CPYMRN, CPYERNCPYPRNFEAT_MOPS
1 00 1001 CPYPWTRN, CPYMWTRN, CPYEWTRNCPYPWTRNFEAT_MOPS
1 00 1010 CPYPRTRN, CPYMRTRN, CPYERTRNCPYPRTRNFEAT_MOPS
1 00 1011 CPYPTRN, CPYMTRN, CPYETRNCPYPTRNFEAT_MOPS
1 00 1100 CPYPN, CPYMN, CPYENCPYPNFEAT_MOPS
1 00 1101 CPYPWTN, CPYMWTN, CPYEWTNCPYPWTNFEAT_MOPS
1 00 1110 CPYPRTN, CPYMRTN, CPYERTNCPYPRTNFEAT_MOPS
1 00 1111 CPYPTN, CPYMTN, CPYETNCPYPTNFEAT_MOPS
1 01 0000 CPYP, CPYM, CPYECPYMFEAT_MOPS
1 01 0001 CPYPWT, CPYMWT, CPYEWTCPYMWTFEAT_MOPS
1 01 0010 CPYPRT, CPYMRT, CPYERTCPYMRTFEAT_MOPS
1 01 0011 CPYPT, CPYMT, CPYETCPYMTFEAT_MOPS
1 01 0100 CPYPWN, CPYMWN, CPYEWNCPYMWNFEAT_MOPS
1 01 0101 CPYPWTWN, CPYMWTWN, CPYEWTWNCPYMWTWNFEAT_MOPS
1 01 0110 CPYPRTWN, CPYMRTWN, CPYERTWNCPYMRTWNFEAT_MOPS
1 01 0111 CPYPTWN, CPYMTWN, CPYETWNCPYMTWNFEAT_MOPS
1 01 1000 CPYPRN, CPYMRN, CPYERNCPYMRNFEAT_MOPS
1 01 1001 CPYPWTRN, CPYMWTRN, CPYEWTRNCPYMWTRNFEAT_MOPS
1 01 1010 CPYPRTRN, CPYMRTRN, CPYERTRNCPYMRTRNFEAT_MOPS
1 01 1011 CPYPTRN, CPYMTRN, CPYETRNCPYMTRNFEAT_MOPS
1 01 1100 CPYPN, CPYMN, CPYENCPYMNFEAT_MOPS
1 01 1101 CPYPWTN, CPYMWTN, CPYEWTNCPYMWTNFEAT_MOPS
1 01 1110 CPYPRTN, CPYMRTN, CPYERTNCPYMRTNFEAT_MOPS
1 01 1111 CPYPTN, CPYMTN, CPYETNCPYMTNFEAT_MOPS
1 10 0000 CPYP, CPYM, CPYECPYEFEAT_MOPS
1 10 0001 CPYPWT, CPYMWT, CPYEWTCPYEWTFEAT_MOPS
1 10 0010 CPYPRT, CPYMRT, CPYERTCPYERTFEAT_MOPS
1 10 0011 CPYPT, CPYMT, CPYETCPYETFEAT_MOPS
1 10 0100 CPYPWN, CPYMWN, CPYEWNCPYEWNFEAT_MOPS
1 10 0101 CPYPWTWN, CPYMWTWN, CPYEWTWNCPYEWTWNFEAT_MOPS
1 10 0110 CPYPRTWN, CPYMRTWN, CPYERTWNCPYERTWNFEAT_MOPS
1 10 0111 CPYPTWN, CPYMTWN, CPYETWNCPYETWNFEAT_MOPS
1 10 1000 CPYPRN, CPYMRN, CPYERNCPYERNFEAT_MOPS
1 10 1001 CPYPWTRN, CPYMWTRN, CPYEWTRNCPYEWTRNFEAT_MOPS
1 10 1010 CPYPRTRN, CPYMRTRN, CPYERTRNCPYERTRNFEAT_MOPS
1 10 1011 CPYPTRN, CPYMTRN, CPYETRNCPYETRNFEAT_MOPS
1 10 1100 CPYPN, CPYMN, CPYENCPYENFEAT_MOPS
1 10 1101 CPYPWTN, CPYMWTN, CPYEWTNCPYEWTNFEAT_MOPS
1 10 1110 CPYPRTN, CPYMRTN, CPYERTNCPYERTNFEAT_MOPS
1 10 1111 CPYPTN, CPYMTN, CPYETNCPYETNFEAT_MOPS
1 11 0000 SETGP, SETGM, SETGESETGPFEAT_MOPS
1 11 0001 SETGPT, SETGMT, SETGETSETGPTFEAT_MOPS
1 11 0010 SETGPN, SETGMN, SETGENSETGPNFEAT_MOPS
1 11 0011 SETGPTN, SETGMTN, SETGETNSETGPTNFEAT_MOPS
1 11 0100 SETGP, SETGM, SETGESETGMFEAT_MOPS
1 11 0101 SETGPT, SETGMT, SETGETSETGMTFEAT_MOPS
1 11 0110 SETGPN, SETGMN, SETGENSETGMNFEAT_MOPS
1 11 0111 SETGPTN, SETGMTN, SETGETNSETGMTNFEAT_MOPS
1 11 1000 SETGP, SETGM, SETGESETGEFEAT_MOPS
1 11 1001 SETGPT, SETGMT, SETGETSETGETFEAT_MOPS
1 11 1010 SETGPN, SETGMN, SETGENSETGENFEAT_MOPS
1 11 1011 SETGPTN, SETGMTN, SETGETNSETGETNFEAT_MOPS
1 11 11xx UNALLOCATED-

Load/store no-allocate pair (offset)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
opc101V000Limm7Rt2RnRt
Decode fields Instruction Details
opc V L
00 0 0 STNP32-bit
00 0 1 LDNP32-bit
00 1 0 STNP (SIMD&FP)32-bit
00 1 1 LDNP (SIMD&FP)32-bit
01 0 UNALLOCATED
01 1 0 STNP (SIMD&FP)64-bit
01 1 1 LDNP (SIMD&FP)64-bit
10 0 0 STNP64-bit
10 0 1 LDNP64-bit
10 1 0 STNP (SIMD&FP)128-bit
10 1 1 LDNP (SIMD&FP)128-bit
11 UNALLOCATED

Load/store register pair (post-indexed)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
opc101V001Limm7Rt2RnRt
Decode fields Instruction Details Feature
opc V L
00 0 0 STP32-bit-
00 0 1 LDP32-bit-
00 1 0 STP (SIMD&FP)32-bit-
00 1 1 LDP (SIMD&FP)32-bit-
01 0 0 STGPFEAT_MTE
01 0 1 LDPSW-
01 1 0 STP (SIMD&FP)64-bit-
01 1 1 LDP (SIMD&FP)64-bit-
10 0 0 STP64-bit-
10 0 1 LDP64-bit-
10 1 0 STP (SIMD&FP)128-bit-
10 1 1 LDP (SIMD&FP)128-bit-
11 UNALLOCATED-

Load/store register pair (offset)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
opc101V010Limm7Rt2RnRt
Decode fields Instruction Details Feature
opc V L
00 0 0 STP32-bit-
00 0 1 LDP32-bit-
00 1 0 STP (SIMD&FP)32-bit-
00 1 1 LDP (SIMD&FP)32-bit-
01 0 0 STGPFEAT_MTE
01 0 1 LDPSW-
01 1 0 STP (SIMD&FP)64-bit-
01 1 1 LDP (SIMD&FP)64-bit-
10 0 0 STP64-bit-
10 0 1 LDP64-bit-
10 1 0 STP (SIMD&FP)128-bit-
10 1 1 LDP (SIMD&FP)128-bit-
11 UNALLOCATED-

Load/store register pair (pre-indexed)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
opc101V011Limm7Rt2RnRt
Decode fields Instruction Details Feature
opc V L
00 0 0 STP32-bit-
00 0 1 LDP32-bit-
00 1 0 STP (SIMD&FP)32-bit-
00 1 1 LDP (SIMD&FP)32-bit-
01 0 0 STGPFEAT_MTE
01 0 1 LDPSW-
01 1 0 STP (SIMD&FP)64-bit-
01 1 1 LDP (SIMD&FP)64-bit-
10 0 0 STP64-bit-
10 0 1 LDP64-bit-
10 1 0 STP (SIMD&FP)128-bit-
10 1 1 LDP (SIMD&FP)128-bit-
11 UNALLOCATED-

Load/store register (unscaled immediate)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size111V00opc0imm900RnRt
Decode fields Instruction Details
size V opc
x1 1 1x UNALLOCATED
00 0 00 STURB
00 0 01 LDURB
00 0 10 LDURSB64-bit
00 0 11 LDURSB32-bit
00 1 00 STUR (SIMD&FP)8-bit
00 1 01 LDUR (SIMD&FP)8-bit
00 1 10 STUR (SIMD&FP)128-bit
00 1 11 LDUR (SIMD&FP)128-bit
01 0 00 STURH
01 0 01 LDURH
01 0 10 LDURSH64-bit
01 0 11 LDURSH32-bit
01 1 00 STUR (SIMD&FP)16-bit
01 1 01 LDUR (SIMD&FP)16-bit
1x 0 11 UNALLOCATED
1x 1 1x UNALLOCATED
10 0 00 STUR32-bit
10 0 01 LDUR32-bit
10 0 10 LDURSW
10 1 00 STUR (SIMD&FP)32-bit
10 1 01 LDUR (SIMD&FP)32-bit
11 0 00 STUR64-bit
11 0 01 LDUR64-bit
11 0 10 PRFUM
11 1 00 STUR (SIMD&FP)64-bit
11 1 01 LDUR (SIMD&FP)64-bit

Load/store register (immediate post-indexed)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size111V00opc0imm901RnRt
Decode fields Instruction Details
size V opc
x1 1 1x UNALLOCATED
00 0 00 STRB (immediate)
00 0 01 LDRB (immediate)
00 0 10 LDRSB (immediate)64-bit
00 0 11 LDRSB (immediate)32-bit
00 1 00 STR (immediate, SIMD&FP)8-bit
00 1 01 LDR (immediate, SIMD&FP)8-bit
00 1 10 STR (immediate, SIMD&FP)128-bit
00 1 11 LDR (immediate, SIMD&FP)128-bit
01 0 00 STRH (immediate)
01 0 01 LDRH (immediate)
01 0 10 LDRSH (immediate)64-bit
01 0 11 LDRSH (immediate)32-bit
01 1 00 STR (immediate, SIMD&FP)16-bit
01 1 01 LDR (immediate, SIMD&FP)16-bit
1x 0 11 UNALLOCATED
1x 1 1x UNALLOCATED
10 0 00 STR (immediate)32-bit
10 0 01 LDR (immediate)32-bit
10 0 10 LDRSW (immediate)
10 1 00 STR (immediate, SIMD&FP)32-bit
10 1 01 LDR (immediate, SIMD&FP)32-bit
11 0 00 STR (immediate)64-bit
11 0 01 LDR (immediate)64-bit
11 0 10 UNALLOCATED
11 1 00 STR (immediate, SIMD&FP)64-bit
11 1 01 LDR (immediate, SIMD&FP)64-bit

Load/store register (unprivileged)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size111V00opc0imm910RnRt
Decode fields Instruction Details
size V opc
1 UNALLOCATED
00 0 00 STTRB
00 0 01 LDTRB
00 0 10 LDTRSB64-bit
00 0 11 LDTRSB32-bit
01 0 00 STTRH
01 0 01 LDTRH
01 0 10 LDTRSH64-bit
01 0 11 LDTRSH32-bit
1x 0 11 UNALLOCATED
10 0 00 STTR32-bit
10 0 01 LDTR32-bit
10 0 10 LDTRSW
11 0 00 STTR64-bit
11 0 01 LDTR64-bit
11 0 10 UNALLOCATED

Load/store register (immediate pre-indexed)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size111V00opc0imm911RnRt
Decode fields Instruction Details
size V opc
x1 1 1x UNALLOCATED
00 0 00 STRB (immediate)
00 0 01 LDRB (immediate)
00 0 10 LDRSB (immediate)64-bit
00 0 11 LDRSB (immediate)32-bit
00 1 00 STR (immediate, SIMD&FP)8-bit
00 1 01 LDR (immediate, SIMD&FP)8-bit
00 1 10 STR (immediate, SIMD&FP)128-bit
00 1 11 LDR (immediate, SIMD&FP)128-bit
01 0 00 STRH (immediate)
01 0 01 LDRH (immediate)
01 0 10 LDRSH (immediate)64-bit
01 0 11 LDRSH (immediate)32-bit
01 1 00 STR (immediate, SIMD&FP)16-bit
01 1 01 LDR (immediate, SIMD&FP)16-bit
1x 0 11 UNALLOCATED
1x 1 1x UNALLOCATED
10 0 00 STR (immediate)32-bit
10 0 01 LDR (immediate)32-bit
10 0 10 LDRSW (immediate)
10 1 00 STR (immediate, SIMD&FP)32-bit
10 1 01 LDR (immediate, SIMD&FP)32-bit
11 0 00 STR (immediate)64-bit
11 0 01 LDR (immediate)64-bit
11 0 10 UNALLOCATED
11 1 00 STR (immediate, SIMD&FP)64-bit
11 1 01 LDR (immediate, SIMD&FP)64-bit

Atomic memory operations

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size111V00AR1Rso3opc00RnRt
Decode fields Instruction Details Feature
size V A R Rs o3 opc
0 1 11x UNALLOCATED-
0 0 1 100 UNALLOCATED-
0 0 1 1 001 UNALLOCATED-
0 0 1 1 010 UNALLOCATED-
0 0 1 1 011 UNALLOCATED-
0 0 1 1 101 UNALLOCATED-
0 1 0 1 001 UNALLOCATED-
0 1 0 1 010 UNALLOCATED-
0 1 0 1 011 UNALLOCATED-
0 1 0 1 101 UNALLOCATED-
0 1 1 1 001 UNALLOCATED-
0 1 1 1 010 UNALLOCATED-
0 1 1 1 011 UNALLOCATED-
0 1 1 1 100 UNALLOCATED-
0 1 1 1 101 UNALLOCATED-
1 UNALLOCATED-
00 0 0 0 0 000 LDADDB, LDADDAB, LDADDALB, LDADDLBLDADDBFEAT_LSE
00 0 0 0 0 001 LDCLRB, LDCLRAB, LDCLRALB, LDCLRLBLDCLRBFEAT_LSE
00 0 0 0 0 010 LDEORB, LDEORAB, LDEORALB, LDEORLBLDEORBFEAT_LSE
00 0 0 0 0 011 LDSETB, LDSETAB, LDSETALB, LDSETLBLDSETBFEAT_LSE
00 0 0 0 0 100 LDSMAXB, LDSMAXAB, LDSMAXALB, LDSMAXLBLDSMAXBFEAT_LSE
00 0 0 0 0 101 LDSMINB, LDSMINAB, LDSMINALB, LDSMINLBLDSMINBFEAT_LSE
00 0 0 0 0 110 LDUMAXB, LDUMAXAB, LDUMAXALB, LDUMAXLBLDUMAXBFEAT_LSE
00 0 0 0 0 111 LDUMINB, LDUMINAB, LDUMINALB, LDUMINLBLDUMINBFEAT_LSE
00 0 0 0 1 000 SWPB, SWPAB, SWPALB, SWPLBSWPBFEAT_LSE
00 0 0 0 1 001 UNALLOCATED-
00 0 0 0 1 010 UNALLOCATED-
00 0 0 0 1 011 UNALLOCATED-
00 0 0 0 1 101 UNALLOCATED-
00 0 0 1 0 000 LDADDB, LDADDAB, LDADDALB, LDADDLBLDADDLBFEAT_LSE
00 0 0 1 0 001 LDCLRB, LDCLRAB, LDCLRALB, LDCLRLBLDCLRLBFEAT_LSE
00 0 0 1 0 010 LDEORB, LDEORAB, LDEORALB, LDEORLBLDEORLBFEAT_LSE
00 0 0 1 0 011 LDSETB, LDSETAB, LDSETALB, LDSETLBLDSETLBFEAT_LSE
00 0 0 1 0 100 LDSMAXB, LDSMAXAB, LDSMAXALB, LDSMAXLBLDSMAXLBFEAT_LSE
00 0 0 1 0 101 LDSMINB, LDSMINAB, LDSMINALB, LDSMINLBLDSMINLBFEAT_LSE
00 0 0 1 0 110 LDUMAXB, LDUMAXAB, LDUMAXALB, LDUMAXLBLDUMAXLBFEAT_LSE
00 0 0 1 0 111 LDUMINB, LDUMINAB, LDUMINALB, LDUMINLBLDUMINLBFEAT_LSE
00 0 0 1 1 000 SWPB, SWPAB, SWPALB, SWPLBSWPLBFEAT_LSE
00 0 1 0 0 000 LDADDB, LDADDAB, LDADDALB, LDADDLBLDADDABFEAT_LSE
00 0 1 0 0 001 LDCLRB, LDCLRAB, LDCLRALB, LDCLRLBLDCLRABFEAT_LSE
00 0 1 0 0 010 LDEORB, LDEORAB, LDEORALB, LDEORLBLDEORABFEAT_LSE
00 0 1 0 0 011 LDSETB, LDSETAB, LDSETALB, LDSETLBLDSETABFEAT_LSE
00 0 1 0 0 100 LDSMAXB, LDSMAXAB, LDSMAXALB, LDSMAXLBLDSMAXABFEAT_LSE
00 0 1 0 0 101 LDSMINB, LDSMINAB, LDSMINALB, LDSMINLBLDSMINABFEAT_LSE
00 0 1 0 0 110 LDUMAXB, LDUMAXAB, LDUMAXALB, LDUMAXLBLDUMAXABFEAT_LSE
00 0 1 0 0 111 LDUMINB, LDUMINAB, LDUMINALB, LDUMINLBLDUMINABFEAT_LSE
00 0 1 0 1 000 SWPB, SWPAB, SWPALB, SWPLBSWPABFEAT_LSE
00 0 1 0 1 100 LDAPRBFEAT_LRCPC
00 0 1 1 0 000 LDADDB, LDADDAB, LDADDALB, LDADDLBLDADDALBFEAT_LSE
00 0 1 1 0 001 LDCLRB, LDCLRAB, LDCLRALB, LDCLRLBLDCLRALBFEAT_LSE
00 0 1 1 0 010 LDEORB, LDEORAB, LDEORALB, LDEORLBLDEORALBFEAT_LSE
00 0 1 1 0 011 LDSETB, LDSETAB, LDSETALB, LDSETLBLDSETALBFEAT_LSE
00 0 1 1 0 100 LDSMAXB, LDSMAXAB, LDSMAXALB, LDSMAXLBLDSMAXALBFEAT_LSE
00 0 1 1 0 101 LDSMINB, LDSMINAB, LDSMINALB, LDSMINLBLDSMINALBFEAT_LSE
00 0 1 1 0 110 LDUMAXB, LDUMAXAB, LDUMAXALB, LDUMAXLBLDUMAXALBFEAT_LSE
00 0 1 1 0 111 LDUMINB, LDUMINAB, LDUMINALB, LDUMINLBLDUMINALBFEAT_LSE
00 0 1 1 1 000 SWPB, SWPAB, SWPALB, SWPLBSWPALBFEAT_LSE
01 0 0 0 0 000 LDADDH, LDADDAH, LDADDALH, LDADDLHLDADDHFEAT_LSE
01 0 0 0 0 001 LDCLRH, LDCLRAH, LDCLRALH, LDCLRLHLDCLRHFEAT_LSE
01 0 0 0 0 010 LDEORH, LDEORAH, LDEORALH, LDEORLHLDEORHFEAT_LSE
01 0 0 0 0 011 LDSETH, LDSETAH, LDSETALH, LDSETLHLDSETHFEAT_LSE
01 0 0 0 0 100 LDSMAXH, LDSMAXAH, LDSMAXALH, LDSMAXLHLDSMAXHFEAT_LSE
01 0 0 0 0 101 LDSMINH, LDSMINAH, LDSMINALH, LDSMINLHLDSMINHFEAT_LSE
01 0 0 0 0 110 LDUMAXH, LDUMAXAH, LDUMAXALH, LDUMAXLHLDUMAXHFEAT_LSE
01 0 0 0 0 111 LDUMINH, LDUMINAH, LDUMINALH, LDUMINLHLDUMINHFEAT_LSE
01 0 0 0 1 000 SWPH, SWPAH, SWPALH, SWPLHSWPHFEAT_LSE
01 0 0 0 1 001 UNALLOCATED-
01 0 0 0 1 010 UNALLOCATED-
01 0 0 0 1 011 UNALLOCATED-
01 0 0 0 1 101 UNALLOCATED-
01 0 0 1 0 000 LDADDH, LDADDAH, LDADDALH, LDADDLHLDADDLHFEAT_LSE
01 0 0 1 0 001 LDCLRH, LDCLRAH, LDCLRALH, LDCLRLHLDCLRLHFEAT_LSE
01 0 0 1 0 010 LDEORH, LDEORAH, LDEORALH, LDEORLHLDEORLHFEAT_LSE
01 0 0 1 0 011 LDSETH, LDSETAH, LDSETALH, LDSETLHLDSETLHFEAT_LSE
01 0 0 1 0 100 LDSMAXH, LDSMAXAH, LDSMAXALH, LDSMAXLHLDSMAXLHFEAT_LSE
01 0 0 1 0 101 LDSMINH, LDSMINAH, LDSMINALH, LDSMINLHLDSMINLHFEAT_LSE
01 0 0 1 0 110 LDUMAXH, LDUMAXAH, LDUMAXALH, LDUMAXLHLDUMAXLHFEAT_LSE
01 0 0 1 0 111 LDUMINH, LDUMINAH, LDUMINALH, LDUMINLHLDUMINLHFEAT_LSE
01 0 0 1 1 000 SWPH, SWPAH, SWPALH, SWPLHSWPLHFEAT_LSE
01 0 1 0 0 000 LDADDH, LDADDAH, LDADDALH, LDADDLHLDADDAHFEAT_LSE
01 0 1 0 0 001 LDCLRH, LDCLRAH, LDCLRALH, LDCLRLHLDCLRAHFEAT_LSE
01 0 1 0 0 010 LDEORH, LDEORAH, LDEORALH, LDEORLHLDEORAHFEAT_LSE
01 0 1 0 0 011 LDSETH, LDSETAH, LDSETALH, LDSETLHLDSETAHFEAT_LSE
01 0 1 0 0 100 LDSMAXH, LDSMAXAH, LDSMAXALH, LDSMAXLHLDSMAXAHFEAT_LSE
01 0 1 0 0 101 LDSMINH, LDSMINAH, LDSMINALH, LDSMINLHLDSMINAHFEAT_LSE
01 0 1 0 0 110 LDUMAXH, LDUMAXAH, LDUMAXALH, LDUMAXLHLDUMAXAHFEAT_LSE
01 0 1 0 0 111 LDUMINH, LDUMINAH, LDUMINALH, LDUMINLHLDUMINAHFEAT_LSE
01 0 1 0 1 000 SWPH, SWPAH, SWPALH, SWPLHSWPAHFEAT_LSE
01 0 1 0 1 100 LDAPRHFEAT_LRCPC
01 0 1 1 0 000 LDADDH, LDADDAH, LDADDALH, LDADDLHLDADDALHFEAT_LSE
01 0 1 1 0 001 LDCLRH, LDCLRAH, LDCLRALH, LDCLRLHLDCLRALHFEAT_LSE
01 0 1 1 0 010 LDEORH, LDEORAH, LDEORALH, LDEORLHLDEORALHFEAT_LSE
01 0 1 1 0 011 LDSETH, LDSETAH, LDSETALH, LDSETLHLDSETALHFEAT_LSE
01 0 1 1 0 100 LDSMAXH, LDSMAXAH, LDSMAXALH, LDSMAXLHLDSMAXALHFEAT_LSE
01 0 1 1 0 101 LDSMINH, LDSMINAH, LDSMINALH, LDSMINLHLDSMINALHFEAT_LSE
01 0 1 1 0 110 LDUMAXH, LDUMAXAH, LDUMAXALH, LDUMAXLHLDUMAXALHFEAT_LSE
01 0 1 1 0 111 LDUMINH, LDUMINAH, LDUMINALH, LDUMINLHLDUMINALHFEAT_LSE
01 0 1 1 1 000 SWPH, SWPAH, SWPALH, SWPLHSWPALHFEAT_LSE
10 0 0 0 0 000 LDADD, LDADDA, LDADDAL, LDADDL32-bit LDADDFEAT_LSE
10 0 0 0 0 001 LDCLR, LDCLRA, LDCLRAL, LDCLRL32-bit LDCLRFEAT_LSE
10 0 0 0 0 010 LDEOR, LDEORA, LDEORAL, LDEORL32-bit LDEORFEAT_LSE
10 0 0 0 0 011 LDSET, LDSETA, LDSETAL, LDSETL32-bit LDSETFEAT_LSE
10 0 0 0 0 100 LDSMAX, LDSMAXA, LDSMAXAL, LDSMAXL32-bit LDSMAXFEAT_LSE
10 0 0 0 0 101 LDSMIN, LDSMINA, LDSMINAL, LDSMINL32-bit LDSMINFEAT_LSE
10 0 0 0 0 110 LDUMAX, LDUMAXA, LDUMAXAL, LDUMAXL32-bit LDUMAXFEAT_LSE
10 0 0 0 0 111 LDUMIN, LDUMINA, LDUMINAL, LDUMINL32-bit LDUMINFEAT_LSE
10 0 0 0 1 000 SWP, SWPA, SWPAL, SWPL32-bit SWPFEAT_LSE
10 0 0 0 1 001 UNALLOCATED-
10 0 0 0 1 010 UNALLOCATED-
10 0 0 0 1 011 UNALLOCATED-
10 0 0 0 1 101 UNALLOCATED-
10 0 0 1 0 000 LDADD, LDADDA, LDADDAL, LDADDL32-bit LDADDLFEAT_LSE
10 0 0 1 0 001 LDCLR, LDCLRA, LDCLRAL, LDCLRL32-bit LDCLRLFEAT_LSE
10 0 0 1 0 010 LDEOR, LDEORA, LDEORAL, LDEORL32-bit LDEORLFEAT_LSE
10 0 0 1 0 011 LDSET, LDSETA, LDSETAL, LDSETL32-bit LDSETLFEAT_LSE
10 0 0 1 0 100 LDSMAX, LDSMAXA, LDSMAXAL, LDSMAXL32-bit LDSMAXLFEAT_LSE
10 0 0 1 0 101 LDSMIN, LDSMINA, LDSMINAL, LDSMINL32-bit LDSMINLFEAT_LSE
10 0 0 1 0 110 LDUMAX, LDUMAXA, LDUMAXAL, LDUMAXL32-bit LDUMAXLFEAT_LSE
10 0 0 1 0 111 LDUMIN, LDUMINA, LDUMINAL, LDUMINL32-bit LDUMINLFEAT_LSE
10 0 0 1 1 000 SWP, SWPA, SWPAL, SWPL32-bit SWPLFEAT_LSE
10 0 1 0 0 000 LDADD, LDADDA, LDADDAL, LDADDL32-bit LDADDAFEAT_LSE
10 0 1 0 0 001 LDCLR, LDCLRA, LDCLRAL, LDCLRL32-bit LDCLRAFEAT_LSE
10 0 1 0 0 010 LDEOR, LDEORA, LDEORAL, LDEORL32-bit LDEORAFEAT_LSE
10 0 1 0 0 011 LDSET, LDSETA, LDSETAL, LDSETL32-bit LDSETAFEAT_LSE
10 0 1 0 0 100 LDSMAX, LDSMAXA, LDSMAXAL, LDSMAXL32-bit LDSMAXAFEAT_LSE
10 0 1 0 0 101 LDSMIN, LDSMINA, LDSMINAL, LDSMINL32-bit LDSMINAFEAT_LSE
10 0 1 0 0 110 LDUMAX, LDUMAXA, LDUMAXAL, LDUMAXL32-bit LDUMAXAFEAT_LSE
10 0 1 0 0 111 LDUMIN, LDUMINA, LDUMINAL, LDUMINL32-bit LDUMINAFEAT_LSE
10 0 1 0 1 000 SWP, SWPA, SWPAL, SWPL32-bit SWPAFEAT_LSE
10 0 1 0 1 100 LDAPR32-bitFEAT_LRCPC
10 0 1 1 0 000 LDADD, LDADDA, LDADDAL, LDADDL32-bit LDADDALFEAT_LSE
10 0 1 1 0 001 LDCLR, LDCLRA, LDCLRAL, LDCLRL32-bit LDCLRALFEAT_LSE
10 0 1 1 0 010 LDEOR, LDEORA, LDEORAL, LDEORL32-bit LDEORALFEAT_LSE
10 0 1 1 0 011 LDSET, LDSETA, LDSETAL, LDSETL32-bit LDSETALFEAT_LSE
10 0 1 1 0 100 LDSMAX, LDSMAXA, LDSMAXAL, LDSMAXL32-bit LDSMAXALFEAT_LSE
10 0 1 1 0 101 LDSMIN, LDSMINA, LDSMINAL, LDSMINL32-bit LDSMINALFEAT_LSE
10 0 1 1 0 110 LDUMAX, LDUMAXA, LDUMAXAL, LDUMAXL32-bit LDUMAXALFEAT_LSE
10 0 1 1 0 111 LDUMIN, LDUMINA, LDUMINAL, LDUMINL32-bit LDUMINALFEAT_LSE
10 0 1 1 1 000 SWP, SWPA, SWPAL, SWPL32-bit SWPALFEAT_LSE
11 0 0 0 0 000 LDADD, LDADDA, LDADDAL, LDADDL64-bit LDADDFEAT_LSE
11 0 0 0 0 001 LDCLR, LDCLRA, LDCLRAL, LDCLRL64-bit LDCLRFEAT_LSE
11 0 0 0 0 010 LDEOR, LDEORA, LDEORAL, LDEORL64-bit LDEORFEAT_LSE
11 0 0 0 0 011 LDSET, LDSETA, LDSETAL, LDSETL64-bit LDSETFEAT_LSE
11 0 0 0 0 100 LDSMAX, LDSMAXA, LDSMAXAL, LDSMAXL64-bit LDSMAXFEAT_LSE
11 0 0 0 0 101 LDSMIN, LDSMINA, LDSMINAL, LDSMINL64-bit LDSMINFEAT_LSE
11 0 0 0 0 110 LDUMAX, LDUMAXA, LDUMAXAL, LDUMAXL64-bit LDUMAXFEAT_LSE
11 0 0 0 0 111 LDUMIN, LDUMINA, LDUMINAL, LDUMINL64-bit LDUMINFEAT_LSE
11 0 0 0 1 000 SWP, SWPA, SWPAL, SWPL64-bit SWPFEAT_LSE
11 0 0 0 1 010 ST64BV0FEAT_LS64_V
11 0 0 0 1 011 ST64BVFEAT_LS64_V
11 0 0 0 11111 1 001 ST64BFEAT_LS64
11 0 0 0 11111 1 101 LD64BFEAT_LS64
11 0 0 1 0 000 LDADD, LDADDA, LDADDAL, LDADDL64-bit LDADDLFEAT_LSE
11 0 0 1 0 001 LDCLR, LDCLRA, LDCLRAL, LDCLRL64-bit LDCLRLFEAT_LSE
11 0 0 1 0 010 LDEOR, LDEORA, LDEORAL, LDEORL64-bit LDEORLFEAT_LSE
11 0 0 1 0 011 LDSET, LDSETA, LDSETAL, LDSETL64-bit LDSETLFEAT_LSE
11 0 0 1 0 100 LDSMAX, LDSMAXA, LDSMAXAL, LDSMAXL64-bit LDSMAXLFEAT_LSE
11 0 0 1 0 101 LDSMIN, LDSMINA, LDSMINAL, LDSMINL64-bit LDSMINLFEAT_LSE
11 0 0 1 0 110 LDUMAX, LDUMAXA, LDUMAXAL, LDUMAXL64-bit LDUMAXLFEAT_LSE
11 0 0 1 0 111 LDUMIN, LDUMINA, LDUMINAL, LDUMINL64-bit LDUMINLFEAT_LSE
11 0 0 1 1 000 SWP, SWPA, SWPAL, SWPL64-bit SWPLFEAT_LSE
11 0 1 0 0 000 LDADD, LDADDA, LDADDAL, LDADDL64-bit LDADDAFEAT_LSE
11 0 1 0 0 001 LDCLR, LDCLRA, LDCLRAL, LDCLRL64-bit LDCLRAFEAT_LSE
11 0 1 0 0 010 LDEOR, LDEORA, LDEORAL, LDEORL64-bit LDEORAFEAT_LSE
11 0 1 0 0 011 LDSET, LDSETA, LDSETAL, LDSETL64-bit LDSETAFEAT_LSE
11 0 1 0 0 100 LDSMAX, LDSMAXA, LDSMAXAL, LDSMAXL64-bit LDSMAXAFEAT_LSE
11 0 1 0 0 101 LDSMIN, LDSMINA, LDSMINAL, LDSMINL64-bit LDSMINAFEAT_LSE
11 0 1 0 0 110 LDUMAX, LDUMAXA, LDUMAXAL, LDUMAXL64-bit LDUMAXAFEAT_LSE
11 0 1 0 0 111 LDUMIN, LDUMINA, LDUMINAL, LDUMINL64-bit LDUMINAFEAT_LSE
11 0 1 0 1 000 SWP, SWPA, SWPAL, SWPL64-bit SWPAFEAT_LSE
11 0 1 0 1 100 LDAPR64-bitFEAT_LRCPC
11 0 1 1 0 000 LDADD, LDADDA, LDADDAL, LDADDL64-bit LDADDALFEAT_LSE
11 0 1 1 0 001 LDCLR, LDCLRA, LDCLRAL, LDCLRL64-bit LDCLRALFEAT_LSE
11 0 1 1 0 010 LDEOR, LDEORA, LDEORAL, LDEORL64-bit LDEORALFEAT_LSE
11 0 1 1 0 011 LDSET, LDSETA, LDSETAL, LDSETL64-bit LDSETALFEAT_LSE
11 0 1 1 0 100 LDSMAX, LDSMAXA, LDSMAXAL, LDSMAXL64-bit LDSMAXALFEAT_LSE
11 0 1 1 0 101 LDSMIN, LDSMINA, LDSMINAL, LDSMINL64-bit LDSMINALFEAT_LSE
11 0 1 1 0 110 LDUMAX, LDUMAXA, LDUMAXAL, LDUMAXL64-bit LDUMAXALFEAT_LSE
11 0 1 1 0 111 LDUMIN, LDUMINA, LDUMINAL, LDUMINL64-bit LDUMINALFEAT_LSE
11 0 1 1 1 000 SWP, SWPA, SWPAL, SWPL64-bit SWPALFEAT_LSE

Load/store register (register offset)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size111V00opc1RmoptionS10RnRt
Decode fields Instruction Details
size V opc option
x1 1 1x UNALLOCATED
00 0 00 != 011 STRB (register)extended register
00 0 00 011 STRB (register)shifted register
00 0 01 != 011 LDRB (register)extended register
00 0 01 011 LDRB (register)shifted register
00 0 10 != 011 LDRSB (register)64-bit with extended register offset
00 0 10 011 LDRSB (register)64-bit with shifted register offset
00 0 11 != 011 LDRSB (register)32-bit with extended register offset
00 0 11 011 LDRSB (register)32-bit with shifted register offset
00 1 00 != 011 STR (register, SIMD&FP)
00 1 00 011 STR (register, SIMD&FP)
00 1 01 != 011 LDR (register, SIMD&FP)
00 1 01 011 LDR (register, SIMD&FP)
00 1 10 STR (register, SIMD&FP)
00 1 11 LDR (register, SIMD&FP)
01 0 00 STRH (register)
01 0 01 LDRH (register)
01 0 10 LDRSH (register)64-bit
01 0 11 LDRSH (register)32-bit
01 1 00 STR (register, SIMD&FP)
01 1 01 LDR (register, SIMD&FP)
1x 0 11 UNALLOCATED
1x 1 1x UNALLOCATED
10 0 00 STR (register)32-bit
10 0 01 LDR (register)32-bit
10 0 10 LDRSW (register)
10 1 00 STR (register, SIMD&FP)
10 1 01 LDR (register, SIMD&FP)
11 0 00 STR (register)64-bit
11 0 01 LDR (register)64-bit
11 0 10 PRFM (register)
11 1 00 STR (register, SIMD&FP)
11 1 01 LDR (register, SIMD&FP)

Load/store register (pac)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size111V00MS1imm9W1RnRt
Decode fields Instruction Details Feature
size V M W
!= 11 UNALLOCATED-
11 0 0 0 LDRAA, LDRABkey A, offsetFEAT_PAuth
11 0 0 1 LDRAA, LDRABkey A, pre-indexedFEAT_PAuth
11 0 1 0 LDRAA, LDRABkey B, offsetFEAT_PAuth
11 0 1 1 LDRAA, LDRABkey B, pre-indexedFEAT_PAuth
11 1 UNALLOCATED-

Load/store register (unsigned immediate)

These instructions are under Loads and Stores.

313029282726252423222120191817161514131211109876543210
size111V01opcimm12RnRt
Decode fields Instruction Details
size V opc
x1 1 1x UNALLOCATED
00 0 00 STRB (immediate)
00 0 01 LDRB (immediate)
00 0 10 LDRSB (immediate)64-bit
00 0 11 LDRSB (immediate)32-bit
00 1 00 STR (immediate, SIMD&FP)8-bit
00 1 01 LDR (immediate, SIMD&FP)8-bit
00 1 10 STR (immediate, SIMD&FP)128-bit
00 1 11 LDR (immediate, SIMD&FP)128-bit
01 0 00 STRH (immediate)
01 0 01 LDRH (immediate)
01 0 10 LDRSH (immediate)64-bit
01 0 11 LDRSH (immediate)32-bit
01 1 00 STR (immediate, SIMD&FP)16-bit
01 1 01 LDR (immediate, SIMD&FP)16-bit
1x 0 11 UNALLOCATED
1x 1 1x UNALLOCATED
10 0 00 STR (immediate)32-bit
10 0 01 LDR (immediate)32-bit
10 0 10 LDRSW (immediate)
10 1 00 STR (immediate, SIMD&FP)32-bit
10 1 01 LDR (immediate, SIMD&FP)32-bit
11 0 00 STR (immediate)64-bit
11 0 01 LDR (immediate)64-bit
11 0 10 PRFM (immediate)
11 1 00 STR (immediate, SIMD&FP)64-bit
11 1 01 LDR (immediate, SIMD&FP)64-bit

Data Processing -- Register

These instructions are under the top-level.

313029282726252423222120191817161514131211109876543210
op0op1101op2op3
Decode fields Instruction details
op0op1op2op3
0 1 0110 Data-processing (2 source)
1 1 0110 Data-processing (1 source)
0 0xxx Logical (shifted register)
0 1xx0 Add/subtract (shifted register)
0 1xx1 Add/subtract (extended register)
1 0000 000000 Add/subtract (with carry)
1 0000 x00001 Rotate right into flags
1 0000 xx0010 Evaluate into flags
1 0010 xxxx0x Conditional compare (register)
1 0010 xxxx1x Conditional compare (immediate)
1 0100 Conditional select
1 1xxx Data-processing (3 source)

Data-processing (2 source)

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sf0S11010110RmopcodeRnRd
Decode fields Instruction Details Feature
sf S opcode
000001 UNALLOCATED-
011xxx UNALLOCATED-
1xxxxx UNALLOCATED-
0 00011x UNALLOCATED-
0 001101 UNALLOCATED-
0 00111x UNALLOCATED-
1 00001x UNALLOCATED-
1 0001xx UNALLOCATED-
1 001xxx UNALLOCATED-
1 01xxxx UNALLOCATED-
0 000000 UNALLOCATED-
0 0 000010 UDIV32-bit-
0 0 000011 SDIV32-bit-
0 0 00010x UNALLOCATED-
0 0 001000 LSLV32-bit-
0 0 001001 LSRV32-bit-
0 0 001010 ASRV32-bit-
0 0 001011 RORV32-bit-
0 0 001100 UNALLOCATED-
0 0 010x11 UNALLOCATED-
0 0 010000 CRC32B, CRC32H, CRC32W, CRC32XCRC32B-
0 0 010001 CRC32B, CRC32H, CRC32W, CRC32XCRC32H-
0 0 010010 CRC32B, CRC32H, CRC32W, CRC32XCRC32W-
0 0 010100 CRC32CB, CRC32CH, CRC32CW, CRC32CXCRC32CB-
0 0 010101 CRC32CB, CRC32CH, CRC32CW, CRC32CXCRC32CH-
0 0 010110 CRC32CB, CRC32CH, CRC32CW, CRC32CXCRC32CW-
1 0 000000 SUBPFEAT_MTE
1 0 000010 UDIV64-bit-
1 0 000011 SDIV64-bit-
1 0 000100 IRGFEAT_MTE
1 0 000101 GMIFEAT_MTE
1 0 001000 LSLV64-bit-
1 0 001001 LSRV64-bit-
1 0 001010 ASRV64-bit-
1 0 001011 RORV64-bit-
1 0 001100 PACGAFEAT_PAuth
1 0 010xx0 UNALLOCATED-
1 0 010x0x UNALLOCATED-
1 0 010011 CRC32B, CRC32H, CRC32W, CRC32XCRC32X-
1 0 010111 CRC32CB, CRC32CH, CRC32CW, CRC32CXCRC32CX-
1 1 000000 SUBPSFEAT_MTE

Data-processing (1 source)

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sf1S11010110opcode2opcodeRnRd
Decode fields Instruction Details Feature
sf S opcode2 opcode Rn
1xxxxx UNALLOCATED-
xxx1x UNALLOCATED-
xx1xx UNALLOCATED-
x1xxx UNALLOCATED-
1xxxx UNALLOCATED-
0 00000 00011x UNALLOCATED-
0 00000 001xxx UNALLOCATED-
0 00000 01xxxx UNALLOCATED-
1 UNALLOCATED-
0 00001 UNALLOCATED-
0 0 00000 000000 RBIT32-bit-
0 0 00000 000001 REV1632-bit-
0 0 00000 000010 REV32-bit-
0 0 00000 000011 UNALLOCATED-
0 0 00000 000100 CLZ32-bit-
0 0 00000 000101 CLS32-bit-
1 0 00000 000000 RBIT64-bit-
1 0 00000 000001 REV1664-bit-
1 0 00000 000010 REV32-
1 0 00000 000011 REV64-bit-
1 0 00000 000100 CLZ64-bit-
1 0 00000 000101 CLS64-bit-
1 0 00001 000000 PACIA, PACIA1716, PACIASP, PACIAZ, PACIZAPACIAFEAT_PAuth
1 0 00001 000001 PACIB, PACIB1716, PACIBSP, PACIBZ, PACIZBPACIBFEAT_PAuth
1 0 00001 000010 PACDA, PACDZAPACDAFEAT_PAuth
1 0 00001 000011 PACDB, PACDZBPACDBFEAT_PAuth
1 0 00001 000100 AUTIA, AUTIA1716, AUTIASP, AUTIAZ, AUTIZAAUTIAFEAT_PAuth
1 0 00001 000101 AUTIB, AUTIB1716, AUTIBSP, AUTIBZ, AUTIZBAUTIBFEAT_PAuth
1 0 00001 000110 AUTDA, AUTDZAAUTDAFEAT_PAuth
1 0 00001 000111 AUTDB, AUTDZBAUTDBFEAT_PAuth
1 0 00001 001000 11111 PACIA, PACIA1716, PACIASP, PACIAZ, PACIZAPACIZAFEAT_PAuth
1 0 00001 001001 11111 PACIB, PACIB1716, PACIBSP, PACIBZ, PACIZBPACIZBFEAT_PAuth
1 0 00001 001010 11111 PACDA, PACDZAPACDZAFEAT_PAuth
1 0 00001 001011 11111 PACDB, PACDZBPACDZBFEAT_PAuth
1 0 00001 001100 11111 AUTIA, AUTIA1716, AUTIASP, AUTIAZ, AUTIZAAUTIZAFEAT_PAuth
1 0 00001 001101 11111 AUTIB, AUTIB1716, AUTIBSP, AUTIBZ, AUTIZBAUTIZBFEAT_PAuth
1 0 00001 001110 11111 AUTDA, AUTDZAAUTDZAFEAT_PAuth
1 0 00001 001111 11111 AUTDB, AUTDZBAUTDZBFEAT_PAuth
1 0 00001 010000 11111 XPACD, XPACI, XPACLRIXPACIFEAT_PAuth
1 0 00001 010001 11111 XPACD, XPACI, XPACLRIXPACDFEAT_PAuth
1 0 00001 01001x UNALLOCATED-
1 0 00001 0101xx UNALLOCATED-
1 0 00001 011xxx UNALLOCATED-

Logical (shifted register)

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfopc01010shiftNRmimm6RnRd
Decode fields Instruction Details
sf opc N imm6
0 1xxxxx UNALLOCATED
0 00 0 AND (shifted register)32-bit
0 00 1 BIC (shifted register)32-bit
0 01 0 ORR (shifted register)32-bit
0 01 1 ORN (shifted register)32-bit
0 10 0 EOR (shifted register)32-bit
0 10 1 EON (shifted register)32-bit
0 11 0 ANDS (shifted register)32-bit
0 11 1 BICS (shifted register)32-bit
1 00 0 AND (shifted register)64-bit
1 00 1 BIC (shifted register)64-bit
1 01 0 ORR (shifted register)64-bit
1 01 1 ORN (shifted register)64-bit
1 10 0 EOR (shifted register)64-bit
1 10 1 EON (shifted register)64-bit
1 11 0 ANDS (shifted register)64-bit
1 11 1 BICS (shifted register)64-bit

Add/subtract (shifted register)

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfopS01011shift0Rmimm6RnRd
Decode fields Instruction Details
sf op S shift imm6
11 UNALLOCATED
0 1xxxxx UNALLOCATED
0 0 0 ADD (shifted register)32-bit
0 0 1 ADDS (shifted register)32-bit
0 1 0 SUB (shifted register)32-bit
0 1 1 SUBS (shifted register)32-bit
1 0 0 ADD (shifted register)64-bit
1 0 1 ADDS (shifted register)64-bit
1 1 0 SUB (shifted register)64-bit
1 1 1 SUBS (shifted register)64-bit

Add/subtract (extended register)

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfopS01011opt1Rmoptionimm3RnRd
Decode fields Instruction Details
sf op S opt imm3
1x1 UNALLOCATED
11x UNALLOCATED
x1 UNALLOCATED
1x UNALLOCATED
0 0 0 00 ADD (extended register)32-bit
0 0 1 00 ADDS (extended register)32-bit
0 1 0 00 SUB (extended register)32-bit
0 1 1 00 SUBS (extended register)32-bit
1 0 0 00 ADD (extended register)64-bit
1 0 1 00 ADDS (extended register)64-bit
1 1 0 00 SUB (extended register)64-bit
1 1 1 00 SUBS (extended register)64-bit

Add/subtract (with carry)

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfopS11010000Rm000000RnRd
Decode fields Instruction Details
sf op S
0 0 0 ADC32-bit
0 0 1 ADCS32-bit
0 1 0 SBC32-bit
0 1 1 SBCS32-bit
1 0 0 ADC64-bit
1 0 1 ADCS64-bit
1 1 0 SBC64-bit
1 1 1 SBCS64-bit

Rotate right into flags

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfopS11010000imm600001Rno2mask
Decode fields Instruction Details Feature
sf op S o2
0 UNALLOCATED-
1 0 0 UNALLOCATED-
1 0 1 0 RMIFFEAT_FlagM
1 0 1 1 UNALLOCATED-
1 1 UNALLOCATED-

Evaluate into flags

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfopS11010000opcode2sz0010Rno3mask
Decode fields Instruction Details Feature
sf op S opcode2 sz o3 mask
0 0 0 UNALLOCATED-
0 0 1 != 000000 UNALLOCATED-
0 0 1 000000 0 != 1101 UNALLOCATED-
0 0 1 000000 1 UNALLOCATED-
0 0 1 000000 0 0 1101 SETF8, SETF16SETF8FEAT_FlagM
0 0 1 000000 1 0 1101 SETF8, SETF16SETF16FEAT_FlagM
0 1 UNALLOCATED-
1 UNALLOCATED-

Conditional compare (register)

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfopS11010010Rmcond0o2Rno3nzcv
Decode fields Instruction Details
sf op S o2 o3
1 UNALLOCATED
1 UNALLOCATED
0 UNALLOCATED
0 0 1 0 0 CCMN (register)32-bit
0 1 1 0 0 CCMP (register)32-bit
1 0 1 0 0 CCMN (register)64-bit
1 1 1 0 0 CCMP (register)64-bit

Conditional compare (immediate)

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfopS11010010imm5cond1o2Rno3nzcv
Decode fields Instruction Details
sf op S o2 o3
1 UNALLOCATED
1 UNALLOCATED
0 UNALLOCATED
0 0 1 0 0 CCMN (immediate)32-bit
0 1 1 0 0 CCMP (immediate)32-bit
1 0 1 0 0 CCMN (immediate)64-bit
1 1 1 0 0 CCMP (immediate)64-bit

Conditional select

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfopS11010100Rmcondop2RnRd
Decode fields Instruction Details
sf op S op2
1x UNALLOCATED
1 UNALLOCATED
0 0 0 00 CSEL32-bit
0 0 0 01 CSINC32-bit
0 1 0 00 CSINV32-bit
0 1 0 01 CSNEG32-bit
1 0 0 00 CSEL64-bit
1 0 0 01 CSINC64-bit
1 1 0 00 CSINV64-bit
1 1 0 01 CSNEG64-bit

Data-processing (3 source)

These instructions are under Data Processing -- Register.

313029282726252423222120191817161514131211109876543210
sfop5411011op31Rmo0RaRnRd
Decode fields Instruction Details
sf op54 op31 o0
00 010 1 UNALLOCATED
00 011 UNALLOCATED
00 100 UNALLOCATED
00 110 1 UNALLOCATED
00 111 UNALLOCATED
01 UNALLOCATED
1x UNALLOCATED
0 00 000 0 MADD32-bit
0 00 000 1 MSUB32-bit
0 00 001 0 UNALLOCATED
0 00 001 1 UNALLOCATED
0 00 010 0 UNALLOCATED
0 00 101 0 UNALLOCATED
0 00 101 1 UNALLOCATED
0 00 110 0 UNALLOCATED
1 00 000 0 MADD64-bit
1 00 000 1 MSUB64-bit
1 00 001 0 SMADDL
1 00 001 1 SMSUBL
1 00 010 0 SMULH
1 00 101 0 UMADDL
1 00 101 1 UMSUBL
1 00 110 0 UMULH

Data Processing -- Scalar Floating-Point and Advanced SIMD

These instructions are under the top-level.

313029282726252423222120191817161514131211109876543210
op0111op1op2op3
Decode fields Instruction details Architecture version
op0op1op2op3
0000 0x x101 00xxxxx10 UNALLOCATED-
0010 0x x101 00xxxxx10 UNALLOCATED-
0100 0x x101 00xxxxx10 Cryptographic AES-
0101 0x x0xx xxx0xxx00 Cryptographic three-register SHA-
0101 0x x0xx xxx0xxx10 UNALLOCATED-
0101 0x x101 00xxxxx10 Cryptographic two-register SHA-
0110 0x x101 00xxxxx10 UNALLOCATED-
0111 0x x0xx xxx0xxxx0 UNALLOCATED-
0111 0x x101 00xxxxx10 UNALLOCATED-
01x1 00 00xx xxx0xxxx1 Advanced SIMD scalar copy-
01x1 01 00xx xxx0xxxx1 UNALLOCATED-
01x1 0x 0111 00xxxxx10 UNALLOCATED-
01x1 0x 10xx xxx00xxx1 Advanced SIMD scalar three same FP16-
01x1 0x 10xx xxx01xxx1 UNALLOCATED-
01x1 0x 1111 00xxxxx10 Advanced SIMD scalar two-register miscellaneous FP16-
01x1 0x x0xx xxx1xxxx0 UNALLOCATED-
01x1 0x x0xx xxx1xxxx1 Advanced SIMD scalar three same extra-
01x1 0x x100 00xxxxx10 Advanced SIMD scalar two-register miscellaneous-
01x1 0x x110 00xxxxx10 Advanced SIMD scalar pairwise-
01x1 0x x1xx 1xxxxxx10 UNALLOCATED-
01x1 0x x1xx x1xxxxx10 UNALLOCATED-
01x1 0x x1xx xxxxxxx00 Advanced SIMD scalar three different-
01x1 0x x1xx xxxxxxxx1 Advanced SIMD scalar three same-
01x1 10 xxxxxxxx1 Advanced SIMD scalar shift by immediate-
01x1 11 xxxxxxxx1 UNALLOCATED-
01x1 1x xxxxxxxx0 Advanced SIMD scalar x indexed element-
0x00 0x x0xx xxx0xxx00 Advanced SIMD table lookup-
0x00 0x x0xx xxx0xxx10 Advanced SIMD permute-
0x10 0x x0xx xxx0xxxx0 Advanced SIMD extract-
0xx0 00 00xx xxx0xxxx1 Advanced SIMD copy-
0xx0 01 00xx xxx0xxxx1 UNALLOCATED-
0xx0 0x 0111 00xxxxx10 UNALLOCATED-
0xx0 0x 10xx xxx00xxx1 Advanced SIMD three same (FP16)-
0xx0 0x 10xx xxx01xxx1 UNALLOCATED-
0xx0 0x 1111 00xxxxx10 Advanced SIMD two-register miscellaneous (FP16)-
0xx0 0x x0xx xxx1xxxx0 UNALLOCATED-
0xx0 0x x0xx xxx1xxxx1 Advanced SIMD three-register extension-
0xx0 0x x100 00xxxxx10 Advanced SIMD two-register miscellaneous-
0xx0 0x x110 00xxxxx10 Advanced SIMD across lanes-
0xx0 0x x1xx 1xxxxxx10 UNALLOCATED-
0xx0 0x x1xx x1xxxxx10 UNALLOCATED-
0xx0 0x x1xx xxxxxxx00 Advanced SIMD three different-
0xx0 0x x1xx xxxxxxxx1 Advanced SIMD three same-
0xx0 10 0000 xxxxxxxx1 Advanced SIMD modified immediate-
0xx0 10 != 0000 xxxxxxxx1 Advanced SIMD shift by immediate-
0xx0 11 xxxxxxxx1 UNALLOCATED-
0xx0 1x xxxxxxxx0 Advanced SIMD vector x indexed element-
1100 00 10xx xxx10xxxx Cryptographic three-register, imm2-
1100 00 11xx xxx1x00xx Cryptographic three-register SHA 512-
1100 00 xxx0xxxxx Cryptographic four-register-
1100 01 00xx XARFEAT_SHA3
1100 01 1000 0001000xx Cryptographic two-register SHA 512-
1xx0 1x UNALLOCATED-
x0x1 0x x0xx Conversion between floating-point and fixed-point-
x0x1 0x x1xx xxx000000 Conversion between floating-point and integer-
x0x1 0x x1xx xxxx10000 Floating-point data-processing (1 source)-
x0x1 0x x1xx xxxxx1000 Floating-point compare-
x0x1 0x x1xx xxxxxx100 Floating-point immediate-
x0x1 0x x1xx xxxxxxx01 Floating-point conditional compare-
x0x1 0x x1xx xxxxxxx10 Floating-point data-processing (2 source)-
x0x1 0x x1xx xxxxxxx11 Floating-point conditional select-
x0x1 1x Floating-point data-processing (3 source)-

Cryptographic AES

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01001110size10100opcode10RnRd
Decode fields Instruction Details
size opcode
x1xxx UNALLOCATED
000xx UNALLOCATED
1xxxx UNALLOCATED
x1 UNALLOCATED
00 00100 AESE
00 00101 AESD
00 00110 AESMC
00 00111 AESIMC
1x UNALLOCATED

Cryptographic three-register SHA

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01011110size0Rm0opcode00RnRd
Decode fields Instruction Details
size opcode
111 UNALLOCATED
x1 UNALLOCATED
00 000 SHA1C
00 001 SHA1P
00 010 SHA1M
00 011 SHA1SU0
00 100 SHA256H
00 101 SHA256H2
00 110 SHA256SU1
1x UNALLOCATED

Cryptographic two-register SHA

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01011110size10100opcode10RnRd
Decode fields Instruction Details
size opcode
xx1xx UNALLOCATED
x1xxx UNALLOCATED
1xxxx UNALLOCATED
x1 UNALLOCATED
00 00000 SHA1H
00 00001 SHA1SU1
00 00010 SHA256SU0
00 00011 UNALLOCATED
1x UNALLOCATED

Advanced SIMD scalar copy

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01op11110000imm50imm41RnRd
Decode fields Instruction Details
op imm4
0 xxx1 UNALLOCATED
0 xx1x UNALLOCATED
0 x1xx UNALLOCATED
0 0000 DUP (element)
0 1xxx UNALLOCATED
1 UNALLOCATED

Advanced SIMD scalar three same FP16

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01U11110a10Rm00opcode1RnRd
Decode fields Instruction Details Feature
U a opcode
110 UNALLOCATED-
1 011 UNALLOCATED-
0 0 011 FMULXFEAT_FP16
0 0 100 FCMEQ (register)FEAT_FP16
0 0 101 UNALLOCATED-
0 0 111 FRECPSFEAT_FP16
0 1 100 UNALLOCATED-
0 1 101 UNALLOCATED-
0 1 111 FRSQRTSFEAT_FP16
1 0 011 UNALLOCATED-
1 0 100 FCMGE (register)FEAT_FP16
1 0 101 FACGEFEAT_FP16
1 0 111 UNALLOCATED-
1 1 010 FABDFEAT_FP16
1 1 100 FCMGT (register)FEAT_FP16
1 1 101 FACGTFEAT_FP16
1 1 111 UNALLOCATED-

Advanced SIMD scalar two-register miscellaneous FP16

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01U11110a111100opcode10RnRd
Decode fields Instruction Details Feature
U a opcode
00xxx UNALLOCATED-
010xx UNALLOCATED-
10xxx UNALLOCATED-
1100x UNALLOCATED-
11110 UNALLOCATED-
0 011xx UNALLOCATED-
0 11111 UNALLOCATED-
1 01111 UNALLOCATED-
1 11100 UNALLOCATED-
0 0 11010 FCVTNS (vector)FEAT_FP16
0 0 11011 FCVTMS (vector)FEAT_FP16
0 0 11100 FCVTAS (vector)FEAT_FP16
0 0 11101 SCVTF (vector, integer)FEAT_FP16
0 1 01100 FCMGT (zero)FEAT_FP16
0 1 01101 FCMEQ (zero)FEAT_FP16
0 1 01110 FCMLT (zero)FEAT_FP16
0 1 11010 FCVTPS (vector)FEAT_FP16
0 1 11011 FCVTZS (vector, integer)FEAT_FP16
0 1 11101 FRECPEFEAT_FP16
0 1 11111 FRECPXFEAT_FP16
1 0 11010 FCVTNU (vector)FEAT_FP16
1 0 11011 FCVTMU (vector)FEAT_FP16
1 0 11100 FCVTAU (vector)FEAT_FP16
1 0 11101 UCVTF (vector, integer)FEAT_FP16
1 1 01100 FCMGE (zero)FEAT_FP16
1 1 01101 FCMLE (zero)FEAT_FP16
1 1 01110 UNALLOCATED-
1 1 11010 FCVTPU (vector)FEAT_FP16
1 1 11011 FCVTZU (vector, integer)FEAT_FP16
1 1 11101 FRSQRTEFEAT_FP16
1 1 11111 UNALLOCATED-

Advanced SIMD scalar three same extra

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01U11110size0Rm1opcode1RnRd
Decode fields Instruction Details Feature
U opcode
001x UNALLOCATED-
01xx UNALLOCATED-
1xxx UNALLOCATED-
0 0000 UNALLOCATED-
0 0001 UNALLOCATED-
1 0000 SQRDMLAH (vector)FEAT_RDM
1 0001 SQRDMLSH (vector)FEAT_RDM

Advanced SIMD scalar two-register miscellaneous

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01U11110size10000opcode10RnRd
Decode fields Instruction Details
U size opcode
0000x UNALLOCATED
00010 UNALLOCATED
0010x UNALLOCATED
00110 UNALLOCATED
01111 UNALLOCATED
1000x UNALLOCATED
10011 UNALLOCATED
10101 UNALLOCATED
10111 UNALLOCATED
1100x UNALLOCATED
11110 UNALLOCATED
0x 011xx UNALLOCATED
0x 11111 UNALLOCATED
1x 10110 UNALLOCATED
1x 11100 UNALLOCATED
0 00011 SUQADD
0 00111 SQABS
0 01000 CMGT (zero)
0 01001 CMEQ (zero)
0 01010 CMLT (zero)
0 01011 ABS
0 10010 UNALLOCATED
0 10100 SQXTN, SQXTN2
0 0x 10110 UNALLOCATED
0 0x 11010 FCVTNS (vector)
0 0x 11011 FCVTMS (vector)
0 0x 11100 FCVTAS (vector)
0 0x 11101 SCVTF (vector, integer)
0 1x 01100 FCMGT (zero)
0 1x 01101 FCMEQ (zero)
0 1x 01110 FCMLT (zero)
0 1x 11010 FCVTPS (vector)
0 1x 11011 FCVTZS (vector, integer)
0 1x 11101 FRECPE
0 1x 11111 FRECPX
1 00011 USQADD
1 00111 SQNEG
1 01000 CMGE (zero)
1 01001 CMLE (zero)
1 01010 UNALLOCATED
1 01011 NEG (vector)
1 10010 SQXTUN, SQXTUN2
1 10100 UQXTN, UQXTN2
1 0x 10110 FCVTXN, FCVTXN2
1 0x 11010 FCVTNU (vector)
1 0x 11011 FCVTMU (vector)
1 0x 11100 FCVTAU (vector)
1 0x 11101 UCVTF (vector, integer)
1 1x 01100 FCMGE (zero)
1 1x 01101 FCMLE (zero)
1 1x 01110 UNALLOCATED
1 1x 11010 FCVTPU (vector)
1 1x 11011 FCVTZU (vector, integer)
1 1x 11101 FRSQRTE
1 1x 11111 UNALLOCATED

Advanced SIMD scalar pairwise

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01U11110size11000opcode10RnRd
Decode fields Instruction Details Feature
U size opcode
00xxx UNALLOCATED-
010xx UNALLOCATED-
01110 UNALLOCATED-
10xxx UNALLOCATED-
1100x UNALLOCATED-
11010 UNALLOCATED-
111xx UNALLOCATED-
1x 01101 UNALLOCATED-
0 11011 ADDP (scalar)-
0 0x 01100 FMAXNMP (scalar)half-precisionFEAT_FP16
0 0x 01101 FADDP (scalar)half-precisionFEAT_FP16
0 0x 01111 FMAXP (scalar)half-precisionFEAT_FP16
0 1x 01100 FMINNMP (scalar)half-precisionFEAT_FP16
0 1x 01111 FMINP (scalar)half-precisionFEAT_FP16
1 11011 UNALLOCATED-
1 0x 01100 FMAXNMP (scalar)single-precision and double-precision-
1 0x 01101 FADDP (scalar)single-precision and double-precision-
1 0x 01111 FMAXP (scalar)single-precision and double-precision-
1 1x 01100 FMINNMP (scalar)single-precision and double-precision-
1 1x 01111 FMINP (scalar)single-precision and double-precision-

Advanced SIMD scalar three different

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01U11110size1Rmopcode00RnRd
Decode fields Instruction Details
U opcode
00xx UNALLOCATED
01xx UNALLOCATED
1000 UNALLOCATED
1010 UNALLOCATED
1100 UNALLOCATED
111x UNALLOCATED
0 1001 SQDMLAL, SQDMLAL2 (vector)
0 1011 SQDMLSL, SQDMLSL2 (vector)
0 1101 SQDMULL, SQDMULL2 (vector)
1 1001 UNALLOCATED
1 1011 UNALLOCATED
1 1101 UNALLOCATED

Advanced SIMD scalar three same

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01U11110size1Rmopcode1RnRd
Decode fields Instruction Details
U size opcode
00000 UNALLOCATED
0001x UNALLOCATED
00100 UNALLOCATED
011xx UNALLOCATED
1001x UNALLOCATED
1x 11011 UNALLOCATED
0 00001 SQADD
0 00101 SQSUB
0 00110 CMGT (register)
0 00111 CMGE (register)
0 01000 SSHL
0 01001 SQSHL (register)
0 01010 SRSHL
0 01011 SQRSHL
0 10000 ADD (vector)
0 10001 CMTST
0 10100 UNALLOCATED
0 10101 UNALLOCATED
0 10110 SQDMULH (vector)
0 10111 UNALLOCATED
0 0x 11000 UNALLOCATED
0 0x 11001 UNALLOCATED
0 0x 11010 UNALLOCATED
0 0x 11011 FMULX
0 0x 11100 FCMEQ (register)
0 0x 11101 UNALLOCATED
0 0x 11110 UNALLOCATED
0 0x 11111 FRECPS
0 1x 11000 UNALLOCATED
0 1x 11001 UNALLOCATED
0 1x 11010 UNALLOCATED
0 1x 11100 UNALLOCATED
0 1x 11101 UNALLOCATED
0 1x 11110 UNALLOCATED
0 1x 11111 FRSQRTS
1 00001 UQADD
1 00101 UQSUB
1 00110 CMHI (register)
1 00111 CMHS (register)
1 01000 USHL
1 01001 UQSHL (register)
1 01010 URSHL
1 01011 UQRSHL
1 10000 SUB (vector)
1 10001 CMEQ (register)
1 10100 UNALLOCATED
1 10101 UNALLOCATED
1 10110 SQRDMULH (vector)
1 10111 UNALLOCATED
1 0x 11000 UNALLOCATED
1 0x 11001 UNALLOCATED
1 0x 11010 UNALLOCATED
1 0x 11011 UNALLOCATED
1 0x 11100 FCMGE (register)
1 0x 11101 FACGE
1 0x 11110 UNALLOCATED
1 0x 11111 UNALLOCATED
1 1x 11000 UNALLOCATED
1 1x 11001 UNALLOCATED
1 1x 11010 FABD
1 1x 11100 FCMGT (register)
1 1x 11101 FACGT
1 1x 11110 UNALLOCATED
1 1x 11111 UNALLOCATED

Advanced SIMD scalar shift by immediate

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01U111110immhimmbopcode1RnRd
Decode fields Instruction Details
U immh opcode
!= 0000 00001 UNALLOCATED
!= 0000 00011 UNALLOCATED
!= 0000 00101 UNALLOCATED
!= 0000 00111 UNALLOCATED
!= 0000 01001 UNALLOCATED
!= 0000 01011 UNALLOCATED
!= 0000 01101 UNALLOCATED
!= 0000 01111 UNALLOCATED
!= 0000 101xx UNALLOCATED
!= 0000 110xx UNALLOCATED
!= 0000 11101 UNALLOCATED
!= 0000 11110 UNALLOCATED
0000 UNALLOCATED
0 != 0000 00000 SSHR
0 != 0000 00010 SSRA
0 != 0000 00100 SRSHR
0 != 0000 00110 SRSRA
0 != 0000 01000 UNALLOCATED
0 != 0000 01010 SHL
0 != 0000 01100 UNALLOCATED
0 != 0000 01110 SQSHL (immediate)
0 != 0000 10000 UNALLOCATED
0 != 0000 10001 UNALLOCATED
0 != 0000 10010 SQSHRN, SQSHRN2
0 != 0000 10011 SQRSHRN, SQRSHRN2
0 != 0000 11100 SCVTF (vector, fixed-point)
0 != 0000 11111 FCVTZS (vector, fixed-point)
1 != 0000 00000 USHR
1 != 0000 00010 USRA
1 != 0000 00100 URSHR
1 != 0000 00110 URSRA
1 != 0000 01000 SRI
1 != 0000 01010 SLI
1 != 0000 01100 SQSHLU
1 != 0000 01110 UQSHL (immediate)
1 != 0000 10000 SQSHRUN, SQSHRUN2
1 != 0000 10001 SQRSHRUN, SQRSHRUN2
1 != 0000 10010 UQSHRN, UQSHRN2
1 != 0000 10011 UQRSHRN, UQRSHRN2
1 != 0000 11100 UCVTF (vector, fixed-point)
1 != 0000 11111 FCVTZU (vector, fixed-point)

Advanced SIMD scalar x indexed element

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
01U11111sizeLMRmopcodeH0RnRd
Decode fields Instruction Details Feature
U size opcode
0000 UNALLOCATED-
0010 UNALLOCATED-
0100 UNALLOCATED-
0110 UNALLOCATED-
1000 UNALLOCATED-
1010 UNALLOCATED-
1110 UNALLOCATED-
01 0001 UNALLOCATED-
01 0101 UNALLOCATED-
01 1001 UNALLOCATED-
0 0011 SQDMLAL, SQDMLAL2 (by element)-
0 0111 SQDMLSL, SQDMLSL2 (by element)-
0 1011 SQDMULL, SQDMULL2 (by element)-
0 1100 SQDMULH (by element)-
0 1101 SQRDMULH (by element)-
0 1111 UNALLOCATED-
0 00 0001 FMLA (by element)half-precisionFEAT_FP16
0 00 0101 FMLS (by element)half-precisionFEAT_FP16
0 00 1001 FMUL (by element)half-precisionFEAT_FP16
0 1x 0001 FMLA (by element)single-precision and double-precision-
0 1x 0101 FMLS (by element)single-precision and double-precision-
0 1x 1001 FMUL (by element)single-precision and double-precision-
1 0011 UNALLOCATED-
1 0111 UNALLOCATED-
1 1011 UNALLOCATED-
1 1100 UNALLOCATED-
1 1101 SQRDMLAH (by element)FEAT_RDM
1 1111 SQRDMLSH (by element)FEAT_RDM
1 00 0001 UNALLOCATED-
1 00 0101 UNALLOCATED-
1 00 1001 FMULX (by element)half-precisionFEAT_FP16
1 1x 0001 UNALLOCATED-
1 1x 0101 UNALLOCATED-
1 1x 1001 FMULX (by element)single-precision and double-precision-

Advanced SIMD table lookup

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0Q001110op20Rm0lenop00RnRd
Decode fields Instruction Details
op2 len op
x1 UNALLOCATED
00 00 0 TBLsingle register table
00 00 1 TBXsingle register table
00 01 0 TBLtwo register table
00 01 1 TBXtwo register table
00 10 0 TBLthree register table
00 10 1 TBXthree register table
00 11 0 TBLfour register table
00 11 1 TBXfour register table
1x UNALLOCATED

Advanced SIMD permute

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0Q001110size0Rm0opcode10RnRd
Decode fields Instruction Details
opcode
000 UNALLOCATED
001 UZP1
010 TRN1
011 ZIP1
100 UNALLOCATED
101 UZP2
110 TRN2
111 ZIP2

Advanced SIMD extract

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0Q101110op20Rm0imm40RnRd
Decode fields Instruction Details
op2
x1 UNALLOCATED
00 EXT
1x UNALLOCATED

Advanced SIMD copy

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0Qop01110000imm50imm41RnRd
Decode fields Instruction Details
Q op imm5 imm4
x0000 UNALLOCATED
0 0000 DUP (element)
0 0001 DUP (general)
0 0010 UNALLOCATED
0 0100 UNALLOCATED
0 0110 UNALLOCATED
0 1xxx UNALLOCATED
0 0 0011 UNALLOCATED
0 0 0101 SMOV
0 0 0111 UMOV
0 1 UNALLOCATED
1 0 0011 INS (general)
1 0 0101 SMOV
1 0 x1000 0111 UMOV
1 1 INS (element)

Advanced SIMD three same (FP16)

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0QU01110a10Rm00opcode1RnRd
Decode fields Instruction Details Feature
U a opcode
0 0 000 FMAXNM (vector)FEAT_FP16
0 0 001 FMLA (vector)FEAT_FP16
0 0 010 FADD (vector)FEAT_FP16
0 0 011 FMULXFEAT_FP16
0 0 100 FCMEQ (register)FEAT_FP16
0 0 101 UNALLOCATED-
0 0 110 FMAX (vector)FEAT_FP16
0 0 111 FRECPSFEAT_FP16
0 1 000 FMINNM (vector)FEAT_FP16
0 1 001 FMLS (vector)FEAT_FP16
0 1 010 FSUB (vector)FEAT_FP16
0 1 011 UNALLOCATED-
0 1 100 UNALLOCATED-
0 1 101 UNALLOCATED-
0 1 110 FMIN (vector)FEAT_FP16
0 1 111 FRSQRTSFEAT_FP16
1 0 000 FMAXNMP (vector)FEAT_FP16
1 0 001 UNALLOCATED-
1 0 010 FADDP (vector)FEAT_FP16
1 0 011 FMUL (vector)FEAT_FP16
1 0 100 FCMGE (register)FEAT_FP16
1 0 101 FACGEFEAT_FP16
1 0 110 FMAXP (vector)FEAT_FP16
1 0 111 FDIV (vector)FEAT_FP16
1 1 000 FMINNMP (vector)FEAT_FP16
1 1 001 UNALLOCATED-
1 1 010 FABDFEAT_FP16
1 1 011 UNALLOCATED-
1 1 100 FCMGT (register)FEAT_FP16
1 1 101 FACGTFEAT_FP16
1 1 110 FMINP (vector)FEAT_FP16
1 1 111 UNALLOCATED-

Advanced SIMD two-register miscellaneous (FP16)

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0QU01110a111100opcode10RnRd
Decode fields Instruction Details Feature
U a opcode
00xxx UNALLOCATED-
010xx UNALLOCATED-
10xxx UNALLOCATED-
11110 UNALLOCATED-
0 011xx UNALLOCATED-
0 11111 UNALLOCATED-
1 11100 UNALLOCATED-
0 0 11000 FRINTN (vector)FEAT_FP16
0 0 11001 FRINTM (vector)FEAT_FP16
0 0 11010 FCVTNS (vector)FEAT_FP16
0 0 11011 FCVTMS (vector)FEAT_FP16
0 0 11100 FCVTAS (vector)FEAT_FP16
0 0 11101 SCVTF (vector, integer)FEAT_FP16
0 1 01100 FCMGT (zero)FEAT_FP16
0 1 01101 FCMEQ (zero)FEAT_FP16
0 1 01110 FCMLT (zero)FEAT_FP16
0 1 01111 FABS (vector)FEAT_FP16
0 1 11000 FRINTP (vector)FEAT_FP16
0 1 11001 FRINTZ (vector)FEAT_FP16
0 1 11010 FCVTPS (vector)FEAT_FP16
0 1 11011 FCVTZS (vector, integer)FEAT_FP16
0 1 11101 FRECPEFEAT_FP16
0 1 11111 UNALLOCATED-
1 0 11000 FRINTA (vector)FEAT_FP16
1 0 11001 FRINTX (vector)FEAT_FP16
1 0 11010 FCVTNU (vector)FEAT_FP16
1 0 11011 FCVTMU (vector)FEAT_FP16
1 0 11100 FCVTAU (vector)FEAT_FP16
1 0 11101 UCVTF (vector, integer)FEAT_FP16
1 1 01100 FCMGE (zero)FEAT_FP16
1 1 01101 FCMLE (zero)FEAT_FP16
1 1 01110 UNALLOCATED-
1 1 01111 FNEG (vector)FEAT_FP16
1 1 11000 UNALLOCATED-
1 1 11001 FRINTI (vector)FEAT_FP16
1 1 11010 FCVTPU (vector)FEAT_FP16
1 1 11011 FCVTZU (vector, integer)FEAT_FP16
1 1 11101 FRSQRTEFEAT_FP16
1 1 11111 FSQRT (vector)FEAT_FP16

Advanced SIMD three-register extension

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0QU01110size0Rm1opcode1RnRd
Decode fields Instruction Details Feature
Q U size opcode
0x 0011 UNALLOCATED-
11 0011 UNALLOCATED-
0 0000 UNALLOCATED-
0 0001 UNALLOCATED-
0 0010 SDOT (vector)FEAT_DotProd
0 1xxx UNALLOCATED-
0 10 0011 USDOT (vector)FEAT_I8MM
1 0000 SQRDMLAH (vector)FEAT_RDM
1 0001 SQRDMLSH (vector)FEAT_RDM
1 0010 UDOT (vector)FEAT_DotProd
1 10xx FCMLAFEAT_FCMA
1 11x0 FCADDFEAT_FCMA
1 00 1101 UNALLOCATED-
1 00 1111 UNALLOCATED-
1 01 1111 BFDOT (vector)FEAT_BF16
1 1x 1101 UNALLOCATED-
1 10 0011 UNALLOCATED-
1 10 1111 UNALLOCATED-
1 11 1111 BFMLALB, BFMLALT (vector)FEAT_BF16
0 01xx UNALLOCATED-
0 1 01 1101 UNALLOCATED-
1 0x 01xx UNALLOCATED-
1 1x 011x UNALLOCATED-
1 0 10 0100 SMMLA (vector)FEAT_I8MM
1 0 10 0101 USMMLA (vector)FEAT_I8MM
1 1 01 1101 BFMMLAFEAT_BF16
1 1 10 0100 UMMLA (vector)FEAT_I8MM
1 1 10 0101 UNALLOCATED-

Advanced SIMD two-register miscellaneous

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0QU01110size10000opcode10RnRd
Decode fields Instruction Details Feature
U size opcode
1000x UNALLOCATED-
10101 UNALLOCATED-
0x 011xx UNALLOCATED-
1x 10111 UNALLOCATED-
1x 11110 UNALLOCATED-
11 10110 UNALLOCATED-
0 00000 REV64-
0 00001 REV16 (vector)-
0 00010 SADDLP-
0 00011 SUQADD-
0 00100 CLS (vector)-
0 00101 CNT-
0 00110 SADALP-
0 00111 SQABS-
0 01000 CMGT (zero)-
0 01001 CMEQ (zero)-
0 01010 CMLT (zero)-
0 01011 ABS-
0 10010 XTN, XTN2-
0 10011 UNALLOCATED-
0 10100 SQXTN, SQXTN2-
0 0x 10110 FCVTN, FCVTN2-
0 0x 10111 FCVTL, FCVTL2-
0 0x 11000 FRINTN (vector)-
0 0x 11001 FRINTM (vector)-
0 0x 11010 FCVTNS (vector)-
0 0x 11011 FCVTMS (vector)-
0 0x 11100 FCVTAS (vector)-
0 0x 11101 SCVTF (vector, integer)-
0 0x 11110 FRINT32Z (vector)FEAT_FRINTTS
0 0x 11111 FRINT64Z (vector)FEAT_FRINTTS
0 1x 01100 FCMGT (zero)-
0 1x 01101 FCMEQ (zero)-
0 1x 01110 FCMLT (zero)-
0 1x 01111 FABS (vector)-
0 1x 11000 FRINTP (vector)-
0 1x 11001 FRINTZ (vector)-
0 1x 11010 FCVTPS (vector)-
0 1x 11011 FCVTZS (vector, integer)-
0 1x 11100 URECPE-
0 1x 11101 FRECPE-
0 1x 11111 UNALLOCATED-
0 10 10110 BFCVTN, BFCVTN2FEAT_BF16
1 00000 REV32 (vector)-
1 00001 UNALLOCATED-
1 00010 UADDLP-
1 00011 USQADD-
1 00100 CLZ (vector)-
1 00110 UADALP-
1 00111 SQNEG-
1 01000 CMGE (zero)-
1 01001 CMLE (zero)-
1 01010 UNALLOCATED-
1 01011 NEG (vector)-
1 10010 SQXTUN, SQXTUN2-
1 10011 SHLL, SHLL2-
1 10100 UQXTN, UQXTN2-
1 0x 10110 FCVTXN, FCVTXN2-
1 0x 10111 UNALLOCATED-
1 0x 11000 FRINTA (vector)-
1 0x 11001 FRINTX (vector)-
1 0x 11010 FCVTNU (vector)-
1 0x 11011 FCVTMU (vector)-
1 0x 11100 FCVTAU (vector)-
1 0x 11101 UCVTF (vector, integer)-
1 0x 11110 FRINT32X (vector)FEAT_FRINTTS
1 0x 11111 FRINT64X (vector)FEAT_FRINTTS
1 00 00101 NOT-
1 01 00101 RBIT (vector)-
1 1x 00101 UNALLOCATED-
1 1x 01100 FCMGE (zero)-
1 1x 01101 FCMLE (zero)-
1 1x 01110 UNALLOCATED-
1 1x 01111 FNEG (vector)-
1 1x 11000 UNALLOCATED-
1 1x 11001 FRINTI (vector)-
1 1x 11010 FCVTPU (vector)-
1 1x 11011 FCVTZU (vector, integer)-
1 1x 11100 URSQRTE-
1 1x 11101 FRSQRTE-
1 1x 11111 FSQRT (vector)-
1 10 10110 UNALLOCATED-

Advanced SIMD across lanes

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0QU01110size11000opcode10RnRd
Decode fields Instruction Details Feature
U size opcode
0000x UNALLOCATED-
00010 UNALLOCATED-
001xx UNALLOCATED-
0100x UNALLOCATED-
01011 UNALLOCATED-
01101 UNALLOCATED-
01110 UNALLOCATED-
10xxx UNALLOCATED-
1100x UNALLOCATED-
111xx UNALLOCATED-
0 00011 SADDLV-
0 01010 SMAXV-
0 11010 SMINV-
0 11011 ADDV-
0 00 01100 FMAXNMVhalf-precisionFEAT_FP16
0 00 01111 FMAXVhalf-precisionFEAT_FP16
0 01 01100 UNALLOCATED-
0 01 01111 UNALLOCATED-
0 10 01100 FMINNMVhalf-precisionFEAT_FP16
0 10 01111 FMINVhalf-precisionFEAT_FP16
0 11 01100 UNALLOCATED-
0 11 01111 UNALLOCATED-
1 00011 UADDLV-
1 01010 UMAXV-
1 11010 UMINV-
1 11011 UNALLOCATED-
1 0x 01100 FMAXNMVsingle-precision and double-precision-
1 0x 01111 FMAXVsingle-precision and double-precision-
1 1x 01100 FMINNMVsingle-precision and double-precision-
1 1x 01111 FMINVsingle-precision and double-precision-

Advanced SIMD three different

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0QU01110size1Rmopcode00RnRd
Decode fields Instruction Details
U opcode
1111 UNALLOCATED
0 0000 SADDL, SADDL2
0 0001 SADDW, SADDW2
0 0010 SSUBL, SSUBL2
0 0011 SSUBW, SSUBW2
0 0100 ADDHN, ADDHN2
0 0101 SABAL, SABAL2
0 0110 SUBHN, SUBHN2
0 0111 SABDL, SABDL2
0 1000 SMLAL, SMLAL2 (vector)
0 1001 SQDMLAL, SQDMLAL2 (vector)
0 1010 SMLSL, SMLSL2 (vector)
0 1011 SQDMLSL, SQDMLSL2 (vector)
0 1100 SMULL, SMULL2 (vector)
0 1101 SQDMULL, SQDMULL2 (vector)
0 1110 PMULL, PMULL2
1 0000 UADDL, UADDL2
1 0001 UADDW, UADDW2
1 0010 USUBL, USUBL2
1 0011 USUBW, USUBW2
1 0100 RADDHN, RADDHN2
1 0101 UABAL, UABAL2
1 0110 RSUBHN, RSUBHN2
1 0111 UABDL, UABDL2
1 1000 UMLAL, UMLAL2 (vector)
1 1001 UNALLOCATED
1 1010 UMLSL, UMLSL2 (vector)
1 1011 UNALLOCATED
1 1100 UMULL, UMULL2 (vector)
1 1101 UNALLOCATED
1 1110 UNALLOCATED

Advanced SIMD three same

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0QU01110size1Rmopcode1RnRd
Decode fields Instruction Details Feature
U size opcode
0 00000 SHADD-
0 00001 SQADD-
0 00010 SRHADD-
0 00100 SHSUB-
0 00101 SQSUB-
0 00110 CMGT (register)-
0 00111 CMGE (register)-
0 01000 SSHL-
0 01001 SQSHL (register)-
0 01010 SRSHL-
0 01011 SQRSHL-
0 01100 SMAX-
0 01101 SMIN-
0 01110 SABD-
0 01111 SABA-
0 10000 ADD (vector)-
0 10001 CMTST-
0 10010 MLA (vector)-
0 10011 MUL (vector)-
0 10100 SMAXP-
0 10101 SMINP-
0 10110 SQDMULH (vector)-
0 10111 ADDP (vector)-
0 0x 11000 FMAXNM (vector)-
0 0x 11001 FMLA (vector)-
0 0x 11010 FADD (vector)-
0 0x 11011 FMULX-
0 0x 11100 FCMEQ (register)-
0 0x 11110 FMAX (vector)-
0 0x 11111 FRECPS-
0 00 00011 AND (vector)-
0 00 11101 FMLAL, FMLAL2 (vector)FMLALFEAT_FHM
0 01 00011 BIC (vector, register)-
0 01 11101 UNALLOCATED-
0 1x 11000 FMINNM (vector)-
0 1x 11001 FMLS (vector)-
0 1x 11010 FSUB (vector)-
0 1x 11011 UNALLOCATED-
0 1x 11100 UNALLOCATED-
0 1x 11110 FMIN (vector)-
0 1x 11111 FRSQRTS-
0 10 00011 ORR (vector, register)-
0 10 11101 FMLSL, FMLSL2 (vector)FMLSLFEAT_FHM
0 11 00011 ORN (vector)-
0 11 11101 UNALLOCATED-
1 00000 UHADD-
1 00001 UQADD-
1 00010 URHADD-
1 00100 UHSUB-
1 00101 UQSUB-
1 00110 CMHI (register)-
1 00111 CMHS (register)-
1 01000 USHL-
1 01001 UQSHL (register)-
1 01010 URSHL-
1 01011 UQRSHL-
1 01100 UMAX-
1 01101 UMIN-
1 01110 UABD-
1 01111 UABA-
1 10000 SUB (vector)-
1 10001 CMEQ (register)-
1 10010 MLS (vector)-
1 10011 PMUL-
1 10100 UMAXP-
1 10101 UMINP-
1 10110 SQRDMULH (vector)-
1 10111 UNALLOCATED-
1 0x 11000 FMAXNMP (vector)-
1 0x 11010 FADDP (vector)-
1 0x 11011 FMUL (vector)-
1 0x 11100 FCMGE (register)-
1 0x 11101 FACGE-
1 0x 11110 FMAXP (vector)-
1 0x 11111 FDIV (vector)-
1 00 00011 EOR (vector)-
1 00 11001 FMLAL, FMLAL2 (vector)FMLAL2FEAT_FHM
1 01 00011 BSL-
1 01 11001 UNALLOCATED-
1 1x 11000 FMINNMP (vector)-
1 1x 11010 FABD-
1 1x 11011 UNALLOCATED-
1 1x 11100 FCMGT (register)-
1 1x 11101 FACGT-
1 1x 11110 FMINP (vector)-
1 1x 11111 UNALLOCATED-
1 10 00011 BIT-
1 10 11001 FMLSL, FMLSL2 (vector)FMLSL2FEAT_FHM
1 11 00011 BIF-
1 11 11001 UNALLOCATED-

Advanced SIMD modified immediate

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0Qop0111100000abccmodeo21defghRd
Decode fields Instruction Details Feature
Q op cmode o2
0 0xxx 1 UNALLOCATED-
0 0xx0 0 MOVI32-bit shifted immediate-
0 0xx1 0 ORR (vector, immediate)32-bit-
0 10xx 1 UNALLOCATED-
0 10x0 0 MOVI16-bit shifted immediate-
0 10x1 0 ORR (vector, immediate)16-bit-
0 110x 0 MOVI32-bit shifting ones-
0 110x 1 UNALLOCATED-
0 1110 0 MOVI8-bit-
0 1110 1 UNALLOCATED-
0 1111 0 FMOV (vector, immediate)single-precision-
0 1111 1 FMOV (vector, immediate)half-precisionFEAT_FP16
1 1 UNALLOCATED-
1 0xx0 0 MVNI32-bit shifted immediate-
1 0xx1 0 BIC (vector, immediate)32-bit-
1 10x0 0 MVNI16-bit shifted immediate-
1 10x1 0 BIC (vector, immediate)16-bit-
1 110x 0 MVNI32-bit shifting ones-
0 1 1110 0 MOVI64-bit scalar-
0 1 1111 0 UNALLOCATED-
1 1 1110 0 MOVI64-bit vector-
1 1 1111 0 FMOV (vector, immediate)double-precision-

Advanced SIMD shift by immediate

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0QU011110!= 0000immbopcode1RnRd
immh

The following constraints also apply to this encoding: immh != 0000 && immh != 0000

Decode fields Instruction Details
U opcode
00001 UNALLOCATED
00011 UNALLOCATED
00101 UNALLOCATED
00111 UNALLOCATED
01001 UNALLOCATED
01011 UNALLOCATED
01101 UNALLOCATED
01111 UNALLOCATED
10101 UNALLOCATED
1011x UNALLOCATED
110xx UNALLOCATED
11101 UNALLOCATED
11110 UNALLOCATED
0 00000 SSHR
0 00010 SSRA
0 00100 SRSHR
0 00110 SRSRA
0 01000 UNALLOCATED
0 01010 SHL
0 01100 UNALLOCATED
0 01110 SQSHL (immediate)
0 10000 SHRN, SHRN2
0 10001 RSHRN, RSHRN2
0 10010 SQSHRN, SQSHRN2
0 10011 SQRSHRN, SQRSHRN2
0 10100 SSHLL, SSHLL2
0 11100 SCVTF (vector, fixed-point)
0 11111 FCVTZS (vector, fixed-point)
1 00000 USHR
1 00010 USRA
1 00100 URSHR
1 00110 URSRA
1 01000 SRI
1 01010 SLI
1 01100 SQSHLU
1 01110 UQSHL (immediate)
1 10000 SQSHRUN, SQSHRUN2
1 10001 SQRSHRUN, SQRSHRUN2
1 10010 UQSHRN, UQSHRN2
1 10011 UQRSHRN, UQRSHRN2
1 10100 USHLL, USHLL2
1 11100 UCVTF (vector, fixed-point)
1 11111 FCVTZU (vector, fixed-point)

Advanced SIMD vector x indexed element

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
0QU01111sizeLMRmopcodeH0RnRd
Decode fields Instruction Details Feature
U size opcode
01 1001 UNALLOCATED-
0 0010 SMLAL, SMLAL2 (by element)-
0 0011 SQDMLAL, SQDMLAL2 (by element)-
0 0110 SMLSL, SMLSL2 (by element)-
0 0111 SQDMLSL, SQDMLSL2 (by element)-
0 1000 MUL (by element)-
0 1010 SMULL, SMULL2 (by element)-
0 1011 SQDMULL, SQDMULL2 (by element)-
0 1100 SQDMULH (by element)-
0 1101 SQRDMULH (by element)-
0 1110 SDOT (by element)FEAT_DotProd
0 0x 0000 UNALLOCATED-
0 0x 0100 UNALLOCATED-
0 00 0001 FMLA (by element)half-precisionFEAT_FP16
0 00 0101 FMLS (by element)half-precisionFEAT_FP16
0 00 1001 FMUL (by element)half-precisionFEAT_FP16
0 00 1111 SUDOT (by element)FEAT_I8MM
0 01 0001 UNALLOCATED-
0 01 0101 UNALLOCATED-
0 01 1111 BFDOT (by element)FEAT_BF16
0 1x 0001 FMLA (by element)single-precision and double-precision-
0 1x 0101 FMLS (by element)single-precision and double-precision-
0 1x 1001 FMUL (by element)single-precision and double-precision-
0 10 0000 FMLAL, FMLAL2 (by element)FMLALFEAT_FHM
0 10 0100 FMLSL, FMLSL2 (by element)FMLSLFEAT_FHM
0 10 1111 USDOT (by element)FEAT_I8MM
0 11 0000 UNALLOCATED-
0 11 0100 UNALLOCATED-
0 11 1111 BFMLALB, BFMLALT (by element)FEAT_BF16
1 0000 MLA (by element)-
1 0010 UMLAL, UMLAL2 (by element)-
1 0100 MLS (by element)-
1 0110 UMLSL, UMLSL2 (by element)-
1 1010 UMULL, UMULL2 (by element)-
1 1011 UNALLOCATED-
1 1101 SQRDMLAH (by element)FEAT_RDM
1 1110 UDOT (by element)FEAT_DotProd
1 1111 SQRDMLSH (by element)FEAT_RDM
1 0x 1000 UNALLOCATED-
1 0x 1100 UNALLOCATED-
1 00 0001 UNALLOCATED-
1 00 0011 UNALLOCATED-
1 00 0101 UNALLOCATED-
1 00 0111 UNALLOCATED-
1 00 1001 FMULX (by element)half-precisionFEAT_FP16
1 01 0xx1 FCMLA (by element)FEAT_FCMA
1 1x 1001 FMULX (by element)single-precision and double-precision-
1 10 0xx1 FCMLA (by element)FEAT_FCMA
1 10 1000 FMLAL, FMLAL2 (by element)FMLAL2FEAT_FHM
1 10 1100 FMLSL, FMLSL2 (by element)FMLSL2FEAT_FHM
1 11 0001 UNALLOCATED-
1 11 0011 UNALLOCATED-
1 11 0101 UNALLOCATED-
1 11 0111 UNALLOCATED-
1 11 1000 UNALLOCATED-
1 11 1100 UNALLOCATED-

Cryptographic three-register, imm2

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
11001110010Rm10imm2opcodeRnRd
Decode fields Instruction Details Feature
opcode
00 SM3TT1AFEAT_SM3
01 SM3TT1BFEAT_SM3
10 SM3TT2AFEAT_SM3
11 SM3TT2BFEAT_SM3

Cryptographic three-register SHA 512

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
11001110011Rm1O00opcodeRnRd
Decode fields Instruction Details Feature
O opcode
0 00 SHA512HFEAT_SHA512
0 01 SHA512H2FEAT_SHA512
0 10 SHA512SU1FEAT_SHA512
0 11 RAX1FEAT_SHA3
1 00 SM3PARTW1FEAT_SM3
1 01 SM3PARTW2FEAT_SM3
1 10 SM4EKEYFEAT_SM4
1 11 UNALLOCATED-

Cryptographic four-register

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
110011100Op0Rm0RaRnRd
Decode fields Instruction Details Feature
Op0
00 EOR3FEAT_SHA3
01 BCAXFEAT_SHA3
10 SM3SS1FEAT_SM3
11 UNALLOCATED-

Cryptographic two-register SHA 512

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
11001110110000001000opcodeRnRd
Decode fields Instruction Details Feature
opcode
00 SHA512SU0FEAT_SHA512
01 SM4EFEAT_SM4
1x UNALLOCATED-

Conversion between floating-point and fixed-point

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
sf0S11110ptype0rmodeopcodescaleRnRd
Decode fields Instruction Details Feature
sf S ptype rmode opcode scale
1xx UNALLOCATED-
x0 00x UNALLOCATED-
x1 01x UNALLOCATED-
0x 00x UNALLOCATED-
1x 01x UNALLOCATED-
10 UNALLOCATED-
1 UNALLOCATED-
0 0xxxxx UNALLOCATED-
0 0 00 00 010 SCVTF (scalar, fixed-point)32-bit to single-precision-
0 0 00 00 011 UCVTF (scalar, fixed-point)32-bit to single-precision-
0 0 00 11 000 FCVTZS (scalar, fixed-point)single-precision to 32-bit-
0 0 00 11 001 FCVTZU (scalar, fixed-point)single-precision to 32-bit-
0 0 01 00 010 SCVTF (scalar, fixed-point)32-bit to double-precision-
0 0 01 00 011 UCVTF (scalar, fixed-point)32-bit to double-precision-
0 0 01 11 000 FCVTZS (scalar, fixed-point)double-precision to 32-bit-
0 0 01 11 001 FCVTZU (scalar, fixed-point)double-precision to 32-bit-
0 0 11 00 010 SCVTF (scalar, fixed-point)32-bit to half-precisionFEAT_FP16
0 0 11 00 011 UCVTF (scalar, fixed-point)32-bit to half-precisionFEAT_FP16
0 0 11 11 000 FCVTZS (scalar, fixed-point)half-precision to 32-bitFEAT_FP16
0 0 11 11 001 FCVTZU (scalar, fixed-point)half-precision to 32-bitFEAT_FP16
1 0 00 00 010 SCVTF (scalar, fixed-point)64-bit to single-precision-
1 0 00 00 011 UCVTF (scalar, fixed-point)64-bit to single-precision-
1 0 00 11 000 FCVTZS (scalar, fixed-point)single-precision to 64-bit-
1 0 00 11 001 FCVTZU (scalar, fixed-point)single-precision to 64-bit-
1 0 01 00 010 SCVTF (scalar, fixed-point)64-bit to double-precision-
1 0 01 00 011 UCVTF (scalar, fixed-point)64-bit to double-precision-
1 0 01 11 000 FCVTZS (scalar, fixed-point)double-precision to 64-bit-
1 0 01 11 001 FCVTZU (scalar, fixed-point)double-precision to 64-bit-
1 0 11 00 010 SCVTF (scalar, fixed-point)64-bit to half-precisionFEAT_FP16
1 0 11 00 011 UCVTF (scalar, fixed-point)64-bit to half-precisionFEAT_FP16
1 0 11 11 000 FCVTZS (scalar, fixed-point)half-precision to 64-bitFEAT_FP16
1 0 11 11 001 FCVTZU (scalar, fixed-point)half-precision to 64-bitFEAT_FP16

Conversion between floating-point and integer

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
sf0S11110ptype1rmodeopcode000000RnRd
Decode fields Instruction Details Feature
sf S ptype rmode opcode
x1 01x UNALLOCATED-
x1 10x UNALLOCATED-
1x 01x UNALLOCATED-
1x 10x UNALLOCATED-
0 10 0xx UNALLOCATED-
0 10 10x UNALLOCATED-
1 UNALLOCATED-
0 0 00 x1 11x UNALLOCATED-
0 0 00 00 000 FCVTNS (scalar)single-precision to 32-bit-
0 0 00 00 001 FCVTNU (scalar)single-precision to 32-bit-
0 0 00 00 010 SCVTF (scalar, integer)32-bit to single-precision-
0 0 00 00 011 UCVTF (scalar, integer)32-bit to single-precision-
0 0 00 00 100 FCVTAS (scalar)single-precision to 32-bit-
0 0 00 00 101 FCVTAU (scalar)single-precision to 32-bit-
0 0 00 00 110 FMOV (general)single-precision to 32-bit-
0 0 00 00 111 FMOV (general)32-bit to single-precision-
0 0 00 01 000 FCVTPS (scalar)single-precision to 32-bit-
0 0 00 01 001 FCVTPU (scalar)single-precision to 32-bit-
0 0 00 1x 11x UNALLOCATED-
0 0 00 10 000 FCVTMS (scalar)single-precision to 32-bit-
0 0 00 10 001 FCVTMU (scalar)single-precision to 32-bit-
0 0 00 11 000 FCVTZS (scalar, integer)single-precision to 32-bit-
0 0 00 11 001 FCVTZU (scalar, integer)single-precision to 32-bit-
0 0 01 0x 11x UNALLOCATED-
0 0 01 00 000 FCVTNS (scalar)double-precision to 32-bit-
0 0 01 00 001 FCVTNU (scalar)double-precision to 32-bit-
0 0 01 00 010 SCVTF (scalar, integer)32-bit to double-precision-
0 0 01 00 011 UCVTF (scalar, integer)32-bit to double-precision-
0 0 01 00 100 FCVTAS (scalar)double-precision to 32-bit-
0 0 01 00 101 FCVTAU (scalar)double-precision to 32-bit-
0 0 01 01 000 FCVTPS (scalar)double-precision to 32-bit-
0 0 01 01 001 FCVTPU (scalar)double-precision to 32-bit-
0 0 01 10 000 FCVTMS (scalar)double-precision to 32-bit-
0 0 01 10 001 FCVTMU (scalar)double-precision to 32-bit-
0 0 01 10 11x UNALLOCATED-
0 0 01 11 000 FCVTZS (scalar, integer)double-precision to 32-bit-
0 0 01 11 001 FCVTZU (scalar, integer)double-precision to 32-bit-
0 0 01 11 110 FJCVTZSFEAT_JSCVT
0 0 01 11 111 UNALLOCATED-
0 0 10 11x UNALLOCATED-
0 0 11 00 000 FCVTNS (scalar)half-precision to 32-bitFEAT_FP16
0 0 11 00 001 FCVTNU (scalar)half-precision to 32-bitFEAT_FP16
0 0 11 00 010 SCVTF (scalar, integer)32-bit to half-precisionFEAT_FP16
0 0 11 00 011 UCVTF (scalar, integer)32-bit to half-precisionFEAT_FP16
0 0 11 00 100 FCVTAS (scalar)half-precision to 32-bitFEAT_FP16
0 0 11 00 101 FCVTAU (scalar)half-precision to 32-bitFEAT_FP16
0 0 11 00 110 FMOV (general)half-precision to 32-bitFEAT_FP16
0 0 11 00 111 FMOV (general)32-bit to half-precisionFEAT_FP16
0 0 11 01 000 FCVTPS (scalar)half-precision to 32-bitFEAT_FP16
0 0 11 01 001 FCVTPU (scalar)half-precision to 32-bitFEAT_FP16
0 0 11 10 000 FCVTMS (scalar)half-precision to 32-bitFEAT_FP16
0 0 11 10 001 FCVTMU (scalar)half-precision to 32-bitFEAT_FP16
0 0 11 11 000 FCVTZS (scalar, integer)half-precision to 32-bitFEAT_FP16
0 0 11 11 001 FCVTZU (scalar, integer)half-precision to 32-bitFEAT_FP16
1 0 00 11x UNALLOCATED-
1 0 00 00 000 FCVTNS (scalar)single-precision to 64-bit-
1 0 00 00 001 FCVTNU (scalar)single-precision to 64-bit-
1 0 00 00 010 SCVTF (scalar, integer)64-bit to single-precision-
1 0 00 00 011 UCVTF (scalar, integer)64-bit to single-precision-
1 0 00 00 100 FCVTAS (scalar)single-precision to 64-bit-
1 0 00 00 101 FCVTAU (scalar)single-precision to 64-bit-
1 0 00 01 000 FCVTPS (scalar)single-precision to 64-bit-
1 0 00 01 001 FCVTPU (scalar)single-precision to 64-bit-
1 0 00 10 000 FCVTMS (scalar)single-precision to 64-bit-
1 0 00 10 001 FCVTMU (scalar)single-precision to 64-bit-
1 0 00 11 000 FCVTZS (scalar, integer)single-precision to 64-bit-
1 0 00 11 001 FCVTZU (scalar, integer)single-precision to 64-bit-
1 0 01 x1 11x UNALLOCATED-
1 0 01 00 000 FCVTNS (scalar)double-precision to 64-bit-
1 0 01 00 001 FCVTNU (scalar)double-precision to 64-bit-
1 0 01 00 010 SCVTF (scalar, integer)64-bit to double-precision-
1 0 01 00 011 UCVTF (scalar, integer)64-bit to double-precision-
1 0 01 00 100 FCVTAS (scalar)double-precision to 64-bit-
1 0 01 00 101 FCVTAU (scalar)double-precision to 64-bit-
1 0 01 00 110 FMOV (general)double-precision to 64-bit-
1 0 01 00 111 FMOV (general)64-bit to double-precision-
1 0 01 01 000 FCVTPS (scalar)double-precision to 64-bit-
1 0 01 01 001 FCVTPU (scalar)double-precision to 64-bit-
1 0 01 1x 11x UNALLOCATED-
1 0 01 10 000 FCVTMS (scalar)double-precision to 64-bit-
1 0 01 10 001 FCVTMU (scalar)double-precision to 64-bit-
1 0 01 11 000 FCVTZS (scalar, integer)double-precision to 64-bit-
1 0 01 11 001 FCVTZU (scalar, integer)double-precision to 64-bit-
1 0 10 x0 11x UNALLOCATED-
1 0 10 01 110 FMOV (general)top half of 128-bit to 64-bit-
1 0 10 01 111 FMOV (general)64-bit to top half of 128-bit-
1 0 10 1x 11x UNALLOCATED-
1 0 11 00 000 FCVTNS (scalar)half-precision to 64-bitFEAT_FP16
1 0 11 00 001 FCVTNU (scalar)half-precision to 64-bitFEAT_FP16
1 0 11 00 010 SCVTF (scalar, integer)64-bit to half-precisionFEAT_FP16
1 0 11 00 011 UCVTF (scalar, integer)64-bit to half-precisionFEAT_FP16
1 0 11 00 100 FCVTAS (scalar)half-precision to 64-bitFEAT_FP16
1 0 11 00 101 FCVTAU (scalar)half-precision to 64-bitFEAT_FP16
1 0 11 00 110 FMOV (general)half-precision to 64-bitFEAT_FP16
1 0 11 00 111 FMOV (general)64-bit to half-precisionFEAT_FP16
1 0 11 01 000 FCVTPS (scalar)half-precision to 64-bitFEAT_FP16
1 0 11 01 001 FCVTPU (scalar)half-precision to 64-bitFEAT_FP16
1 0 11 10 000 FCVTMS (scalar)half-precision to 64-bitFEAT_FP16
1 0 11 10 001 FCVTMU (scalar)half-precision to 64-bitFEAT_FP16
1 0 11 11 000 FCVTZS (scalar, integer)half-precision to 64-bitFEAT_FP16
1 0 11 11 001 FCVTZU (scalar, integer)half-precision to 64-bitFEAT_FP16

Floating-point data-processing (1 source)

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
M0S11110ptype1opcode10000RnRd
Decode fields Instruction Details Feature
M S ptype opcode
1xxxxx UNALLOCATED-
1 UNALLOCATED-
0 0 00 000000 FMOV (register)single-precision-
0 0 00 000001 FABS (scalar)single-precision-
0 0 00 000010 FNEG (scalar)single-precision-
0 0 00 000011 FSQRT (scalar)single-precision-
0 0 00 000100 UNALLOCATED-
0 0 00 000101 FCVTsingle-precision to double-precision-
0 0 00 000110 UNALLOCATED-
0 0 00 000111 FCVTsingle-precision to half-precision-
0 0 00 001000 FRINTN (scalar)single-precision-
0 0 00 001001 FRINTP (scalar)single-precision-
0 0 00 001010 FRINTM (scalar)single-precision-
0 0 00 001011 FRINTZ (scalar)single-precision-
0 0 00 001100 FRINTA (scalar)single-precision-
0 0 00 001101 UNALLOCATED-
0 0 00 001110 FRINTX (scalar)single-precision-
0 0 00 001111 FRINTI (scalar)single-precision-
0 0 00 010000 FRINT32Z (scalar)single-precisionFEAT_FRINTTS
0 0 00 010001 FRINT32X (scalar)single-precisionFEAT_FRINTTS
0 0 00 010010 FRINT64Z (scalar)single-precisionFEAT_FRINTTS
0 0 00 010011 FRINT64X (scalar)single-precisionFEAT_FRINTTS
0 0 00 0101xx UNALLOCATED-
0 0 00 011xxx UNALLOCATED-
0 0 01 000000 FMOV (register)double-precision-
0 0 01 000001 FABS (scalar)double-precision-
0 0 01 000010 FNEG (scalar)double-precision-
0 0 01 000011 FSQRT (scalar)double-precision-
0 0 01 000100 FCVTdouble-precision to single-precision-
0 0 01 000101 UNALLOCATED-
0 0 01 000110 BFCVTFEAT_BF16
0 0 01 000111 FCVTdouble-precision to half-precision-
0 0 01 001000 FRINTN (scalar)double-precision-
0 0 01 001001 FRINTP (scalar)double-precision-
0 0 01 001010 FRINTM (scalar)double-precision-
0 0 01 001011 FRINTZ (scalar)double-precision-
0 0 01 001100 FRINTA (scalar)double-precision-
0 0 01 001101 UNALLOCATED-
0 0 01 001110 FRINTX (scalar)double-precision-
0 0 01 001111 FRINTI (scalar)double-precision-
0 0 01 010000 FRINT32Z (scalar)double-precisionFEAT_FRINTTS
0 0 01 010001 FRINT32X (scalar)double-precisionFEAT_FRINTTS
0 0 01 010010 FRINT64Z (scalar)double-precisionFEAT_FRINTTS
0 0 01 010011 FRINT64X (scalar)double-precisionFEAT_FRINTTS
0 0 01 0101xx UNALLOCATED-
0 0 01 011xxx UNALLOCATED-
0 0 10 0xxxxx UNALLOCATED-
0 0 11 000000 FMOV (register)half-precisionFEAT_FP16
0 0 11 000001 FABS (scalar)half-precisionFEAT_FP16
0 0 11 000010 FNEG (scalar)half-precisionFEAT_FP16
0 0 11 000011 FSQRT (scalar)half-precisionFEAT_FP16
0 0 11 000100 FCVThalf-precision to single-precision-
0 0 11 000101 FCVThalf-precision to double-precision-
0 0 11 00011x UNALLOCATED-
0 0 11 001000 FRINTN (scalar)half-precisionFEAT_FP16
0 0 11 001001 FRINTP (scalar)half-precisionFEAT_FP16
0 0 11 001010 FRINTM (scalar)half-precisionFEAT_FP16
0 0 11 001011 FRINTZ (scalar)half-precisionFEAT_FP16
0 0 11 001100 FRINTA (scalar)half-precisionFEAT_FP16
0 0 11 001101 UNALLOCATED-
0 0 11 001110 FRINTX (scalar)half-precisionFEAT_FP16
0 0 11 001111 FRINTI (scalar)half-precisionFEAT_FP16
0 0 11 01xxxx UNALLOCATED-
1 UNALLOCATED-

Floating-point compare

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
M0S11110ptype1Rmop1000Rnopcode2
Decode fields Instruction Details Feature
M S ptype op opcode2
xxxx1 UNALLOCATED-
xxx1x UNALLOCATED-
xx1xx UNALLOCATED-
x1 UNALLOCATED-
1x UNALLOCATED-
10 UNALLOCATED-
1 UNALLOCATED-
0 0 00 00 00000 FCMP-
0 0 00 00 01000 FCMP-
0 0 00 00 10000 FCMPE-
0 0 00 00 11000 FCMPE-
0 0 01 00 00000 FCMP-
0 0 01 00 01000 FCMP-
0 0 01 00 10000 FCMPE-
0 0 01 00 11000 FCMPE-
0 0 11 00 00000 FCMPFEAT_FP16
0 0 11 00 01000 FCMPFEAT_FP16
0 0 11 00 10000 FCMPEFEAT_FP16
0 0 11 00 11000 FCMPEFEAT_FP16
1 UNALLOCATED-

Floating-point immediate

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
M0S11110ptype1imm8100imm5Rd
Decode fields Instruction Details Feature
M S ptype imm5
xxxx1 UNALLOCATED-
xxx1x UNALLOCATED-
xx1xx UNALLOCATED-
x1xxx UNALLOCATED-
1xxxx UNALLOCATED-
10 UNALLOCATED-
1 UNALLOCATED-
0 0 00 00000 FMOV (scalar, immediate)single-precision-
0 0 01 00000 FMOV (scalar, immediate)double-precision-
0 0 11 00000 FMOV (scalar, immediate)half-precisionFEAT_FP16
1 UNALLOCATED-

Floating-point conditional compare

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
M0S11110ptype1Rmcond01Rnopnzcv
Decode fields Instruction Details Feature
M S ptype op
10 UNALLOCATED-
1 UNALLOCATED-
0 0 00 0 FCCMPsingle-precision-
0 0 00 1 FCCMPEsingle-precision-
0 0 01 0 FCCMPdouble-precision-
0 0 01 1 FCCMPEdouble-precision-
0 0 11 0 FCCMPhalf-precisionFEAT_FP16
0 0 11 1 FCCMPEhalf-precisionFEAT_FP16
1 UNALLOCATED-

Floating-point data-processing (2 source)

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
M0S11110ptype1Rmopcode10RnRd
Decode fields Instruction Details Feature
M S ptype opcode
1xx1 UNALLOCATED-
1x1x UNALLOCATED-
11xx UNALLOCATED-
10 UNALLOCATED-
1 UNALLOCATED-
0 0 00 0000 FMUL (scalar)single-precision-
0 0 00 0001 FDIV (scalar)single-precision-
0 0 00 0010 FADD (scalar)single-precision-
0 0 00 0011 FSUB (scalar)single-precision-
0 0 00 0100 FMAX (scalar)single-precision-
0 0 00 0101 FMIN (scalar)single-precision-
0 0 00 0110 FMAXNM (scalar)single-precision-
0 0 00 0111 FMINNM (scalar)single-precision-
0 0 00 1000 FNMUL (scalar)single-precision-
0 0 01 0000 FMUL (scalar)double-precision-
0 0 01 0001 FDIV (scalar)double-precision-
0 0 01 0010 FADD (scalar)double-precision-
0 0 01 0011 FSUB (scalar)double-precision-
0 0 01 0100 FMAX (scalar)double-precision-
0 0 01 0101 FMIN (scalar)double-precision-
0 0 01 0110 FMAXNM (scalar)double-precision-
0 0 01 0111 FMINNM (scalar)double-precision-
0 0 01 1000 FNMUL (scalar)double-precision-
0 0 11 0000 FMUL (scalar)half-precisionFEAT_FP16
0 0 11 0001 FDIV (scalar)half-precisionFEAT_FP16
0 0 11 0010 FADD (scalar)half-precisionFEAT_FP16
0 0 11 0011 FSUB (scalar)half-precisionFEAT_FP16
0 0 11 0100 FMAX (scalar)half-precisionFEAT_FP16
0 0 11 0101 FMIN (scalar)half-precisionFEAT_FP16
0 0 11 0110 FMAXNM (scalar)half-precisionFEAT_FP16
0 0 11 0111 FMINNM (scalar)half-precisionFEAT_FP16
0 0 11 1000 FNMUL (scalar)half-precisionFEAT_FP16
1 UNALLOCATED-

Floating-point conditional select

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
M0S11110ptype1Rmcond11RnRd
Decode fields Instruction Details Feature
M S ptype
10 UNALLOCATED-
1 UNALLOCATED-
0 0 00 FCSELsingle-precision-
0 0 01 FCSELdouble-precision-
0 0 11 FCSELhalf-precisionFEAT_FP16
1 UNALLOCATED-

Floating-point data-processing (3 source)

These instructions are under Data Processing -- Scalar Floating-Point and Advanced SIMD.

313029282726252423222120191817161514131211109876543210
M0S11111ptypeo1Rmo0RaRnRd
Decode fields Instruction Details Feature
M S ptype o1 o0
10 UNALLOCATED-
1 UNALLOCATED-
0 0 00 0 0 FMADDsingle-precision-
0 0 00 0 1 FMSUBsingle-precision-
0 0 00 1 0 FNMADDsingle-precision-
0 0 00 1 1 FNMSUBsingle-precision-
0 0 01 0 0 FMADDdouble-precision-
0 0 01 0 1 FMSUBdouble-precision-
0 0 01 1 0 FNMADDdouble-precision-
0 0 01 1 1 FNMSUBdouble-precision-
0 0 11 0 0 FMADDhalf-precisionFEAT_FP16
0 0 11 0 1 FMSUBhalf-precisionFEAT_FP16
0 0 11 1 0 FNMADDhalf-precisionFEAT_FP16
0 0 11 1 1 FNMSUBhalf-precisionFEAT_FP16
1 UNALLOCATED-

Internal version only: isa v33.11seprel, AdvSIMD v29.05, pseudocode v2021-09_rel, sve v2021-09_rc3d ; Build timestamp: 2021-10-06T11:41

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