

## Top-level encodings for A64

|     |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31  | 30 | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| op0 |    | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

op0      op1

### Instruction details

| op0 | op1  | Instruction details                                                        |
|-----|------|----------------------------------------------------------------------------|
| 0   | 0000 | <a href="#">Reserved</a>                                                   |
| 1   | 0000 | <a href="#">SME encodings</a>                                              |
|     | 0001 | UNALLOCATED                                                                |
|     | 0010 | <a href="#">SVE encodings</a>                                              |
|     | 0011 | UNALLOCATED                                                                |
|     | 100x | <a href="#">Data Processing -- Immediate</a>                               |
|     | 101x | <a href="#">Branches, Exception Generating and System instructions</a>     |
|     | x1x0 | <a href="#">Loads and Stores</a>                                           |
|     | x101 | <a href="#">Data Processing -- Register</a>                                |
|     | x111 | <a href="#">Data Processing -- Scalar Floating-Point and Advanced SIMD</a> |

### Reserved

These instructions are under the [top-level](#).

|    |     |      |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|-----|------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30  | 29   | 28 | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | op0 | 0000 |    | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

op0      op1

### Instruction details

|       |              |                     |
|-------|--------------|---------------------|
| 00    | 000000000    | <a href="#">UDF</a> |
|       | != 000000000 | UNALLOCATED         |
| != 00 |              | UNALLOCATED         |

### SME encodings

These instructions are under the [top-level](#).

|    |     |      |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|-----|------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30  | 29   | 28 | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | op0 | 0000 |    | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

op0

op1

op2

### Instruction details

|    |                   |      |                                                                                      |
|----|-------------------|------|--------------------------------------------------------------------------------------|
| 0x | x10xxxxxxxxxxxxxx | xx1x | UNALLOCATED                                                                          |
| 0x | x11xxxxxxxxxxxxxx | x0xx | <a href="#">SME Outer Product - 64 bit</a>                                           |
| 0x | x11xxxxxxxxxxxxxx | x1xx | UNALLOCATED                                                                          |
| 00 | x0xxxxxxxxxxxxxx  |      | UNALLOCATED                                                                          |
| 00 | x10xxxxxxxxxxxxxx | x00x | <a href="#">SME FP Outer Product - 32 bit</a>                                        |
| 00 | x10xxxxxxxxxxxxxx | x10x | <a href="#">SME2 Outer Product - Misc</a>                                            |
| 01 | x10xxxxxxxxxxxxxx | xx0x | <a href="#">SME Integer Outer Product - 32 bit</a>                                   |
| 01 | 00xxxxxxxxxxxxxx  |      | <a href="#">SME2 Multi-vector - Memory (Contiguous)</a>                              |
| 01 | 10xxxxxxxxxxxxxx  |      | <a href="#">SME2 Multi-vector - Memory (Strided)</a>                                 |
| 10 | 0xx000x0xxxxxxxx  | 0xxx | <a href="#">SME Move into Array</a>                                                  |
| 10 | 0xx000x0xxxxxxxx  | 1xxx | UNALLOCATED                                                                          |
| 10 | 0xx000x1xxxxxxxx  |      | <a href="#">SME Move from Array</a>                                                  |
| 10 | 0xx010xxxxxxxxxx  | x0xx | <a href="#">SME Add Vector to Array</a>                                              |
| 10 | 0xx010xxxxxxxxxx  | x1xx | UNALLOCATED                                                                          |
| 10 | 0xx1xxxxxxxxxxxxx |      | UNALLOCATED                                                                          |
| 10 | 00x011xxxxxxxxxx  |      | UNALLOCATED                                                                          |
| 10 | 0000010xxxxxxxxx  |      | <a href="#">SME Zero</a>                                                             |
| 10 | 0000011xxxxxxxxx  |      | <a href="#">SME2 Multiple Zero</a>                                                   |
| 10 | 0010010xxxxxxxxx  |      | <a href="#">SME2 Zero Lookup Table</a>                                               |
| 10 | 0010011xxxxxxxxx  |      | <a href="#">SME2 Move Lookup Table</a>                                               |
| 10 | 01x001xxxxxxxxxx  |      | <a href="#">SME2 Expand Lookup Table (Contiguous)</a>                                |
| 10 | 010011xxxxxxxxxx  |      | <a href="#">SME2 Expand Lookup Table (Non-contiguous)</a>                            |
| 10 | 011011xxxxxxxxxx  |      | UNALLOCATED                                                                          |
| 10 | 1xx00xxxxxxxxxxx  |      | <a href="#">SME2 Multi-vector - Indexed (One register)</a>                           |
| 10 | 1xx01xxxx0xxxxxx  |      | <a href="#">SME2 Multi-vector - Indexed (Two registers)</a>                          |
| 10 | 1xx01xxxx1xxxxxx  |      | <a href="#">SME2 Multi-vector - Indexed (Four registers)</a>                         |
| 10 | 1xx1xxxxx100xxx   |      | <a href="#">SME2 Multi-vector - SVE Select</a>                                       |
| 10 | 1xx1xxxxx110xxx   |      | <a href="#">SME2 Multi-vector - SVE Constructive Binary</a>                          |
| 10 | 1xx1xxxxx111000   |      | <a href="#">SME2 Multi-vector - SVE Constructive Unary</a>                           |
| 10 | 1xx1xxxxx111001   |      | UNALLOCATED                                                                          |
| 10 | 1xx1xxxxx11101*   |      | UNALLOCATED                                                                          |
| 10 | 1xx1xxxxx010110*  |      | <a href="#">SME2 Multi-vector - Multiple Vectors SVE Destructive (Two registers)</a> |

|    |                       |                                                                                          |
|----|-----------------------|------------------------------------------------------------------------------------------|
| 10 | 1xx1xxxx010111*x xxx0 | <a href="#">SME2 Multi-vector - Multiple Vectors SVE Destructive (Four registers)</a>    |
| 10 | 1xx10xxxx10100*x      | <a href="#">SME2 Multi-vector - Multiple and Single SVE Destructive (Two registers)</a>  |
| 10 | 1xx10xxxx10101*x xxx0 | <a href="#">SME2 Multi-vector - Multiple and Single SVE Destructive (Four registers)</a> |
| 10 | 1xx10xxx0101x1*x xxx1 | UNALLOCATED                                                                              |
| 10 | 1xx10xxx01111xx       | UNALLOCATED                                                                              |
| 10 | 1xx10xxx11x11xx       | UNALLOCATED                                                                              |
| 10 | 1xx10xxx110101*x xxx1 | UNALLOCATED                                                                              |
| 10 | 1xx11xxxx1111xx       | UNALLOCATED                                                                              |
| 10 | 1xx11xxx01010xx       | UNALLOCATED                                                                              |
| 10 | 1xx11xxx010111*x xxx1 | UNALLOCATED                                                                              |
| 10 | 1xx11xxx1101xxx       | UNALLOCATED                                                                              |
| 10 | 10x1xxxxx0xxxxxx      | <a href="#">SME2 Multi-vector - Multiple and Single Array Vectors</a>                    |
| 10 | 11x1xxxx00xxxxxx      | <a href="#">SME2 Multi-vector - Multiple Array Vectors (Two registers)</a>               |
| 10 | 11x1xxxx10xxxxxx      | <a href="#">SME2 Multi-vector - Multiple Array Vectors (Four registers)</a>              |
| 11 |                       | <a href="#">SME Memory</a>                                                               |

## SME Outer Product - 64 bit

These instructions are under [SME encodings](#).

|    |     |      |     |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|-----|------|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30  | 29   | 28  | 27 | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 10 | op0 | 0000 | op1 | 11 | op2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0 |   |

| Decode fields |     |     | Instruction details                     |
|---------------|-----|-----|-----------------------------------------|
| op0           | op1 | op2 |                                         |
| 0             | 0   | 0   | <a href="#">SME FP64 outer product</a>  |
| 0             | 0   | 1   | UNALLOCATED                             |
| 0             | 1   |     | UNALLOCATED                             |
| 1             |     |     | <a href="#">SME Int16 outer product</a> |

## SME FP64 outer product

These instructions are under [SME Outer Product - 64 bit](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | Zm | Pm | Pn |    |    |    |    |    |    |    |    |    | Zn | S | 0 | ZAda |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b>           | <b>Feature</b>  |
|----------------------|--------------------------------------|-----------------|
| <b>S</b>             |                                      |                 |
| 0                    | <a href="#">FMOPA (non-widening)</a> | FEAT_SME_F64F64 |
| 1                    | <a href="#">FMOPS (non-widening)</a> | FEAT_SME_F64F64 |

### SME Int16 outer product

These instructions are under [SME Outer Product - 64 bit](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| 1  | 0  | 1  | 0  | 0  | 0  | 0  | u0 | 1  | 1  | u1 | Zm | Pm | Pn | Zn | S  | 0  | ZAda |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| <b>Decode fields</b> |           |          | <b>Instruction Details</b>    | <b>Feature</b>  |
|----------------------|-----------|----------|-------------------------------|-----------------|
| <b>u0</b>            | <b>u1</b> | <b>S</b> |                               |                 |
| 0                    | 0         | 0        | <a href="#">SMOPA (4-way)</a> | FEAT_SME_I16I64 |
| 0                    | 0         | 1        | <a href="#">SMOPS (4-way)</a> | FEAT_SME_I16I64 |
| 0                    | 1         | 0        | <a href="#">SUMOPA</a>        | FEAT_SME_I16I64 |
| 0                    | 1         | 1        | <a href="#">SUMOPS</a>        | FEAT_SME_I16I64 |
| 1                    | 0         | 0        | <a href="#">USMOPA</a>        | FEAT_SME_I16I64 |
| 1                    | 0         | 1        | <a href="#">USMOPS</a>        | FEAT_SME_I16I64 |
| 1                    | 1         | 0        | <a href="#">UMOPA (4-way)</a> | FEAT_SME_I16I64 |
| 1                    | 1         | 1        | <a href="#">UMOPS (4-way)</a> | FEAT_SME_I16I64 |

### SME FP Outer Product - 32 bit

These instructions are under [SME encodings](#).

|         |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|---------|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 31      | 30  | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| 1000000 | op0 | 010 | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 00 |   |

| <b>Decode fields</b> |            | <b>Instruction details</b>                      |
|----------------------|------------|-------------------------------------------------|
| <b>op0</b>           | <b>op1</b> |                                                 |
| 0                    | 0          | <a href="#">SME FP32 outer product</a>          |
| 0                    | 1          | UNALLOCATED                                     |
| 1                    | 0          | <a href="#">SME BF16 widening outer product</a> |
| 1                    | 1          | <a href="#">SME FP16 widening outer product</a> |

### SME FP32 outer product

These instructions are under [SME FP Outer Product - 32 bit](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | Zm | Pm | Pn | Zn | S  | 0  | 0  | ZAda |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

**Decode fields**  
S

**Instruction Details**

**Feature**

|   |                                      |          |
|---|--------------------------------------|----------|
| 0 | <a href="#">FMOPA (non-widening)</a> | FEAT_SME |
| 1 | <a href="#">FMOPS (non-widening)</a> | FEAT_SME |

### SME BF16 widening outer product

These instructions are under [SME FP Outer Product - 32 bit](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13   | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | Zm | Pm | Pn | Zn | S  | 0  | 0  | ZAda |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

**Decode fields**  
S

**Instruction Details**

**Feature**

|   |                                   |          |
|---|-----------------------------------|----------|
| 0 | <a href="#">BFMOPA (widening)</a> | FEAT_SME |
| 1 | <a href="#">BFMOPS (widening)</a> | FEAT_SME |

### SME FP16 widening outer product

These instructions are under [SME FP Outer Product - 32 bit](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13   | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | Zm | Pm | Pn | Zn | S  | 0  | 0  | ZAda |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

**Decode fields**  
S

**Instruction Details**

**Feature**

|   |                                  |          |
|---|----------------------------------|----------|
| 0 | <a href="#">FMOPA (widening)</a> | FEAT_SME |
| 1 | <a href="#">FMOPS (widening)</a> | FEAT_SME |

### SME2 Outer Product - Misc

These instructions are under [SME encodings](#).

|         |     |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    |     |   |   |
|---------|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----|-----|---|---|
| 31      | 30  | 29 | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2   | 1 | 0 |
| 1000000 | op0 | 10 | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | 10 | op2 |   |   |

**Decode fields**  
op0    op1    op2

**Instruction details**

|   |   |   |                                                      |
|---|---|---|------------------------------------------------------|
| 0 | 0 |   | <a href="#">SME2 32-bit binary outer product</a>     |
| 0 | 1 |   | UNALLOCATED                                          |
| 1 | 0 | 0 | <a href="#">SME2 FP16 non-widening outer product</a> |

|   |   |   |                                                      |
|---|---|---|------------------------------------------------------|
| 1 | 1 | 0 | <a href="#">SME2 BF16 non-widening outer product</a> |
| 1 |   | 1 | UNALLOCATED                                          |

### SME2 32-bit binary outer product

These instructions are under [SME2 Outer Product - Misc.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | Zm | Pm | Pn | Zn | S  | 1  | 0  | ZAda |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Decode fields<br>S | Instruction Details   | Feature   |
|--------------------|-----------------------|-----------|
| 0                  | <a href="#">BMOPA</a> | FEAT_SME2 |
| 1                  | <a href="#">BMOPS</a> | FEAT_SME2 |

### SME2 FP16 non-widening outer product

These instructions are under [SME2 Outer Product - Misc.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | Zm | Pm | Pn | Zn | S  | 1  | 0  | 0  | ZAda |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>S | Instruction Details                  | Feature         |
|--------------------|--------------------------------------|-----------------|
| 0                  | <a href="#">FMOPA (non-widening)</a> | FEAT_SME_F16F16 |
| 1                  | <a href="#">FMOPS (non-widening)</a> | FEAT_SME_F16F16 |

### SME2 BF16 non-widening outer product

These instructions are under [SME2 Outer Product - Misc.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | Zm | Pm | Pn | Zn | S  | 1  | 0  | 0  | ZAda |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>S | Instruction Details                   | Feature         |
|--------------------|---------------------------------------|-----------------|
| 0                  | <a href="#">BFMOPA (non-widening)</a> | FEAT_SVE_B16B16 |
| 1                  | <a href="#">BFMOPS (non-widening)</a> | FEAT_SVE_B16B16 |

### SME Integer Outer Product - 32 bit

These instructions are under [SME encodings](#).

|         |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|---------|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| 1010000 |    |    |    |    |    |    | 10 | op0 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | op10 |   |   |   |   |   |   |

**Decode fields**  
**op0**      **op1**

**Instruction details**

|   |   |                                                  |
|---|---|--------------------------------------------------|
| 0 | 1 | <a href="#">SME2 Int16 two-way outer product</a> |
| 1 | 1 | UNALLOCATED                                      |
|   | 0 | <a href="#">SME Int8 outer product</a>           |

**SME2 Int16 two-way outer product**

These instructions are under [SME Integer Outer Product - 32 bit](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |      |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 0  | 0  | u0 | 1  | 0  | 0  |    | Zm |    | Pm |    | Pn |    | Zn |    | S  | 1  | 0 | ZAda |   |   |   |   |   |   |   |   |

**Decode fields**  
**u0**      **S**

**Instruction Details**

**Feature**

|   |   |                               |           |
|---|---|-------------------------------|-----------|
| 0 | 0 | <a href="#">SMOPA (2-way)</a> | FEAT_SME2 |
| 0 | 1 | <a href="#">SMOPS (2-way)</a> | FEAT_SME2 |
| 1 | 0 | <a href="#">UMOPA (2-way)</a> | FEAT_SME2 |
| 1 | 1 | <a href="#">UMOPS (2-way)</a> | FEAT_SME2 |

**SME Int8 outer product**

These instructions are under [SME Integer Outer Product - 32 bit](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |      |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 0  | 0  | u0 | 1  | 0  | u1 |    | Zm |    | Pm |    | Pn |    | Zn |    | S  | 0  | 0 | ZAda |   |   |   |   |   |   |   |   |

**Decode fields**  
**u0**      **u1**      **S**

**Instruction Details**

**Feature**

|   |   |   |                               |          |
|---|---|---|-------------------------------|----------|
| 0 | 0 | 0 | <a href="#">SMOPA (4-way)</a> | FEAT_SME |
| 0 | 0 | 1 | <a href="#">SMOPS (4-way)</a> | FEAT_SME |
| 0 | 1 | 0 | <a href="#">SUMOPA</a>        | FEAT_SME |
| 0 | 1 | 1 | <a href="#">SUMOPS</a>        | FEAT_SME |
| 1 | 0 | 0 | <a href="#">USMOPA</a>        | FEAT_SME |
| 1 | 0 | 1 | <a href="#">USMOPS</a>        | FEAT_SME |
| 1 | 1 | 0 | <a href="#">UMOPA (4-way)</a> | FEAT_SME |
| 1 | 1 | 1 | <a href="#">UMOPS (4-way)</a> | FEAT_SME |

## SME2 Multi-vector - Memory (Contiguous)

These instructions are under [SME encodings](#).

|                                                                                       |     |
|---------------------------------------------------------------------------------------|-----|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |     |
| 101000000                                                                             | op0 |

| Decode fields |     |     | Instruction details                                                                     |
|---------------|-----|-----|-----------------------------------------------------------------------------------------|
| op0           | op1 | op2 |                                                                                         |
| 00x           | 0   |     | <a href="#">SME2 multi-vec contiguous load (scalar plus scalar, two registers)</a>      |
| 00x           | 1   | 0   | <a href="#">SME2 multi-vec contiguous load (scalar plus scalar, four registers)</a>     |
| 01x           | 0   |     | <a href="#">SME2 multi-vec contiguous store (scalar plus scalar, two registers)</a>     |
| 01x           | 1   | 0   | <a href="#">SME2 multi-vec contiguous store (scalar plus scalar, four registers)</a>    |
| 0xx           | 1   | 1   | UNALLOCATED                                                                             |
| 100           | 0   |     | <a href="#">SME2 multi-vec contiguous load (scalar plus immediate, two registers)</a>   |
| 100           | 1   | 0   | <a href="#">SME2 multi-vec contiguous load (scalar plus immediate, four registers)</a>  |
| 110           | 0   |     | <a href="#">SME2 multi-vec contiguous store (scalar plus immediate, two registers)</a>  |
| 110           | 1   | 0   | <a href="#">SME2 multi-vec contiguous store (scalar plus immediate, four registers)</a> |
| 1x0           | 1   | 1   | UNALLOCATED                                                                             |
| 1x1           |     |     | UNALLOCATED                                                                             |

### SME2 multi-vec contiguous load (scalar plus scalar, two registers)

These instructions are under [SME2 Multi-vector - Memory \(Contiguous\)](#).

|                                                                                       |  |
|---------------------------------------------------------------------------------------|--|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |
| 1 0 1 0 0 0 0 0 0 0   Rm   0 msz   PNg   Rn   Zt   N                                  |  |

| Decode fields |   | Instruction Details                                                | Feature     |
|---------------|---|--------------------------------------------------------------------|-------------|
| msz           | N |                                                                    |             |
| 00            | 0 | <a href="#">LD1B (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 00            | 1 | <a href="#">LDNT1B (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 01            | 0 | <a href="#">LD1H (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 01            | 1 | <a href="#">LDNT1H (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |

| Decode fields |   | Instruction Details                                                | Feature     |
|---------------|---|--------------------------------------------------------------------|-------------|
| msz           | N |                                                                    |             |
| 10            | 0 | <a href="#">LD1W (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 10            | 1 | <a href="#">LDNT1W (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 11            | 0 | <a href="#">LD1D (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 11            | 1 | <a href="#">LDNT1D (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |

## SME2 multi-vec contiguous load (scalar plus scalar, four registers)

These instructions are under [SME2 Multi-vector - Memory \(Contiguous\)](#).

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0  
| 1 0 1 0 0 0 0 0 0 0 | Rm | 1 | msz | Png | Rn | Zt | 0 | N |

| Decode fields |   | Instruction Details                                                | Feature     |
|---------------|---|--------------------------------------------------------------------|-------------|
| msz           | N |                                                                    |             |
| 00            | 0 | <a href="#">LD1B (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 00            | 1 | <a href="#">LDNT1B (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 01            | 0 | <a href="#">LD1H (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 01            | 1 | <a href="#">LDNT1H (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 10            | 0 | <a href="#">LD1W (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 10            | 1 | <a href="#">LDNT1W (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 11            | 0 | <a href="#">LD1D (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 11            | 1 | <a href="#">LDNT1D (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |

## SME2 multi-vec contiguous store (scalar plus scalar, two registers)

These instructions are under [SME2 Multi-vector - Memory \(Contiguous\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | Rm | 0  | msz | PNg |    |    |    |    |    |    | Rn |   | Zt | N |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                                | Feature     |
|---------------|---|--------------------------------------------------------------------|-------------|
| msz           | N |                                                                    |             |
| 00            | 0 | <a href="#">ST1B (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 00            | 1 | <a href="#">STNT1B (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 01            | 0 | <a href="#">ST1H (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 01            | 1 | <a href="#">STNT1H (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 10            | 0 | <a href="#">ST1W (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 10            | 1 | <a href="#">STNT1W (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 11            | 0 | <a href="#">ST1D (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 11            | 1 | <a href="#">STNT1D (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |

## SME2 multi-vec contiguous store (scalar plus scalar, four registers)

These instructions are under [SME2 Multi-vector - Memory \(Contiguous\)](#).

| Decode fields |   | Instruction Details                                                | Feature     |
|---------------|---|--------------------------------------------------------------------|-------------|
| msz           | N |                                                                    |             |
| 00            | 0 | <a href="#">ST1B (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 00            | 1 | <a href="#">STNT1B (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 01            | 0 | <a href="#">ST1H (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 01            | 1 | <a href="#">STNT1H (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 10            | 0 | <a href="#">ST1W (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 10            | 1 | <a href="#">STNT1W (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |
| 11            | 0 | <a href="#">ST1D (scalar plus scalar, consecutive registers)</a>   | FEAT_SVE2p1 |
| 11            | 1 | <a href="#">STNT1D (scalar plus scalar, consecutive registers)</a> | FEAT_SVE2p1 |

### SME2 multi-vec contiguous load (scalar plus immediate, two registers)

These instructions are under [SME2 Multi-vector - Memory \(Contiguous\)](#).

| Decode fields |   | Instruction Details                                                   | Feature     |
|---------------|---|-----------------------------------------------------------------------|-------------|
| msz           | N |                                                                       |             |
| 00            | 0 | <a href="#">LD1B (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 00            | 1 | <a href="#">LDNT1B (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |
| 01            | 0 | <a href="#">LD1H (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 01            | 1 | <a href="#">LDNT1H (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |
| 10            | 0 | <a href="#">LD1W (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 10            | 1 | <a href="#">LDNT1W (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |
| 11            | 0 | <a href="#">LD1D (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 11            | 1 | <a href="#">LDNT1D (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |

## SME2 multi-vec contiguous load (scalar plus immediate, four registers)

These instructions are under [SME2 Multi-vector - Memory \(Contiguous\)](#).

| Decode fields |   | Instruction Details                                                   | Feature     |
|---------------|---|-----------------------------------------------------------------------|-------------|
| msz           | N |                                                                       |             |
| 00            | 0 | <a href="#">LD1B (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 00            | 1 | <a href="#">LDNT1B (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |
| 01            | 0 | <a href="#">LD1H (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 01            | 1 | <a href="#">LDNT1H (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |
| 10            | 0 | <a href="#">LD1W (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 10            | 1 | <a href="#">LDNT1W (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |
| 11            | 0 | <a href="#">LD1D (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 11            | 1 | <a href="#">LDNT1D (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |

#### SME2 multi-vec contiguous store (scalar plus immediate, two registers)

These instructions are under [SME2 Multi-vector - Memory \(Contiguous\)](#).

| Decode fields |   | Instruction Details                                                   | Feature     |
|---------------|---|-----------------------------------------------------------------------|-------------|
| msz           | N |                                                                       |             |
| 00            | 0 | <a href="#">ST1B (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 00            | 1 | <a href="#">STNT1B (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |
| 01            | 0 | <a href="#">ST1H (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 01            | 1 | <a href="#">STNT1H (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |
| 10            | 0 | <a href="#">ST1W (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 10            | 1 | <a href="#">STNT1W (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |
| 11            | 0 | <a href="#">ST1D (scalar plus immediate, consecutive registers)</a>   | FEAT_SVE2p1 |
| 11            | 1 | <a href="#">STNT1D (scalar plus immediate, consecutive registers)</a> | FEAT_SVE2p1 |

#### **SME2 multi-vec contiguous store (scalar plus immediate, four registers)**

These instructions are under [SME2 Multi-vector - Memory \(Contiguous\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |      |   |     |     |  |    |    |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------|---|-----|-----|--|----|----|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | imm4 | 1 | msz | PNG |  | Rn | Zt | O | N |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------|---|-----|-----|--|----|----|---|---|

| Decode fields |   | Instruction Details                                                   |  | Feature     |
|---------------|---|-----------------------------------------------------------------------|--|-------------|
| msz           | N |                                                                       |  |             |
| 00            | 0 | <a href="#">ST1B (scalar plus immediate, consecutive registers)</a>   |  | FEAT_SVE2p1 |
| 00            | 1 | <a href="#">STNT1B (scalar plus immediate, consecutive registers)</a> |  | FEAT_SVE2p1 |
| 01            | 0 | <a href="#">ST1H (scalar plus immediate, consecutive registers)</a>   |  | FEAT_SVE2p1 |
| 01            | 1 | <a href="#">STNT1H (scalar plus immediate, consecutive registers)</a> |  | FEAT_SVE2p1 |
| 10            | 0 | <a href="#">ST1W (scalar plus immediate, consecutive registers)</a>   |  | FEAT_SVE2p1 |
| 10            | 1 | <a href="#">STNT1W (scalar plus immediate, consecutive registers)</a> |  | FEAT_SVE2p1 |
| 11            | 0 | <a href="#">ST1D (scalar plus immediate, consecutive registers)</a>   |  | FEAT_SVE2p1 |
| 11            | 1 | <a href="#">STNT1D (scalar plus immediate, consecutive registers)</a> |  | FEAT_SVE2p1 |

## SME2 Multi-vector - Memory (Strided)

These instructions are under [SME encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     |     | Instruction details                                                                         |
|---------------|-----|-----|---------------------------------------------------------------------------------------------|
| op0           | op1 | op2 |                                                                                             |
| 00x           | 0   |     | <a href="#">SME2 multi-vec non-contiguous load (scalar plus scalar, two registers)</a>      |
| 00x           | 1   | 0   | <a href="#">SME2 multi-vec non-contiguous load (scalar plus scalar, four registers)</a>     |
| 01x           | 0   |     | <a href="#">SME2 multi-vec non-contiguous store (scalar plus scalar, two registers)</a>     |
| 01x           | 1   | 0   | <a href="#">SME2 multi-vec non-contiguous store (scalar plus scalar, four registers)</a>    |
| 0xx           | 1   | 1   | UNALLOCATED                                                                                 |
| 100           | 0   |     | <a href="#">SME2 multi-vec non-contiguous load (scalar plus immediate, two registers)</a>   |
| 100           | 1   | 0   | <a href="#">SME2 multi-vec non-contiguous load (scalar plus immediate, four registers)</a>  |
| 110           | 0   |     | <a href="#">SME2 multi-vec non-contiguous store (scalar plus immediate, two registers)</a>  |
| 110           | 1   | 0   | <a href="#">SME2 multi-vec non-contiguous store (scalar plus immediate, four registers)</a> |

|     |   |   |             |
|-----|---|---|-------------|
| 1x0 | 1 | 1 | UNALLOCATED |
| 1x1 |   |   | UNALLOCATED |

### SME2 multi-vec non-contiguous load (scalar plus scalar, two registers)

These instructions are under [SME2 Multi-vector - Memory \(Strided\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |     |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17  | 16 | 15 | 14  | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | Rm | 0  | msz | PNg |    | Rn | Zth | N  |    | Ztl |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                            |  |  | Feature   |
|---------------|---|----------------------------------------------------------------|--|--|-----------|
| msz           | N |                                                                |  |  |           |
| 00            | 0 | <a href="#">LD1B (scalar plus scalar, strided registers)</a>   |  |  | FEAT_SME2 |
| 00            | 1 | <a href="#">LDNT1B (scalar plus scalar, strided registers)</a> |  |  | FEAT_SME2 |
| 01            | 0 | <a href="#">LD1H (scalar plus scalar, strided registers)</a>   |  |  | FEAT_SME2 |
| 01            | 1 | <a href="#">LDNT1H (scalar plus scalar, strided registers)</a> |  |  | FEAT_SME2 |
| 10            | 0 | <a href="#">LD1W (scalar plus scalar, strided registers)</a>   |  |  | FEAT_SME2 |
| 10            | 1 | <a href="#">LDNT1W (scalar plus scalar, strided registers)</a> |  |  | FEAT_SME2 |
| 11            | 0 | <a href="#">LD1D (scalar plus scalar, strided registers)</a>   |  |  | FEAT_SME2 |
| 11            | 1 | <a href="#">LDNT1D (scalar plus scalar, strided registers)</a> |  |  | FEAT_SME2 |

### SME2 multi-vec non-contiguous load (scalar plus scalar, four registers)

These instructions are under [SME2 Multi-vector - Memory \(Strided\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |     |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17  | 16 | 15 | 14  | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | Rm | 1  | msz | PNg |    | Rn | Zth | N  | 0  | Ztl |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                            |  |  | Feature   |
|---------------|---|----------------------------------------------------------------|--|--|-----------|
| msz           | N |                                                                |  |  |           |
| 00            | 0 | <a href="#">LD1B (scalar plus scalar, strided registers)</a>   |  |  | FEAT_SME2 |
| 00            | 1 | <a href="#">LDNT1B (scalar plus scalar, strided registers)</a> |  |  | FEAT_SME2 |
| 01            | 0 | <a href="#">LD1H (scalar plus scalar, strided registers)</a>   |  |  | FEAT_SME2 |

| Decode fields |   | Instruction Details                                            |  | Feature   |
|---------------|---|----------------------------------------------------------------|--|-----------|
| msz           | N |                                                                |  |           |
| 01            | 1 | <a href="#">LDNT1H (scalar plus scalar, strided registers)</a> |  | FEAT_SME2 |
| 10            | 0 | <a href="#">LD1W (scalar plus scalar, strided registers)</a>   |  | FEAT_SME2 |
| 10            | 1 | <a href="#">LDNT1W (scalar plus scalar, strided registers)</a> |  | FEAT_SME2 |
| 11            | 0 | <a href="#">LD1D (scalar plus scalar, strided registers)</a>   |  | FEAT_SME2 |
| 11            | 1 | <a href="#">LDNT1D (scalar plus scalar, strided registers)</a> |  | FEAT_SME2 |

## SME2 multi-vec non-contiguous store (scalar plus scalar, two registers)

These instructions are under [SME2 Multi-vector - Memory \(Strided\)](#).

| Decode fields |   | Instruction Details                                            | Feature   |
|---------------|---|----------------------------------------------------------------|-----------|
| msz           | N |                                                                |           |
| 00            | 0 | <a href="#">ST1B (scalar plus scalar, strided registers)</a>   | FEAT_SME2 |
| 00            | 1 | <a href="#">STNT1B (scalar plus scalar, strided registers)</a> | FEAT_SME2 |
| 01            | 0 | <a href="#">ST1H (scalar plus scalar, strided registers)</a>   | FEAT_SME2 |
| 01            | 1 | <a href="#">STNT1H (scalar plus scalar, strided registers)</a> | FEAT_SME2 |
| 10            | 0 | <a href="#">ST1W (scalar plus scalar, strided registers)</a>   | FEAT_SME2 |
| 10            | 1 | <a href="#">STNT1W (scalar plus scalar, strided registers)</a> | FEAT_SME2 |
| 11            | 0 | <a href="#">ST1D (scalar plus scalar, strided registers)</a>   | FEAT_SME2 |
| 11            | 1 | <a href="#">STNT1D (scalar plus scalar, strided registers)</a> | FEAT_SME2 |

### SME2 multi-vec non-contiguous store (scalar plus scalar, four registers)

These instructions are under [SME2 Multi-vector - Memory \(Strided\)](#).

| Decode fields |   | Instruction Details                                            |  | Feature   |
|---------------|---|----------------------------------------------------------------|--|-----------|
| msz           | N |                                                                |  |           |
| 00            | 0 | <a href="#">ST1B (scalar plus scalar, strided registers)</a>   |  | FEAT_SME2 |
| 00            | 1 | <a href="#">STNT1B (scalar plus scalar, strided registers)</a> |  | FEAT_SME2 |
| 01            | 0 | <a href="#">ST1H (scalar plus scalar, strided registers)</a>   |  | FEAT_SME2 |
| 01            | 1 | <a href="#">STNT1H (scalar plus scalar, strided registers)</a> |  | FEAT_SME2 |
| 10            | 0 | <a href="#">ST1W (scalar plus scalar, strided registers)</a>   |  | FEAT_SME2 |
| 10            | 1 | <a href="#">STNT1W (scalar plus scalar, strided registers)</a> |  | FEAT_SME2 |
| 11            | 0 | <a href="#">ST1D (scalar plus scalar, strided registers)</a>   |  | FEAT_SME2 |
| 11            | 1 | <a href="#">STNT1D (scalar plus scalar, strided registers)</a> |  | FEAT_SME2 |

## SME2 multi-vec non-contiguous load (scalar plus immediate, two registers)

These instructions are under [SME2 Multi-vector - Memory \(Strided\)](#).

| Decode fields |   | Instruction Details                                               | Feature   |
|---------------|---|-------------------------------------------------------------------|-----------|
| msz           | N |                                                                   |           |
| 00            | 0 | <a href="#">LD1B (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 00            | 1 | <a href="#">LDNT1B (scalar plus immediate, strided registers)</a> | FEAT_SME2 |
| 01            | 0 | <a href="#">LD1H (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 01            | 1 | <a href="#">LDNT1H (scalar plus immediate, strided registers)</a> | FEAT_SME2 |
| 10            | 0 | <a href="#">LD1W (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 10            | 1 | <a href="#">LDNT1W (scalar plus immediate, strided registers)</a> | FEAT_SME2 |
| 11            | 0 | <a href="#">LD1D (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 11            | 1 | <a href="#">LDNT1D (scalar plus immediate, strided registers)</a> | FEAT_SME2 |

## SME2 multi-vec non-contiguous load (scalar plus immediate, four registers)

These instructions are under [SME2 Multi-vector - Memory \(Strided\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |      |   |     |     |  |    |     |   |   |     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------|---|-----|-----|--|----|-----|---|---|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | imm4 | 1 | msz | PNq |  | Rn | Zth | N | 0 | Ztl |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------|---|-----|-----|--|----|-----|---|---|-----|

| Decode fields |   | Instruction Details                                               | Feature   |
|---------------|---|-------------------------------------------------------------------|-----------|
| msz           | N |                                                                   |           |
| 00            | 0 | <a href="#">LD1B (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 00            | 1 | <a href="#">LDNT1B (scalar plus immediate, strided registers)</a> | FEAT_SME2 |
| 01            | 0 | <a href="#">LD1H (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 01            | 1 | <a href="#">LDNT1H (scalar plus immediate, strided registers)</a> | FEAT_SME2 |
| 10            | 0 | <a href="#">LD1W (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 10            | 1 | <a href="#">LDNT1W (scalar plus immediate, strided registers)</a> | FEAT_SME2 |
| 11            | 0 | <a href="#">LD1D (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 11            | 1 | <a href="#">LDNT1D (scalar plus immediate, strided registers)</a> | FEAT_SME2 |

#### SME2 multi-vec non-contiguous store (scalar plus immediate, two registers)

These instructions are under [SME2 Multi-vector - Memory \(Strided\)](#).

| Decode fields |   | Instruction Details                                               | Feature   |
|---------------|---|-------------------------------------------------------------------|-----------|
| msz           | N |                                                                   |           |
| 00            | 0 | <a href="#">ST1B (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 00            | 1 | <a href="#">STNT1B (scalar plus immediate, strided registers)</a> | FEAT_SME2 |
| 01            | 0 | <a href="#">ST1H (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 01            | 1 | <a href="#">STNT1H (scalar plus immediate, strided registers)</a> | FEAT_SME2 |
| 10            | 0 | <a href="#">ST1W (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 10            | 1 | <a href="#">STNT1W (scalar plus immediate, strided registers)</a> | FEAT_SME2 |
| 11            | 0 | <a href="#">ST1D (scalar plus immediate, strided registers)</a>   | FEAT_SME2 |
| 11            | 1 | <a href="#">STNT1D (scalar plus immediate, strided registers)</a> | FEAT_SME2 |

### SME2 multi-vec non-contiguous store (scalar plus immediate, four registers)

These instructions are under [SME2 Multi-vector - Memory \(Strided\)](#).

| Decode fields |   | Instruction Details                                               |  |  |  |  |  | Feature   |
|---------------|---|-------------------------------------------------------------------|--|--|--|--|--|-----------|
| msz           | N |                                                                   |  |  |  |  |  |           |
| 00            | 0 | <a href="#">ST1B (scalar plus immediate, strided registers)</a>   |  |  |  |  |  | FEAT_SME2 |
| 00            | 1 | <a href="#">STNT1B (scalar plus immediate, strided registers)</a> |  |  |  |  |  | FEAT_SME2 |
| 01            | 0 | <a href="#">ST1H (scalar plus immediate, strided registers)</a>   |  |  |  |  |  | FEAT_SME2 |
| 01            | 1 | <a href="#">STNT1H (scalar plus immediate, strided registers)</a> |  |  |  |  |  | FEAT_SME2 |
| 10            | 0 | <a href="#">ST1W (scalar plus immediate, strided registers)</a>   |  |  |  |  |  | FEAT_SME2 |
| 10            | 1 | <a href="#">STNT1W (scalar plus immediate, strided registers)</a> |  |  |  |  |  | FEAT_SME2 |
| 11            | 0 | <a href="#">ST1D (scalar plus immediate, strided registers)</a>   |  |  |  |  |  | FEAT_SME2 |
| 11            | 1 | <a href="#">STNT1D (scalar plus immediate, strided registers)</a> |  |  |  |  |  | FEAT_SME2 |

## SME Move into Array

These instructions are under [SME encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     |     |     |       |     | Instruction details                                    |  |  | Feature   |
|---------------|-----|-----|-----|-------|-----|--------------------------------------------------------|--|--|-----------|
| op0           | op1 | op2 | op3 | op4   | op5 |                                                        |  |  |           |
| 00            | 1   | 00  | 010 | x0    | 0   | <a href="#">MOVA (vector to array, two registers)</a>  |  |  | FEAT_SME2 |
| 00            | 1   | 00  | 011 | 00    | 0   | <a href="#">MOVA (vector to array, four registers)</a> |  |  | FEAT_SME2 |
| 00            | 1   | 00  | 0x0 | x0    | 1   | UNALLOCATED                                            |  |  | -         |
| 00            | 1   | 00  | 0x0 | x1    |     | UNALLOCATED                                            |  |  | -         |
| 00            | 1   | 00  | 0x1 | 00    | 1   | UNALLOCATED                                            |  |  | -         |
| 00            | 1   | 00  | 0x1 | != 00 |     | UNALLOCATED                                            |  |  | -         |
| 00            | 1   | 01  | 000 | x0    | 1   | UNALLOCATED                                            |  |  | -         |
| 00            | 1   | 01  | 000 | x1    |     | UNALLOCATED                                            |  |  | -         |
| 00            | 1   | 01  | 001 | 00    | 1   | UNALLOCATED                                            |  |  | -         |
| 00            | 1   | 01  | 001 | != 00 |     | UNALLOCATED                                            |  |  | -         |
| 00            | 1   | 01  | 01x |       |     | UNALLOCATED                                            |  |  | -         |
| != 00         | 1   | 0x  | 000 | x0    | 1   | UNALLOCATED                                            |  |  | -         |

|       |   |    |     |    |   |                                                          |   |
|-------|---|----|-----|----|---|----------------------------------------------------------|---|
| != 00 | 1 | 0x | 000 | x1 |   | UNALLOCATED                                              | - |
| != 00 | 1 | 0x | 001 | 00 | 1 | UNALLOCATED                                              | - |
| != 00 | 1 | 0x | 001 | 01 |   | UNALLOCATED                                              | - |
| != 00 | 1 | 0x | 001 | 1x |   | UNALLOCATED                                              | - |
| != 00 | 1 | 0x | 01x |    |   | UNALLOCATED                                              | - |
|       | 0 |    |     |    |   | <a href="#">SME move vector to array</a>                 | - |
|       | 1 | 0x | 000 | x0 | 0 | <a href="#">SME2 move vector to tile, two registers</a>  | - |
|       | 1 | 0x | 001 | 00 | 0 | <a href="#">SME2 move vector to tile, four registers</a> | - |
|       | 1 | 0x | 1xx |    |   | UNALLOCATED                                              | - |
|       | 1 | 1x |     |    |   | UNALLOCATED                                              | - |

## SME move vector to array

These instructions are under [SME Move into Array](#).

| Decode fields |   | Instruction Details                                     | Feature  |
|---------------|---|---------------------------------------------------------|----------|
| size          | Q |                                                         |          |
| 0x            | 1 | UNALLOCATED                                             | -        |
| 00            | 0 | <a href="#">MOVA (vector to tile, single)</a> " 8-bit   | FEAT_SME |
| 01            | 0 | <a href="#">MOVA (vector to tile, single)</a> " 16-bit  | FEAT_SME |
| 10            | 0 | <a href="#">MOVA (vector to tile, single)</a> " 32-bit  | FEAT_SME |
| 10            | 1 | UNALLOCATED                                             | -        |
| 11            | 0 | <a href="#">MOVA (vector to tile, single)</a> " 64-bit  | FEAT_SME |
| 11            | 1 | <a href="#">MOVA (vector to tile, single)</a> " 128-bit | FEAT_SME |

## SME2 move vector to tile, two registers

These instructions are under [SME Move into Array](#).

| Decode fields<br>size | Instruction Details                                                | Feature   |
|-----------------------|--------------------------------------------------------------------|-----------|
| 00                    | <a href="#">MOVA (vector to tile, two registers)</a><br>â€” 8-bit  | FEAT_SME2 |
| 01                    | <a href="#">MOVA (vector to tile, two registers)</a><br>â€” 16-bit | FEAT_SME2 |
| 10                    | <a href="#">MOVA (vector to tile, two registers)</a><br>â€” 32-bit | FEAT_SME2 |
| 11                    | <a href="#">MOVA (vector to tile, two registers)</a><br>â€” 64-bit | FEAT_SME2 |

### SME2 move vector to tile, four registers

These instructions are under [SME Move into Array](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | size | 0  | 0  | 0  | 1  | 0  | 0  | V  | Rs | 0  | 0  | 1  | Zn | 0  | 0 | 0 | 0 | opc |   |   |   |   |   |   |

| Decode fields<br>size | Instruction Details                                                 | Feature   |
|-----------------------|---------------------------------------------------------------------|-----------|
| opc                   |                                                                     |           |
| 0x                    | UNALLOCATED                                                         | -         |
| 00                    | <a href="#">MOVA (vector to tile, four registers)</a><br>â€” 8-bit  | FEAT_SME2 |
| 01                    | <a href="#">MOVA (vector to tile, four registers)</a><br>â€” 16-bit | FEAT_SME2 |
| 10                    | <a href="#">MOVA (vector to tile, four registers)</a><br>â€” 32-bit | FEAT_SME2 |
| 10                    | UNALLOCATED                                                         | -         |
| 11                    | <a href="#">MOVA (vector to tile, four registers)</a><br>â€” 64-bit | FEAT_SME2 |

### SME Move from Array

These instructions are under [SME encodings](#).

|          |     |     |     |    |     |    |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
|----------|-----|-----|-----|----|-----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|---|---|---|---|
| 31       | 30  | 29  | 28  | 27 | 26  | 25 | 24 | 23  | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3 | 2 | 1 | 0 |
| 11000000 | op0 | 000 | op1 | 1  | op2 |    |    | op3 | op4 |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | op5 |   |   |   |   |

| op0 | op1 | op2 | op3 | op4 | op5 | Decode fields | Instruction details                                   | Feature   |
|-----|-----|-----|-----|-----|-----|---------------|-------------------------------------------------------|-----------|
| 00  | 1   | 00  | 010 | 00  | x0  |               | <a href="#">MOVA (array to vector, two registers)</a> | FEAT_SME2 |

|       |   |    |        |    |       |                                                                  |             |
|-------|---|----|--------|----|-------|------------------------------------------------------------------|-------------|
| 00    | 1 | 00 | 010    | 10 | x0    | <a href="#">MOVAZ (array to vector, two registers)</a>           | FEAT_SME2p1 |
| 00    | 1 | 00 | 011    | 00 | 00    | <a href="#">MOVA (array to vector, four registers)</a>           | FEAT_SME2   |
| 00    | 1 | 00 | 011    | 10 | 00    | <a href="#">MOVAZ (array to vector, four registers)</a>          | FEAT_SME2p1 |
| 00    | 1 | 00 | 0x0    | x0 | x1    | UNALLOCATED                                                      | -           |
| 00    | 1 | 00 | 0x1    | x0 | != 00 | UNALLOCATED                                                      | -           |
| 00    | 1 | 00 | 0xx    | x1 |       | UNALLOCATED                                                      | -           |
| 00    | 1 | 01 | 000    | x0 | x1    | UNALLOCATED                                                      | -           |
| 00    | 1 | 01 | 001    | x0 | != 00 | UNALLOCATED                                                      | -           |
| 00    | 1 | 01 | 00x    | x1 |       | UNALLOCATED                                                      | -           |
| 00    | 1 | 01 | 01x    |    |       | UNALLOCATED                                                      | -           |
| != 00 | 1 | 0x | 000    | x0 | x1    | UNALLOCATED                                                      | -           |
| != 00 | 1 | 0x | 001    | x0 | 01    | UNALLOCATED                                                      | -           |
| != 00 | 1 | 0x | 001    | x0 | 1x    | UNALLOCATED                                                      | -           |
| != 00 | 1 | 0x | 00x    | x1 |       | UNALLOCATED                                                      | -           |
| != 00 | 1 | 0x | 01x    |    |       | UNALLOCATED                                                      | -           |
|       | 0 |    | 000    | 1x |       | <a href="#">SME zeroing move array to vector</a>                 | -           |
|       | 0 |    | != 000 | 1x |       | UNALLOCATED                                                      | -           |
|       | 0 |    |        | 0x |       | <a href="#">SME move array to vector</a>                         | -           |
|       | 1 | 0x | 000    | 00 | x0    | <a href="#">SME2 move tile to vector, two registers</a>          | -           |
|       | 1 | 0x | 000    | 10 | x0    | <a href="#">SME2 zeroing move tile to vector, two registers</a>  | -           |
|       | 1 | 0x | 001    | 00 | 00    | <a href="#">SME2 move tile to vector, four registers</a>         | -           |
|       | 1 | 0x | 001    | 10 | 00    | <a href="#">SME2 zeroing move tile to vector, four registers</a> | -           |
|       | 1 | 0x | 1xx    |    |       | UNALLOCATED                                                      | -           |
|       | 1 | 1x |        |    |       | UNALLOCATED                                                      | -           |

## SME zeroing move array to vector

These instructions are under [SME Move from Array](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |     |   |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | size | 0  | 0  | 0  | 0  | 1  | Q  | V  | Rs | 0  | 0  | 0  | 1  | opc |   | Zd |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                        |  |  | Feature     |
|---------------|---|------------------------------------------------------------|--|--|-------------|
| size          | Q |                                                            |  |  |             |
| 0x            | 1 | UNALLOCATED                                                |  |  | -           |
| 00            | 0 | <a href="#">MOVAZ (tile to vector, single) â€” 8-bit</a>   |  |  | FEAT_SME2p1 |
| 01            | 0 | <a href="#">MOVAZ (tile to vector, single) â€” 16-bit</a>  |  |  | FEAT_SME2p1 |
| 10            | 0 | <a href="#">MOVAZ (tile to vector, single) â€” 32-bit</a>  |  |  | FEAT_SME2p1 |
| 10            | 1 | UNALLOCATED                                                |  |  | -           |
| 11            | 0 | <a href="#">MOVAZ (tile to vector, single) â€” 64-bit</a>  |  |  | FEAT_SME2p1 |
| 11            | 1 | <a href="#">MOVAZ (tile to vector, single) â€” 128-bit</a> |  |  | FEAT_SME2p1 |

## SME move array to vector

These instructions are under [SME Move from Array](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | size | 0  | 0  | 0  | 0  | 1  | Q  | V  | Rs | Pg | 0  | opc |    | Zd |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                       |  |  | Feature  |
|---------------|---|-----------------------------------------------------------|--|--|----------|
| size          | Q |                                                           |  |  |          |
| 0x            | 1 | UNALLOCATED                                               |  |  | -        |
| 00            | 0 | <a href="#">MOVA (tile to vector, single) â€” 8-bit</a>   |  |  | FEAT_SME |
| 01            | 0 | <a href="#">MOVA (tile to vector, single) â€” 16-bit</a>  |  |  | FEAT_SME |
| 10            | 0 | <a href="#">MOVA (tile to vector, single) â€” 32-bit</a>  |  |  | FEAT_SME |
| 10            | 1 | UNALLOCATED                                               |  |  | -        |
| 11            | 0 | <a href="#">MOVA (tile to vector, single) â€” 64-bit</a>  |  |  | FEAT_SME |
| 11            | 1 | <a href="#">MOVA (tile to vector, single) â€” 128-bit</a> |  |  | FEAT_SME |

## SME2 move tile to vector, two registers

These instructions are under [SME Move from Array](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | size | 0  | 0  | 0  | 1  | 1  | 0  | V  | Rs | 0  | 0  | 0  | 0  | 0  | opc | Zd | 0 |   |   |   |   |   |   |   |

| Decode fields<br>size | Instruction Details                                                | Feature   |
|-----------------------|--------------------------------------------------------------------|-----------|
| 00                    | <a href="#">MOVA (tile to vector, two registers)</a><br>â€” 8-bit  | FEAT_SME2 |
| 01                    | <a href="#">MOVA (tile to vector, two registers)</a><br>â€” 16-bit | FEAT_SME2 |
| 10                    | <a href="#">MOVA (tile to vector, two registers)</a><br>â€” 32-bit | FEAT_SME2 |
| 11                    | <a href="#">MOVA (tile to vector, two registers)</a><br>â€” 64-bit | FEAT_SME2 |

## SME2 zeroing move tile to vector, two registers

These instructions are under [SME Move from Array](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | size | 0  | 0  | 0  | 1  | 1  | 0  | V  | Rs | 0  | 0  | 0  | 1  | 0  | opc | Zd | 0 |   |   |   |   |   |   |   |

| Decode fields<br>size | Instruction Details                                                 | Feature     |
|-----------------------|---------------------------------------------------------------------|-------------|
| 00                    | <a href="#">MOVAZ (tile to vector, two registers)</a><br>â€” 8-bit  | FEAT_SME2p1 |
| 01                    | <a href="#">MOVAZ (tile to vector, two registers)</a><br>â€” 16-bit | FEAT_SME2p1 |
| 10                    | <a href="#">MOVAZ (tile to vector, two registers)</a><br>â€” 32-bit | FEAT_SME2p1 |
| 11                    | <a href="#">MOVAZ (tile to vector, two registers)</a><br>â€” 64-bit | FEAT_SME2p1 |

## SME2 move tile to vector, four registers

These instructions are under [SME Move from Array](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | size | 0  | 0  | 0  | 1  | 1  | 0  | V  | Rs | 0  | 0  | 1  | 0  | 0  | opc | Zd | 0 | 0 |   |   |   |   |   |   |

| Decode fields |     | Instruction Details                                                 |  | Feature   |
|---------------|-----|---------------------------------------------------------------------|--|-----------|
| size          | opc |                                                                     |  |           |
| 0x            | 1xx | UNALLOCATED                                                         |  | -         |
| 00            | 0xx | <a href="#">MOVA (tile to vector, four registers)</a><br>â€” 8-bit  |  | FEAT_SME2 |
| 01            | 0xx | <a href="#">MOVA (tile to vector, four registers)</a><br>â€” 16-bit |  | FEAT_SME2 |
| 10            | 0xx | <a href="#">MOVA (tile to vector, four registers)</a><br>â€” 32-bit |  | FEAT_SME2 |
| 10            | 1xx | UNALLOCATED                                                         |  | -         |
| 11            |     | <a href="#">MOVA (tile to vector, four registers)</a><br>â€” 64-bit |  | FEAT_SME2 |

### SME2 zeroing move tile to vector, four registers

These instructions are under [SME Move from Array](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | size | 0  | 0  | 0  | 1  | 1  | 0  | V  | Rs | 0  | 0  | 1  | 1  | 0  | opc | Zd | 0 | 0 |   |   |   |   |   |   |

| Decode fields |     | Instruction Details                                                  |  | Feature     |
|---------------|-----|----------------------------------------------------------------------|--|-------------|
| size          | opc |                                                                      |  |             |
| 0x            | 1xx | UNALLOCATED                                                          |  | -           |
| 00            | 0xx | <a href="#">MOVAZ (tile to vector, four registers)</a><br>â€” 8-bit  |  | FEAT_SME2p1 |
| 01            | 0xx | <a href="#">MOVAZ (tile to vector, four registers)</a><br>â€” 16-bit |  | FEAT_SME2p1 |
| 10            | 0xx | <a href="#">MOVAZ (tile to vector, four registers)</a><br>â€” 32-bit |  | FEAT_SME2p1 |
| 10            | 1xx | UNALLOCATED                                                          |  | -           |
| 11            |     | <a href="#">MOVAZ (tile to vector, four registers)</a><br>â€” 64-bit |  | FEAT_SME2p1 |

### SME Add Vector to Array

These instructions are under [SME encodings](#).

|          |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----------|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 31       | 30  | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 11000000 | op0 | 010 | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   | op20 |   |   |   |   |   |   |   |

| Decode fields |     |     | Instruction details |  |
|---------------|-----|-----|---------------------|--|
| op0           | op1 | op2 |                     |  |
| 0             |     |     | UNALLOCATED         |  |

|   |       |   |                                         |
|---|-------|---|-----------------------------------------|
| 1 | 00    | 0 | <a href="#">SME add vector to array</a> |
| 1 | 00    | 1 | UNALLOCATED                             |
| 1 | != 00 |   | UNALLOCATED                             |

## SME add vector to array

These instructions are under [SME Add Vector to Array](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | op | 0  | 1  | 0  | 0  | 0  | V  | Pm | Pn | Zn | 0  | 0  | opc2 |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |      | Instruction Details              | Feature         |
|---------------|---|------|----------------------------------|-----------------|
| op            | V | opc2 |                                  |                 |
| 0             |   | 1xx  | UNALLOCATED                      | -               |
| 0             | 0 | 0xx  | <a href="#">ADDHA</a> â€“ 32-bit | FEAT_SME        |
| 0             | 1 | 0xx  | <a href="#">ADDVA</a> â€“ 32-bit | FEAT_SME        |
| 1             | 0 |      | <a href="#">ADDHA</a> â€“ 64-bit | FEAT_SME_I16I64 |
| 1             | 1 |      | <a href="#">ADDVA</a> â€“ 64-bit | FEAT_SME_I16I64 |

## SME Zero

These instructions are under [SME encodings](#).

|                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1100000000000010 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction details         | Feature  |
|---------------|--|-----------------------------|----------|
| op0           |  |                             |          |
| 0000000000    |  | <a href="#">ZERO (tile)</a> | FEAT_SME |
| != 0000000000 |  | UNALLOCATED                 | -        |

## SME2 Multiple Zero

These instructions are under [SME encodings](#).

|                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1100000000000011 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction details                             |
|---------------|--|-------------------------------------------------|
| op0           |  |                                                 |
| 0000000000    |  | <a href="#">SME multiple vectors zero array</a> |
| != 0000000000 |  | UNALLOCATED                                     |

## SME multiple vectors zero array

These instructions are under [SME2 Multiple Zero](#).

| Decode fields |      | Instruction Details                                           | Feature     |
|---------------|------|---------------------------------------------------------------|-------------|
| opc           | opc2 |                                                               |             |
| x1x           | 1xx  | UNALLOCATED                                                   | -           |
| 000           |      | <u>ZERO (single-vector)</u> â€” <u>two ZA single-vectors</u>  | FEAT_SME2p1 |
| 001           |      | <u>ZERO (double-vector)</u> â€” <u>one ZA double-vector</u>   | FEAT_SME2p1 |
| 010           | 0xx  | <u>ZERO (double-vector)</u> â€” <u>two ZA double-vectors</u>  | FEAT_SME2p1 |
| 011           | 0xx  | <u>ZERO (double-vector)</u> â€” <u>four ZA double-vectors</u> | FEAT_SME2p1 |
| 100           |      | <u>ZERO (single-vector)</u> â€” <u>four ZA single-vectors</u> | FEAT_SME2p1 |
| 101           | 0xx  | <u>ZERO (quad-vector)</u> â€” <u>one ZA quad-vector</u>       | FEAT_SME2p1 |
| 101           | 1xx  | UNALLOCATED                                                   | -           |
| 11x           | 01x  | UNALLOCATED                                                   | -           |
| 110           | 00x  | <u>ZERO (quad-vector)</u> â€” <u>two ZA quad-vectors</u>      | FEAT_SME2p1 |
| 111           | 00x  | <u>ZERO (quad-vector)</u> â€” <u>four ZA quad-vectors</u>     | FEAT_SME2p1 |

## SME2 Zero Lookup Table

These instructions are under [SME encodings](#).

|                                                                                       |                |     |   |
|---------------------------------------------------------------------------------------|----------------|-----|---|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 | 11000000010010 | op0 | 0 |
|---------------------------------------------------------------------------------------|----------------|-----|---|

| Decode fields<br>op0 | Instruction details                    |
|----------------------|----------------------------------------|
| 00000000000000       | <a href="#">SME2 zero lookup table</a> |
| != 00000000000000    | UNALLOCATED                            |

## SME2 zero lookup table

These instructions are under [SME encodings](#).

| <b>Decode fields</b><br><b>opc</b> | <b>Instruction Details</b> | <b>Feature</b> |
|------------------------------------|----------------------------|----------------|
| 0000                               | UNALLOCATED                | -              |
| 0001                               | <a href="#">ZERO (ZT0)</a> | FEAT_SME2      |
| 001x                               | UNALLOCATED                | -              |
| 01xx                               | UNALLOCATED                | -              |
| 1xxx                               | UNALLOCATED                | -              |

### SME2 zero lookup table

These instructions are under [SME2 Zero Lookup Table](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | opc |   |

| <b>Decode fields</b><br><b>opc</b> | <b>Instruction Details</b> | <b>Feature</b> |
|------------------------------------|----------------------------|----------------|
| 0000                               | UNALLOCATED                | -              |
| 0001                               | <a href="#">ZERO (ZT0)</a> | FEAT_SME2      |
| 001x                               | UNALLOCATED                | -              |
| 01xx                               | UNALLOCATED                | -              |
| 1xxx                               | UNALLOCATED                | -              |

### SME2 Move Lookup Table

These instructions are under [SME encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |     |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|-----|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5   | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | op0 | op1 |   |   |   |   |   |

| <b>Decode fields</b><br><b>op0</b> <b>op1</b> |       | <b>Instruction details</b>                  |
|-----------------------------------------------|-------|---------------------------------------------|
| 0                                             | 00    | <a href="#">SME2 move from lookup table</a> |
| 1                                             | 00    | <a href="#">SME2 move into lookup table</a> |
|                                               | != 00 | UNALLOCATED                                 |

### SME2 move from lookup table

These instructions are under [SME2 Move Lookup Table](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |   |     |   |   |   |    |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|---|-----|---|---|---|----|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6 | 5 | 4  | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | imm3 |    |    |    |    |   | opc |   |   |   | Rt |   |   |   |   |

| <b>Decode fields</b><br>opc | <b>Instruction Details</b>           | <b>Feature</b> |
|-----------------------------|--------------------------------------|----------------|
| 000xxxx                     | UNALLOCATED                          | -              |
| 0010xxx                     | UNALLOCATED                          | -              |
| 00110xx                     | UNALLOCATED                          | -              |
| 001110x                     | UNALLOCATED                          | -              |
| 0011110                     | UNALLOCATED                          | -              |
| 0011111                     | <a href="#">MOVT (ZT0 to scalar)</a> | FEAT_SME2      |
| 01xxxxx                     | UNALLOCATED                          | -              |
| 1xxxxxx                     | UNALLOCATED                          | -              |

### SME2 move into lookup table

These instructions are under [SME2 Move Lookup Table](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15   | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | imm3 |    | opc |    | Rt |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b><br>opc | <b>Instruction Details</b>           | <b>Feature</b> |
|-----------------------------|--------------------------------------|----------------|
| 000xxxx                     | UNALLOCATED                          | -              |
| 0010xxx                     | UNALLOCATED                          | -              |
| 00110xx                     | UNALLOCATED                          | -              |
| 001110x                     | UNALLOCATED                          | -              |
| 0011110                     | UNALLOCATED                          | -              |
| 0011111                     | <a href="#">MOVT (scalar to ZT0)</a> | FEAT_SME2      |
| 01xxxxx                     | UNALLOCATED                          | -              |
| 1xxxxxx                     | UNALLOCATED                          | -              |

### SME2 Expand Lookup Table (Contiguous)

These instructions are under [SME encodings](#).

|           |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |
|-----------|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| 31        | 30  | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
| 110000001 | op0 | 001 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | op2 |   |   |   |

| <b>Decode fields</b> |     |       | <b>Instruction details</b>                                         |
|----------------------|-----|-------|--------------------------------------------------------------------|
| op0                  | op1 | op2   |                                                                    |
| 0                    | 00  |       | UNALLOCATED                                                        |
| 0                    | 10  | 00    | <a href="#">SME2 lookup table expand four contiguous registers</a> |
| 0                    | 10  | != 00 | UNALLOCATED                                                        |

|   |    |    |                                                                   |
|---|----|----|-------------------------------------------------------------------|
| 0 | x1 | x0 | <a href="#">SME2 lookup table expand two contiguous registers</a> |
| 0 | x1 | x1 | UNALLOCATED                                                       |
| 1 |    |    | <a href="#">SME2 lookup table expand one register</a>             |

---

### SME2 lookup table expand four contiguous registers

These instructions are under [SME2 Expand Lookup Table \(Contiguous\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |      |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|------|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 | 15   | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | opc | 1  | 0  | size | opc2 | Zn |    | Zd | 0  | 0 |   |   |   |   |   |   |   |   |   |

| Decode fields<br>opc      opc2 |    | Instruction Details                    | Feature   |
|--------------------------------|----|----------------------------------------|-----------|
| 00x                            |    | UNALLOCATED                            | -         |
| 01x                            | 00 | <a href="#">LUTI4 (four registers)</a> | FEAT_SME2 |
| 01x                            | 01 | UNALLOCATED                            | -         |
| 01x                            | 1x | UNALLOCATED                            | -         |
| 1xx                            | 00 | <a href="#">LUTI2 (four registers)</a> | FEAT_SME2 |
| 1xx                            | 01 | UNALLOCATED                            | -         |
| 1xx                            | 1x | UNALLOCATED                            | -         |

---

### SME2 lookup table expand two contiguous registers

These instructions are under [SME2 Expand Lookup Table \(Contiguous\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |      |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16   | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | opc | 1  | size | opc2 | Zn |    | Zd | 0  |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>opc      opc2 |    | Instruction Details                   | Feature   |
|--------------------------------|----|---------------------------------------|-----------|
| 00xx                           |    | UNALLOCATED                           | -         |
| 01xx                           | 00 | <a href="#">LUTI4 (two registers)</a> | FEAT_SME2 |
| 01xx                           | 01 | UNALLOCATED                           | -         |
| 01xx                           | 1x | UNALLOCATED                           | -         |
| 1xxx                           | 00 | <a href="#">LUTI2 (two registers)</a> | FEAT_SME2 |
| 1xxx                           | 01 | UNALLOCATED                           | -         |
| 1xxx                           | 1x | UNALLOCATED                           | -         |

---

### SME2 lookup table expand one register

These instructions are under [SME2 Expand Lookup Table \(Contiguous\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |     |      |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18   | 17   | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | opc | size | opc2 | Zn |    | Zd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields**  
**opc      opc2**

### Instruction Details

### Feature

|        |    |                                |           |
|--------|----|--------------------------------|-----------|
| 00xxxx |    | UNALLOCATED                    | -         |
| 01xxxx | 00 | <a href="#">LUTI4 (single)</a> | FEAT_SME2 |
| 01xxxx | 01 | UNALLOCATED                    | -         |
| 01xxxx | 1x | UNALLOCATED                    | -         |
| 1xxxxx | 00 | <a href="#">LUTI2 (single)</a> | FEAT_SME2 |
| 1xxxxx | 01 | UNALLOCATED                    | -         |
| 1xxxxx | 1x | UNALLOCATED                    | -         |

## SME2 Expand Lookup Table (Non-contiguous)

These instructions are under [SME encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |      |      |    |    |     |    |   |     |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|------|------|----|----|-----|----|---|-----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 | 15   | 14   | 13 | 12 | 11  | 10 | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | opc | 1  | 0  | size | opc2 | Zn |    | Zdh | 0  | 0 | Zdl |   |   |   |   |   |   |   |   |

**Decode fields**  
**op0      op1**

### Instruction details

|       |    |                                                                        |
|-------|----|------------------------------------------------------------------------|
| 00    |    | UNALLOCATED                                                            |
| 10    | 00 | <a href="#">SME2 lookup table expand four non-contiguous registers</a> |
| 10    | 01 | UNALLOCATED                                                            |
| != 00 | 1x | UNALLOCATED                                                            |
| x1    | 0x | <a href="#">SME2 lookup table expand two non-contiguous registers</a>  |

## SME2 lookup table expand four non-contiguous registers

These instructions are under [SME2 Expand Lookup Table \(Non-contiguous\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |      |      |    |    |     |    |   |     |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|------|------|----|----|-----|----|---|-----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 | 15   | 14   | 13 | 12 | 11  | 10 | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | opc | 1  | 0  | size | opc2 | Zn |    | Zdh | 0  | 0 | Zdl |   |   |   |   |   |   |   |   |

**Decode fields**  
**opc      opc2**

### Instruction Details

### Feature

|     |    |                                        |             |
|-----|----|----------------------------------------|-------------|
| 00x |    | UNALLOCATED                            | -           |
| 01x | 00 | <a href="#">LUTI4 (four registers)</a> | FEAT_SME2p1 |
| 01x | 01 | UNALLOCATED                            | -           |

| Decode fields |      | Instruction Details                    |             | Feature |
|---------------|------|----------------------------------------|-------------|---------|
| opc           | opc2 |                                        |             |         |
| 01x           | 1x   | UNALLOCATED                            | -           |         |
| 1xx           | 00   | <a href="#">LUTI2 (four registers)</a> | FEAT_SME2p1 |         |
| 1xx           | 01   | UNALLOCATED                            | -           |         |
| 1xx           | 1x   | UNALLOCATED                            | -           |         |

### SME2 lookup table expand two non-contiguous registers

These instructions are under [SME2 Expand Lookup Table \(Non-contiguous\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |      |      |    |     |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|------|------|----|-----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15   | 14   | 13 | 12  | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  |    | opc | 1  | size | opc2 | Zn | Zdh | 0  | Zdl |   |   |   |   |   |   |   |   |   |   |

| Decode fields |      | Instruction Details                   |             | Feature |
|---------------|------|---------------------------------------|-------------|---------|
| opc           | opc2 |                                       |             |         |
| 00xx          |      | UNALLOCATED                           | -           |         |
| 01xx          | 00   | <a href="#">LUTI4 (two registers)</a> | FEAT_SME2p1 |         |
| 01xx          | 01   | UNALLOCATED                           | -           |         |
| 01xx          | 1x   | UNALLOCATED                           | -           |         |
| 1xxx          | 00   | <a href="#">LUTI2 (two registers)</a> | FEAT_SME2p1 |         |
| 1xxx          | 01   | UNALLOCATED                           | -           |         |
| 1xxx          | 1x   | UNALLOCATED                           | -           |         |

### SME2 Multi-vector - Indexed (One register)

These instructions are under [SME encodings](#).

|    |    |    |    |    |          |    |     |    |    |    |    |    |    |    |    |    |    |    |     |    |    |   |   |   |   |   |   |     |   |   |   |
|----|----|----|----|----|----------|----|-----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|---|---|---|---|---|---|-----|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26       | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|    |    |    |    |    | 11000001 |    | op0 | 00 |    |    |    |    |    |    |    |    |    |    | op1 |    |    |   |   |   |   |   |   | op2 |   |   |   |

| Decode fields |     |     | Instruction details                                                    |
|---------------|-----|-----|------------------------------------------------------------------------|
| op0           | op1 | op2 |                                                                        |
| 00            |     |     | <a href="#">SME2 multi-vec indexed long long MLA one source 32-bit</a> |
| 01            |     |     | UNALLOCATED                                                            |
| 10            | 0   | 0   | <a href="#">SME2 multi-vec indexed long long MLA one source 64-bit</a> |
| 10            | 0   | 1   | UNALLOCATED                                                            |
| 10            | 1   |     | <a href="#">SME2 multi-vec indexed long FMA one source</a>             |
| 11            | 0   |     | UNALLOCATED                                                            |
| 11            | 1   |     | <a href="#">SME2 multi-vec indexed long MLA one source</a>             |

## SME2 multi-vec indexed long long MLA one source 32-bit

These instructions are under [SME2 Multi-vector - Indexed \(One register\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | Zm | i4h | Rv | i4l |    |    | Zn | U  | S  | op | off2 |   |   |   |   |   |   |   |   |   |

| Decode fields |   |    | Instruction Details                                   |  |  | Feature   |  |  |
|---------------|---|----|-------------------------------------------------------|--|--|-----------|--|--|
| U             | S | op |                                                       |  |  |           |  |  |
|               | 1 | 1  | UNALLOCATED                                           |  |  | -         |  |  |
| 0             | 0 | 0  | <a href="#">SMLALL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |  |  |
| 0             | 0 | 1  | <a href="#">USMLALL (multiple and indexed vector)</a> |  |  | FEAT_SME2 |  |  |
| 0             | 1 | 0  | <a href="#">SMLSLL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |  |  |
| 1             | 0 | 0  | <a href="#">UMLALL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |  |  |
| 1             | 0 | 1  | <a href="#">SUMLALL (multiple and indexed vector)</a> |  |  | FEAT_SME2 |  |  |
| 1             | 1 | 0  | <a href="#">UMLSLL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |  |  |

## SME2 multi-vec indexed long long MLA one source 64-bit

These instructions are under [SME2 Multi-vector - Indexed \(One register\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |     |    |    |    |    |    |   |      |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|-----|----|----|----|----|----|---|------|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | Zm | i3h | Rv | 0  | i3l |    |    | Zn | U  | S  | 0 | off2 |   |   |   |   |   |   |   |   |

| Decode fields |   |  | Instruction Details                                  |  |  | Feature         |  |  |
|---------------|---|--|------------------------------------------------------|--|--|-----------------|--|--|
| U             | S |  |                                                      |  |  |                 |  |  |
| 0             | 0 |  | <a href="#">SMLALL (multiple and indexed vector)</a> |  |  | FEAT_SME_I16I64 |  |  |
| 0             | 1 |  | <a href="#">SMLSLL (multiple and indexed vector)</a> |  |  | FEAT_SME_I16I64 |  |  |
| 1             | 0 |  | <a href="#">UMLALL (multiple and indexed vector)</a> |  |  | FEAT_SME_I16I64 |  |  |
| 1             | 1 |  | <a href="#">UMLSLL (multiple and indexed vector)</a> |  |  | FEAT_SME_I16I64 |  |  |

## SME2 multi-vec indexed long FMA one source

These instructions are under [SME2 Multi-vector - Indexed \(One register\)](#).

| Decode fields |   | Instruction Details                                  | Feature   |
|---------------|---|------------------------------------------------------|-----------|
| op            | s |                                                      |           |
| 0             | 0 | <a href="#">FMLAL (multiple and indexed vector)</a>  | FEAT_SME2 |
| 0             | 1 | <a href="#">FMLS (multiple and indexed vector)</a>   | FEAT_SME2 |
| 1             | 0 | <a href="#">BFMLAL (multiple and indexed vector)</a> | FEAT_SME2 |
| 1             | 1 | <a href="#">BFMLS (multiple and indexed vector)</a>  | FEAT_SME2 |

**SME2 multi-vec indexed long MLA one source**

These instructions are under [SME2 Multi-vector - Indexed \(One register\)](#).

| Decode fields |   | Instruction Details                                  | Feature   |
|---------------|---|------------------------------------------------------|-----------|
| U             | S |                                                      |           |
| 0             | 0 | <a href="#">SMLAL (multiple and indexed vector)</a>  | FEAT_SME2 |
| 0             | 1 | <a href="#">SMLS L (multiple and indexed vector)</a> | FEAT_SME2 |
| 1             | 0 | <a href="#">UMLAL (multiple and indexed vector)</a>  | FEAT_SME2 |
| 1             | 1 | <a href="#">UMLSL (multiple and indexed vector)</a>  | FEAT_SME2 |

## SME2 Multi-vector - Indexed (Two registers)

These instructions are under [SME encodings](#).

|          |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |     |   |   |   |   |   |
|----------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|---|
| 31       | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1 | 0 |
| 11000001 | op0 | 01 |    |    |    |    |    |    |    |    |    |    |    |    | 0  | op1 |    |    |    |    |    |   |   |   |   | op2 |   |   |   |   |   |

| Decode fields |     |     | Instruction details                                                     |
|---------------|-----|-----|-------------------------------------------------------------------------|
| op0           | op1 | op2 |                                                                         |
| 00            | 0x  |     | <a href="#">SME2 multi-vec indexed long long MLA two sources 32-bit</a> |
| 00            | 1x  |     | <a href="#">SME2 multi-vec ternary indexed two registers 16-bit</a>     |

|    |    |   |                                                                         |
|----|----|---|-------------------------------------------------------------------------|
| 01 |    |   | <a href="#">SME2 multi-vec ternary indexed two registers 32-bit</a>     |
| 10 | 00 | 0 | <a href="#">SME2 multi-vec indexed long long MLA two sources 64-bit</a> |
| 10 | 1x | 0 | <a href="#">SME2 multi-vec indexed long FMA two sources</a>             |
| 11 | 00 | 0 | <a href="#">SME2 multi-vec ternary indexed two registers 64-bit</a>     |
| 11 | 1x | 0 | <a href="#">SME2 multi-vec indexed long MLA two sources</a>             |
| 1x | 00 | 1 | UNALLOCATED                                                             |
| 1x | 01 |   | UNALLOCATED                                                             |
| 1x | 1x | 1 | UNALLOCATED                                                             |

## SME2 multi-vec indexed long long MLA two sources 32-bit

These instructions are under [SME2 Multi-vector - Indexed \(Two registers\)](#).

| Decode fields |   |   | Instruction Details                                   | Feature   |
|---------------|---|---|-------------------------------------------------------|-----------|
| op            | U | S |                                                       |           |
| 0             | 0 | 0 | <a href="#">SMLALL (multiple and indexed vector)</a>  | FEAT_SME2 |
| 0             | 0 | 1 | <a href="#">SMLSLL (multiple and indexed vector)</a>  | FEAT_SME2 |
| 0             | 1 | 0 | <a href="#">UMLALL (multiple and indexed vector)</a>  | FEAT_SME2 |
| 0             | 1 | 1 | <a href="#">UMLSLL (multiple and indexed vector)</a>  | FEAT_SME2 |
| 1             |   | 1 | UNALLOCATED                                           | -         |
| 1             | 0 | 0 | <a href="#">USMLALL (multiple and indexed vector)</a> | FEAT_SME2 |
| 1             | 1 | 0 | <a href="#">SUMLALL (multiple and indexed vector)</a> | FEAT_SME2 |

## SME2 multi-vec ternary indexed two registers 16-bit

These instructions are under [SME2 Multi-vector - Indexed \(Two registers\)](#).

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0  
| 1 1 0 0 0 0 1 0 0 0 1 | Zm | 0 | Rv | 1 | i3h | Zn | op | S | i3l | off3

| Decode fields |   | Instruction Details                                 | Feature         |
|---------------|---|-----------------------------------------------------|-----------------|
| op            | S |                                                     |                 |
| 0             | 0 | <a href="#">FMLA (multiple and indexed vector)</a>  | FEAT_SME_F16F16 |
| 0             | 1 | <a href="#">FMLS (multiple and indexed vector)</a>  | FEAT_SME_F16F16 |
| 1             | 0 | <a href="#">BFMLA (multiple and indexed vector)</a> | FEAT_SVE_B16B16 |
| 1             | 1 | <a href="#">BFMLS (multiple and indexed vector)</a> | FEAT_SVE_B16B16 |

## SME2 multi-vec ternary indexed two registers 32-bit

These instructions are under [SME2 Multi-vector - Indexed \(Two registers\)](#).

| Decode fields |      | Instruction Details                                       | Feature   |
|---------------|------|-----------------------------------------------------------|-----------|
| op            | opc2 |                                                           |           |
| 0             | 000  | <a href="#">FMLA (multiple and indexed vector)</a>        | FEAT_SME2 |
| 0             | 001  | <a href="#">FVDOT</a>                                     | FEAT_SME2 |
| 0             | 010  | <a href="#">FMLS (multiple and indexed vector)</a>        | FEAT_SME2 |
| 0             | 011  | <a href="#">BFVTDOT</a>                                   | FEAT_SME2 |
| 0             | 1x1  | UNALLOCATED                                               | -         |
| 0             | 100  | <a href="#">SVDOT (2-way)</a>                             | FEAT_SME2 |
| 0             | 110  | <a href="#">UVDOT (2-way)</a>                             | FEAT_SME2 |
| 1             | 000  | <a href="#">SDOT (2-way, multiple and indexed vector)</a> | FEAT_SME2 |
| 1             | 001  | <a href="#">FDOT (multiple and indexed vector)</a>        | FEAT_SME2 |
| 1             | 010  | <a href="#">UDOT (2-way, multiple and indexed vector)</a> | FEAT_SME2 |
| 1             | 011  | <a href="#">BFDOT (multiple and indexed vector)</a>       | FEAT_SME2 |
| 1             | 100  | <a href="#">SDOT (4-way, multiple and indexed vector)</a> | FEAT_SME2 |
| 1             | 101  | <a href="#">USDOT (multiple and indexed vector)</a>       | FEAT_SME2 |
| 1             | 110  | <a href="#">UDOT (4-way, multiple and indexed vector)</a> | FEAT_SME2 |
| 1             | 111  | <a href="#">SUDOT (multiple and indexed vector)</a>       | FEAT_SME2 |

## SME2 multi-vec indexed long long MLA two sources 64-bit

These instructions are under [SME2 Multi-vector - Indexed \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |     |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | Zm | 0  | Rv | 0  | 0  | i3h | Zn | 0  | U  | S  | i3l | o1 |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                  |  |  |  |  |  |  |  |  |  | Feature         |  |  |  |  |  |  |  |  |  |
|---------------|---|------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|
| U             | S |                                                      |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |
| 0             | 0 | <a href="#">SMLALL (multiple and indexed vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME_I16I64 |  |  |  |  |  |  |  |  |  |
| 0             | 1 | <a href="#">SMLSLL (multiple and indexed vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME_I16I64 |  |  |  |  |  |  |  |  |  |
| 1             | 0 | <a href="#">UMLALL (multiple and indexed vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME_I16I64 |  |  |  |  |  |  |  |  |  |
| 1             | 1 | <a href="#">UMLSL (multiple and indexed vector)</a>  |  |  |  |  |  |  |  |  |  | FEAT_SME_I16I64 |  |  |  |  |  |  |  |  |  |

## SME2 multi-vec indexed long FMA two sources

These instructions are under [SME2 Multi-vector - Indexed \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |     |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|-----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10  | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | Zm | 0  | Rv | 1  | i3h | Zn | 0  | op | S  | i3l | off2 |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                  |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |  |  |  |  |
|---------------|---|------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|--|--|
| op            | S |                                                      |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |
| 0             | 0 | <a href="#">FMLAL (multiple and indexed vector)</a>  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |
| 0             | 1 | <a href="#">FMLSL (multiple and indexed vector)</a>  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |
| 1             | 0 | <a href="#">BFMLAL (multiple and indexed vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |
| 1             | 1 | <a href="#">BFMLSL (multiple and indexed vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |

## SME2 multi-vec ternary indexed two registers 64-bit

These instructions are under [SME2 Multi-vector - Indexed \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | Zm | 0  | Rv | 0  | 0  | i1 | Zn | 0  | opc |    | off3 |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b>                                |  |  | <b>Feature</b>  |
|----------------------|-----------------------------------------------------------|--|--|-----------------|
| <b>opc</b>           |                                                           |  |  |                 |
| 00                   | <a href="#">FMLA (multiple and indexed vector)</a>        |  |  | FEAT_SME_F64F64 |
| 01                   | <a href="#">SDOT (4-way, multiple and indexed vector)</a> |  |  | FEAT_SME_I16I64 |
| 10                   | <a href="#">FMLS (multiple and indexed vector)</a>        |  |  | FEAT_SME_F64F64 |
| 11                   | <a href="#">UDOT (4-way, multiple and indexed vector)</a> |  |  | FEAT_SME_I16I64 |

### SME2 multi-vec indexed long MLA two sources

These instructions are under [SME2 Multi-vector - Indexed \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |     |      |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|-----|------|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10  | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | Zm | 0  | Rv | 1  | i3h | Zn | 0  | U  | S  | i3l | off2 |   |   |   |   |   |   |   |   |   |  |

| <b>Decode fields</b> | <b>Instruction Details</b> |                                                     |  | <b>Feature</b> |
|----------------------|----------------------------|-----------------------------------------------------|--|----------------|
| <b>U</b>             | <b>S</b>                   |                                                     |  |                |
| 0                    | 0                          | <a href="#">SMLAL (multiple and indexed vector)</a> |  |                |
| 0                    | 1                          | <a href="#">SMLSL (multiple and indexed vector)</a> |  |                |
| 1                    | 0                          | <a href="#">UMLAL (multiple and indexed vector)</a> |  |                |
| 1                    | 1                          | <a href="#">UMLSL (multiple and indexed vector)</a> |  |                |

### SME2 Multi-vector - Indexed (Four registers)

These instructions are under [SME encodings](#).

|          |    |    |     |    |    |    |    |    |     |    |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----------|----|----|-----|----|----|----|----|----|-----|----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31       | 30 | 29 | 28  | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 11000001 |    |    | op0 | 01 |    |    | 1  |    | op1 |    | op2 |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| <b>Decode fields</b> | <b>Instruction details</b> |            |                                                                          |
|----------------------|----------------------------|------------|--------------------------------------------------------------------------|
| <b>op0</b>           | <b>op1</b>                 | <b>op2</b> |                                                                          |
| 00                   | 0x                         | 0x         | <a href="#">SME2 multi-vec indexed long long MLA four sources 32-bit</a> |
| 00                   | 1x                         | 0x         | <a href="#">SME2 multi-vec ternary indexed four registers 16-bit</a>     |
| 01                   |                            | 0x         | <a href="#">SME2 multi-vec ternary indexed four registers 32-bit</a>     |
| 0x                   |                            | 1x         | UNALLOCATED                                                              |

|    |    |           |                                                                          |
|----|----|-----------|--------------------------------------------------------------------------|
| 10 | 00 | 00        | <a href="#">SME2 multi-vec indexed long long MLA four sources 64-bit</a> |
| 10 | 00 | $\neq$ 00 | UNALLOCATED                                                              |
| 10 | 01 |           | UNALLOCATED                                                              |
| 10 | 1x | 00        | <a href="#">SME2 multi-vec indexed long FMA four sources</a>             |
| 10 | 1x | $\neq$ 00 | UNALLOCATED                                                              |
| 11 | 0x | 00        | <a href="#">SME2 multi-vec ternary indexed four registers 64-bit</a>     |
| 11 | 1x | 00        | <a href="#">SME2 multi-vec indexed long MLA four sources</a>             |
| 11 |    | $\neq$ 00 | UNALLOCATED                                                              |

### SME2 multi-vec indexed long long MLA four sources 32-bit

These instructions are under [SME2 Multi-vector - Indexed \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | Zm | 1  | Rv | 0  | i4h | Zn | 0  | op | U  | S  | i4l | o1 |   |   |   |   |   |   |   |   |

| Decode fields |   |   | Instruction Details                                   |  |  | Feature   |
|---------------|---|---|-------------------------------------------------------|--|--|-----------|
| op            | U | S |                                                       |  |  |           |
| 0             | 0 | 0 | <a href="#">SMLALL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |
| 0             | 0 | 1 | <a href="#">SMLSLL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |
| 0             | 1 | 0 | <a href="#">UMLALL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |
| 0             | 1 | 1 | <a href="#">UMLSLL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |
| 1             |   | 1 | UNALLOCATED                                           |  |  | -         |
| 1             | 0 | 0 | <a href="#">USMLALL (multiple and indexed vector)</a> |  |  | FEAT_SME2 |
| 1             | 1 | 0 | <a href="#">SUMLALL (multiple and indexed vector)</a> |  |  | FEAT_SME2 |

### SME2 multi-vec ternary indexed four registers 16-bit

These instructions are under [SME2 Multi-vector - Indexed \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |     |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|-----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10  | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | Zm | 1  | Rv | 1  | i3h | Zn | 0  | op | S  | i3l | off3 |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                 |  |  |  | Feature         |
|---------------|---|-----------------------------------------------------|--|--|--|-----------------|
| op            | S |                                                     |  |  |  |                 |
| 0             | 0 | <a href="#">FMLA (multiple and indexed vector)</a>  |  |  |  | FEAT_SME_F16F16 |
| 0             | 1 | <a href="#">FMLS (multiple and indexed vector)</a>  |  |  |  | FEAT_SME_F16F16 |
| 1             | 0 | <a href="#">BFMLA (multiple and indexed vector)</a> |  |  |  | FEAT_SVE_B16B16 |
| 1             | 1 | <a href="#">BFMLS (multiple and indexed vector)</a> |  |  |  | FEAT_SVE_B16B16 |

### SME2 multi-vec ternary indexed four registers 32-bit

These instructions are under [SME2 Multi-vector - Indexed \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 1  | Zm | 1  | Rv | op | i2 | Zn | 0  | opc2 | off3 |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |      | Instruction Details                                       |  |  |  | Feature   |
|---------------|------|-----------------------------------------------------------|--|--|--|-----------|
| op            | opc2 |                                                           |  |  |  |           |
| 0             | 0x1  | UNALLOCATED                                               |  |  |  | -         |
| 0             | 000  | <a href="#">FMLA (multiple and indexed vector)</a>        |  |  |  | FEAT_SME2 |
| 0             | 010  | <a href="#">FMLS (multiple and indexed vector)</a>        |  |  |  | FEAT_SME2 |
| 0             | 100  | <a href="#">SVDOT (4-way)</a>                             |  |  |  | FEAT_SME2 |
| 0             | 101  | <a href="#">USVDOT</a>                                    |  |  |  | FEAT_SME2 |
| 0             | 110  | <a href="#">UVDOT (4-way)</a>                             |  |  |  | FEAT_SME2 |
| 0             | 111  | <a href="#">SUVDOT</a>                                    |  |  |  | FEAT_SME2 |
| 1             | 000  | <a href="#">SDOT (2-way, multiple and indexed vector)</a> |  |  |  | FEAT_SME2 |
| 1             | 001  | <a href="#">FDOT (multiple and indexed vector)</a>        |  |  |  | FEAT_SME2 |
| 1             | 010  | <a href="#">UDOT (2-way, multiple and indexed vector)</a> |  |  |  | FEAT_SME2 |
| 1             | 011  | <a href="#">BFDOT (multiple and indexed vector)</a>       |  |  |  | FEAT_SME2 |
| 1             | 100  | <a href="#">SDOT (4-way, multiple and indexed vector)</a> |  |  |  | FEAT_SME2 |
| 1             | 101  | <a href="#">USDOT (multiple and indexed vector)</a>       |  |  |  | FEAT_SME2 |
| 1             | 110  | <a href="#">UDOT (4-way, multiple and indexed vector)</a> |  |  |  | FEAT_SME2 |
| 1             | 111  | <a href="#">SUDOT (multiple and indexed vector)</a>       |  |  |  | FEAT_SME2 |

## SME2 multi-vec indexed long long MLA four sources 64-bit

These instructions are under [SME2 Multi-vector - Indexed \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |   |     |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|---|-----|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8   | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | Zm | 1  | Rv | 0  | 0  | i3h | Zn | 0  | 0  | U  | S | i3l | o1 |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                  |  |  |  |  |  |  |  |  |  |  |  | Feature         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| U             | S |                                                      |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 0 | <a href="#">SMLALL (multiple and indexed vector)</a> |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME_I16I64 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 1 | <a href="#">SMLSLL (multiple and indexed vector)</a> |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME_I16I64 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             | 0 | <a href="#">UMLALL (multiple and indexed vector)</a> |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME_I16I64 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             | 1 | <a href="#">UMLSL (multiple and indexed vector)</a>  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME_I16I64 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## SME2 multi-vec indexed long FMA four sources

These instructions are under [SME2 Multi-vector - Indexed \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |     |      |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|-----|------|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | Zm | 1  | Rv | 1  | i3h | Zn | 0  | 0  | op | S  | i3l | off2 |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                  |  |  |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| op            | S |                                                      |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 0 | <a href="#">FMLAL (multiple and indexed vector)</a>  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 1 | <a href="#">FMLS (multiple and indexed vector)</a>   |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             | 0 | <a href="#">BFMLAL (multiple and indexed vector)</a> |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             | 1 | <a href="#">BFMLS (multiple and indexed vector)</a>  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## SME2 multi-vec ternary indexed four registers 64-bit

These instructions are under [SME2 Multi-vector - Indexed \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | Zm | 1  | Rv | 0  | op | i1 | Zn | 0  | 0  | opc2 | off3 |   |   |   |   |   |   |   |   |   |

| Decode fields |      | Instruction Details                                       |  |  | Feature         |
|---------------|------|-----------------------------------------------------------|--|--|-----------------|
| op            | opc2 |                                                           |  |  |                 |
| 0             | 00   | <a href="#">FMLA (multiple and indexed vector)</a>        |  |  | FEAT_SME_F64F64 |
| 0             | 01   | <a href="#">SDOT (4-way, multiple and indexed vector)</a> |  |  | FEAT_SME_I16I64 |
| 0             | 10   | <a href="#">FMLS (multiple and indexed vector)</a>        |  |  | FEAT_SME_F64F64 |
| 0             | 11   | <a href="#">UDOT (4-way, multiple and indexed vector)</a> |  |  | FEAT_SME_I16I64 |
| 1             | x0   | UNALLOCATED                                               |  |  | -               |
| 1             | 01   | <a href="#">SVDOT (4-way)</a>                             |  |  | FEAT_SME_I16I64 |
| 1             | 11   | <a href="#">UVDOT (4-way)</a>                             |  |  | FEAT_SME_I16I64 |

### SME2 multi-vec indexed long MLA four sources

These instructions are under [SME2 Multi-vector - Indexed \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | Zm | 1  | Rv | 1  | i3h | Zn | 0  | 0  | U  | S  | i3 | off2 |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                  |  |  | Feature   |
|---------------|---|------------------------------------------------------|--|--|-----------|
| U             | S |                                                      |  |  |           |
| 0             | 0 | <a href="#">SMLAL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |
| 0             | 1 | <a href="#">SMLS L (multiple and indexed vector)</a> |  |  | FEAT_SME2 |
| 1             | 0 | <a href="#">UMLAL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |
| 1             | 1 | <a href="#">UMLSL (multiple and indexed vector)</a>  |  |  | FEAT_SME2 |

### SME2 Multi-vector - SVE Select

These instructions are under [SME encodings](#).

|          |    |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |   |     |   |   |   |   |   |   |
|----------|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|---|-----|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26  | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
| 11000001 |    |    | 1  |    | op0 | 100 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | op1 |   | op2 |   |   |   |   |   |   |

| Decode fields |       |       | Instruction details                    |  | Feature   |
|---------------|-------|-------|----------------------------------------|--|-----------|
| op0           | op1   | op2   |                                        |  |           |
| 01            | 00    | 00    | <a href="#">SEL â€” Four registers</a> |  | FEAT_SME2 |
| 01            | 00    | != 00 | UNALLOCATED                            |  | -         |
| 01            | != 00 |       | UNALLOCATED                            |  | -         |

|    |    |    |                                     |           |
|----|----|----|-------------------------------------|-----------|
| 11 |    |    | UNALLOCATED                         | -         |
| x0 | x0 | x0 | <a href="#">SEL “ Two registers</a> | FEAT_SME2 |
| x0 | x0 | x1 | UNALLOCATED                         | -         |
| x0 | x1 |    | UNALLOCATED                         | -         |

## SME2 Multi-vector - SVE Constructive Binary

These instructions are under [SME encodings](#).

|                                                                                       |
|---------------------------------------------------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| 11000001   op0   1   110   op1   0   op2                                              |

| Decode fields |     |     | Instruction details                                                         |
|---------------|-----|-----|-----------------------------------------------------------------------------|
| op0           | op1 | op2 |                                                                             |
| 00            | 101 |     | <a href="#">SME2 multi-vec quadwords ZIP two registers</a>                  |
| 01            | 101 |     | UNALLOCATED                                                                 |
| 10            | 101 |     | UNALLOCATED                                                                 |
| 11            | 101 |     | <a href="#">SME2 multi-vec saturating shift right narrow two registers</a>  |
|               | 000 |     | <a href="#">SME2 multi-vec FCLAMP two registers</a>                         |
|               | 001 |     | <a href="#">SME2 multi-vec CLAMP two registers</a>                          |
|               | 010 | 0   | <a href="#">SME2 multi-vec FCLAMP four registers</a>                        |
|               | 011 | 0   | <a href="#">SME2 multi-vec CLAMP four registers</a>                         |
|               | 01x | 1   | UNALLOCATED                                                                 |
|               | 100 |     | <a href="#">SME2 multi-vec ZIP two registers</a>                            |
|               | 11x |     | <a href="#">SME2 multi-vec saturating shift right narrow four registers</a> |

## SME2 multi-vec quadwords ZIP two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Binary](#).

|                                                                                       |
|---------------------------------------------------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| 1 1 0 0 0 0 0 1 0 0 1   Zm   1 1 0 1 0 1   Zn   Zd   op                               |

| Decode fields | Instruction Details                 | Feature   |
|---------------|-------------------------------------|-----------|
| op            |                                     |           |
| 0             | <a href="#">ZIP (two registers)</a> | FEAT_SME2 |
| 1             | <a href="#">UZP (two registers)</a> | FEAT_SME2 |

## SME2 multi-vec saturating shift right narrow two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Binary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | op | imm4 | 1  | 1  | 0  | 1  | 0  | 1  | Zn | U  | Zd |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                     |  |  |  | Feature   |  |
|---------------|---|-----------------------------------------|--|--|--|-----------|--|
| op            | U |                                         |  |  |  |           |  |
| 0             | 0 | <a href="#">SQRSHR (two registers)</a>  |  |  |  | FEAT_SME2 |  |
| 0             | 1 | <a href="#">UQRSHR (two registers)</a>  |  |  |  | FEAT_SME2 |  |
| 1             | 0 | <a href="#">SQRSHRU (two registers)</a> |  |  |  | FEAT_SME2 |  |
| 1             | 1 | UNALLOCATED                             |  |  |  | -         |  |

### SME2 multi-vec FCLAMP two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Binary](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 1  | 1  | 0  | 0  | 0  | 0  | Zn |    | Zd | op |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |    | Instruction Details     |  |  |  | Feature         |  |
|---------------|----|-------------------------|--|--|--|-----------------|--|
| size          | op |                         |  |  |  |                 |  |
|               | 1  | UNALLOCATED             |  |  |  | -               |  |
| != 00         | 0  | <a href="#">FCLAMP</a>  |  |  |  | FEAT_SME2       |  |
| 00            | 0  | <a href="#">BFCLAMP</a> |  |  |  | FEAT_SVE_B16B16 |  |

### SME2 multi-vec CLAMP two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Binary](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 1  | 1  | 0  | 0  | 0  | 1  | Zn |    | Zd | U  |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details    |  |  |  | Feature   |  |
|---------------|--|------------------------|--|--|--|-----------|--|
| U             |  |                        |  |  |  |           |  |
| 0             |  | <a href="#">SCLAMP</a> |  |  |  | FEAT_SME2 |  |
| 1             |  | <a href="#">UCLAMP</a> |  |  |  | FEAT_SME2 |  |

### SME2 multi-vec FCLAMP four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Binary](#).

| <b>Decode fields</b> |           | <b>Instruction Details</b> | <b>Feature</b>  |
|----------------------|-----------|----------------------------|-----------------|
| <b>size</b>          | <b>op</b> |                            |                 |
|                      | 1         | UNALLOCATED                | -               |
| != 00                | 0         | <a href="#">FCLAMP</a>     | FEAT_SME2       |
| 00                   | 0         | <a href="#">BFCLAMP</a>    | FEAT_SVE_B16B16 |

## SME2 multi-vec CLAMP four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Binary](#).

| <b>Decode fields</b> | <b>Instruction Details</b> | <b>Feature</b> |
|----------------------|----------------------------|----------------|
| U                    | <a href="#">SCLAMP</a>     | FEAT_SME2      |
| 1                    | <a href="#">UCLAMP</a>     | FEAT_SME2      |

## SME2 multi-vec ZIP two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Binary](#).

| <b>Decode fields<br/>op</b> | <b>Instruction Details</b>          | <b>Feature</b> |
|-----------------------------|-------------------------------------|----------------|
| 0                           | <a href="#">ZIP (two registers)</a> | FEAT_SME2      |
| 1                           | <a href="#">UZP (two registers)</a> | FEAT_SME2      |

## SME2 multi-vec saturating shift right narrow four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Binary](#).

| Decode fields |    |   | Instruction Details                      | Feature   |
|---------------|----|---|------------------------------------------|-----------|
| N             | op | U |                                          |           |
|               | 1  | 1 | UNALLOCATED                              | -         |
| 0             | 0  | 0 | <a href="#">SQRSHR (four registers)</a>  | FEAT_SME2 |
| 0             | 0  | 1 | <a href="#">UQRSHR (four registers)</a>  | FEAT_SME2 |
| 0             | 1  | 0 | <a href="#">SQRSHRU (four registers)</a> | FEAT_SME2 |
| 1             | 0  | 0 | <a href="#">SQRSHRN</a>                  | FEAT_SME2 |
| 1             | 0  | 1 | <a href="#">UQRSHRN</a>                  | FEAT_SME2 |
| 1             | 1  | 0 | <a href="#">SQRSHRUN</a>                 | FEAT_SME2 |

## SME2 Multi-vector - SVE Constructive Unary

These instructions are under [SME encodings](#).

|          |    |     |    |    |     |    |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |   |   |     |   |   |   |   |   |
|----------|----|-----|----|----|-----|----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|---|---|-----|---|---|---|---|---|
| 31       | 30 | 29  | 28 | 27 | 26  | 25 | 24     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6 | 5   | 4 | 3 | 2 | 1 | 0 |
|          |    |     |    |    |     |    |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |   |   |     |   |   |   |   |   |
| 11000001 |    | op0 | 1  |    | op1 |    | 111000 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | op2 |   |   | op3 |   |   |   |   |   |

| op0 | Decode fields |       |       | Instruction details                                             |
|-----|---------------|-------|-------|-----------------------------------------------------------------|
|     | op1           | op2   | op3   |                                                                 |
| 00  | 00001         |       | x0    | <a href="#">SME2 multi-vec FP to int convert two registers</a>  |
| 00  | 00001         |       | x1    | UNALLOCATED                                                     |
| 00  | 00010         |       | x0    | <a href="#">SME2 multi-vec int to FP two registers</a>          |
| 00  | 00010         |       | x1    | UNALLOCATED                                                     |
| 00  | 00100         |       |       | UNALLOCATED                                                     |
| 00  | 10001         | 0x    | 00    | <a href="#">SME2 multi-vec FP to int convert four registers</a> |
| 00  | 10001         | 0x    | != 00 | UNALLOCATED                                                     |
| 00  | 10001         | 1x    |       | UNALLOCATED                                                     |
| 00  | 10010         | 0x    | 00    | <a href="#">SME2 multi-vec int to FP four registers</a>         |
| 00  | 10010         | 0x    | != 00 | UNALLOCATED                                                     |
| 00  | 10010         | 1x    |       | UNALLOCATED                                                     |
| 00  | 10111         | 00    | x0    | <a href="#">SME2 multi-vec quadwords ZIP four registers</a>     |
| 00  | 1011x         | 00    | x1    | UNALLOCATED                                                     |
| 00  | 1011x         | != 00 |       | UNALLOCATED                                                     |
| 00  | 10x00         |       |       | UNALLOCATED                                                     |
| 01  | 00001         |       |       | UNALLOCATED                                                     |
| 01  | x0010         |       |       | UNALLOCATED                                                     |
| 0x  | 00000         |       |       | <a href="#">SME2 multi-vec FP down convert two registers</a>    |

|       |       |       |       |                                                                |
|-------|-------|-------|-------|----------------------------------------------------------------|
| 0x    | 00011 |       |       | <a href="#">SME2 multi-vec int down convert two registers</a>  |
| 0x    | 0011x |       |       | UNALLOCATED                                                    |
| 10    | 00000 |       |       | <a href="#">SME2 multi-vec convert two registers</a>           |
| 10    | 00001 |       |       | UNALLOCATED                                                    |
| 10    | 00x1x |       |       | UNALLOCATED                                                    |
| 11    | 000xx |       |       | UNALLOCATED                                                    |
| 11    | 0011x |       |       | UNALLOCATED                                                    |
| 1x    | 10010 |       |       | UNALLOCATED                                                    |
| != 00 | 1000x |       |       | UNALLOCATED                                                    |
| != 00 | 10110 | 00    | x1    | UNALLOCATED                                                    |
| != 00 | 10110 | 01    |       | UNALLOCATED                                                    |
| != 00 | 10110 | 1x    |       | UNALLOCATED                                                    |
| != 00 | 10111 |       |       | UNALLOCATED                                                    |
| != 00 | x0100 |       |       | UNALLOCATED                                                    |
|       | 00101 |       |       | <a href="#">SME2 multi-vec unpack two registers</a>            |
|       | 01xxx | x0    | x0    | <a href="#">SME2 multi-vec FRINT two registers</a>             |
|       | 01xxx | x0    | x1    | UNALLOCATED                                                    |
|       | 01xxx | x1    |       | UNALLOCATED                                                    |
|       | 10011 |       |       | <a href="#">SME2 multi-vec int down convert four registers</a> |
|       | 10101 | x0    | 0x    | <a href="#">SME2 multi-vec unpack four registers</a>           |
|       | 10101 | x0    | 1x    | UNALLOCATED                                                    |
|       | 10101 | x1    |       | UNALLOCATED                                                    |
|       | 10110 | 00    | x0    | <a href="#">SME2 multi-vec ZIP four registers</a>              |
|       | 11xxx | 00    | 00    | <a href="#">SME2 multi-vec FRINT four registers</a>            |
|       | 11xxx | 00    | != 00 | UNALLOCATED                                                    |
|       | 11xxx | != 00 |       | UNALLOCATED                                                    |

### SME2 multi-vec FP to int convert two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 0  | 0  | 0 | Zn | U | Zd | 0 |   |   |   |   |   |

| Decode fields<br>U | Instruction Details    | Feature   |
|--------------------|------------------------|-----------|
| 0                  | <a href="#">FCVTZS</a> | FEAT_SME2 |
| 1                  | <a href="#">FCVTZU</a> | FEAT_SME2 |

## SME2 multi-vec int to FP two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | Zn | U | Zd | 0 | 0 | 0 | 0 | 0 | 0 |   |

| Decode fields<br>U | Instruction Details  | Feature   |
|--------------------|----------------------|-----------|
| 0                  | <a href="#">SCVT</a> | FEAT_SME2 |
| 1                  | <a href="#">UCVT</a> | FEAT_SME2 |

## SME2 multi-vec FP to int convert four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | Zn | 0 | U | Zd | 0 | 0 | 0 | 0 | 0 | 0 |

| Decode fields<br>U | Instruction Details    | Feature   |
|--------------------|------------------------|-----------|
| 0                  | <a href="#">FCVTZS</a> | FEAT_SME2 |
| 1                  | <a href="#">FCVTZU</a> | FEAT_SME2 |

## SME2 multi-vec int to FP four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | Zn | 0 | U | Zd | 0 | 0 | 0 | 0 | 0 | 0 |

| Decode fields<br>U | Instruction Details  | Feature   |
|--------------------|----------------------|-----------|
| 0                  | <a href="#">SCVT</a> | FEAT_SME2 |
| 1                  | <a href="#">UCVT</a> | FEAT_SME2 |

## SME2 multi-vec quadwords ZIP four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |    |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|----|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5  | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | Zn | 0 | 0 | Zd | op | 0 |   |   |   |   |

| Decode fields<br>op | Instruction Details                  | Feature   |
|---------------------|--------------------------------------|-----------|
| 0                   | <a href="#">ZIP (four registers)</a> | FEAT_SME2 |
| 1                   | <a href="#">UZP (four registers)</a> | FEAT_SME2 |

### SME2 multi-vec FP down convert two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | op | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | Zn | N |   | Zd |   |   |   |   |   |   |

| Decode fields<br>op | N | Instruction Details              | Feature   |
|---------------------|---|----------------------------------|-----------|
| 0                   | 0 | <a href="#">FCVT (narrowing)</a> | FEAT_SME2 |
| 0                   | 1 | <a href="#">FCVTN</a>            | FEAT_SME2 |
| 1                   | 0 | <a href="#">BFCVT</a>            | FEAT_SME2 |
| 1                   | 1 | <a href="#">BFCVTN</a>           | FEAT_SME2 |

### SME2 multi-vec int down convert two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | op | 1  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | Zn | U |   | Zd |   |   |   |   |   |   |

| Decode fields<br>op | U | Instruction Details                    | Feature   |
|---------------------|---|----------------------------------------|-----------|
| 0                   | 0 | <a href="#">SQCVT (two registers)</a>  | FEAT_SME2 |
| 0                   | 1 | <a href="#">UQCVT (two registers)</a>  | FEAT_SME2 |
| 1                   | 0 | <a href="#">SQCVTU (two registers)</a> | FEAT_SME2 |
| 1                   | 1 | UNALLOCATED                            | -         |

### SME2 multi-vec convert two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | Zn |   | Zd |   | L |   |   |   |   |   |   |

| Decode fields<br>L | Instruction Details             | Feature         |
|--------------------|---------------------------------|-----------------|
| 0                  | <a href="#">FCVT (widening)</a> | FEAT_SME_F16F16 |
| 1                  | <a href="#">FCVTL</a>           | FEAT_SME_F16F16 |

### SME2 multi-vec unpack two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | Zn |    | Zd |   | U |   |   |   |   |   |   |   |

| Decode fields<br>U | Instruction Details   | Feature   |
|--------------------|-----------------------|-----------|
| 0                  | <a href="#">SUNPK</a> | FEAT_SME2 |
| 1                  | <a href="#">UUNPK</a> | FEAT_SME2 |

### SME2 multi-vec FRINT two registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | 1  | opc | 1  | 1  | 1  | 0  | 0  | 0  | Zn | 0  | Zd | 0 |   |   |   |   |   |   |   |   |   |

| Decode fields<br>size | opc | Instruction Details    | Feature   |
|-----------------------|-----|------------------------|-----------|
| 0x                    |     | UNALLOCATED            | -         |
| 10                    | 000 | <a href="#">FRINTN</a> | FEAT_SME2 |
| 10                    | 001 | <a href="#">FRINTP</a> | FEAT_SME2 |
| 10                    | 010 | <a href="#">FRINTM</a> | FEAT_SME2 |
| 10                    | 011 | UNALLOCATED            | -         |
| 10                    | 100 | <a href="#">FRINTA</a> | FEAT_SME2 |
| 10                    | 101 | UNALLOCATED            | -         |
| 10                    | 11x | UNALLOCATED            | -         |
| 11                    |     | UNALLOCATED            | -         |

### SME2 multi-vec int down convert four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |    |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|----|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | sz | op | 1  | 1  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | Zn | N | U |   | Zd |   |   |   |   |   |

| Decode fields |   |   | Instruction Details     |  |  |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|---|-------------------------|--|--|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| op            | N | U |                         |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 0 | 0 | SQCVT (four registers)  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 0 | 1 | UQCVT (four registers)  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 1 | 0 | SQCVTN                  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 1 | 1 | UQCVTN                  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             |   | 1 | UNALLOCATED             |  |  |  |  |  |  |  |  |  |  |  | -         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             | 0 | 0 | SQCVTU (four registers) |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             | 1 | 0 | SQCVTUN                 |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### SME2 multi-vec unpack four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 1  | 0  | 1  | 0  | 1  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | Zn | 0 | Zd | 0 | U |   |   |   |   |   |

| Decode fields |  |  | Instruction Details |  |  |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|--|--|---------------------|--|--|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| U             |  |  |                     |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             |  |  | SUNPK               |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             |  |  | UUNPK               |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### SME2 multi-vec ZIP four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |    |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|----|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6  | 5  | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 1  | 0  | 1  | 1  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | Zn | 0 | 0 | Zd | op | 0 |   |   |   |   |

| Decode fields |  |  | Instruction Details  |  |  |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|--|--|----------------------|--|--|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| op            |  |  |                      |  |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             |  |  | ZIP (four registers) |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             |  |  | UZP (four registers) |  |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### SME2 multi-vec FRINT four registers

These instructions are under [SME2 Multi-vector - SVE Constructive Unary](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 1  | 1  | opc | 1  | 1  | 1  | 0  | 0  | 0  | Zn | 0  | 0  | Zd | 0 | 0 |   |   |   |   |   |   |   |

| Decode fields |     | Instruction Details    |  | Feature   |
|---------------|-----|------------------------|--|-----------|
| size          | opc |                        |  |           |
| 0x            |     | UNALLOCATED            |  | -         |
| 10            | 000 | <a href="#">FRINTN</a> |  | FEAT_SME2 |
| 10            | 001 | <a href="#">FRINTP</a> |  | FEAT_SME2 |
| 10            | 010 | <a href="#">FRINTM</a> |  | FEAT_SME2 |
| 10            | 011 | UNALLOCATED            |  | -         |
| 10            | 100 | <a href="#">FRINTA</a> |  | FEAT_SME2 |
| 10            | 101 | UNALLOCATED            |  | -         |
| 10            | 11x | UNALLOCATED            |  | -         |
| 11            |     | UNALLOCATED            |  | -         |

## SME2 Multi-vector - Multiple Vectors SVE Destructive (Two registers)

These instructions are under [SME encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |        |    |     |    |     |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|--------|----|-----|----|-----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18 | 17  | 16 | 15  | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 11000001 |    |    |    |    |    |    | 1  |    |    |    |    | 010110 |    | op0 |    | op1 |    | op2 |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |           |     | Instruction details                                                                      |
|---------------|-----------|-----|------------------------------------------------------------------------------------------|
| op0           | op1       | op2 |                                                                                          |
| 0             | 000       | 0x  | <a href="#">SME2 multiple vectors int min/max two registers</a>                          |
| 0             | 010       |     | <a href="#">SME2 multiple vectors FP min/max two registers</a>                           |
| 0             | 0x1       |     | UNALLOCATED                                                                              |
| 0             | 10x       |     | <a href="#">SME2 multiple vectors shift two registers</a>                                |
| 0             | 11x       |     | UNALLOCATED                                                                              |
| 1             | 000       | 00  | <a href="#">SME2 multi-vector signed saturating doubling multiply high two registers</a> |
| 1             | 000       | 01  | UNALLOCATED                                                                              |
| 1             | !=<br>000 |     | UNALLOCATED                                                                              |
|               | 000       | 1x  | UNALLOCATED                                                                              |

### SME2 multiple vectors int min/max two registers

These instructions are under [SME2 Multi-vector - Multiple Vectors SVE Destructive \(Two registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |     |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|-----|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5   | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 0  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 1 | 0 | opc | Zdn | U |   |   |   |   |

| Decode fields |   | Instruction Details     |  | Feature   |
|---------------|---|-------------------------|--|-----------|
| op            | U |                         |  |           |
| 0             | 0 | SMAX (multiple vectors) |  | FEAT_SME2 |
| 0             | 1 | UMAX (multiple vectors) |  | FEAT_SME2 |
| 1             | 0 | SMIN (multiple vectors) |  | FEAT_SME2 |
| 1             | 1 | UMIN (multiple vectors) |  | FEAT_SME2 |

### SME2 multiple vectors FP min/max two registers

These instructions are under [SME2 Multi-vector - Multiple Vectors SVE Destructive \(Two registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |     |    |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|-----|----|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5   | 4  | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 0  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 0 | 1 | 0 | opc | Zdn | o2 |   |   |   |   |

| Decode fields |     |    | Instruction Details        |  | Feature         |
|---------------|-----|----|----------------------------|--|-----------------|
| size          | opc | o2 |                            |  |                 |
|               | 1x  |    | UNALLOCATED                |  | -               |
| != 00         | 00  | 0  | FMAX (multiple vectors)    |  | FEAT_SME2       |
| != 00         | 00  | 1  | FMIN (multiple vectors)    |  | FEAT_SME2       |
| != 00         | 01  | 0  | FMAXNM (multiple vectors)  |  | FEAT_SME2       |
| != 00         | 01  | 1  | FMINNM (multiple vectors)  |  | FEAT_SME2       |
| 00            | 00  | 0  | BFMAX (multiple vectors)   |  | FEAT_SVE_B16B16 |
| 00            | 00  | 1  | BFMIN (multiple vectors)   |  | FEAT_SVE_B16B16 |
| 00            | 01  | 0  | BFMAXNM (multiple vectors) |  | FEAT_SVE_B16B16 |
| 00            | 01  | 1  | BFMINNM (multiple vectors) |  | FEAT_SVE_B16B16 |

### SME2 multiple vectors shift two registers

These instructions are under [SME2 Multi-vector - Multiple Vectors SVE Destructive \(Two registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |     |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|-----|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5   | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 0  | 1  | 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | 0  | 0 | 1 | 0 | opc | Zdn | U |   |   |   |   |

| Decode fields |   | Instruction Details |  | Feature |
|---------------|---|---------------------|--|---------|
| opc           | U |                     |  |         |
| 000           |   | UNALLOCATED         |  | -       |

| Decode fields |   | Instruction Details                      |  | Feature   |
|---------------|---|------------------------------------------|--|-----------|
| opc           | U |                                          |  |           |
| 001           | 0 | <a href="#">SRSHL (multiple vectors)</a> |  | FEAT_SME2 |
| 001           | 1 | <a href="#">URSHL (multiple vectors)</a> |  | FEAT_SME2 |
| 01x           |   | UNALLOCATED                              |  | -         |
| 1xx           |   | UNALLOCATED                              |  | -         |

### SME2 multi-vector signed saturating doubling multiply high two registers

These instructions are under [SME2 Multi-vector - Multiple Vectors SVE Destructive \(Two registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |     |    |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----|----|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2  | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 0  | 1  | 0  | 1  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | Zdn | op |   |   |

| Decode fields |  | Instruction Details                        |  | Feature   |
|---------------|--|--------------------------------------------|--|-----------|
| op            |  |                                            |  |           |
| 0             |  | <a href="#">SQDMULH (multiple vectors)</a> |  | FEAT_SME2 |
| 1             |  | UNALLOCATED                                |  | -         |

### SME2 Multi-vector - Multiple Vectors SVE Destructive (Four registers)

These instructions are under [SME encodings](#).

|          |    |    |    |    |     |        |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|-----|--------|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26  | 25     | 24  | 23  | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 11000001 |    |    | 1  |    | op0 | 010111 | op1 | op2 | op3 |    | 0  |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     |        |     | Instruction details                                                                       |
|---------------|-----|--------|-----|-------------------------------------------------------------------------------------------|
| op0           | op1 | op2    | op3 |                                                                                           |
| 0             | 0   | 000    | 0x  | <a href="#">SME2 multiple vectors int min/max four registers</a>                          |
| 0             | 0   | 010    |     | <a href="#">SME2 multiple vectors FP min/max four registers</a>                           |
| 0             | 0   | 0x1    |     | UNALLOCATED                                                                               |
| 0             | 0   | 10x    |     | <a href="#">SME2 multiple vectors shift four registers</a>                                |
| 0             | 0   | 11x    |     | UNALLOCATED                                                                               |
| 0             | 1   | 000    | 00  | <a href="#">SME2 multi-vector signed saturating doubling multiply high four registers</a> |
| 0             | 1   | 000    | 01  | UNALLOCATED                                                                               |
| 0             | 1   | != 000 |     | UNALLOCATED                                                                               |
| 0             |     | 000    | 1x  | UNALLOCATED                                                                               |
| 1             |     |        |     | UNALLOCATED                                                                               |

## SME2 multiple vectors int min/max four registers

These instructions are under [SME2 Multi-vector - Multiple Vectors SVE Destructive \(Four registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |     |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|-----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 0 | op | Zdn | 0 | U |   |   |   |   |   |

| Decode fields |   | Instruction Details                     |  | Feature   |
|---------------|---|-----------------------------------------|--|-----------|
| op            | U |                                         |  |           |
| 0             | 0 | <a href="#">SMAX (multiple vectors)</a> |  | FEAT_SME2 |
| 0             | 1 | <a href="#">UMAX (multiple vectors)</a> |  | FEAT_SME2 |
| 1             | 0 | <a href="#">SMIN (multiple vectors)</a> |  | FEAT_SME2 |
| 1             | 1 | <a href="#">UMIN (multiple vectors)</a> |  | FEAT_SME2 |

## SME2 multiple vectors FP min/max four registers

These instructions are under [SME2 Multi-vector - Multiple Vectors SVE Destructive \(Four registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 0  | 0  | 1  | 0  | opc | Zdn | 0 | o2 |   |   |   |   |   |   |

| Decode fields |     |    | Instruction Details                        |  | Feature         |
|---------------|-----|----|--------------------------------------------|--|-----------------|
| size          | opc | o2 |                                            |  |                 |
|               | 1x  |    | UNALLOCATED                                |  | -               |
| != 00         | 00  | 0  | <a href="#">FMAX (multiple vectors)</a>    |  | FEAT_SME2       |
| != 00         | 00  | 1  | <a href="#">FMIN (multiple vectors)</a>    |  | FEAT_SME2       |
| != 00         | 01  | 0  | <a href="#">FMAXNM (multiple vectors)</a>  |  | FEAT_SME2       |
| != 00         | 01  | 1  | <a href="#">FMINNM (multiple vectors)</a>  |  | FEAT_SME2       |
| 00            | 00  | 0  | <a href="#">BFMAX (multiple vectors)</a>   |  | FEAT_SVE_B16B16 |
| 00            | 00  | 1  | <a href="#">BFMIN (multiple vectors)</a>   |  | FEAT_SVE_B16B16 |
| 00            | 01  | 0  | <a href="#">BFMAXNM (multiple vectors)</a> |  | FEAT_SVE_B16B16 |
| 00            | 01  | 1  | <a href="#">BFMINNM (multiple vectors)</a> |  | FEAT_SVE_B16B16 |

## SME2 multiple vectors shift four registers

These instructions are under [SME2 Multi-vector - Multiple Vectors SVE Destructive \(Four registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 0  | 1  | 0  | opc | Zdn | 0 | U |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                      | Feature   |
|---------------|---|------------------------------------------|-----------|
| opc           | U |                                          |           |
| 000           |   | UNALLOCATED                              | -         |
| 001           | 0 | <a href="#">SRSHL (multiple vectors)</a> | FEAT_SME2 |
| 001           | 1 | <a href="#">URSHL (multiple vectors)</a> | FEAT_SME2 |
| 01x           |   | UNALLOCATED                              | -         |
| 1xx           |   | UNALLOCATED                              | -         |

### SME2 multi-vector signed saturating doubling multiply high four registers

These instructions are under [SME2 Multi-vector - Multiple Vectors SVE Destructive \(Four registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |    |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1 | 0  |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | Zm | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Zdn | 0 | op |

| Decode fields |  | Instruction Details                        | Feature   |
|---------------|--|--------------------------------------------|-----------|
| op            |  |                                            |           |
| 0             |  | <a href="#">SQDMULH (multiple vectors)</a> | FEAT_SME2 |
| 1             |  | UNALLOCATED                                | -         |

### SME2 Multi-vector - Multiple and Single SVE Destructive (Two registers)

These instructions are under [SME encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |       |     |     |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|-------|-----|-----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19  | 18  | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 11000001 |    |    | 10 |    |    |    |    |    |    |    | 10100 | op0 | op1 |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |         | Instruction details                                                                      |
|---------------|---------|------------------------------------------------------------------------------------------|
| op0           | op1     |                                                                                          |
| 0             | 0000x   | <a href="#">SME2 single-multi int min/max two registers</a>                              |
| 0             | 0100x   | <a href="#">SME2 single-multi FP min/max two registers</a>                               |
| 0             | 0x!=00x | UNALLOCATED                                                                              |
| 0             | 10xxx   | <a href="#">SME2 single-multi shift two registers</a>                                    |
| 0             | 11000   | <a href="#">SME2 single-multi add two registers</a>                                      |
| 0             | 11!=000 | UNALLOCATED                                                                              |
| 1             | 00000   | <a href="#">SME2 single-multi signed saturating doubling multiply high two registers</a> |
| 1             | !=00000 | UNALLOCATED                                                                              |

## SME2 single-multi int min/max two registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Two registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |     |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|-----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | op | Zdn | U |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                               |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |  |  |
|---------------|---|---------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|
| op            | U |                                                   |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |
| 0             | 0 | <a href="#">SMAX (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |
| 0             | 1 | <a href="#">UMAX (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |
| 1             | 0 | <a href="#">SMIN (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |
| 1             | 1 | <a href="#">UMIN (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |

## SME2 single-multi FP min/max two registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Two registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |     |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|-----|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7   | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0 | op | Zdn | o2 |   |   |   |   |   |   |

| Decode fields |    |    | Instruction Details                                  |  |  |  |  |  |  |  |  |  | Feature         |  |  |  |  |  |  |  |
|---------------|----|----|------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|
| size          | op | o2 |                                                      |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |
| != 00         | 0  | 0  | <a href="#">FMAX (multiple and single vector)</a>    |  |  |  |  |  |  |  |  |  | FEAT_SME2       |  |  |  |  |  |  |  |
| != 00         | 0  | 1  | <a href="#">FMIN (multiple and single vector)</a>    |  |  |  |  |  |  |  |  |  | FEAT_SME2       |  |  |  |  |  |  |  |
| != 00         | 1  | 0  | <a href="#">FMAXNM (multiple and single vector)</a>  |  |  |  |  |  |  |  |  |  | FEAT_SME2       |  |  |  |  |  |  |  |
| != 00         | 1  | 1  | <a href="#">FMINNM (multiple and single vector)</a>  |  |  |  |  |  |  |  |  |  | FEAT_SME2       |  |  |  |  |  |  |  |
| 00            | 0  | 0  | <a href="#">BFMAX (multiple and single vector)</a>   |  |  |  |  |  |  |  |  |  | FEAT_SVE_B16B16 |  |  |  |  |  |  |  |
| 00            | 0  | 1  | <a href="#">BFMIN (multiple and single vector)</a>   |  |  |  |  |  |  |  |  |  | FEAT_SVE_B16B16 |  |  |  |  |  |  |  |
| 00            | 1  | 0  | <a href="#">BFMAXNM (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SVE_B16B16 |  |  |  |  |  |  |  |
| 00            | 1  | 1  | <a href="#">BFMINNM (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SVE_B16B16 |  |  |  |  |  |  |  |

## SME2 single-multi shift two registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Two registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | opc | Zdn | U |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                |  |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |
|---------------|---|----------------------------------------------------|--|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|
| opc           | U |                                                    |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |
| 000           |   | UNALLOCATED                                        |  |  |  |  |  |  |  |  |  |  | -         |  |  |  |  |  |
| 001           | 0 | <a href="#">SRSHL (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |
| 001           | 1 | <a href="#">URSHL (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |
| 01x           |   | UNALLOCATED                                        |  |  |  |  |  |  |  |  |  |  | -         |  |  |  |  |  |
| 1xx           |   | UNALLOCATED                                        |  |  |  |  |  |  |  |  |  |  | -         |  |  |  |  |  |

### SME2 single-multi add two registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Two registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0 | Zdn | op |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details             |  |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |
|---------------|--|---------------------------------|--|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|
| op            |  |                                 |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |
| 0             |  | <a href="#">ADD (to vector)</a> |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |
| 1             |  | UNALLOCATED                     |  |  |  |  |  |  |  |  |  |  | -         |  |  |  |  |  |

### SME2 single-multi signed saturating doubling multiply high two registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Two registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0 | Zdn | op |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                                  |  |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |
|---------------|--|------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|
| op            |  |                                                      |  |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |
| 0             |  | <a href="#">SQDMULH (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |
| 1             |  | UNALLOCATED                                          |  |  |  |  |  |  |  |  |  |  | -         |  |  |  |  |  |

## SME2 Multi-vector - Multiple and Single SVE Destructive (Four registers)

These instructions are under [SME encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |     |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15    | 14  | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 11000001 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 10101 | op0 | op1 |    |    |    |   |   |   |   |   |   |   |   | 0 |   |

| Decode fields |         | Instruction details                                                                       |  |
|---------------|---------|-------------------------------------------------------------------------------------------|--|
| op0           | op1     |                                                                                           |  |
| 0             | 0000x   | <a href="#">SME2 single-multi int min/max four registers</a>                              |  |
| 0             | 0100x   | <a href="#">SME2 single-multi FP min/max four registers</a>                               |  |
| 0             | 0x!=00x | UNALLOCATED                                                                               |  |
| 0             | 10xxx   | <a href="#">SME2 single-multi shift four registers</a>                                    |  |
| 0             | 11000   | <a href="#">SME2 single-multi add four registers</a>                                      |  |
| 0             | 11!=000 | UNALLOCATED                                                                               |  |
| 1             | 00000   | <a href="#">SME2 single-multi signed saturating doubling multiply high four registers</a> |  |
| 1             | !=00000 | UNALLOCATED                                                                               |  |

## SME2 single-multi int min/max four registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Four registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | op | Zdn | 0 | U |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                               |  | Feature   |
|---------------|---|---------------------------------------------------|--|-----------|
| op            | U |                                                   |  |           |
| 0             | 0 | <a href="#">SMAX (multiple and single vector)</a> |  | FEAT_SME2 |
| 0             | 1 | <a href="#">UMAX (multiple and single vector)</a> |  | FEAT_SME2 |
| 1             | 0 | <a href="#">SMIN (multiple and single vector)</a> |  | FEAT_SME2 |
| 1             | 1 | <a href="#">UMIN (multiple and single vector)</a> |  | FEAT_SME2 |

## SME2 single-multi FP min/max four registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Four registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | op | Zdn | 0 | o2 |   |   |   |   |   |   |

| Decode fields |    |    | Instruction Details                                  | Feature         |
|---------------|----|----|------------------------------------------------------|-----------------|
| size          | op | o2 |                                                      |                 |
| != 00         | 0  | 0  | <a href="#">FMAX (multiple and single vector)</a>    | FEAT_SME2       |
| != 00         | 0  | 1  | <a href="#">FMIN (multiple and single vector)</a>    | FEAT_SME2       |
| != 00         | 1  | 0  | <a href="#">FMAXNM (multiple and single vector)</a>  | FEAT_SME2       |
| != 00         | 1  | 1  | <a href="#">FMINNM (multiple and single vector)</a>  | FEAT_SME2       |
| 00            | 0  | 0  | <a href="#">BFMAX (multiple and single vector)</a>   | FEAT_SVE_B16B16 |
| 00            | 0  | 1  | <a href="#">BFMIN (multiple and single vector)</a>   | FEAT_SVE_B16B16 |
| 00            | 1  | 0  | <a href="#">BFMAXNM (multiple and single vector)</a> | FEAT_SVE_B16B16 |
| 00            | 1  | 1  | <a href="#">BFMINNM (multiple and single vector)</a> | FEAT_SVE_B16B16 |

### SME2 single-multi shift four registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Four registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | opc | Zdn | 0 | U |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                | Feature   |
|---------------|---|----------------------------------------------------|-----------|
| opc           | U |                                                    |           |
| 000           |   | UNALLOCATED                                        | -         |
| 001           | 0 | <a href="#">SRSHL (multiple and single vector)</a> | FEAT_SME2 |
| 001           | 1 | <a href="#">URSHL (multiple and single vector)</a> | FEAT_SME2 |
| 01x           |   | UNALLOCATED                                        | -         |
| 1xx           |   | UNALLOCATED                                        | -         |

### SME2 single-multi add four registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Four registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 1  | 0  | 0  | 0 | Zdn | 0 | op |   |   |   |   |   |   |

| <b>Decode fields</b> |  | <b>Instruction Details</b>      | <b>Feature</b> |
|----------------------|--|---------------------------------|----------------|
| <b>op</b>            |  |                                 |                |
| 0                    |  | <a href="#">ADD (to vector)</a> | FEAT_SME2      |
| 1                    |  | UNALLOCATED                     | -              |

### SME2 single-multi signed saturating doubling multiply high four registers

These instructions are under [SME2 Multi-vector - Multiple and Single SVE Destructive \(Four registers\)](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | size | 1  | 0  | Zm | 1  | 0  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0 | Zdn | 0 | op |   |   |   |   |   |   |

| <b>Decode fields</b> |  | <b>Instruction Details</b>                           | <b>Feature</b> |
|----------------------|--|------------------------------------------------------|----------------|
| <b>op</b>            |  |                                                      |                |
| 0                    |  | <a href="#">SQDMULH (multiple and single vector)</a> | FEAT_SME2      |
| 1                    |  | UNALLOCATED                                          | -              |

### SME2 Multi-vector - Multiple and Single Array Vectors

These instructions are under [SME encodings](#).

|           |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |   |   |   |   |     |   |   |   |   |   |
|-----------|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|---|---|---|---|-----|---|---|---|---|---|
| 31        | 30  | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1 | 0 |
| 110000010 | op0 | op1 | op1 |    |    |    |    |    |    |    |    |    |    |    | 0  |    | op2 |    |    |    |    |   |   |   |   | op3 |   |   |   |   |   |

| <b>Decode fields</b> |            |            |            | <b>Instruction details</b>                                          |
|----------------------|------------|------------|------------|---------------------------------------------------------------------|
| <b>op0</b>           | <b>op1</b> | <b>op2</b> | <b>op3</b> |                                                                     |
| 0                    | 0          | 010        | xx0x       | <a href="#">SME2 single-multi long FMA two sources</a>              |
| 0                    | 0          | 011        |            | <a href="#">SME2 multiple and single vector long FMA one source</a> |
| 0                    | 0          | 100        |            | <a href="#">SME2 single-multi FP dot product two registers</a>      |
| 0                    | 0          | 101        | x1xx       | <a href="#">SME2 single-multi mixed dot product two registers</a>   |
| 0                    | 1          | 010        | xx0x       | <a href="#">SME2 single-multi long FMA four sources</a>             |
| 0                    | 1          | 100        |            | <a href="#">SME2 single-multi FP dot product four registers</a>     |
| 0                    | 1          | 101        | x1xx       | <a href="#">SME2 single-multi mixed dot product four registers</a>  |
| 1                    | 0          | 010        | xx0x       | <a href="#">SME2 single-multi long MLA two sources</a>              |

|   |   |     |      |                                                                              |
|---|---|-----|------|------------------------------------------------------------------------------|
| 1 | 0 | 011 |      | <a href="#">SME2 multiple and single vector long<br/>MLA one source</a>      |
| 1 | 0 | 101 | x1xx | <a href="#">SME2 single-multi two-way dot product<br/>two registers</a>      |
| 1 | 1 | 010 | xx0x | <a href="#">SME2 single-multi long MLA four<br/>sources</a>                  |
| 1 | 1 | 101 | x1xx | <a href="#">SME2 single-multi two-way dot product<br/>four registers</a>     |
| 1 |   | 100 |      | UNALLOCATED                                                                  |
|   | 0 | 000 | xxx0 | <a href="#">SME2 single-multi long long MLA two<br/>sources</a>              |
|   | 0 | 001 |      | <a href="#">SME2 multiple and single vector long<br/>long FMA one source</a> |
|   | 0 | 101 | x0xx | <a href="#">SME2 single-multi four-way dot product<br/>two registers</a>     |
|   | 0 | 110 | 0xxx | <a href="#">SME2 single-multi ternary FP two<br/>registers</a>               |
|   | 0 | 110 | 1xxx | <a href="#">SME2 single-multi ternary int two<br/>registers</a>              |
|   | 0 | 111 | 0xxx | <a href="#">SME2 single-multi ternary FP16 two<br/>registers</a>             |
|   | 1 | 000 | xxx0 | <a href="#">SME2 single-multi long long MLA four<br/>sources</a>             |
|   | 1 | 0x1 |      | UNALLOCATED                                                                  |
|   | 1 | 101 | x0xx | <a href="#">SME2 single-multi four-way dot product<br/>four registers</a>    |
|   | 1 | 110 | 0xxx | <a href="#">SME2 single-multi ternary FP four<br/>registers</a>              |
|   | 1 | 110 | 1xxx | <a href="#">SME2 single-multi ternary int four<br/>registers</a>             |
|   | 1 | 111 | 0xxx | <a href="#">SME2 single-multi ternary FP16 four<br/>registers</a>            |
|   |   | 000 | xxx1 | UNALLOCATED                                                                  |
|   |   | 010 | xx1x | UNALLOCATED                                                                  |
|   |   | 111 | 1xxx | UNALLOCATED                                                                  |

SME2 single-multi long FMA two sources

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

| Decode fields |   | Instruction Details                                 | Feature   |
|---------------|---|-----------------------------------------------------|-----------|
| op            | S |                                                     |           |
| 0             | 0 | <a href="#">FMLAL (multiple and single vector)</a>  | FEAT_SME2 |
| 0             | 1 | <a href="#">FMLS (multiple and single vector)</a>   | FEAT_SME2 |
| 1             | 0 | <a href="#">BFMLAL (multiple and single vector)</a> | FEAT_SME2 |
| 1             | 1 | <a href="#">BFMLS (multiple and single vector)</a>  | FEAT_SME2 |

### SME2 multiple and single vector long FMA one source

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |      |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7 | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | Zm | 0  | Rv | 0  | 1  | 1  |    |    |    |    | Zn | op | S | off3 |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                 | Feature   |
|---------------|---|-----------------------------------------------------|-----------|
| op            | S |                                                     |           |
| 0             | 0 | <a href="#">FMLAL (multiple and single vector)</a>  | FEAT_SME2 |
| 0             | 1 | <a href="#">FMLS (multiple and single vector)</a>   | FEAT_SME2 |
| 1             | 0 | <a href="#">BFMLAL (multiple and single vector)</a> | FEAT_SME2 |
| 1             | 1 | <a href="#">BFMLS (multiple and single vector)</a>  | FEAT_SME2 |

### SME2 single-multi FP dot product two registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | Zm | 0  | Rv | 1  | 0  | 0  |    |    |    |    | Zn | opc | off3 |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                                | Feature   |
|---------------|--|----------------------------------------------------|-----------|
| opc           |  |                                                    |           |
| x1            |  | UNALLOCATED                                        | -         |
| 00            |  | <a href="#">FDOT (multiple and single vector)</a>  | FEAT_SME2 |
| 10            |  | <a href="#">BFDOT (multiple and single vector)</a> | FEAT_SME2 |

### SME2 single-multi mixed dot product two registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | Zm | 0  | Rv | 1  | 0  | 1  | Zn | U  | 1  | off3 |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                                |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |  |  |  |  |
|---------------|--|----------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|--|--|
| U             |  |                                                    |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |
| 0             |  | <a href="#">USDOT (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |
| 1             |  | <a href="#">SUDOT (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |

### SME2 single-multi long FMA four sources

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | Zm | 0  | Rv | 0  | 1  | 0  | Zn | op | S  | 0  | off2 |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                                  |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |  |  |  |  |
|---------------|--|------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|--|--|
| op            |  | S                                                    |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |
| 0             |  | <a href="#">FMLAL (multiple and single vector)</a>   |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |
| 0             |  | <a href="#">FMLS L (multiple and single vector)</a>  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |
| 1             |  | <a href="#">BFMLAL (multiple and single vector)</a>  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |
| 1             |  | <a href="#">BFMLS L (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |

### SME2 single-multi FP dot product four registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | Zm | 0  | Rv | 1  | 0  | 0  | Zn | opc | off3 |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                                |  |  |  |  |  |  |  |  |  | Feature   |  |  |  |  |  |  |  |  |  |
|---------------|--|----------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------|--|--|--|--|--|--|--|--|--|
| opc           |  |                                                    |  |  |  |  |  |  |  |  |  |           |  |  |  |  |  |  |  |  |  |
| x1            |  | UNALLOCATED                                        |  |  |  |  |  |  |  |  |  | -         |  |  |  |  |  |  |  |  |  |
| 00            |  | <a href="#">FDOT (multiple and single vector)</a>  |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |
| 10            |  | <a href="#">BFDOT (multiple and single vector)</a> |  |  |  |  |  |  |  |  |  | FEAT_SME2 |  |  |  |  |  |  |  |  |  |

### SME2 single-multi mixed dot product four registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | Zm | 0  | Rv | 1  | 0  | 1  | Zn | U  | 1  | off3 |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b>                         | <b>Feature</b> |
|----------------------|----------------------------------------------------|----------------|
| <b>U</b>             |                                                    |                |
| 0                    | <a href="#">USDOT (multiple and single vector)</a> | FEAT_SME2      |
| 1                    | <a href="#">SUDOT (multiple and single vector)</a> | FEAT_SME2      |

## SME2 single-multi long MLA two sources

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

| Decode fields |   | Instruction Details                                 | Feature   |
|---------------|---|-----------------------------------------------------|-----------|
| U             | S |                                                     |           |
| 0             | 0 | <a href="#">SMLAL (multiple and single vector)</a>  | FEAT_SME2 |
| 0             | 1 | <a href="#">SMLS L (multiple and single vector)</a> | FEAT_SME2 |
| 1             | 0 | <a href="#">UMLAL (multiple and single vector)</a>  | FEAT_SME2 |
| 1             | 1 | <a href="#">UMLSL (multiple and single vector)</a>  | FEAT_SME2 |

SME2 multiple and single vector long MLA one source

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

| Decode fields |   | Instruction Details                                 | Feature   |
|---------------|---|-----------------------------------------------------|-----------|
| U             | S |                                                     |           |
| 0             | 0 | <a href="#">SMLAL (multiple and single vector)</a>  | FEAT_SME2 |
| 0             | 1 | <a href="#">SMLS L (multiple and single vector)</a> | FEAT_SME2 |
| 1             | 0 | <a href="#">UMLAL (multiple and single vector)</a>  | FEAT_SME2 |
| 1             | 1 | <a href="#">UMLSL (multiple and single vector)</a>  | FEAT_SME2 |

## SME2 single-multi two-way dot product two registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

| <b>Decode fields</b> | <b>Instruction Details</b>                               |  |  | <b>Feature</b> |
|----------------------|----------------------------------------------------------|--|--|----------------|
| <b>U</b>             |                                                          |  |  |                |
| 0                    | <a href="#">SDOT (2-way, multiple and single vector)</a> |  |  | FEAT_SME2      |
| 1                    | <a href="#">UDOT (2-way, multiple and single vector)</a> |  |  | FEAT_SME2      |

### SME2 single-multi long MLA four sources

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 1  | Zm | 0  | Rv | 0  | 1  | 0  | Zn | U  | S  | 0  | off2 |   |   |   |   |   |   |   |   |   |  |

| <b>Decode fields</b> | <b>Instruction Details</b> |                                                     |  | <b>Feature</b> |           |
|----------------------|----------------------------|-----------------------------------------------------|--|----------------|-----------|
| <b>U</b>             | <b>S</b>                   |                                                     |  |                |           |
| 0                    | 0                          | <a href="#">SMLAL (multiple and single vector)</a>  |  |                | FEAT_SME2 |
| 0                    | 1                          | <a href="#">SMLS L (multiple and single vector)</a> |  |                | FEAT_SME2 |
| 1                    | 0                          | <a href="#">UMLAL (multiple and single vector)</a>  |  |                | FEAT_SME2 |
| 1                    | 1                          | <a href="#">UMLSL (multiple and single vector)</a>  |  |                | FEAT_SME2 |

### SME2 single-multi two-way dot product four registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 1  | Zm | 0  | Rv | 1  | 0  | 1  | Zn | U  | 1  | off3 |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b>                               |  |  | <b>Feature</b> |
|----------------------|----------------------------------------------------------|--|--|----------------|
| <b>U</b>             |                                                          |  |  |                |
| 0                    | <a href="#">SDOT (2-way, multiple and single vector)</a> |  |  | FEAT_SME2      |
| 1                    | <a href="#">UDOT (2-way, multiple and single vector)</a> |  |  | FEAT_SME2      |

### SME2 single-multi long long MLA two sources

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 0  | Zm | 0  | Rv | 0  | 0  | 0  | Zn | U  | S  | op | 0 | 01 |   |   |   |   |   |   |   |   |  |

| Decode fields |   |   |    | Instruction Details                                  | Feature   |
|---------------|---|---|----|------------------------------------------------------|-----------|
| sz            | U | S | op |                                                      |           |
|               | 0 | 0 | 0  | <a href="#">SMLALL (multiple and single vector)</a>  | FEAT_SME2 |
|               | 0 | 1 | 0  | <a href="#">SMMLSLL (multiple and single vector)</a> | FEAT_SME2 |
|               | 1 | 0 | 0  | <a href="#">UMLALL (multiple and single vector)</a>  | FEAT_SME2 |
|               | 1 | 1 | 0  | <a href="#">UMLSLL (multiple and single vector)</a>  | FEAT_SME2 |
| 0             |   | 1 | 1  | UNALLOCATED                                          | -         |
| 0             | 0 | 0 | 1  | <a href="#">USMLALL (multiple and single vector)</a> | FEAT_SME2 |
| 0             | 1 | 0 | 1  | <a href="#">SUMLALL (multiple and single vector)</a> | FEAT_SME2 |
| 1             |   |   | 1  | UNALLOCATED                                          | -         |

### SME2 multiple and single vector long long FMA one source

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 0  | Zm | 0  | Rv | 0  | 0  | 1  | Zn | U  | S  | op | off2 |   |   |   |   |   |   |   |   |   |  |

| Decode fields |   |   |    | Instruction Details                                  | Feature   |
|---------------|---|---|----|------------------------------------------------------|-----------|
| sz            | U | S | op |                                                      |           |
|               | 0 | 0 | 0  | <a href="#">SMLALL (multiple and single vector)</a>  | FEAT_SME2 |
|               | 0 | 1 | 0  | <a href="#">SMMLSLL (multiple and single vector)</a> | FEAT_SME2 |
|               | 1 | 0 | 0  | <a href="#">UMLALL (multiple and single vector)</a>  | FEAT_SME2 |
|               | 1 | 1 | 0  | <a href="#">UMLSLL (multiple and single vector)</a>  | FEAT_SME2 |
| 0             | 0 | 0 | 1  | <a href="#">USMLALL (multiple and single vector)</a> | FEAT_SME2 |
| 0             | 0 | 1 | 1  | UNALLOCATED                                          | -         |
| 0             | 1 |   | 1  | UNALLOCATED                                          | -         |
| 1             |   |   | 1  | UNALLOCATED                                          | -         |

### SME2 single-multi four-way dot product two registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 0  | Zm | 0  | Rv | 1  | 0  | 1  | Zn | U  | 0  | off3 |   |   |   |   |   |   |   |   |   |   |

#### Decode fields

#### Instruction Details

#### Feature

**U**

|   |                                                          |           |
|---|----------------------------------------------------------|-----------|
| 0 | <a href="#">SDOT (4-way, multiple and single vector)</a> | FEAT_SME2 |
| 1 | <a href="#">UDOT (4-way, multiple and single vector)</a> | FEAT_SME2 |

### SME2 single-multi ternary FP two registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 0  | Zm | 0  | Rv | 1  | 1  | 0  | Zn | 0  | S  | off3 |   |   |   |   |   |   |   |   |   |   |

#### Decode fields

**S**

#### Instruction Details

#### Feature

|   |                                                   |           |
|---|---------------------------------------------------|-----------|
| 0 | <a href="#">FMLA (multiple and single vector)</a> | FEAT_SME2 |
| 1 | <a href="#">FMLS (multiple and single vector)</a> | FEAT_SME2 |

### SME2 single-multi ternary int two registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 0  | Zm | 0  | Rv | 1  | 1  | 0  | Zn | 1  | S  | off3 |   |   |   |   |   |   |   |   |   |   |

#### Decode fields

**S**

#### Instruction Details

#### Feature

|   |                                                                 |           |
|---|-----------------------------------------------------------------|-----------|
| 0 | <a href="#">ADD (array results, multiple and single vector)</a> | FEAT_SME2 |
| 1 | <a href="#">SUB (array results, multiple and single vector)</a> | FEAT_SME2 |

### SME2 single-multi ternary FP16 two registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 0  | Zm | 0  | Rv | 1  | 1  | 1  | Zn | 0  | S  | off3 |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                |  |  | Feature         |
|---------------|---|----------------------------------------------------|--|--|-----------------|
| sz            | S |                                                    |  |  |                 |
| 0             | 0 | <a href="#">FMLA (multiple and single vector)</a>  |  |  | FEAT_SME_F16F16 |
| 0             | 1 | <a href="#">FMLS (multiple and single vector)</a>  |  |  | FEAT_SME_F16F16 |
| 1             | 0 | <a href="#">BFMLA (multiple and single vector)</a> |  |  | FEAT_SVE_B16B16 |
| 1             | 1 | <a href="#">BFMLS (multiple and single vector)</a> |  |  | FEAT_SVE_B16B16 |

### SME2 single-multi long long MLA four sources

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 1  | Zm | 0  | Rv | 0  | 0  | 0  | Zn | U  | S  | op | 0 | 0 | 1 |   |   |   |   |   |   |   |

| Decode fields |   |   |    | Instruction Details                                  |  |  | Feature   |
|---------------|---|---|----|------------------------------------------------------|--|--|-----------|
| sz            | U | S | op |                                                      |  |  |           |
|               | 0 | 0 | 0  | <a href="#">SMLALL (multiple and single vector)</a>  |  |  | FEAT_SME2 |
|               | 0 | 1 | 0  | <a href="#">SMLSLL (multiple and single vector)</a>  |  |  | FEAT_SME2 |
|               | 1 | 0 | 0  | <a href="#">UMLALL (multiple and single vector)</a>  |  |  | FEAT_SME2 |
|               | 1 | 1 | 0  | <a href="#">UMLSLL (multiple and single vector)</a>  |  |  | FEAT_SME2 |
| 0             |   | 1 | 1  | UNALLOCATED                                          |  |  | -         |
| 0             | 0 | 0 | 1  | <a href="#">USMLALL (multiple and single vector)</a> |  |  | FEAT_SME2 |
| 0             | 1 | 0 | 1  | <a href="#">SUMLALL (multiple and single vector)</a> |  |  | FEAT_SME2 |
| 1             |   |   | 1  | UNALLOCATED                                          |  |  | -         |

### SME2 single-multi four-way dot product four registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 1  | Zm | 0  | Rv | 1  | 0  | 1  | Zn | U  | 0  | off3 |   |   |   |   |   |   |   |   |   |   |

### Decode fields

### Instruction Details

### Feature

**U**

|   |                                                          |           |
|---|----------------------------------------------------------|-----------|
| 0 | <a href="#">SDOT (4-way, multiple and single vector)</a> | FEAT_SME2 |
| 1 | <a href="#">UDOT (4-way, multiple and single vector)</a> | FEAT_SME2 |

## SME2 single-multi ternary FP four registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 1  | Zm | 0  | Rv | 1  | 1  | 0  | Zn | 0  | S  | off3 |   |   |   |   |   |   |   |   |   |   |

### Decode fields

**S**

### Instruction Details

### Feature

|   |                                                   |           |
|---|---------------------------------------------------|-----------|
| 0 | <a href="#">FMLA (multiple and single vector)</a> | FEAT_SME2 |
| 1 | <a href="#">FMLS (multiple and single vector)</a> | FEAT_SME2 |

## SME2 single-multi ternary int four registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 1  | Zm | 0  | Rv | 1  | 1  | 0  | Zn | 1  | S  | off3 |   |   |   |   |   |   |   |   |   |   |

### Decode fields

**S**

### Instruction Details

### Feature

|   |                                                                 |           |
|---|-----------------------------------------------------------------|-----------|
| 0 | <a href="#">ADD (array results, multiple and single vector)</a> | FEAT_SME2 |
| 1 | <a href="#">SUB (array results, multiple and single vector)</a> | FEAT_SME2 |

## SME2 single-multi ternary FP16 four registers

These instructions are under [SME2 Multi-vector - Multiple and Single Array Vectors](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | sz | 1  | 1  |    | Zm | 0  | Rv | 1  | 1  | 1  |    | Zn |    | 0 | S |   | off3 |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                | Feature         |
|---------------|---|----------------------------------------------------|-----------------|
| sz            | S |                                                    |                 |
| 0             | 0 | <a href="#">FMLA (multiple and single vector)</a>  | FEAT_SME_F16F16 |
| 0             | 1 | <a href="#">FMLS (multiple and single vector)</a>  | FEAT_SME_F16F16 |
| 1             | 0 | <a href="#">BFMLA (multiple and single vector)</a> | FEAT_SVE_B16B16 |
| 1             | 1 | <a href="#">BFMLS (multiple and single vector)</a> | FEAT_SVE_B16B16 |

## SME2 Multi-vector - Multiple Array Vectors (Two registers)

These instructions are under [SME encodings](#).

| Decode fields |       |     |     |       | Instruction details                                                | Feature   |
|---------------|-------|-----|-----|-------|--------------------------------------------------------------------|-----------|
| op0           | op1   | op2 | op3 | op4   |                                                                    |           |
| 0             | 00    | x0  | 11x | 1xxxx | UNALLOCATED                                                        | -         |
| 0             |       |     | 010 | 0xx0x | <a href="#">SME2 multiple vectors long FMA two sources</a>         | -         |
| 0             |       |     | 100 | 1x1xx | UNALLOCATED                                                        | -         |
| 0             |       |     | 100 | xx0xx | <a href="#">SME2 multiple vectors FP dot product two registers</a> | -         |
| 0             |       |     | 101 | 001xx | <a href="#">USDOT (multiple vectors) – Two ZA single-vectors</a>   | FEAT_SME2 |
| 0             |       |     | 101 | 011xx | UNALLOCATED                                                        | -         |
| 0             |       |     | 101 | 1xxxx | UNALLOCATED                                                        | -         |
| 1             | 00    | x0  | 1xx | 1xxxx | UNALLOCATED                                                        | -         |
| 1             | 00    | x1  | 10x | 1xxxx | UNALLOCATED                                                        | -         |
| 1             | != 00 |     | 10x | 1xxxx | UNALLOCATED                                                        | -         |
| 1             |       |     | 010 | 0xx0x | <a href="#">SME2 multiple vectors long MLA two sources</a>         | -         |

|   |       |    |     |        |                                                                          |   |
|---|-------|----|-----|--------|--------------------------------------------------------------------------|---|
| 1 |       |    | 100 | 0x0xx  | UNALLOCATED                                                              | - |
| 1 |       |    | 101 | 0x1xx  | <a href="#">SME2 multiple vectors two-way dot product two registers</a>  | - |
|   | 00    | 00 | 111 | 00xxx  | <a href="#">SME2 multiple vectors binary FP two registers</a>            | - |
|   | 00    | 00 | 111 | 01xxx  | <a href="#">SME2 multiple vectors binary int two registers</a>           | - |
|   | 00    | 10 | 111 | 00xxx  | <a href="#">SME2 multiple vectors binary FP16 two registers</a>          | - |
|   | 00    | 10 | 111 | 01xxx  | UNALLOCATED                                                              | - |
|   | 00    | x1 | 110 | 1xxxx  | UNALLOCATED                                                              | - |
|   | 00    | x1 | 111 |        | UNALLOCATED                                                              | - |
|   | != 00 |    | 110 | 1xxxx  | UNALLOCATED                                                              | - |
|   | != 00 |    | 111 |        | UNALLOCATED                                                              | - |
|   |       |    | 000 | 0xxxx0 | <a href="#">SME2 multiple vectors long long MLA two sources</a>          | - |
|   |       |    | 000 | 0xxx1  | UNALLOCATED                                                              | - |
|   |       |    | 010 | 0xx1x  | UNALLOCATED                                                              | - |
|   |       |    | 0x0 | 1xxxx  | UNALLOCATED                                                              | - |
|   |       |    | 0x1 |        | UNALLOCATED                                                              | - |
|   |       |    | 100 | 0x1xx  | <a href="#">SME2 multiple vectors ternary FP16 two registers</a>         | - |
|   |       |    | 101 | 0x0xx  | <a href="#">SME2 multiple vectors four-way dot product two registers</a> | - |
|   |       |    | 110 | 00xxx  | <a href="#">SME2 multiple vectors ternary FP two registers</a>           | - |
|   |       |    | 110 | 01xxx  | <a href="#">SME2 multiple vectors ternary int two registers</a>          | - |

### SME2 multiple vectors long FMA two sources

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |      |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | Zm | 0  | 0  | Rv | 0  | 1  | 0  | Zn | 0  | op | S  | 0 | off2 |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                       |  |  | Feature   |
|---------------|---|-------------------------------------------|--|--|-----------|
| op            | S |                                           |  |  |           |
| 0             | 0 | <a href="#">FMLAL (multiple vectors)</a>  |  |  | FEAT_SME2 |
| 0             | 1 | <a href="#">FMLS (multiple vectors)</a>   |  |  | FEAT_SME2 |
| 1             | 0 | <a href="#">BFMLAL (multiple vectors)</a> |  |  | FEAT_SME2 |
| 1             | 1 | <a href="#">BFMLS (multiple vectors)</a>  |  |  | FEAT_SME2 |

### SME2 multiple vectors FP dot product two registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | Zm | 0  | 0  | Rv | 1  | 0  | 0  | Zn | 0  | opc | 0  | off3 |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                      |  |  | Feature   |
|---------------|--|------------------------------------------|--|--|-----------|
| opc           |  |                                          |  |  |           |
| 00            |  | <a href="#">FDOT (multiple vectors)</a>  |  |  | FEAT_SME2 |
| 01            |  | <a href="#">BFDOT (multiple vectors)</a> |  |  | FEAT_SME2 |
| 1x            |  | UNALLOCATED                              |  |  | -         |

### SME2 multiple vectors long MLA two sources

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |      |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | Zm | 0  | 0  | Rv | 0  | 1  | 0  | Zn | 0  | U  | S  | 0 | off2 |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                      |  |  | Feature   |
|---------------|---|------------------------------------------|--|--|-----------|
| U             | S |                                          |  |  |           |
| 0             | 0 | <a href="#">SMLAL (multiple vectors)</a> |  |  | FEAT_SME2 |
| 0             | 1 | <a href="#">SMLS (multiple vectors)</a>  |  |  | FEAT_SME2 |
| 1             | 0 | <a href="#">UMLAL (multiple vectors)</a> |  |  | FEAT_SME2 |
| 1             | 1 | <a href="#">UMLS (multiple vectors)</a>  |  |  | FEAT_SME2 |

### SME2 multiple vectors two-way dot product two registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | Zm | 0  | 0  | Rv | 1  | 0  | 1  | Zn | 0  | U  | 1  | off3 |   |   |   |   |   |   |   |   |   |

| Decode fields<br><b>U</b> | Instruction Details                            | Feature   |
|---------------------------|------------------------------------------------|-----------|
| 0                         | <a href="#">SDOT (2-way, multiple vectors)</a> | FEAT_SME2 |
| 1                         | <a href="#">UDOT (2-way, multiple vectors)</a> | FEAT_SME2 |

### SME2 multiple vectors binary FP two registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | 0  | 0  | 0  | 0  | 0  | Rv | 1  | 1  | 1  | Zm | 0  | 0 | S | off3 |   |   |   |   |   |   |   |

| Decode fields<br><b>S</b> | Instruction Details  | Feature   |
|---------------------------|----------------------|-----------|
| 0                         | <a href="#">FADD</a> | FEAT_SME2 |
| 1                         | <a href="#">FSUB</a> | FEAT_SME2 |

### SME2 multiple vectors binary int two registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | 0  | 0  | 0  | 0  | 0  | Rv | 1  | 1  | 1  | Zm | 0  | 1 | S | off3 |   |   |   |   |   |   |   |

| Decode fields<br><b>S</b> | Instruction Details                      | Feature   |
|---------------------------|------------------------------------------|-----------|
| 0                         | <a href="#">ADD (array accumulators)</a> | FEAT_SME2 |
| 1                         | <a href="#">SUB (array accumulators)</a> | FEAT_SME2 |

### SME2 multiple vectors binary FP16 two registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | 0  | 0  | 1  | 0  | 0  | 0  | Rv | 1  | 1  | 1  | Zm | 0 | 0 | S | off3 |   |   |   |   |   |   |

| Decode fields |   | Instruction Details   |  | Feature         |
|---------------|---|-----------------------|--|-----------------|
| sz            | S |                       |  |                 |
| 0             | 0 | <a href="#">FADD</a>  |  | FEAT_SME_F16F16 |
| 0             | 1 | <a href="#">FSUB</a>  |  | FEAT_SME_F16F16 |
| 1             | 0 | <a href="#">BFADD</a> |  | FEAT_SVE_B16B16 |
| 1             | 1 | <a href="#">BFSUB</a> |  | FEAT_SVE_B16B16 |

### SME2 multiple vectors long long MLA two sources

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | Zm | 0  | 0  | Rv | 0  | 0  | 0  | Zn | 0  | U  | S  | op | 0 | 0 | 1 | 0 |   |   |   |   |   |

| Decode fields |   |   |    | Instruction Details                        |  |  |  | Feature   |
|---------------|---|---|----|--------------------------------------------|--|--|--|-----------|
| sz            | U | S | op |                                            |  |  |  |           |
|               | 0 | 0 | 0  | <a href="#">SMLALL (multiple vectors)</a>  |  |  |  | FEAT_SME2 |
|               | 0 | 1 | 0  | <a href="#">SMILSLL (multiple vectors)</a> |  |  |  | FEAT_SME2 |
|               | 1 | 0 | 0  | <a href="#">UMLALL (multiple vectors)</a>  |  |  |  | FEAT_SME2 |
|               | 1 | 1 | 0  | <a href="#">UMLSLL (multiple vectors)</a>  |  |  |  | FEAT_SME2 |
| 0             | 0 | 0 | 1  | <a href="#">USMLALL (multiple vectors)</a> |  |  |  | FEAT_SME2 |
| 0             | 0 | 1 | 1  | UNALLOCATED                                |  |  |  | -         |
| 0             | 1 |   | 1  | UNALLOCATED                                |  |  |  | -         |
| 1             |   |   | 1  | UNALLOCATED                                |  |  |  | -         |

### SME2 multiple vectors ternary FP16 two registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | Zm | 0  | 0  | Rv | 1  | 0  | 0  | Zn | 0  | S  | 1  | off3 |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                      |  | Feature         |
|---------------|---|------------------------------------------|--|-----------------|
| sz            | S |                                          |  |                 |
| 0             | 0 | <a href="#">FMLA (multiple vectors)</a>  |  | FEAT_SME_F16F16 |
| 0             | 1 | <a href="#">FMLS (multiple vectors)</a>  |  | FEAT_SME_F16F16 |
| 1             | 0 | <a href="#">BFMLA (multiple vectors)</a> |  | FEAT_SVE_B16B16 |
| 1             | 1 | <a href="#">BFMLS (multiple vectors)</a> |  | FEAT_SVE_B16B16 |

## SME2 multiple vectors four-way dot product two registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

| <b>Decode fields</b> | <b>Instruction Details</b>                     | <b>Feature</b> |
|----------------------|------------------------------------------------|----------------|
| <b>U</b>             |                                                |                |
| 0                    | <a href="#">SDOT (4-way, multiple vectors)</a> | FEAT_SME2      |
| 1                    | <a href="#">UDOT (4-way, multiple vectors)</a> | FEAT_SME2      |

## SME2 multiple vectors ternary FP two registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

| <b>Decode fields</b> | <b>Instruction Details</b>              | <b>Feature</b> |
|----------------------|-----------------------------------------|----------------|
| S                    |                                         |                |
| 0                    | <a href="#">FMLA (multiple vectors)</a> | FEAT_SME2      |
| 1                    | <a href="#">FMLS (multiple vectors)</a> | FEAT_SME2      |

## SME2 multiple vectors ternary int two registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Two registers\)](#).

| <b>Decode fields</b> | <b>Instruction Details</b>                            | <b>Feature</b> |
|----------------------|-------------------------------------------------------|----------------|
| <b>S</b>             |                                                       |                |
| 0                    | <a href="#">ADD (array results, multiple vectors)</a> | FEAT_SME2      |
| 1                    | <a href="#">SUB (array results, multiple vectors)</a> | FEAT_SME2      |

## SME2 Multi-vector - Multiple Array Vectors (Four registers)

These instructions are under [SME encodings](#).

| Decode fields |       |     |     |     |      | Instruction details                                                      | Feature   |
|---------------|-------|-----|-----|-----|------|--------------------------------------------------------------------------|-----------|
| op0           | op1   | op2 | op3 | op4 | op5  |                                                                          |           |
| 0             | 00    | x0  | 11x | 01  |      | UNALLOCATED                                                              | -         |
| 0             |       | x0  | 010 | 00  | xx0x | <a href="#">SME2 multiple vectors long FMA four sources</a>              | -         |
| 0             |       | x0  | 100 | 01  | x1xx | UNALLOCATED                                                              | -         |
| 0             |       | x0  | 100 | 0x  | x0xx | <a href="#">SME2 multiple vectors FP dot product four registers</a>      | -         |
| 0             |       | x0  | 101 | 00  | 01xx | <a href="#">USDOT (multiple vectors) â€“ Four ZA single-vectors</a>      | FEAT_SME2 |
| 0             |       | x0  | 101 | 00  | 11xx | UNALLOCATED                                                              | -         |
| 0             |       | x0  | 101 | 01  |      | UNALLOCATED                                                              | -         |
| 1             | 00    | x0  | 1xx | 01  |      | UNALLOCATED                                                              | -         |
| 1             | != 00 | x0  | 10x | 01  |      | UNALLOCATED                                                              | -         |
| 1             |       | x0  | 010 | 00  | xx0x | <a href="#">SME2 multiple vectors long MLA four sources</a>              | -         |
| 1             |       | x0  | 100 | 00  | x0xx | UNALLOCATED                                                              | -         |
| 1             |       | x0  | 101 | 00  | x1xx | <a href="#">SME2 multiple vectors two-way dot product four registers</a> | -         |
|               | 00    | 00  | 111 | 00  | 0xxx | <a href="#">SME2 multiple vectors binary FP four registers</a>           | -         |
|               | 00    | 00  | 111 | 00  | 1xxx | <a href="#">SME2 multiple vectors binary int four registers</a>          | -         |
|               | 00    | 10  | 111 | 00  | 0xxx | <a href="#">SME2 multiple vectors binary FP16 four registers</a>         | -         |
|               | 00    | 10  | 111 | 00  | 1xxx | UNALLOCATED                                                              | -         |
|               | 00    | x0  | 1xx | 1x  |      | UNALLOCATED                                                              | -         |
|               | != 00 | x0  | 10x | 1x  |      | UNALLOCATED                                                              | -         |

|  |           |    |     |           |      |                                                                           |   |
|--|-----------|----|-----|-----------|------|---------------------------------------------------------------------------|---|
|  | $\neq 00$ | x0 | 110 | 01        |      | UNALLOCATED                                                               | - |
|  | $\neq 00$ | x0 | 110 | 1x        |      | UNALLOCATED                                                               | - |
|  | $\neq 00$ | x0 | 111 |           |      | UNALLOCATED                                                               | - |
|  |           | x0 | 000 | 00        | xxx0 | <a href="#">SME2 multiple vectors long long MLA four sources</a>          | - |
|  |           | x0 | 000 | 00        | xxx1 | UNALLOCATED                                                               | - |
|  |           | x0 | 010 | 00        | xx1x | UNALLOCATED                                                               | - |
|  |           | x0 | 0x0 | $\neq 00$ |      | UNALLOCATED                                                               | - |
|  |           | x0 | 0x1 |           |      | UNALLOCATED                                                               | - |
|  |           | x0 | 100 | 00        | x1xx | <a href="#">SME2 multiple vectors ternary FP16 four registers</a>         | - |
|  |           | x0 | 101 | 00        | x0xx | <a href="#">SME2 multiple vectors four-way dot product four registers</a> | - |
|  |           | x0 | 110 | 00        | 0xxx | <a href="#">SME2 multiple vectors ternary FP four registers</a>           | - |
|  |           | x0 | 110 | 00        | 1xxx | <a href="#">SME2 multiple vectors ternary int four registers</a>          | - |
|  |           | x1 |     |           |      | UNALLOCATED                                                               | - |

### SME2 multiple vectors long FMA four sources

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | Zm | 0  | 1  | 0  | Rv | 0  | 1  | 0  | Zn | 0  | 0  | op | S | 0 | off2 |   |   |   |   |   |   |

| Decode fields | Instruction Details |                                            | Feature   |
|---------------|---------------------|--------------------------------------------|-----------|
| op            | S                   |                                            |           |
| 0             | 0                   | <a href="#">FMLAL (multiple vectors)</a>   | FEAT_SME2 |
| 0             | 1                   | <a href="#">FMLS L (multiple vectors)</a>  | FEAT_SME2 |
| 1             | 0                   | <a href="#">BFMLAL (multiple vectors)</a>  | FEAT_SME2 |
| 1             | 1                   | <a href="#">BFMLS L (multiple vectors)</a> | FEAT_SME2 |

## SME2 multiple vectors FP dot product four registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |      |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|------|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | Zm | 0  | 1  | 0  | Rv | 1  | 0  | 0  | Zn | 0  | opc | 0 | off3 |   |   |   |   |   |   |   |   |

| Decode fields<br>opc | Instruction Details                      | Feature   |
|----------------------|------------------------------------------|-----------|
| 00                   | <a href="#">FDOT (multiple vectors)</a>  | FEAT_SME2 |
| 01                   | <a href="#">BFDOT (multiple vectors)</a> | FEAT_SME2 |
| 1x                   | UNALLOCATED                              | -         |

## SME2 multiple vectors long MLA four sources

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | Zm | 0  | 1  | 0  | Rv | 0  | 1  | 0  | Zn | 0  | 0  | U | S | 0 | off2 |   |   |   |   |   |   |

| Decode fields<br>U | S | Instruction Details                       | Feature   |
|--------------------|---|-------------------------------------------|-----------|
| 0                  | 0 | <a href="#">SMLAL (multiple vectors)</a>  | FEAT_SME2 |
| 0                  | 1 | <a href="#">SMLS L (multiple vectors)</a> | FEAT_SME2 |
| 1                  | 0 | <a href="#">UMLAL (multiple vectors)</a>  | FEAT_SME2 |
| 1                  | 1 | <a href="#">UMLSL (multiple vectors)</a>  | FEAT_SME2 |

## SME2 multiple vectors two-way dot product four registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | Zm | 0  | 1  | 0  | Rv | 1  | 0  | 1  | Zn | 0  | 0  | U | 1 | off3 |   |   |   |   |   |   |   |

| Decode fields<br>U | Instruction Details                            | Feature   |
|--------------------|------------------------------------------------|-----------|
| 0                  | <a href="#">SDOT (2-way, multiple vectors)</a> | FEAT_SME2 |
| 1                  | <a href="#">UDOT (2-way, multiple vectors)</a> | FEAT_SME2 |

## SME2 multiple vectors binary FP four registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |      |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|------|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | 0  | 0  | 0  | 1  | 0  | Rv | 1  | 1  | 1  | Zm | 0  | 0 | 0 | S | off3 |   |   |   |   |   |   |

**Decode fields**  
S

**Instruction Details**

**Feature**

|   |                      |           |
|---|----------------------|-----------|
| 0 | <a href="#">FADD</a> | FEAT_SME2 |
| 1 | <a href="#">FSUB</a> | FEAT_SME2 |

### SME2 multiple vectors binary int four registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |      |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|------|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5    | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | 0  | 0  | 0  | 0  | 1  | 0  | Rv | 1  | 1  | 1  | Zm | 0 | 0 | 1 | S | off3 |   |   |   |   |   |

**Decode fields**  
S

**Instruction Details**

**Feature**

|   |                                          |           |
|---|------------------------------------------|-----------|
| 0 | <a href="#">ADD (array accumulators)</a> | FEAT_SME2 |
| 1 | <a href="#">SUB (array accumulators)</a> | FEAT_SME2 |

### SME2 multiple vectors binary FP16 four registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |      |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|------|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5    | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | 0  | 0  | 1  | 0  | 1  | 0  | Rv | 1  | 1  | 1  | Zm | 0 | 0 | 0 | S | off3 |   |   |   |   |   |

**Decode fields**  
sz S

**Instruction Details**

**Feature**

|   |   |                       |                 |
|---|---|-----------------------|-----------------|
| 0 | 0 | <a href="#">FADD</a>  | FEAT_SME_F16F16 |
| 0 | 1 | <a href="#">FSUB</a>  | FEAT_SME_F16F16 |
| 1 | 0 | <a href="#">BFADD</a> | FEAT_SVE_B16B16 |
| 1 | 1 | <a href="#">BFSUB</a> | FEAT_SVE_B16B16 |

### SME2 multiple vectors long long MLA four sources

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |   |    |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|---|----|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | Zm | 0  | 1  | 0  | Rv | 0  | 0  | 0  | Zn | 0  | 0  | U | S | op | 0 | 01 |   |   |   |   |   |

| Decode fields |   |   |    | Instruction Details                        | Feature   |
|---------------|---|---|----|--------------------------------------------|-----------|
| sz            | U | S | op |                                            |           |
|               | 0 | 0 | 0  | <a href="#">SMLALL (multiple vectors)</a>  | FEAT_SME2 |
|               | 0 | 1 | 0  | <a href="#">SMILSLL (multiple vectors)</a> | FEAT_SME2 |
|               | 1 | 0 | 0  | <a href="#">UMLALL (multiple vectors)</a>  | FEAT_SME2 |
|               | 1 | 1 | 0  | <a href="#">UMLSLL (multiple vectors)</a>  | FEAT_SME2 |
| 0             | 0 | 0 | 1  | <a href="#">USMLALL (multiple vectors)</a> | FEAT_SME2 |
| 0             | 0 | 1 | 1  | UNALLOCATED                                | -         |
| 0             | 1 |   | 1  | UNALLOCATED                                | -         |
| 1             |   |   | 1  | UNALLOCATED                                | -         |

### SME2 multiple vectors ternary FP16 four registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | Zm | 0  | 1  | 0  | Rv | 1  | 0  | 0  | Zn | 0  | 0  | S | 1 | off3 |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                      | Feature         |
|---------------|---|------------------------------------------|-----------------|
| sz            | S |                                          |                 |
| 0             | 0 | <a href="#">FMLA (multiple vectors)</a>  | FEAT_SME_F16F16 |
| 0             | 1 | <a href="#">FMLS (multiple vectors)</a>  | FEAT_SME_F16F16 |
| 1             | 0 | <a href="#">BFMLA (multiple vectors)</a> | FEAT_SVE_B16B16 |
| 1             | 1 | <a href="#">BFMLS (multiple vectors)</a> | FEAT_SVE_B16B16 |

### SME2 multiple vectors four-way dot product four registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | Zm | 0  | 1  | 0  | Rv | 1  | 0  | 1  | Zn | 0  | 0  | U | 0 | off3 |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                            | Feature   |
|---------------|--|------------------------------------------------|-----------|
| U             |  |                                                |           |
| 0             |  | <a href="#">SDOT (4-way, multiple vectors)</a> | FEAT_SME2 |
| 1             |  | <a href="#">UDOT (4-way, multiple vectors)</a> | FEAT_SME2 |

## SME2 multiple vectors ternary FP four registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | Zm | 0  | 1  | 0  | Rv | 1  | 1  | 0  | Zn | 0  | 0  | 0 | S | off3 |   |   |   |   |   |   |   |

| Decode fields<br>S | Instruction Details                     | Feature   |
|--------------------|-----------------------------------------|-----------|
| 0                  | <a href="#">FMLA (multiple vectors)</a> | FEAT_SME2 |
| 1                  | <a href="#">FMLS (multiple vectors)</a> | FEAT_SME2 |

## SME2 multiple vectors ternary int four registers

These instructions are under [SME2 Multi-vector - Multiple Array Vectors \(Four registers\)](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | sz | 1  | Zm | 0  | 1  | 0  | Rv | 1  | 1  | 0  | Zn | 0  | 0  | 1 | S | off3 |   |   |   |   |   |   |   |

| Decode fields<br>S | Instruction Details                                   | Feature   |
|--------------------|-------------------------------------------------------|-----------|
| 0                  | <a href="#">ADD (array results, multiple vectors)</a> | FEAT_SME2 |
| 1                  | <a href="#">SUB (array results, multiple vectors)</a> | FEAT_SME2 |

## SME Memory

These instructions are under [SME encodings](#).

|         |     |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |     |   |   |   |   |   |   |
|---------|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|-----|---|---|---|---|---|---|
| 31      | 30  | 29  | 28  | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
| 1110000 | op0 | op1 | op2 | op3 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   | op4 |   |   |   |   |   |   |

| op0  | op1   | op2 | op3     | op4 | Decode fields                                     | Instruction details | Feature |
|------|-------|-----|---------|-----|---------------------------------------------------|---------------------|---------|
| 0xx0 |       |     |         | 0xx | <a href="#">SME load array vector (elements)</a>  | -                   |         |
| 0xx1 |       |     |         | 0xx | <a href="#">SME store array vector (elements)</a> | -                   |         |
| 0xxx |       |     |         | 1xx | UNALLOCATED                                       | -                   |         |
| 100x | 00000 | 0   | xx000   | 0xx | <a href="#">SME save and restore array</a>        | -                   |         |
| 100x | 00000 | 0   | xx000   | 1xx | UNALLOCATED                                       | -                   |         |
| 100x | 00000 | 0   | xx!=000 |     | UNALLOCATED                                       | -                   |         |

|      |                 |   |                 |               |                                                  |          |
|------|-----------------|---|-----------------|---------------|--------------------------------------------------|----------|
| 100x | $\neq$<br>00000 | 0 |                 |               | UNALLOCATED                                      | -        |
| 100x |                 | 1 | 00000           | 000           | <a href="#">SME2 lookup table<br/>load/store</a> | -        |
| 100x |                 | 1 | 00000           | $\neq$<br>000 | UNALLOCATED                                      | -        |
| 100x |                 | 1 | $\neq$<br>00000 |               | UNALLOCATED                                      | -        |
| 101x |                 |   |                 |               | UNALLOCATED                                      | -        |
| 110x |                 |   |                 |               | UNALLOCATED                                      | -        |
| 1110 |                 |   |                 | 0xx           | <a href="#">LD1Q</a>                             | FEAT_SME |
| 1111 |                 |   |                 | 0xx           | <a href="#">ST1Q</a>                             | FEAT_SME |
| 111x |                 |   |                 | 1xx           | UNALLOCATED                                      | -        |

### SME load array vector (elements)

These instructions are under [SME Memory](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 1  | 1  | 1  | 0  | 0  | 0  | 0  | msz | 0  | Rm | V  | Rs | Pg |    | Rn | 0  | opc |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

#### Decode fields

msz

#### Instruction Details

#### Feature

|    |                                                       |          |
|----|-------------------------------------------------------|----------|
| 00 | <a href="#">LD1B (scalar plus scalar, tile slice)</a> | FEAT_SME |
| 01 | <a href="#">LD1H (scalar plus scalar, tile slice)</a> | FEAT_SME |
| 10 | <a href="#">LD1W (scalar plus scalar, tile slice)</a> | FEAT_SME |
| 11 | <a href="#">LD1D (scalar plus scalar, tile slice)</a> | FEAT_SME |

### SME store array vector (elements)

These instructions are under [SME Memory](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 1  | 1  | 1  | 0  | 0  | 0  | 0  | msz | 1  | Rm | V  | Rs | Pg |    | Rn | 0  | opc |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

#### Decode fields

msz

#### Instruction Details

#### Feature

|    |                                                       |          |
|----|-------------------------------------------------------|----------|
| 00 | <a href="#">ST1B (scalar plus scalar, tile slice)</a> | FEAT_SME |
| 01 | <a href="#">ST1H (scalar plus scalar, tile slice)</a> | FEAT_SME |
| 10 | <a href="#">ST1W (scalar plus scalar, tile slice)</a> | FEAT_SME |
| 11 | <a href="#">ST1D (scalar plus scalar, tile slice)</a> | FEAT_SME |

## SME save and restore array

These instructions are under [SME Memory](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | op | 0  | 0  | 0  | 0  | 0  | Rv | 0  | 0  | 0  | Rn | 0  | imm4 |   |   |   |   |   |   |   |   |   |

| Decode fields<br>op | Instruction Details          | Feature  |
|---------------------|------------------------------|----------|
| 0                   | <a href="#">LDR (vector)</a> | FEAT_SME |
| 1                   | <a href="#">STR (vector)</a> | FEAT_SME |

---

## SME2 lookup table load/store

These instructions are under [SME Memory](#).

|    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |      |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|------|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | opc | 1  | 0  | 0  | 0  | 0  | Rn | 0  | 0  | 0  | opc2 |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>opc | Decode fields<br>opc2 | Instruction Details       | Feature   |
|----------------------|-----------------------|---------------------------|-----------|
| x0xxxx               |                       | UNALLOCATED               | -         |
| x10xxx               |                       | UNALLOCATED               | -         |
| x110xx               |                       | UNALLOCATED               | -         |
| x1110x               |                       | UNALLOCATED               | -         |
| x11110               |                       | UNALLOCATED               | -         |
| x11111               | 01                    | UNALLOCATED               | -         |
| x11111               | 1x                    | UNALLOCATED               | -         |
| 011111               | 00                    | <a href="#">LDR (ZT0)</a> | FEAT_SME2 |
| 111111               | 00                    | <a href="#">STR (ZT0)</a> | FEAT_SME2 |

---

## SVE encodings

These instructions are under the [top-level](#).

|     |      |    |     |    |    |     |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|------|----|-----|----|----|-----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31  | 30   | 29 | 28  | 27 | 26 | 25  | 24 | 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| op0 | 0010 |    | op1 |    |    | op2 |    |    | op3 |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>op0 | Decode fields<br>op1 | Decode fields<br>op2 | Decode fields<br>op3 | Instruction details                                        | Feature |
|----------------------|----------------------|----------------------|----------------------|------------------------------------------------------------|---------|
| 000                  | 0xx0xxxx             | x1xxxx               |                      | <a href="#">SVE Integer Multiply-Add - Predicated</a>      | -       |
| 000                  | 0xx0xxxx             | 000xxx               |                      | <a href="#">SVE Integer Binary Arithmetic - Predicated</a> | -       |

|     |          |        |  |                                                                  |             |
|-----|----------|--------|--|------------------------------------------------------------------|-------------|
| 000 | 0xx0xxxx | 001xxx |  | <a href="#">SVE Integer Reduction</a>                            | -           |
| 000 | 0xx0xxxx | 100xxx |  | <a href="#">SVE Bitwise Shift - Predicated</a>                   | -           |
| 000 | 0xx0xxxx | 101xxx |  | <a href="#">SVE Integer Unary Arithmetic - Predicated</a>        | -           |
| 000 | 0xx1xxxx | 000xxx |  | <a href="#">SVE integer add/ subtract vectors (unpredicated)</a> | -           |
| 000 | 0xx1xxxx | 001xxx |  | <a href="#">SVE Bitwise Logical - Unpredicated</a>               | -           |
| 000 | 0xx1xxxx | 0100xx |  | <a href="#">SVE Index Generation</a>                             | -           |
| 000 | 0xx1xxxx | 0101xx |  | <a href="#">SVE Stack Allocation</a>                             | -           |
| 000 | 0xx1xxxx | 011xxx |  | <a href="#">SVE2 Integer Multiply - Unpredicated</a>             | -           |
| 000 | 0xx1xxxx | 100xxx |  | <a href="#">SVE Bitwise Shift - Unpredicated</a>                 | -           |
| 000 | 0xx1xxxx | 1010xx |  | <a href="#">SVE address generation</a>                           | -           |
| 000 | 0xx1xxxx | 1011xx |  | <a href="#">SVE Integer Misc - Unpredicated</a>                  | -           |
| 000 | 0xx1xxxx | 11xxxx |  | <a href="#">SVE Element Count</a>                                | -           |
| 000 | 1xx00xxx |        |  | <a href="#">SVE Bitwise Immediate</a>                            | -           |
| 000 | 1xx01xxx |        |  | <a href="#">SVE Integer Wide Immediate - Predicated</a>          | -           |
| 000 | 1xx1xxxx | 001000 |  | <a href="#">DUP (indexed)</a>                                    | -           |
| 000 | 1xx1xxxx | 001001 |  | <a href="#">SVE Permute Vector - One Source Quadwords</a>        | -           |
| 000 | 1xx1xxxx | 00101x |  | <a href="#">SVE table lookup (three sources)</a>                 | -           |
| 000 | 1xx1xxxx | 001100 |  | <a href="#">TBL â€“ SVE</a>                                      | -           |
| 000 | 1xx1xxxx | 001101 |  | <a href="#">TBXQ</a>                                             | FEAT_SVE2p1 |
| 000 | 1xx1xxxx | 001110 |  | <a href="#">SVE Permute Vector - Unpredicated</a>                | -           |
| 000 | 1xx1xxxx | 001111 |  | UNALLOCATED                                                      | -           |
| 000 | 1xx1xxxx | 010xxx |  | <a href="#">SVE Permute Predicate</a>                            | -           |
| 000 | 1xx1xxxx | 011xxx |  | <a href="#">SVE permute vector elements</a>                      | -           |
| 000 | 1xx1xxxx | 10xxxx |  | <a href="#">SVE Permute Vector - Predicated</a>                  | -           |
| 000 | 1xx1xxxx | 11xxxx |  | <a href="#">SEL (vectors)</a>                                    | -           |
| 000 | 10x1xxxx | 000xxx |  | <a href="#">SVE Permute Vector - Extract</a>                     | -           |
| 000 | 11x1xxxx | 000xxx |  | <a href="#">SVE Permute Vector - Segments</a>                    | -           |
| 001 | 0xx0xxxx |        |  | <a href="#">SVE Integer Compare - Vectors</a>                    | -           |

|     |                 |   |  |                                                                   |   |
|-----|-----------------|---|--|-------------------------------------------------------------------|---|
| 001 | 0xx1xxxx        |   |  | <a href="#">SVE integer compare with unsigned immediate</a>       | - |
| 001 | 1xx0xxxx0xxxx   |   |  | <a href="#">SVE integer compare with signed immediate</a>         | - |
| 001 | 1xx00xxx01xxxx  |   |  | <a href="#">SVE predicate logical operations</a>                  | - |
| 001 | 1xx00xxx11xxxx  |   |  | <a href="#">SVE Propagate Break</a>                               | - |
| 001 | 1xx01xxx01xxxx  |   |  | <a href="#">SVE Partition Break</a>                               | - |
| 001 | 1xx01xxx11xxxx  |   |  | <a href="#">SVE Predicate Misc</a>                                | - |
| 001 | 1xx1xxxx00xxxx  |   |  | <a href="#">SVE Integer Compare - Scalars</a>                     | - |
| 001 | 1xx1xxxx01xxxx  | 0 |  | <a href="#">SVE broadcast predicate element</a>                   | - |
| 001 | 1xx1xxxx01xxxx  | 1 |  | <a href="#">SVE Scalar Integer Compare - Predicate-as-counter</a> | - |
| 001 | 1xx1xxxx11xxxx  |   |  | <a href="#">SVE Integer Wide Immediate - Unpredicated</a>         | - |
| 001 | 1xx100xxx10xxxx |   |  | <a href="#">SVE Predicate Count</a>                               | - |
| 001 | 1xx101xx1000xx  |   |  | <a href="#">SVE Inc/Dec by Predicate Count</a>                    | - |
| 001 | 1xx101xx1001xx  |   |  | <a href="#">SVE Write FFR</a>                                     | - |
| 001 | 1xx101xx101xxx  |   |  | UNALLOCATED                                                       | - |
| 001 | 1xx11xxx10xxxx  |   |  | UNALLOCATED                                                       | - |
| 010 | 0xx0xxxx0xxxxx  |   |  | <a href="#">SVE Integer Multiply-Add - Unpredicated</a>           | - |
| 010 | 0xx0xxxx10xxxx  |   |  | <a href="#">SVE2 Integer - Predicated</a>                         | - |
| 010 | 0xx0xxxx11000x  |   |  | <a href="#">SVE integer clamp</a>                                 | - |
| 010 | 0xx0xxxx1101xx  |   |  | UNALLOCATED                                                       | - |
| 010 | 0xx0xxxx111xxx  |   |  | <a href="#">SVE permute vector elements (quadwords)</a>           | - |
| 010 | 0xx1xxxx        |   |  | <a href="#">SVE Multiply - Indexed</a>                            | - |
| 010 | 0x10xxxx11001x  |   |  | UNALLOCATED                                                       | - |
| 010 | 0000xxxx11001x  |   |  | <a href="#">SVE two-way dot product</a>                           | - |
| 010 | 0100xxxx11001x  |   |  | <a href="#">SVE two-way dot product (indexed)</a>                 | - |
| 010 | 1xx0xxxx0xxxxx  |   |  | <a href="#">SVE2 Widening Integer Arithmetic</a>                  | - |
| 010 | 1xx0xxxx10xxxx  |   |  | <a href="#">SVE Misc</a>                                          | - |
| 010 | 1xx0xxxx11xxxx  |   |  | <a href="#">SVE2 Accumulate</a>                                   | - |
| 010 | 1xx1xxxx0xxxxx  |   |  | <a href="#">SVE2 Narrowing</a>                                    | - |

|     |                  |  |                                                                    |   |
|-----|------------------|--|--------------------------------------------------------------------|---|
| 010 | 1xx1xxxx 00xxx   |  | <a href="#">SVE2 character match</a>                               | - |
| 010 | 1xx1xxxx 01xxx   |  | <a href="#">SVE2 Histogram Computation - Segment</a>               | - |
| 010 | 1xx1xxxx 10xxx   |  | <a href="#">HISTCNT</a>                                            | - |
| 010 | 1xx1xxxx 11xxx   |  | <a href="#">SVE2 Crypto Extensions</a>                             | - |
| 011 | 0xx0xxxx 0xxxxx  |  | <a href="#">FCMLA (vectors)</a>                                    | - |
| 011 | 0xx00x1 xxxxxxxx |  | UNALLOCATED                                                        | - |
| 011 | 0xx0000 000xxx   |  | <a href="#">FCADD</a>                                              | - |
| 011 | 0xx0000 010xxx   |  | UNALLOCATED                                                        | - |
| 011 | 0xx0000 011xxx   |  | UNALLOCATED                                                        | - |
| 011 | 0xx0000 1xxxxx   |  | UNALLOCATED                                                        | - |
| 011 | 0xx0010 000xxx   |  | UNALLOCATED                                                        | - |
| 011 | 0xx0010 010xxx   |  | <a href="#">SVE floating-point convert precision odd elements</a>  | - |
| 011 | 0xx0010 11xxxx   |  | UNALLOCATED                                                        | - |
| 011 | 0xx010xx 000xxx  |  | <a href="#">SVE2 floating-point pairwise operations</a>            | - |
| 011 | 0xx010xx 010xxx  |  | <a href="#">SVE floating-point recursive reduction (quadwords)</a> | - |
| 011 | 0xx010xx 11xxxx  |  | UNALLOCATED                                                        | - |
| 011 | 0xx011xx 1xxxxx  |  | UNALLOCATED                                                        | - |
| 011 | 0xx1xxxx 0000xx  |  | <a href="#">SVE floating-point multiply-add (indexed)</a>          | - |
| 011 | 0xx1xxxx 0001xx  |  | <a href="#">SVE floating-point complex multiply-add (indexed)</a>  | - |
| 011 | 0xx1xxxx 0010x0  |  | <a href="#">SVE floating-point multiply (indexed)</a>              | - |
| 011 | 0xx1xxxx 001001  |  | <a href="#">SVE FP clamp</a>                                       | - |
| 011 | 0xx1xxxx 001011  |  | UNALLOCATED                                                        | - |
| 011 | 0xx1xxxx 0011xx  |  | UNALLOCATED                                                        | - |
| 011 | 0xx1xxxx 01x0xx  |  | <a href="#">SVE Floating Point Widening Multiply-Add - Indexed</a> | - |
| 011 | 0xx1xxxx 01x1xx  |  | UNALLOCATED                                                        | - |
| 011 | 0xx1xxxx 10x00x  |  | <a href="#">SVE Floating Point Widening Multiply-Add</a>           | - |
| 011 | 0xx1xxxx 10x01x  |  | UNALLOCATED                                                        | - |
| 011 | 0xx1xxxx 10x1xx  |  | UNALLOCATED                                                        | - |
| 011 | 0xx1xxxx 110xxx  |  | UNALLOCATED                                                        | - |
| 011 | 0xx1xxxx 111000  |  | UNALLOCATED                                                        | - |

|     |          |        |  |                                                                               |   |
|-----|----------|--------|--|-------------------------------------------------------------------------------|---|
| 011 | 0xx1xxxx | 111001 |  | <a href="#">SVE floating point matrix multiply accumulate</a>                 | - |
| 011 | 0xx1xxxx | 11101x |  | UNALLOCATED                                                                   | - |
| 011 | 0xx1xxxx | 1111xx |  | UNALLOCATED                                                                   | - |
| 011 | 1xx0xxxx | 1xxxxx |  | <a href="#">SVE floating-point compare vectors</a>                            | - |
| 011 | 1xx0xxxx | 000xxx |  | <a href="#">SVE floating-point arithmetic (unpredicated)</a>                  | - |
| 011 | 1xx0xxxx | 100xxx |  | <a href="#">SVE Floating Point Arithmetic - Predicated</a>                    | - |
| 011 | 1xx0xxxx | 101xxx |  | <a href="#">SVE Floating Point Unary Operations - Predicated</a>              | - |
| 011 | 1xx000x  | 001xxx |  | <a href="#">SVE floating-point recursive reduction</a>                        | - |
| 011 | 1xx001x  | 0010xx |  | UNALLOCATED                                                                   | - |
| 011 | 1xx001x  | 0011xx |  | <a href="#">SVE Floating Point Unary Operations - Unpredicated</a>            | - |
| 011 | 1xx010x  | 001xxx |  | <a href="#">SVE Floating Point Compare - with Zero</a>                        | - |
| 011 | 1xx011x  | 001xxx |  | <a href="#">SVE Floating Point Accumulating Reduction</a>                     | - |
| 011 | 1xx1xxxx |        |  | <a href="#">SVE Floating Point Multiply-Add</a>                               | - |
| 100 |          |        |  | <a href="#">SVE Memory - 32-bit Gather and Unsized Contiguous</a>             | - |
| 101 |          |        |  | <a href="#">SVE Memory - Contiguous Load</a>                                  | - |
| 110 |          |        |  | <a href="#">SVE Memory - 64-bit Gather</a>                                    | - |
| 111 |          | 0x0xxx |  | <a href="#">SVE Memory - Contiguous Store and Unsized Contiguous</a>          | - |
| 111 |          | 001xxx |  | <a href="#">SVE Memory - Non-temporal and Quadword Scatter Store</a>          | - |
| 111 |          | 011xxx |  | <a href="#">SVE Memory - Non-temporal and Multi-register Contiguous Store</a> | - |

|     |  |        |  |                                                                     |   |
|-----|--|--------|--|---------------------------------------------------------------------|---|
| 111 |  | 1x0xxx |  | <a href="#">SVE Memory - Scatter with Optional Sign Extend</a>      | - |
| 111 |  | 101xxx |  | <a href="#">SVE Memory - Scatter</a>                                | - |
| 111 |  | 111xxx |  | <a href="#">SVE Memory - Contiguous Store with Immediate Offset</a> | - |

## SVE Integer Multiply-Add - Predicated

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 00000100 |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    | op0 | 1  |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Decode fields<br>op0 | Instruction details                                                         |
|----------------------|-----------------------------------------------------------------------------|
| 0                    | <a href="#">SVE integer multiply-accumulate writing addend (predicated)</a> |
| 1                    | <a href="#">SVE integer multiply-add writing multiplicand (predicated)</a>  |

## SVE integer multiply-accumulate writing addend (predicated)

These instructions are under [SVE Integer Multiply-Add - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  |    | Zm | 0  | 1  | op | Pg |    | Zn |    | Zda |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>op | Instruction Details           |
|---------------------|-------------------------------|
| 0                   | <a href="#">MLA (vectors)</a> |
| 1                   | <a href="#">MLS (vectors)</a> |

## SVE integer multiply-add writing multiplicand (predicated)

These instructions are under [SVE Integer Multiply-Add - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  |    | Zm | 1  | 1  | op | Pg |    | Za |    | Zdn |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>op | Instruction Details |
|---------------------|---------------------|
| 0                   | <a href="#">MAD</a> |

| Decode fields | Instruction Details |
|---------------|---------------------|
| op            |                     |
| 1             | <u>MSB</u>          |

## SVE Integer Binary Arithmetic - Predicated

These instructions are under [SVE encodings](#).

|          |    |    |    |       |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|-------|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27    | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00000100 |    |    |    | 0 op0 |    |    |    | 000 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction details</b>                                    |
|----------------------|---------------------------------------------------------------|
| <b>op0</b>           |                                                               |
| 00x                  | <a href="#">SVE integer add/subtract vectors (predicated)</a> |
| 01x                  | <a href="#">SVE integer min/max/difference (predicated)</a>   |
| 100                  | <a href="#">SVE integer multiply vectors (predicated)</a>     |
| 101                  | <a href="#">SVE integer divide vectors (predicated)</a>       |
| 11x                  | <a href="#">SVE bitwise logical operations (predicated)</a>   |

## SVE integer add/subtract vectors (predicated)

These instructions are under [SVE Integer Binary Arithmetic - Predicated](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |   |   |     |   |   |   |    |    |     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|----|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | 0 | 0 | opc | 0 | 0 | 0 | Pq | Zm | Zdn |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|----|-----|

| <b>Decode fields</b> | <b>Instruction Details</b>                |
|----------------------|-------------------------------------------|
| <b>opc</b>           |                                           |
| 000                  | <a href="#">ADD (vectors, predicated)</a> |
| 001                  | <a href="#">SUB (vectors, predicated)</a> |
| 010                  | UNALLOCATED                               |
| 011                  | <a href="#">SUBR (vectors)</a>            |
| 1xx                  | UNALLOCATED                               |

## SVE integer min/max/difference (predicated)

These instructions are under [SVE Integer Binary Arithmetic - Predicated](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |   |   |     |   |   |   |   |    |    |     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|---|----|----|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | 0 | 1 | opc | U | 0 | 0 | 0 | Pa | Zm | Zdn |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|---|----|----|-----|

| Decode fields |   | Instruction Details            |
|---------------|---|--------------------------------|
| opc           | U |                                |
| 00            | 0 | <a href="#">SMAX (vectors)</a> |
| 00            | 1 | <a href="#">UMAX (vectors)</a> |
| 01            | 0 | <a href="#">SMIN (vectors)</a> |
| 01            | 1 | <a href="#">UMIN (vectors)</a> |
| 10            | 0 | <a href="#">SABD</a>           |
| 10            | 1 | <a href="#">UABD</a>           |
| 11            |   | UNALLOCATED                    |

### SVE integer multiply vectors (predicated)

These instructions are under [SVE Integer Binary Arithmetic - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 1  | 0  | 0  | H  | U  | 0  | 0  | 0  | Pg |    | Zm |    | Zdn |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                       |
|---------------|---|-------------------------------------------|
| H             | U |                                           |
| 0             | 0 | <a href="#">MUL (vectors, predicated)</a> |
| 0             | 1 | UNALLOCATED                               |
| 1             | 0 | <a href="#">SMULH (predicated)</a>        |
| 1             | 1 | <a href="#">UMULH (predicated)</a>        |

### SVE integer divide vectors (predicated)

These instructions are under [SVE Integer Binary Arithmetic - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 1  | 0  | 1  | R  | U  | 0  | 0  | 0  | Pg |    | Zm |    | Zdn |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details   |
|---------------|---|-----------------------|
| R             | U |                       |
| 0             | 0 | <a href="#">SDIV</a>  |
| 0             | 1 | <a href="#">UDIV</a>  |
| 1             | 0 | <a href="#">SDIVR</a> |
| 1             | 1 | <a href="#">UDIVR</a> |

## SVE bitwise logical operations (predicated)

These instructions are under [SVE Integer Binary Arithmetic - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 1  | 1  | opc | 0  | 0  | 0  | Pg |    | Zm |    | Zdn |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>opc | Instruction Details                       |
|----------------------|-------------------------------------------|
| 000                  | <a href="#">ORR (vectors, predicated)</a> |
| 001                  | <a href="#">EOR (vectors, predicated)</a> |
| 010                  | <a href="#">AND (vectors, predicated)</a> |
| 011                  | <a href="#">BIC (vectors, predicated)</a> |
| 1xx                  | UNALLOCATED                               |

## SVE Integer Reduction

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 0  | 0  | op0 |    |    | 001 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>op0 | Instruction details                                        |
|----------------------|------------------------------------------------------------|
| 000                  | <a href="#">SVE integer add reduction (predicated)</a>     |
| 001                  | <a href="#">SVE integer add reduction (quadwords)</a>      |
| 010                  | <a href="#">SVE integer min/max reduction (predicated)</a> |
| 011                  | <a href="#">SVE integer min/max reduction (quadwords)</a>  |
| 10x                  | <a href="#">SVE constructive prefix (predicated)</a>       |
| 110                  | <a href="#">SVE bitwise logical reduction (predicated)</a> |
| 111                  | <a href="#">SVE bitwise logical reduction (quadwords)</a>  |

## SVE integer add reduction (predicated)

These instructions are under [SVE Integer Reduction](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 0  | 0  | op | U  | 0  | 0  | 1  | Pg |    | Zn |    | Vd |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>op | U | Instruction Details   |
|---------------------|---|-----------------------|
| 0                   | 0 | <a href="#">SADDV</a> |
| 0                   | 1 | <a href="#">UADDV</a> |

| Decode fields |   | Instruction Details |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|---------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| op            | U |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             |   | UNALLOCATED         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### SVE integer add reduction (quadwords)

These instructions are under [SVE Integer Reduction](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 0  | 0  | 1  | op | U  | 0  | 0  | 1  | Pg |    | Zn |    | Vd |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Feature     |  |  |  |  |
|---------------|---|-----------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-------------|--|--|--|--|
| op            | U |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |  |  |  |  |
| 0             | 0 | UNALLOCATED           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | -           |  |  |  |  |
| 0             | 1 | <a href="#">ADDQV</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SVE2p1 |  |  |  |  |
| 1             |   | UNALLOCATED           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | -           |  |  |  |  |

### SVE integer min/max reduction (predicated)

These instructions are under [SVE Integer Reduction](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 0  | 1  | 0  | op | U  | 0  | 0  | 1  | Pg |    | Zn |    | Vd |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|-----------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| op            | U |                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 0 | <a href="#">SMAXV</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0             | 1 | <a href="#">UMAXV</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             | 0 | <a href="#">SMINV</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1             | 1 | <a href="#">UMINV</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### SVE integer min/max reduction (quadwords)

These instructions are under [SVE Integer Reduction](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 0  | 1  | 1  | op | U  | 0  | 0  | 1  | Pg |    | Zn |    | Vd |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Feature     |  |  |  |  |
|---------------|---|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-------------|--|--|--|--|
| op            | U |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |  |  |  |  |
| 0             | 0 | <a href="#">SMAXQV</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SVE2p1 |  |  |  |  |
| 0             | 1 | <a href="#">UMAXQV</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SVE2p1 |  |  |  |  |
| 1             | 0 | <a href="#">SMINQV</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | FEAT_SVE2p1 |  |  |  |  |

| Decode fields |   | Instruction Details    | Feature     |
|---------------|---|------------------------|-------------|
| op            | U |                        |             |
| 1             | 1 | <a href="#">UMINQV</a> | FEAT_SVE2p1 |

## SVE constructive prefix (predicated)

These instructions are under [SVE Integer Reduction](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |   |   |     |   |   |   |   |    |  |    |  |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|---|----|--|----|--|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | 1 | 0 | opc | M | 0 | 0 | 1 | Pq |  | Zn |  | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|---|----|--|----|--|----|

| <b>Decode fields</b> | <b>Instruction Details</b>           |
|----------------------|--------------------------------------|
| <b>opc</b>           |                                      |
| 00                   | <a href="#">MOVPRFX (predicated)</a> |
| 01                   | UNALLOCATED                          |
| 1x                   | UNALLOCATED                          |

## SVE bitwise logical reduction (predicated)

These instructions are under [SVE Integer Reduction](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |   |   |   |     |   |   |   |    |  |    |  |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|---|-----|---|---|---|----|--|----|--|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | 1 | 1 | 0 | opc | 0 | 0 | 1 | Pq |  | Zn |  | Vd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|---|-----|---|---|---|----|--|----|--|----|

| <b>Decode fields</b> | <b>Instruction Details</b> |
|----------------------|----------------------------|
| <b>opc</b>           |                            |
| 00                   | <a href="#">ORV</a>        |
| 01                   | <a href="#">EORV</a>       |
| 10                   | <a href="#">ANDV</a>       |
| 11                   | UNALLOCATED                |

## SVE bitwise logical reduction (quadwords)

These instructions are under [SVE Integer Reduction](#).

| <b>Decode fields</b> | <b>Instruction Details</b>   | <b>Feature</b> |
|----------------------|------------------------------|----------------|
| <b>opc</b>           |                              |                |
| 00                   | <a href="#"><u>ORQV</u></a>  | FEAT_SVE2p1    |
| 01                   | <a href="#"><u>EORQV</u></a> | FEAT_SVE2p1    |
| 10                   | <a href="#"><u>ANDQV</u></a> | FEAT_SVE2p1    |

| Decode fields |  | Instruction Details |  |  |   | Feature |  |
|---------------|--|---------------------|--|--|---|---------|--|
| opc           |  |                     |  |  |   |         |  |
| 11            |  | UNALLOCATED         |  |  | - |         |  |

### SVE Bitwise Shift - Predicated

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |     |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|-----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25  | 24 | 23 | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00000100 |    |    |    |    | 0  | op0 |    |    |    |    | 100 |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     | Instruction details                                             |  |  |  |  |  |  |  |  |  |
|---------------|-----|-----------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| opc           | op0 | <a href="#">SVE bitwise shift by immediate (predicated)</a>     |  |  |  |  |  |  |  |  |  |
| 0x            |     | <a href="#">SVE bitwise shift by vector (predicated)</a>        |  |  |  |  |  |  |  |  |  |
| 10            |     | <a href="#">SVE bitwise shift by wide elements (predicated)</a> |  |  |  |  |  |  |  |  |  |

### SVE bitwise shift by immediate (predicated)

These instructions are under [SVE Bitwise Shift - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |      |      |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|------|------|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13   | 12   | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | tszh | 0  | 0  | opc | L  | U  | 1  | 0  | 0  | Pg | tszl | imm3 | Zdn |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   | Instruction Details                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|---|---------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| opc           | L | U |                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 0 | 0 | <a href="#">ASR (immediate, predicated)</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 0 | 1 | <a href="#">LSR (immediate, predicated)</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 1 | 0 | UNALLOCATED                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 1 | 1 | <a href="#">LSL (immediate, predicated)</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 0 | 0 | <a href="#">ASRD</a>                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 0 | 1 | UNALLOCATED                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 1 | 0 | <a href="#">SQSHL (immediate)</a>           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 1 | 1 | <a href="#">UQSHL (immediate)</a>           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10            |   |   | UNALLOCATED                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11            | 0 | 0 | <a href="#">SRSHR</a>                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11            | 0 | 1 | <a href="#">URSHR</a>                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11            | 1 | 0 | UNALLOCATED                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11            | 1 | 1 | <a href="#">SQSHLU</a>                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### SVE bitwise shift by vector (predicated)

These instructions are under [SVE Bitwise Shift - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 1  | 0  | R  | L  | U  | 1  | 0  | 0  | Pg |    | Zm |    | Zdn |   |   |   |   |   |   |   |   |   |

**Decode fields**      **Instruction Details**  
**R      L      U**

|   |   |   |                               |
|---|---|---|-------------------------------|
|   | 1 | 0 | UNALLOCATED                   |
| 0 | 0 | 0 | <a href="#">ASR (vectors)</a> |
| 0 | 0 | 1 | <a href="#">LSR (vectors)</a> |
| 0 | 1 | 1 | <a href="#">LSL (vectors)</a> |
| 1 | 0 | 0 | <a href="#">ASRR</a>          |
| 1 | 0 | 1 | <a href="#">LSRR</a>          |
| 1 | 1 | 1 | <a href="#">LSLR</a>          |

### SVE bitwise shift by wide elements (predicated)

These instructions are under [SVE Bitwise Shift - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 1  | 1  | R  | L  | U  | 1  | 0  | 0  | Pg |    | Zm |    | Zdn |   |   |   |   |   |   |   |   |   |

**Decode fields**      **Instruction Details**  
**R      L      U**

|   |   |   |                                                 |
|---|---|---|-------------------------------------------------|
| 0 | 0 | 0 | <a href="#">ASR (wide elements, predicated)</a> |
| 0 | 0 | 1 | <a href="#">LSR (wide elements, predicated)</a> |
| 0 | 1 | 0 | UNALLOCATED                                     |
| 0 | 1 | 1 | <a href="#">LSL (wide elements, predicated)</a> |
| 1 |   |   | UNALLOCATED                                     |

### SVE Integer Unary Arithmetic - Predicated

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |     |    |    |    |     |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20 | 19 | 18  | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | op0 |    |    | 0  | op0 |    |    | 101 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields**      **Instruction details**  
**op0**

|    |                                                           |
|----|-----------------------------------------------------------|
| 0x | UNALLOCATED                                               |
| 10 | <a href="#">SVE integer unary operations (predicated)</a> |
| 11 | <a href="#">SVE bitwise unary operations (predicated)</a> |

### SVE integer unary operations (predicated)

These instructions are under [SVE Integer Unary Arithmetic - Predicated](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |   |   |     |   |   |   |    |  |    |  |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|--|----|--|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | 1 | 0 | opc | 1 | 0 | 1 | Pg |  | Zn |  | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|--|----|--|----|

| <b>Decode fields</b> | <b>Instruction Details</b>              |
|----------------------|-----------------------------------------|
| <b>opc</b>           |                                         |
| 000                  | <u>SXTB, SXTH, SXTW</u> â€” <u>SXTB</u> |
| 001                  | <u>UXTB, UXTH, UXTW</u> â€” <u>UXTB</u> |
| 010                  | <u>SXTB, SXTH, SXTW</u> â€” <u>SXTH</u> |
| 011                  | <u>UXTB, UXTH, UXTW</u> â€” <u>UXTH</u> |
| 100                  | <u>SXTB, SXTH, SXTW</u> â€” <u>SXTW</u> |
| 101                  | <u>UXTB, UXTH, UXTW</u> â€” <u>UXTW</u> |
| 110                  | <u>ABS</u>                              |
| 111                  | <u>NEG</u>                              |

## SVE bitwise unary operations (predicated)

These instructions are under [SVE Integer Unary Arithmetic - Predicated](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |   |   |     |   |   |   |    |  |    |  |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|--|----|--|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | 1 | 1 | opc | 1 | 0 | 1 | Pq |  | Zn |  | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|--|----|--|----|

| <b>Decode fields</b> | <b>Instruction Details</b>          |
|----------------------|-------------------------------------|
| <b>opc</b>           |                                     |
| 000                  | <a href="#"><u>CLS</u></a>          |
| 001                  | <a href="#"><u>CLZ</u></a>          |
| 010                  | <a href="#"><u>CNT</u></a>          |
| 011                  | <a href="#"><u>CNOT</u></a>         |
| 100                  | <a href="#"><u>FABS</u></a>         |
| 101                  | <a href="#"><u>FNEG</u></a>         |
| 110                  | <a href="#"><u>NOT (vector)</u></a> |
| 111                  | UNALLOCATED                         |

## SVE integer add/subtract vectors (unpredicated)

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |    |   |   |   |     |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|-----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 1 | Zm | 0 | 0 | 0 | opc | Zn | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|-----|----|----|

**Decode fields****opc****Instruction Details**

|     |                                               |
|-----|-----------------------------------------------|
| 000 | <a href="#">ADD (vectors, unpredicated)</a>   |
| 001 | <a href="#">SUB (vectors, unpredicated)</a>   |
| 01x | UNALLOCATED                                   |
| 100 | <a href="#">SQADD (vectors, unpredicated)</a> |
| 101 | <a href="#">UQADD (vectors, unpredicated)</a> |
| 110 | <a href="#">SQSUB (vectors, unpredicated)</a> |
| 111 | <a href="#">UQSUB (vectors, unpredicated)</a> |

**SVE Bitwise Logical - Unpredicated**These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | opc | 1  | Zm | 0  | 0  | 1  | 1  | 0  | 0  | Zn | Zd |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields****op0****Instruction details**

|     |                                                               |
|-----|---------------------------------------------------------------|
| 0xx | UNALLOCATED                                                   |
| 100 | <a href="#">SVE bitwise logical operations (unpredicated)</a> |
| 101 | <a href="#">XAR</a>                                           |
| 11x | <a href="#">SVE2 bitwise ternary operations</a>               |

**SVE bitwise logical operations (unpredicated)**These instructions are under [SVE Bitwise Logical - Unpredicated](#).

|    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | opc | 1  | Zm | 0  | 0  | 1  | 1  | 0  | 0  | Zn | Zd |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields****opc****Instruction Details**

|    |                                             |
|----|---------------------------------------------|
| 00 | <a href="#">AND (vectors, unpredicated)</a> |
| 01 | <a href="#">ORR (vectors, unpredicated)</a> |
| 10 | <a href="#">EOR (vectors, unpredicated)</a> |
| 11 | <a href="#">BIC (vectors, unpredicated)</a> |

**SVE2 bitwise ternary operations**These instructions are under [SVE Bitwise Logical - Unpredicated](#).

|    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | opc | 1  | Zm | 0  | 0  | 1  | 1  | 1  | 0  | 2  | Zk | Zdn |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

|     |    |
|-----|----|
| opc | o2 |
|-----|----|

### Instruction Details

|    |   |                       |
|----|---|-----------------------|
| 00 | 0 | <a href="#">EOR3</a>  |
| 00 | 1 | <a href="#">BSL</a>   |
| 01 | 0 | <a href="#">BCAX</a>  |
| 01 | 1 | <a href="#">BSL1N</a> |
| 1x | 0 | UNALLOCATED           |
| 10 | 1 | <a href="#">BSL2N</a> |
| 11 | 1 | <a href="#">NBSL</a>  |

## SVE Index Generation

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |      |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|------|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00000100 |    |    |    |    |    |    | 1  |    |    |    |    | 0100 |    | op0 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

|     |
|-----|
| op0 |
|-----|

### Instruction details

|    |                                           |
|----|-------------------------------------------|
| 00 | <a href="#">INDEX (immediates)</a>        |
| 01 | <a href="#">INDEX (scalar, immediate)</a> |
| 10 | <a href="#">INDEX (immediate, scalar)</a> |
| 11 | <a href="#">INDEX (scalars)</a>           |

## SVE Stack Allocation

These instructions are under [SVE encodings](#).

|          |    |    |    |     |    |    |    |    |    |    |    |      |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|-----|----|----|----|----|----|----|----|------|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00000100 |    |    |    | op0 | 1  |    |    |    |    |    |    | 0101 |    | op1 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

|     |     |
|-----|-----|
| op0 | op1 |
|-----|-----|

### Instruction details

|   |   |                                                      |
|---|---|------------------------------------------------------|
| 0 | 0 | <a href="#">SVE stack frame adjustment</a>           |
| 0 | 1 | <a href="#">Streaming SVE stack frame adjustment</a> |
| 1 | 0 | <a href="#">SVE stack frame size</a>                 |
| 1 | 1 | <a href="#">Streaming SVE stack frame size</a>       |

## SVE stack frame adjustment

These instructions are under [SVE Stack Allocation](#).

| Decode fields | Instruction Details |
|---------------|---------------------|
| op            |                     |

|   |              |
|---|--------------|
| 0 | <u>ADDVL</u> |
| 1 | <u>ADDPL</u> |

## **Streaming SVE stack frame adjustment**

These instructions are under [SVE Stack Allocation](#).

| <b>Decode fields</b> | <b>Instruction Details</b> | <b>Feature</b> |
|----------------------|----------------------------|----------------|
| <b>op</b>            |                            |                |

|   |               |          |
|---|---------------|----------|
| 0 | <u>ADDSVL</u> | FEAT_SME |
| 1 | <u>ADDSPL</u> | FEAT_SME |

## SVE stack frame size

These instructions are under [SVE Stack Allocation](#).

| Decode fields |       | Instruction Details |
|---------------|-------|---------------------|
| op            | opc2  |                     |
| 0             | 0xxxx | UNALLOCATED         |
| 0             | 10xxx | UNALLOCATED         |
| 0             | 110xx | UNALLOCATED         |
| 0             | 1110x | UNALLOCATED         |
| 0             | 11110 | UNALLOCATED         |
| 0             | 11111 | <u>RDVL</u>         |
| 1             |       | UNALLOCATED         |

## Streaming SVE stack frame size

These instructions are under [SVE Stack Allocation](#).

|    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |      |    |   |   |   |   |    |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|------|----|---|---|---|---|----|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11   | 10 | 9 | 8 | 7 | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | op | 1  |    | opc2 |    | 0  | 1  | 0  | 1  | 1  |    | imm6 |    |   |   |   |   | Rd |   |   |   |   |   |

| Decode fields |       | Instruction Details   | Feature  |
|---------------|-------|-----------------------|----------|
| op            | opc2  |                       |          |
| 0             | 0xxxx | UNALLOCATED           | -        |
| 0             | 10xxx | UNALLOCATED           | -        |
| 0             | 110xx | UNALLOCATED           | -        |
| 0             | 1110x | UNALLOCATED           | -        |
| 0             | 11110 | UNALLOCATED           | -        |
| 0             | 11111 | <a href="#">RDSVL</a> | FEAT_SME |
| 1             |       | UNALLOCATED           | -        |

## SVE2 Integer Multiply - Unpredicated

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction details                                                          |
|---------------|--|------------------------------------------------------------------------------|
| op0           |  |                                                                              |
| 0x            |  | <a href="#">SVE2 integer multiply vectors (unpredicated)</a>                 |
| 10            |  | <a href="#">SVE2 signed saturating doubling multiply high (unpredicated)</a> |
| 11            |  | UNALLOCATED                                                                  |

## SVE2 integer multiply vectors (unpredicated)

These instructions are under [SVE2 Integer Multiply - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | Zm | 0  | 1  | 1  | 0  | opc |    | Zn |    | Zd |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     | Instruction Details                         |
|---------------|-----|---------------------------------------------|
| size          | opc |                                             |
|               | 00  | <a href="#">MUL (vectors, unpredicated)</a> |
|               | 10  | <a href="#">SMULH (unpredicated)</a>        |
|               | 11  | <a href="#">UMULH (unpredicated)</a>        |
| 00            | 01  | <a href="#">PMUL</a>                        |
| 01            | 01  | UNALLOCATED                                 |
| 1x            | 01  | UNALLOCATED                                 |

## SVE2 signed saturating doubling multiply high (unpredicated)

These instructions are under [SVE2 Integer Multiply - Unpredicated](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |    |   |   |   |   |   |   |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 1 | Zm | 0 | 1 | 1 | 1 | 0 | R | Zn | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|----|----|

| <b>Decode fields</b> | <b>Instruction Details</b>         |
|----------------------|------------------------------------|
| R                    | <a href="#">SODMULH (vectors)</a>  |
| 0                    | <a href="#">SQRDMULH (vectors)</a> |
| 1                    | <a href="#">SQRDMULH (vectors)</a> |

## SVE Bitwise Shift - Unpredicated

These instructions are under [SVE encodings](#).

| <b>Decode fields</b> | <b>Instruction details</b>                                        |
|----------------------|-------------------------------------------------------------------|
| <b>op0</b>           | <a href="#">SVE bitwise shift by wide elements (unpredicated)</a> |
| 1                    | <a href="#">SVE bitwise shift by immediate (unpredicated)</a>     |

## SVE bitwise shift by wide elements (unpredicated)

These instructions are under [SVE Bitwise Shift - Unpredicated](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |    |   |   |   |   |     |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|-----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 1 | Zm | 1 | 0 | 0 | 0 | opc | Zn | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|-----|----|----|

| <b>Decode fields</b> | <b>Instruction Details</b>                        |
|----------------------|---------------------------------------------------|
| <b>opc</b>           |                                                   |
| 00                   | <a href="#">ASR (wide elements, unpredicated)</a> |
| 01                   | <a href="#">LSR (wide elements, unpredicated)</a> |
| 10                   | UNALLOCATED                                       |
| 11                   | <a href="#">LSL (wide elements, unpredicated)</a> |

## SVE bitwise shift by immediate (unpredicated)

These instructions are under [SVE Bitwise Shift - Unpredicated](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |      |   |      |      |   |   |   |   |     |    |  |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------|---|------|------|---|---|---|---|-----|----|--|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | tszh | 1 | tszl | imm3 | 1 | 0 | 0 | 1 | opc | Zn |  | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------|---|------|------|---|---|---|---|-----|----|--|----|

| Decode fields |  | Instruction Details                           |
|---------------|--|-----------------------------------------------|
| opc           |  |                                               |
| 00            |  | <a href="#">ASR (immediate, unpredicated)</a> |
| 01            |  | <a href="#">LSR (immediate, unpredicated)</a> |
| 10            |  | UNALLOCATED                                   |
| 11            |  | <a href="#">LSL (immediate, unpredicated)</a> |

## SVE address generation

These instructions are under [SVE encodings](#).

| <b>Decode fields</b> | <b>Instruction Details</b>                                               |
|----------------------|--------------------------------------------------------------------------|
| <b>opc</b>           |                                                                          |
| 00                   | <a href="#">ADR</a> â€“ <a href="#">Unpacked 32-bit signed offsets</a>   |
| 01                   | <a href="#">ADR</a> â€“ <a href="#">Unpacked 32-bit unsigned offsets</a> |
| 1x                   | <a href="#">ADR</a> â€“ <a href="#">Packed offsets</a>                   |

## SVE Integer Misc - Unpredicated

These instructions are under [SVE encodings](#).

| <b>Decode fields</b> | <b>Instruction details</b>                                 |
|----------------------|------------------------------------------------------------|
| <b>op0</b>           |                                                            |
| 0x                   | <a href="#">SVE floating-point trig select coefficient</a> |
| 10                   | <a href="#">SVE floating-point exponential accelerator</a> |
| 11                   | <a href="#">SVE constructive prefix (unpredicated)</a>     |

## SVE floating-point trig select coefficient

These instructions are under [SVE Integer Misc - Unpredicated](#).

| <b>Decode fields</b> |  | <b>Instruction Details</b> |
|----------------------|--|----------------------------|
| <b>opc</b>           |  |                            |

|   |                        |  |
|---|------------------------|--|
| 0 | <a href="#">FTSSEL</a> |  |
| 1 | UNALLOCATED            |  |

---

### SVE floating-point exponential accelerator

These instructions are under [SVE Integer Misc - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|-----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  | opc |    | 1  | 0  | 1  | 1  | 1  | 0  |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> |  | <b>Instruction Details</b> |
|----------------------|--|----------------------------|
| <b>opc</b>           |  |                            |

|       |                       |  |
|-------|-----------------------|--|
| 00000 | <a href="#">FEXPA</a> |  |
| 00001 | UNALLOCATED           |  |
| 0001x | UNALLOCATED           |  |
| 001xx | UNALLOCATED           |  |
| 01xxx | UNALLOCATED           |  |
| 1xxxx | UNALLOCATED           |  |

---

### SVE constructive prefix (unpredicated)

These instructions are under [SVE Integer Misc - Unpredicated](#).

|    |    |    |    |    |    |    |    |     |    |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | opc | 1  | opc2 |    | 1  | 0  | 1  | 1  | 1  | 1  |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> |             | <b>Instruction Details</b> |
|----------------------|-------------|----------------------------|
| <b>opc</b>           | <b>opc2</b> |                            |

|    |       |                                        |
|----|-------|----------------------------------------|
| 00 | 00000 | <a href="#">MOVPRFX (unpredicated)</a> |
| 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](#).

|          |    |    |    |    |    |    |    |     |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00000100 |    |    |    |    |    |    | 1  | op0 |    |    |    | 11 |    | op1 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     | Instruction details                                              |  |
|---------------|-----|------------------------------------------------------------------|--|
| op0           | op1 |                                                                  |  |
| 0             | 00x | <a href="#">SVE saturating inc/dec vector by element count</a>   |  |
| 0             | 100 | <a href="#">SVE element count</a>                                |  |
| 0             | 101 | UNALLOCATED                                                      |  |
| 1             | 000 | <a href="#">SVE inc/dec vector by element count</a>              |  |
| 1             | 100 | <a href="#">SVE inc/dec register by element count</a>            |  |
| 1             | x01 | UNALLOCATED                                                      |  |
|               | 01x | UNALLOCATED                                                      |  |
|               | 11x | <a href="#">SVE saturating inc/dec register by element count</a> |  |

## SVE saturating inc/dec vector by element count

These instructions are under [SVE Element Count](#).

|    |    |    |    |    |    |    |    |      |    |    |      |    |    |    |    |    |    |         |    |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|------|----|----|----|----|----|----|---------|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13      | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  | 0  | imm4 | 1  | 1  | 0  | 0  | D  | U  | pattern |    | Zdn |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   | Instruction Details             |  |
|---------------|---|---|---------------------------------|--|
| size          | D | U |                                 |  |
| 00            |   |   | UNALLOCATED                     |  |
| 01            | 0 | 0 | <a href="#">SQINCH (vector)</a> |  |
| 01            | 0 | 1 | <a href="#">UQINCH (vector)</a> |  |
| 01            | 1 | 0 | <a href="#">SQDECW (vector)</a> |  |
| 01            | 1 | 1 | <a href="#">UQDECW (vector)</a> |  |
| 10            | 0 | 0 | <a href="#">SQINCW (vector)</a> |  |
| 10            | 0 | 1 | <a href="#">UQINCW (vector)</a> |  |
| 10            | 1 | 0 | <a href="#">SQDECW (vector)</a> |  |
| 10            | 1 | 1 | <a href="#">UQDECW (vector)</a> |  |
| 11            | 0 | 0 | <a href="#">SQINCD (vector)</a> |  |
| 11            | 0 | 1 | <a href="#">UQINCD (vector)</a> |  |
| 11            | 1 | 0 | <a href="#">SQDECW (vector)</a> |  |
| 11            | 1 | 1 | <a href="#">UQDECW (vector)</a> |  |

## SVE element count

These instructions are under [SVE Element Count](#).

|    |    |    |    |    |    |    |    |      |    |    |      |    |    |    |    |    |    |         |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|------|----|----|----|----|----|----|---------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13      | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  | 0  | imm4 | 1  | 1  | 1  | 0  | 0  | op | pattern | Rd |    |    |   |   |   |   |   |   |   |   |   |   |

#### Decode fields

size      op

#### Instruction Details

|    |   |                                                                 |
|----|---|-----------------------------------------------------------------|
|    | 1 | UNALLOCATED                                                     |
| 00 | 0 | <a href="#">CNTB, CNTD, CNTH, CNTW</a> â€“ <a href="#">CNTB</a> |
| 01 | 0 | <a href="#">CNTB, CNTD, CNTH, CNTW</a> â€“ <a href="#">CNTH</a> |
| 10 | 0 | <a href="#">CNTB, CNTD, CNTH, CNTW</a> â€“ <a href="#">CNTW</a> |
| 11 | 0 | <a href="#">CNTB, CNTD, CNTH, CNTW</a> â€“ <a href="#">CNTD</a> |

### SVE inc/dec vector by element count

These instructions are under [SVE Element Count](#).

|    |    |    |    |    |    |    |    |      |    |    |      |    |    |    |    |    |    |         |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|------|----|----|----|----|----|----|---------|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13      | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  | 1  | imm4 | 1  | 1  | 0  | 0  | 0  | D  | pattern | Zdn |    |    |   |   |   |   |   |   |   |   |   |   |

#### Decode fields

size      D

#### Instruction Details

|    |   |                                                                    |
|----|---|--------------------------------------------------------------------|
| 00 |   | UNALLOCATED                                                        |
| 01 | 0 | <a href="#">INCD, INCH, INCW (vector)</a> â€“ <a href="#">INCH</a> |
| 01 | 1 | <a href="#">DECD, DECH, DECW (vector)</a> â€“ <a href="#">DECH</a> |
| 10 | 0 | <a href="#">INCD, INCH, INCW (vector)</a> â€“ <a href="#">INCW</a> |
| 10 | 1 | <a href="#">DECD, DECH, DECW (vector)</a> â€“ <a href="#">DECW</a> |
| 11 | 0 | <a href="#">INCD, INCH, INCW (vector)</a> â€“ <a href="#">INCD</a> |
| 11 | 1 | <a href="#">DECD, DECH, DECW (vector)</a> â€“ <a href="#">DECD</a> |

### SVE inc/dec register by element count

These instructions are under [SVE Element Count](#).

|    |    |    |    |    |    |    |    |      |    |    |      |    |    |    |    |    |    |         |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|------|----|----|----|----|----|----|---------|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13      | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  | 1  | imm4 | 1  | 1  | 1  | 0  | 0  | D  | pattern | Rdn |    |    |   |   |   |   |   |   |   |   |   |   |

#### Decode fields

size      D

#### Instruction Details

|    |   |                                                                          |
|----|---|--------------------------------------------------------------------------|
| 00 | 0 | <a href="#">INCB, INCD, INCH, INCW (scalar)</a> â€“ <a href="#">INCB</a> |
| 00 | 1 | <a href="#">DECB, DECD, DECH, DECW (scalar)</a> â€“ <a href="#">DECB</a> |
| 01 | 0 | <a href="#">INCB, INCD, INCH, INCW (scalar)</a> â€“ <a href="#">INCH</a> |
| 01 | 1 | <a href="#">DECB, DECD, DECH, DECW (scalar)</a> â€“ <a href="#">DECH</a> |

| Decode fields |   | Instruction Details                                                                                                         |
|---------------|---|-----------------------------------------------------------------------------------------------------------------------------|
| size          | D |                                                                                                                             |
| 10            | 0 | <a href="#">INCB</a> , <a href="#">INCD</a> , <a href="#">INCH</a> , <a href="#">INCW (scalar)</a> â€” <a href="#">INCW</a> |
| 10            | 1 | <a href="#">DECB</a> , <a href="#">DECD</a> , <a href="#">DECH</a> , <a href="#">DECW (scalar)</a> â€” <a href="#">DECW</a> |
| 11            | 0 | <a href="#">INCB</a> , <a href="#">INCD</a> , <a href="#">INCH</a> , <a href="#">INCW (scalar)</a> â€” <a href="#">INCD</a> |
| 11            | 1 | <a href="#">DECB</a> , <a href="#">DECD</a> , <a href="#">DECH</a> , <a href="#">DECW (scalar)</a> â€” <a href="#">DECD</a> |

## SVE saturating inc/dec register by element count

These instructions are under [SVE Element Count](#).

|    |    |    |    |    |    |    |    |      |    |    |    |      |    |    |    |    |    |    |    |    |         |   |     |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|------|----|----|----|----|----|----|----|----|---------|---|-----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10      | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  | sf |    | imm4 |    | 1  | 1  | 1  | 1  | D  | U  |    | pattern |   | Rdn |   |   |   |   |   |   |   |   |

| Decode fields |    |   |   | Instruction Details                                        |
|---------------|----|---|---|------------------------------------------------------------|
| size          | sf | D | U |                                                            |
| 00            | 0  | 0 | 0 | <a href="#">SQINCB</a> â€” <a href="#">32-bit</a>          |
| 00            | 0  | 0 | 1 | <a href="#">UQINCB</a> â€” <a href="#">32-bit</a>          |
| 00            | 0  | 1 | 0 | <a href="#">SQDECB</a> â€” <a href="#">32-bit</a>          |
| 00            | 0  | 1 | 1 | <a href="#">UQDECB</a> â€” <a href="#">32-bit</a>          |
| 00            | 1  | 0 | 0 | <a href="#">SQINCB</a> â€” <a href="#">64-bit</a>          |
| 00            | 1  | 0 | 1 | <a href="#">UQINCB</a> â€” <a href="#">64-bit</a>          |
| 00            | 1  | 1 | 0 | <a href="#">SQDECB</a> â€” <a href="#">64-bit</a>          |
| 00            | 1  | 1 | 1 | <a href="#">UQDECB</a> â€” <a href="#">64-bit</a>          |
| 01            | 0  | 0 | 0 | <a href="#">SQINCH (scalar)</a> â€” <a href="#">32-bit</a> |
| 01            | 0  | 0 | 1 | <a href="#">UQINCH (scalar)</a> â€” <a href="#">32-bit</a> |
| 01            | 0  | 1 | 0 | <a href="#">SQDECH (scalar)</a> â€” <a href="#">32-bit</a> |
| 01            | 0  | 1 | 1 | <a href="#">UQDECH (scalar)</a> â€” <a href="#">32-bit</a> |
| 01            | 1  | 0 | 0 | <a href="#">SQINCH (scalar)</a> â€” <a href="#">64-bit</a> |
| 01            | 1  | 0 | 1 | <a href="#">UQINCH (scalar)</a> â€” <a href="#">64-bit</a> |
| 01            | 1  | 1 | 0 | <a href="#">SQDECH (scalar)</a> â€” <a href="#">64-bit</a> |
| 01            | 1  | 1 | 1 | <a href="#">UQDECH (scalar)</a> â€” <a href="#">64-bit</a> |
| 10            | 0  | 0 | 0 | <a href="#">SQINCW (scalar)</a> â€” <a href="#">32-bit</a> |
| 10            | 0  | 0 | 1 | <a href="#">UQINCW (scalar)</a> â€” <a href="#">32-bit</a> |
| 10            | 0  | 1 | 0 | <a href="#">SQDECW (scalar)</a> â€” <a href="#">32-bit</a> |
| 10            | 0  | 1 | 1 | <a href="#">UQDECW (scalar)</a> â€” <a href="#">32-bit</a> |
| 10            | 1  | 0 | 0 | <a href="#">SQINCW (scalar)</a> â€” <a href="#">64-bit</a> |
| 10            | 1  | 0 | 1 | <a href="#">UQINCW (scalar)</a> â€” <a href="#">64-bit</a> |
| 10            | 1  | 1 | 0 | <a href="#">SQDECW (scalar)</a> â€” <a href="#">64-bit</a> |
| 10            | 1  | 1 | 1 | <a href="#">UQDECW (scalar)</a> â€” <a href="#">64-bit</a> |
| 11            | 0  | 0 | 0 | <a href="#">SQINCD (scalar)</a> â€” <a href="#">32-bit</a> |

| Decode fields |    |   |   | Instruction Details                        |
|---------------|----|---|---|--------------------------------------------|
| size          | sf | D | U |                                            |
| 11            | 0  | 0 | 1 | <a href="#">UQINCD (scalar)</a> â€“ 32-bit |
| 11            | 0  | 1 | 0 | <a href="#">SQDECD (scalar)</a> â€“ 32-bit |
| 11            | 0  | 1 | 1 | <a href="#">UQDECD (scalar)</a> â€“ 32-bit |
| 11            | 1  | 0 | 0 | <a href="#">SQINCD (scalar)</a> â€“ 64-bit |
| 11            | 1  | 0 | 1 | <a href="#">UQINCD (scalar)</a> â€“ 64-bit |
| 11            | 1  | 1 | 0 | <a href="#">SQDECD (scalar)</a> â€“ 64-bit |
| 11            | 1  | 1 | 1 | <a href="#">UQDECD (scalar)</a> â€“ 64-bit |

## SVE Bitwise Immediate

These instructions are under [SVE encodings](#).

|          |    |     |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29  | 28 | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00000101 |    | op0 | 00 | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |       | Instruction details                                               |
|---------------|-------|-------------------------------------------------------------------|
| op0           | op1   |                                                                   |
| 11            | 00    | <a href="#">DUPM</a>                                              |
| != 11         | 00    | <a href="#">SVE bitwise logical with immediate (unpredicated)</a> |
|               | != 00 | UNALLOCATED                                                       |

## SVE bitwise logical with immediate (unpredicated)

These instructions are under [SVE Bitwise Immediate](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15    | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | !  | =  | 11 | 0  | 0  | 0  | 0  |    | imm13 |    |    |    |    |    | Zdn |   |   |   |   |   |   |   |   |   |

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

| Decode fields |  | Instruction Details             |
|---------------|--|---------------------------------|
| opc           |  |                                 |
| 00            |  | <a href="#">ORR (immediate)</a> |
| 01            |  | <a href="#">EOR (immediate)</a> |
| 10            |  | <a href="#">AND (immediate)</a> |

## SVE Integer Wide Immediate - Predicated

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 00000101 |    |    |    |    |    |    |    | 01 |    |    |    |    |    |    |    |    | op0 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Decode fields | Instruction details |
|---------------|---------------------|
| op0           |                     |

|     |                                                         |
|-----|---------------------------------------------------------|
| 0xx | <a href="#">SVE copy integer immediate (predicated)</a> |
| 10x | UNALLOCATED                                             |
| 110 | <a href="#">FCPY</a>                                    |
| 111 | UNALLOCATED                                             |

## SVE copy integer immediate (predicated)

These instructions are under [SVE Integer Wide Immediate - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 0  | 1  | Pg | 0  | M  | sh |    |    | imm8 |    |    |    |    | Zd |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction Details |
|---------------|---------------------|
| M             |                     |

|   |                                          |
|---|------------------------------------------|
| 0 | <a href="#">CPY (immediate, zeroing)</a> |
| 1 | <a href="#">CPY (immediate, merging)</a> |

## SVE Permute Vector - One Source Quadwords

These instructions are under [SVE encodings](#).

|          |    |    |    |    |     |    |     |    |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|-----|----|-----|----|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26  | 25 | 24  | 23 | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00000101 |    |    |    |    | op0 | 1  | op1 |    |    |    |    | 001001 |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction details | Feature |
|---------------|---------------------|---------|
| op0           |                     |         |
| op1           |                     |         |

|    |   |                      |             |
|----|---|----------------------|-------------|
| 00 |   | <a href="#">DUPQ</a> | FEAT_SVE2p1 |
| 01 | 0 | <a href="#">EXTQ</a> | FEAT_SVE2p1 |
| 01 | 1 | UNALLOCATED          | -           |
| 1x |   | UNALLOCATED          | -           |

## SVE table lookup (three sources)

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | Zm | 0  | 0  | 1  | 0  | 1  | op | Zn | Zd |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

**op**

|   |                     |
|---|---------------------|
| 0 | <a href="#">TBL</a> |
| 1 | <a href="#">TBX</a> |

### Instruction Details

## SVE Permute Vector - Unpredicated

These instructions are under [SVE encodings](#).

|          |    |    |     |     |    |        |     |    |     |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|-----|-----|----|--------|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28  | 27  | 26 | 25     | 24  | 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00000101 |    | 1  | op0 | op1 |    | 001110 | op2 |    | op3 |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

**op0    op1    op2    op3**

### Instruction details

|    |        |   |   |                                                |
|----|--------|---|---|------------------------------------------------|
| 00 | 000    |   |   | <a href="#">DUP (scalar)</a>                   |
| 00 | 100    |   |   | <a href="#">INSR (scalar)</a>                  |
| 00 | x10    |   |   | UNALLOCATED                                    |
| 00 | xx1    |   |   | UNALLOCATED                                    |
| 01 | xx0    |   | 0 | <a href="#">SVE move predicate from vector</a> |
| 01 | xx0    |   | 1 | UNALLOCATED                                    |
| 01 | xx1    | 0 |   | <a href="#">SVE move predicate into vector</a> |
| 01 | xx1    | 1 |   | UNALLOCATED                                    |
| 10 | 0xx    |   |   | <a href="#">SVE unpack vector elements</a>     |
| 10 | 100    |   |   | <a href="#">INSR (SIMD&amp;FP scalar)</a>      |
| 10 | 110    |   |   | UNALLOCATED                                    |
| 10 | 1x1    |   |   | UNALLOCATED                                    |
| 11 | 000    |   |   | <a href="#">REV (vector)</a>                   |
| 11 | != 000 |   |   | UNALLOCATED                                    |

## SVE move predicate from vector

These instructions are under [SVE Permute Vector - Unpredicated](#).

|    |    |    |    |    |    |    |    |     |    |    |    |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | opc | 1  | 0  | 1  | opc2 | 0  | 0  | 0  | 1  | 1  | 1  | 0  | Zn | 0  | Pd |   |   |   |   |   |   |   |   |   |

### Decode fields

**opc    opc2**

### Instruction Details

### Feature

|    |    |             |   |
|----|----|-------------|---|
| 00 | 00 | UNALLOCATED | - |
|----|----|-------------|---|

| Decode fields |      | Instruction Details                                | Feature     |
|---------------|------|----------------------------------------------------|-------------|
| opc           | opc2 |                                                    |             |
| 00            | 01   | <a href="#">PMOV (to predicate) â€“ byte</a>       | FEAT_SVE2p1 |
| 00            | 1x   | <a href="#">PMOV (to predicate) â€“ halfword</a>   | FEAT_SVE2p1 |
| 01            |      | <a href="#">PMOV (to predicate) â€“ word</a>       | FEAT_SVE2p1 |
| 1x            |      | <a href="#">PMOV (to predicate) â€“ doubleword</a> | FEAT_SVE2p1 |

## SVE move predicate into vector

These instructions are under [SVE Permute Vector - Unpredicated](#).

|    |    |    |    |    |    |    |    |     |    |    |    |      |    |    |    |    |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | opc | 1  | 0  | 1  | opc2 | 1  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | Pn |   | Zd |   |   |   |   |   |   |   |

| Decode fields |      | Instruction Details                                                  | Feature     |
|---------------|------|----------------------------------------------------------------------|-------------|
| opc           | opc2 |                                                                      |             |
| 00            | 00   | UNALLOCATED                                                          | -           |
| 00            | 01   | <a href="#">PMOV (to vector)</a> $\times$ <a href="#">byte</a>       | FEAT_SVE2p1 |
| 00            | 1x   | <a href="#">PMOV (to vector)</a> $\times$ <a href="#">halfword</a>   | FEAT_SVE2p1 |
| 01            |      | <a href="#">PMOV (to vector)</a> $\times$ <a href="#">word</a>       | FEAT_SVE2p1 |
| 1x            |      | <a href="#">PMOV (to vector)</a> $\times$ <a href="#">doubleword</a> | FEAT_SVE2p1 |

## SVE unpack vector elements

These instructions are under [SVE Permute Vector - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 1  | 0  | 0  | U  | H  | 0  | 0  | 1  | 1  | 1  | 0  | Zn |   |   | Zd |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                                           |
|---------------|---|-------------------------------------------------------------------------------|
| U             | H |                                                                               |
| 0             | 0 | <a href="#">SUNPKHI</a> , <a href="#">SUNPKLO</a> â€” <a href="#">SUNPKLO</a> |
| 0             | 1 | <a href="#">SUNPKHI</a> , <a href="#">SUNPKLO</a> â€” <a href="#">SUNPKHI</a> |
| 1             | 0 | <a href="#">UUNPKHI</a> , <a href="#">UUNPKLO</a> â€” <a href="#">UUNPKLO</a> |
| 1             | 1 | <a href="#">UUNPKHI</a> , <a href="#">UUNPKLO</a> â€” <a href="#">UUNPKHI</a> |

## SVE Permute Predicate

These instructions are under [SVE encodings](#).

| Decode fields |       |      |     | Instruction details                            |
|---------------|-------|------|-----|------------------------------------------------|
| op0           | op1   | op2  | op3 |                                                |
| 00            | 1000x | 0000 | 0   | <a href="#">SVE unpack predicate elements</a>  |
| 01            | 1000x | 0000 | 0   | UNALLOCATED                                    |
| 10            | 1000x | 0000 | 0   | UNALLOCATED                                    |
| 11            | 1000x | 0000 | 0   | UNALLOCATED                                    |
|               | 0xxxx | xxx0 | 0   | <a href="#">SVE permute predicate elements</a> |
|               | 0xxxx | xxx1 | 0   | UNALLOCATED                                    |
|               | 10100 | 0000 | 0   | <a href="#">REV (predicate)</a>                |
|               | 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](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | H  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | Pn | 0 | Pd |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                                          |
|---------------|--|--------------------------------------------------------------|
| H             |  |                                                              |
| 0             |  | <a href="#">PUNPKHI, PUNPKLO</a> â€“ <a href="#">PUNPKLO</a> |
| 1             |  | <a href="#">PUNPKHI, PUNPKLO</a> â€“ <a href="#">PUNPKHI</a> |

### SVE permute predicate elements

These instructions are under [SVE Permute Predicate](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | Pm | 0  | 1  | 0  | opc | H  | 0  | Pn | 0  | Pd |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                                              |
|---------------|---|------------------------------------------------------------------|
| opc           |   |                                                                  |
| 00            | 0 | <a href="#">ZIP1, ZIP2 (predicates)</a> â€“ <a href="#">ZIP1</a> |
| 00            | 1 | <a href="#">ZIP1, ZIP2 (predicates)</a> â€“ <a href="#">ZIP2</a> |

| Decode fields |   | Instruction Details                                              |
|---------------|---|------------------------------------------------------------------|
| opc           | H |                                                                  |
| 01            | 0 | <a href="#">UZP1, UZP2 (predicates)</a> â€“ <a href="#">UZP1</a> |
| 01            | 1 | <a href="#">UZP1, UZP2 (predicates)</a> â€“ <a href="#">UZP2</a> |
| 10            | 0 | <a href="#">TRN1, TRN2 (predicates)</a> â€“ <a href="#">TRN1</a> |
| 10            | 1 | <a href="#">TRN1, TRN2 (predicates)</a> â€“ <a href="#">TRN2</a> |
| 11            |   | UNALLOCATED                                                      |

### SVE permute vector elements

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | Zm | 0  | 1  | 1  | opc |    | Zn |    | Zd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                                           |
|---------------|--|---------------------------------------------------------------|
| opc           |  |                                                               |
| 000           |  | <a href="#">ZIP1, ZIP2 (vectors)</a> â€“ <a href="#">ZIP1</a> |
| 001           |  | <a href="#">ZIP1, ZIP2 (vectors)</a> â€“ <a href="#">ZIP2</a> |
| 010           |  | <a href="#">UZP1, UZP2 (vectors)</a> â€“ <a href="#">UZP1</a> |
| 011           |  | <a href="#">UZP1, UZP2 (vectors)</a> â€“ <a href="#">UZP2</a> |
| 100           |  | <a href="#">TRN1, TRN2 (vectors)</a> â€“ <a href="#">TRN1</a> |
| 101           |  | <a href="#">TRN1, TRN2 (vectors)</a> â€“ <a href="#">TRN2</a> |
| 11x           |  | UNALLOCATED                                                   |

### SVE Permute Vector - Predicated

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |     |     |     |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|-----|-----|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | op0 | op1 | op2 | 10 | op3 |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     |     |     | Instruction details                                                |
|---------------|-----|-----|-----|--------------------------------------------------------------------|
| op0           | op1 | op2 | op3 |                                                                    |
| 0             | 000 | 0   | 0   | <a href="#">CPY (SIMD&amp;FP scalar)</a>                           |
| 0             | 000 | 1   | 0   | <a href="#">COMPACT</a>                                            |
| 0             | 000 |     | 1   | <a href="#">SVE extract element to general register</a>            |
| 0             | 001 |     | 0   | <a href="#">SVE extract element to SIMD&amp;FP scalar register</a> |
| 0             | 01x |     | 0   | <a href="#">SVE reverse within elements</a>                        |
| 0             | 01x |     | 1   | UNALLOCATED                                                        |
| 0             | 100 | 0   | 1   | <a href="#">CPY (scalar)</a>                                       |
| 0             | 100 | 1   | 1   | UNALLOCATED                                                        |

|   |        |   |   |                                                                         |
|---|--------|---|---|-------------------------------------------------------------------------|
| 0 | 100    |   | 0 | <a href="#">SVE conditionally broadcast element to vector</a>           |
| 0 | 101    |   | 0 | <a href="#">SVE conditionally extract element to SIMD&amp;FP scalar</a> |
| 0 | 110    | 0 | 0 | <a href="#">SPICE à€” Destructive</a>                                   |
| 0 | 110    | 1 | 0 | <a href="#">SPICE à€” Constructive</a>                                  |
| 0 | 110    |   | 1 | UNALLOCATED                                                             |
| 0 | 111    | 0 | 0 | <a href="#">SVE reverse doublewords</a>                                 |
| 0 | 111    | 0 | 1 | UNALLOCATED                                                             |
| 0 | 111    | 1 |   | UNALLOCATED                                                             |
| 0 | x01    |   | 1 | UNALLOCATED                                                             |
| 1 | 000    |   | 0 | UNALLOCATED                                                             |
| 1 | 000    |   | 1 | <a href="#">SVE conditionally extract element to general register</a>   |
| 1 | != 000 |   |   | UNALLOCATED                                                             |

### SVE extract element to general register

These instructions are under [SVE Permute Vector - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 0  | 0  | 0  | B  | 1  | 0  | 1  | Pg |    | Zn |    | Rd |   |   |   |   |   |   |   |   |   |

| Decode fields<br>B | Instruction Details            |
|--------------------|--------------------------------|
| 0                  | <a href="#">LASTA (scalar)</a> |
| 1                  | <a href="#">LASTB (scalar)</a> |

### SVE extract element to SIMD&FP scalar register

These instructions are under [SVE Permute Vector - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 0  | 0  | 1  | B  | 1  | 0  | 0  | Pg |    | Zn |    | Vd |   |   |   |   |   |   |   |   |   |

| Decode fields<br>B | Instruction Details                        |
|--------------------|--------------------------------------------|
| 0                  | <a href="#">LASTA (SIMD&amp;FP scalar)</a> |
| 1                  | <a href="#">LASTB (SIMD&amp;FP scalar)</a> |

### SVE reverse within elements

These instructions are under [SVE Permute Vector - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |     |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|-----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18  | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 0  | 1  | opc | 1  | 0  | 0  | Pg |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |   |

#### Decode fields

#### Instruction Details

opc

|    |                                                                                                       |
|----|-------------------------------------------------------------------------------------------------------|
| 00 | <a href="#">REV<sub>B</sub>, REV<sub>H</sub>, REV<sub>W</sub></a> â€“ <a href="#">REV<sub>B</sub></a> |
| 01 | <a href="#">REV<sub>B</sub>, REV<sub>H</sub>, REV<sub>W</sub></a> â€“ <a href="#">REV<sub>H</sub></a> |
| 10 | <a href="#">REV<sub>B</sub>, REV<sub>H</sub>, REV<sub>W</sub></a> â€“ <a href="#">REV<sub>W</sub></a> |
| 11 | <a href="#">RBIT</a>                                                                                  |

### SVE conditionally broadcast element to vector

These instructions are under [SVE Permute Vector - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 1  | 0  | 0  | B  | 1  | 0  | 0  | Pg |    | Zm |    | Zdn |   |   |   |   |   |   |   |   |   |

#### Decode fields

#### Instruction Details

B

|   |                                  |
|---|----------------------------------|
| 0 | <a href="#">CLASTA (vectors)</a> |
| 1 | <a href="#">CLASTB (vectors)</a> |

### SVE conditionally extract element to SIMD&FP scalar

These instructions are under [SVE Permute Vector - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 1  | 0  | 1  | B  | 1  | 0  | 0  | Pg |    | Zm |    | Vdn |   |   |   |   |   |   |   |   |   |

#### Decode fields

#### Instruction Details

B

|   |                                             |
|---|---------------------------------------------|
| 0 | <a href="#">CLASTA (SIMD&amp;FP scalar)</a> |
| 1 | <a href="#">CLASTB (SIMD&amp;FP scalar)</a> |

### SVE reverse doublewords

These instructions are under [SVE Permute Vector - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 1  | 1  | 1  | 0  | 1  | 0  | 0  | Pg |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b><br>size | <b>Instruction Details</b> | <b>Feature</b> |
|------------------------------|----------------------------|----------------|
| 00                           | <a href="#">REVD</a>       | FEAT_SVE2p1    |
| 01                           | UNALLOCATED                | -              |
| 1x                           | UNALLOCATED                | -              |

### SVE conditionally extract element to general register

These instructions are under [SVE Permute Vector - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 1  | 0  | 0  | 0  | B  | 1  | 0  | 1  | Pg | Zm | Rdn |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b><br><b>B</b> | <b>Instruction Details</b>      |
|----------------------------------|---------------------------------|
| 0                                | <a href="#">CLASTA (scalar)</a> |
| 1                                | <a href="#">CLASTB (scalar)</a> |

### SVE Permute Vector - Extract

These instructions are under [SVE encodings](#).

|           |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31        | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 000001010 | op0 | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b><br><b>op0</b> | <b>Instruction details</b>           |
|------------------------------------|--------------------------------------|
| 0                                  | <a href="#">EXT â€“ Destructive</a>  |
| 1                                  | <a href="#">EXT â€“ Constructive</a> |

### SVE Permute Vector - Segments

These instructions are under [SVE encodings](#).

|           |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31        | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 000001011 | op0 | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b><br><b>op0</b> | <b>Instruction details</b>                  |
|------------------------------------|---------------------------------------------|
| 0                                  | <a href="#">SVE permute vector segments</a> |
| 1                                  | UNALLOCATED                                 |

### SVE permute vector segments

These instructions are under [SVE Permute Vector - Segments](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 1  | Zm | 0  | 0  | 0  | opc | H  |    | Zn |    | Zd |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                  |                        | Feature    |
|---------------|---|--------------------------------------|------------------------|------------|
| opc           | H |                                      |                        |            |
| 00            | 0 | <a href="#">ZIP1, ZIP2 (vectors)</a> | " <a href="#">ZIP1</a> | FEAT_F64MM |
| 00            | 1 | <a href="#">ZIP1, ZIP2 (vectors)</a> | " <a href="#">ZIP2</a> | FEAT_F64MM |
| 01            | 0 | <a href="#">UZP1, UZP2 (vectors)</a> | " <a href="#">UZP1</a> | FEAT_F64MM |
| 01            | 1 | <a href="#">UZP1, UZP2 (vectors)</a> | " <a href="#">UZP2</a> | FEAT_F64MM |
| 10            |   | UNALLOCATED                          |                        | -          |
| 11            | 0 | <a href="#">TRN1, TRN2 (vectors)</a> | " <a href="#">TRN1</a> | FEAT_F64MM |
| 11            | 1 | <a href="#">TRN1, TRN2 (vectors)</a> | " <a href="#">TRN2</a> | FEAT_F64MM |

## SVE Integer Compare - Vectors

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00100100 |    |    |    |    |    |    |    |    |    |    | 0  |    |    |    | op0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction details                                    |  |
|---------------|--|--------------------------------------------------------|--|
| op0           |  |                                                        |  |
| 0             |  | <a href="#">SVE integer compare vectors</a>            |  |
| 1             |  | <a href="#">SVE integer compare with wide elements</a> |  |

## SVE integer compare vectors

These instructions are under [SVE Integer Compare - Vectors](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm | op | 0  | o2 | Pg |    | Zn | ne | Pd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |    |    | Instruction Details                           |                         |
|---------------|----|----|-----------------------------------------------|-------------------------|
| op            | o2 | ne |                                               |                         |
| 0             | 0  | 0  | <a href="#">CMP&lt;cc&gt; (vectors)</a>       | " <a href="#">CMPHS</a> |
| 0             | 0  | 1  | <a href="#">CMP&lt;cc&gt; (vectors)</a>       | " <a href="#">CMPI</a>  |
| 0             | 1  | 0  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> | " <a href="#">CMPEQ</a> |
| 0             | 1  | 1  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> | " <a href="#">CMPNE</a> |
| 1             | 0  | 0  | <a href="#">CMP&lt;cc&gt; (vectors)</a>       | " <a href="#">CMPGE</a> |
| 1             | 0  | 1  | <a href="#">CMP&lt;cc&gt; (vectors)</a>       | " <a href="#">CMPGT</a> |
| 1             | 1  | 0  | <a href="#">CMP&lt;cc&gt; (vectors)</a>       | " <a href="#">CMPEQ</a> |
| 1             | 1  | 1  | <a href="#">CMP&lt;cc&gt; (vectors)</a>       | " <a href="#">CMPNE</a> |

## SVE integer compare with wide elements

These instructions are under [SVE Integer Compare - Vectors](#).

| Decode fields |    |    | Instruction Details                                                     |
|---------------|----|----|-------------------------------------------------------------------------|
| U             | lt | ne |                                                                         |
| 0             | 0  | 0  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> â€“ <a href="#">CMPGE</a> |
| 0             | 0  | 1  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> â€“ <a href="#">CMPGT</a> |
| 0             | 1  | 0  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> â€“ <a href="#">CMPLT</a> |
| 0             | 1  | 1  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> â€“ <a href="#">CMPLE</a> |
| 1             | 0  | 0  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> â€“ <a href="#">CMPHS</a> |
| 1             | 0  | 1  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> â€“ <a href="#">CMPHI</a> |
| 1             | 1  | 0  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> â€“ <a href="#">CMPLO</a> |
| 1             | 1  | 1  | <a href="#">CMP&lt;cc&gt; (wide elements)</a> â€“ <a href="#">CMPLS</a> |

## SVE integer compare with unsigned immediate

These instructions are under [SVE encodings](#).

| Decode fields |    | Instruction Details                                                  |
|---------------|----|----------------------------------------------------------------------|
| lt            | ne |                                                                      |
| 0             | 0  | <a href="#">CMP&lt;cc&gt; (immediate)</a> â€“ <a href="#">CMPHIS</a> |
| 0             | 1  | <a href="#">CMP&lt;cc&gt; (immediate)</a> â€“ <a href="#">CMPHI</a>  |
| 1             | 0  | <a href="#">CMP&lt;cc&gt; (immediate)</a> â€“ <a href="#">CMPLO</a>  |
| 1             | 1  | <a href="#">CMP&lt;cc&gt; (immediate)</a> â€“ <a href="#">CMPLS</a>  |

## SVE integer compare with signed immediate

These instructions are under [SVE encodings](#).

| Decode fields |    |    | Instruction Details                             |
|---------------|----|----|-------------------------------------------------|
| op            | o2 | ne |                                                 |
| 0             | 0  | 0  | <u>CMP&lt;cc&gt;</u> (immediate) → <u>CMPGE</u> |

| Decode fields |    |    | Instruction Details                                                 |
|---------------|----|----|---------------------------------------------------------------------|
| op            | o2 | ne |                                                                     |
| 0             | 0  | 1  | <a href="#">CMP&lt;cc&gt; (immediate)</a> â€“ <a href="#">CMPGT</a> |
| 0             | 1  | 0  | <a href="#">CMP&lt;cc&gt; (immediate)</a> â€“ <a href="#">CMPLT</a> |
| 0             | 1  | 1  | <a href="#">CMP&lt;cc&gt; (immediate)</a> â€“ <a href="#">CMPLE</a> |
| 1             | 0  | 0  | <a href="#">CMP&lt;cc&gt; (immediate)</a> â€“ <a href="#">CMPEQ</a> |
| 1             | 0  | 1  | <a href="#">CMP&lt;cc&gt; (immediate)</a> â€“ <a href="#">CMPNE</a> |
| 1             | 1  |    | UNALLOCATED                                                         |

### SVE predicate logical operations

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | op | S  | 0  | 0  | Pm | 0  | 1  | Pg | o2 | Pn | o3 | Pd |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |    |    | Instruction Details              |
|---------------|---|----|----|----------------------------------|
| op            | S | o2 | o3 |                                  |
| 0             | 0 | 0  | 0  | <a href="#">AND (predicates)</a> |
| 0             | 0 | 0  | 1  | <a href="#">BIC (predicates)</a> |
| 0             | 0 | 1  | 0  | <a href="#">EOR (predicates)</a> |
| 0             | 0 | 1  | 1  | <a href="#">SEL (predicates)</a> |
| 0             | 1 | 0  | 0  | <a href="#">ANDS</a>             |
| 0             | 1 | 0  | 1  | <a href="#">BICS</a>             |
| 0             | 1 | 1  | 0  | <a href="#">EORS</a>             |
| 0             | 1 | 1  | 1  | UNALLOCATED                      |
| 1             | 0 | 0  | 0  | <a href="#">ORR (predicates)</a> |
| 1             | 0 | 0  | 1  | <a href="#">ORN (predicates)</a> |
| 1             | 0 | 1  | 0  | <a href="#">NOR</a>              |
| 1             | 0 | 1  | 1  | <a href="#">NAND</a>             |
| 1             | 1 | 0  | 0  | <a href="#">ORRS</a>             |
| 1             | 1 | 0  | 1  | <a href="#">ORNS</a>             |
| 1             | 1 | 1  | 0  | <a href="#">NORS</a>             |
| 1             | 1 | 1  | 1  | <a href="#">NANDS</a>            |

### SVE Propagate Break

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00100101 |    |    | 00 |    |    | 11 |    | op0 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction details |
|---------------|--|---------------------|
|               |  |                     |

| <b>op0</b> |                                                             |
|------------|-------------------------------------------------------------|
| 0          | <a href="#">SVE propagate break from previous partition</a> |
| 1          | UNALLOCATED                                                 |

## SVE propagate break from previous partition

These instructions are under [SVE Propagate Break](#).

| Decode fields |   |   | Instruction Details    |
|---------------|---|---|------------------------|
| op            | S | B |                        |
| 0             | 0 | 0 | <a href="#">BRKPA</a>  |
| 0             | 0 | 1 | <a href="#">BRKPB</a>  |
| 0             | 1 | 0 | <a href="#">BRKPAS</a> |
| 0             | 1 | 1 | <a href="#">BRKPBS</a> |
| 1             |   |   | UNALLOCATED            |

## SVE Partition Break

These instructions are under [SVE encodings](#).

| Decode fields |         |     |     | Instruction details                                   |
|---------------|---------|-----|-----|-------------------------------------------------------|
| op0           | op1     | op2 | op3 |                                                       |
| 0             | 1000    | 0   | 0   | <a href="#">SVE propagate break to next partition</a> |
| 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   |     | <a href="#">SVE partition break condition</a>         |

## SVE propagate break to next partition

These instructions are under [SVE Partition Break](#).

### Decode fields

**S**

### Instruction Details

|   |                       |
|---|-----------------------|
| 0 | <a href="#">BRKN</a>  |
| 1 | <a href="#">BRKNS</a> |

### SVE partition break condition

These instructions are under [SVE Partition Break](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | B  | S  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | Pg | 0  | Pn | M  | M | Pd |   |   |   |   |   |   |   |   |

### Decode fields

**B      S      M**

### Instruction Details

|   |   |   |                       |
|---|---|---|-----------------------|
|   | 1 | 1 | UNALLOCATED           |
| 0 | 0 |   | <a href="#">BRKA</a>  |
| 0 | 1 | 0 | <a href="#">BRKAS</a> |
| 1 | 0 |   | <a href="#">BRKB</a>  |
| 1 | 1 | 0 | <a href="#">BRKBS</a> |

### SVE Predicate Misc

These instructions are under [SVE encodings](#).

|          |    |    |    |    |     |    |    |    |     |    |     |    |     |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|-----|----|----|----|-----|----|-----|----|-----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26  | 25 | 24 | 23 | 22  | 21 | 20  | 19 | 18  | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00100101 |    |    | 01 |    | op0 |    | 11 |    | op1 |    | op2 |    | op3 |    | op4 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

**op0**

**op1**

**op2**

**op3**

**op4**

### Instruction details

|      |     |       |         |   |                                                          |
|------|-----|-------|---------|---|----------------------------------------------------------|
| 0000 |     | x0    |         | 0 | <a href="#">SVE predicate test</a>                       |
| 0100 |     | x0    |         | 0 | UNALLOCATED                                              |
| 0x10 |     | x0    |         | 0 | UNALLOCATED                                              |
| 0xx1 |     | x0    |         | 0 | UNALLOCATED                                              |
| 0xxx |     | x1    |         | 0 | UNALLOCATED                                              |
| 1000 | 000 | 00    |         | 0 | <a href="#">SVE predicate first active</a>               |
| 1000 | 000 | != 00 |         | 0 | UNALLOCATED                                              |
| 1000 | 100 | 10    | 0000    | 0 | <a href="#">SVE predicate zero</a>                       |
| 1000 | 100 | 10    | != 0000 | 0 | UNALLOCATED                                              |
| 1000 | 110 | 00    |         | 0 | <a href="#">SVE predicate read from FFR (predicated)</a> |
| 1001 | 000 | 0x    |         | 0 | UNALLOCATED                                              |

|      |     |       |         |   |                                                            |
|------|-----|-------|---------|---|------------------------------------------------------------|
| 1001 | 000 | 10    |         | 0 | <a href="#">PNEXT</a>                                      |
| 1001 | 000 | 11    |         | 0 | UNALLOCATED                                                |
| 1001 | 100 | 10    |         | 0 | UNALLOCATED                                                |
| 1001 | 110 | 00    | 0000    | 0 | <a href="#">SVE predicate read from FFR (unpredicated)</a> |
| 1001 | 110 | 00    | != 0000 | 0 | UNALLOCATED                                                |
| 100x | 010 |       |         | 0 | UNALLOCATED                                                |
| 100x | 100 | 0x    |         | 0 | <a href="#">SVE predicate initialize</a>                   |
| 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.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | op | S  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | Pg | 0  | Pn | 0  | opc2 |   |   |   |   |   |   |   |   |   |

| Decode fields |   |      | Instruction Details   |
|---------------|---|------|-----------------------|
| op            | S | opc2 |                       |
| 0             | 0 |      | UNALLOCATED           |
| 0             | 1 | 0000 | <a href="#">PTEST</a> |
| 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.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | op | S  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | Pg | 0 | Pdn |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details    |
|---------------|---|------------------------|
| op            | S |                        |
| 0             | 0 | UNALLOCATED            |
| 0             | 1 | <a href="#">PFIRST</a> |
| 1             |   | UNALLOCATED            |

---

### SVE predicate zero

These instructions are under [SVE Predicate Misc.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | op | S  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 1  | 0 | 0 | 0 | 0 | 0 | 0 | Pd |   |   |   |

| Decode fields |   | Instruction Details    |
|---------------|---|------------------------|
| op            | S |                        |
| 0             | 0 | <a href="#">PFALSE</a> |
| 0             | 1 | UNALLOCATED            |
| 1             |   | UNALLOCATED            |

---

### SVE predicate read from FFR (predicated)

These instructions are under [SVE Predicate Misc.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | op | S  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | 0 | Pg | 0 | Pd |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                |
|---------------|---|------------------------------------|
| op            | S |                                    |
| 0             | 0 | <a href="#">RDFFR (predicated)</a> |
| 0             | 1 | <a href="#">RDFFRS</a>             |
| 1             |   | UNALLOCATED                        |

---

### SVE predicate read from FFR (unpredicated)

These instructions are under [SVE Predicate Misc.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |    |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|----|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | op | S  | 0  | 1  | 1  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | Pd |   |   |   |   |

| Decode fields |   | Instruction Details                  |
|---------------|---|--------------------------------------|
| op            | S |                                      |
| 0             | 0 | <a href="#">RDFFR (unpredicated)</a> |

| Decode fields |   | Instruction Details |
|---------------|---|---------------------|
| op            | S |                     |
| 0             | 1 | UNALLOCATED         |
| 1             |   | UNALLOCATED         |

---

### SVE predicate initialize

These instructions are under [SVE Predicate Misc.](#)

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |         |   |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|---------|---|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10      | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 0  | 1  | 1  | 0  | 0  | S  | 1  | 1  | 1  | 0  | 0  | 0  | pattern | 0 | Pd |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details               |
|---------------|--|-----------------------------------|
| S             |  |                                   |
| 0             |  | <a href="#">PTRUE (predicate)</a> |
| 1             |  | <a href="#">PTRUES</a>            |

---

### SVE Integer Compare - Scalars

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |   |   |   |   |   |   |   |   |     |   |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |  |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  |    |    | 1  |    |    |    | 00 | op0 | op1 |    |    |    |    |    |   |   |   |   |   |   |   |   | op2 |   |  |

| Decode fields |       |         | Instruction details                                        |
|---------------|-------|---------|------------------------------------------------------------|
| op0           | op1   | op2     |                                                            |
| 0x            |       |         | <a href="#">SVE integer compare scalar count and limit</a> |
| 10            | 00    | 0000    | <a href="#">SVE conditionally terminate scalars</a>        |
| 10            | 00    | != 0000 | UNALLOCATED                                                |
| 11            | 00    |         | <a href="#">SVE pointer conflict compare</a>               |
| 1x            | != 00 |         | UNALLOCATED                                                |

---

### SVE integer compare scalar count and limit

These instructions are under [SVE Integer Compare - Scalars](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  |    | Rm | 0  | 0  | 0  | sf | U  | lt |    |    |    |    | Rn | eq | Pd |   |   |   |   |   |   |   |  |

| Decode fields |    |    | Instruction Details                 |
|---------------|----|----|-------------------------------------|
| U             | lt | eq |                                     |
| 0             | 0  | 0  | <a href="#">WHILEGE (predicate)</a> |
| 0             | 0  | 1  | <a href="#">WHILEGT (predicate)</a> |
| 0             | 1  | 0  | <a href="#">WHILELT (predicate)</a> |

| Decode fields |    |    | Instruction Details                 |
|---------------|----|----|-------------------------------------|
| U             | lt | eq |                                     |
| 0             | 1  | 1  | <a href="#">WHILELE (predicate)</a> |
| 1             | 0  | 0  | <a href="#">WHILEHS (predicate)</a> |
| 1             | 0  | 1  | <a href="#">WHILEHI (predicate)</a> |
| 1             | 1  | 0  | <a href="#">WHILELO (predicate)</a> |
| 1             | 1  | 1  | <a href="#">WHILELS (predicate)</a> |

### SVE conditionally terminate scalars

These instructions are under [SVE Integer Compare - Scalars](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | op | sz | 1  | Rm | 0  | 0  | 1  | 0  | 0  | 0  | Rn | ne | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |   |

| Decode fields |    | Instruction Details                                          |
|---------------|----|--------------------------------------------------------------|
| op            | ne |                                                              |
| 0             |    | UNALLOCATED                                                  |
| 1             | 0  | <a href="#">CTERMEQ, CTERMNE</a> â€“ <a href="#">CTERMEQ</a> |
| 1             | 1  | <a href="#">CTERMEQ, CTERMNE</a> â€“ <a href="#">CTERMNE</a> |

### SVE pointer conflict compare

These instructions are under [SVE Integer Compare - Scalars](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | Rm | 0  | 0  | 1  | 1  | 0  | 0  | Rn | rw | Pd |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details     |
|---------------|--|-------------------------|
| rw            |  |                         |
| 0             |  | <a href="#">WHILEWR</a> |
| 1             |  | <a href="#">WHILERW</a> |

### SVE broadcast predicate element

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |      |    |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|------|----|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | i1 | tszh | 1  | tszl | Rv | 0  | 1  | Pn | S  | Pm | 0  | Pd |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction Details  | Feature     |
|---------------|----------------------|-------------|
| S             |                      |             |
| 0             | <a href="#">PSEL</a> | FEAT_SVE2p1 |

| Decode fields |  | Instruction Details |   |  |  | Feature |
|---------------|--|---------------------|---|--|--|---------|
| S             |  |                     |   |  |  |         |
| 1             |  | UNALLOCATED         | - |  |  |         |

## SVE Scalar Integer Compare - Predicate-as-counter

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |   |     |   |   |     |   |   |   |   |   |
|----------|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|---|-----|---|---|-----|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25  | 24 | 23 | 22 | 21  | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6 | 5   | 4 | 3 | 2 | 1 | 0 |
| 00100101 |    |    |    | 1  |    | op0 |    | 01 |    | op1 |    |    |    |    |    |    |    |    |    |    |    |   | op2 |   | 1 | op3 |   |   |   |   |   |

| op0      | op1 | op2       | op3 | Decode fields                                                                     | Instruction details | Feature |
|----------|-----|-----------|-----|-----------------------------------------------------------------------------------|---------------------|---------|
| 00000    | 110 |           |     | <a href="#">SVE extract mask predicate from predicate-as-counter</a>              | -                   |         |
| 00000    | 111 | 000000    | 0   | <a href="#">PTRUE (predicate as counter)</a>                                      | FEAT_SVE2p1         |         |
| 00000    | 111 | 000000    | 1   | UNALLOCATED                                                                       | -                   |         |
| 00000    | 111 | != 000000 |     | UNALLOCATED                                                                       | -                   |         |
| != 00000 | 11x |           |     | UNALLOCATED                                                                       | -                   |         |
|          | 01x |           |     | <a href="#">SVE integer compare scalar count and limit (predicate pair)</a>       | -                   |         |
|          | x0x |           |     | <a href="#">SVE integer compare scalar count and limit (predicate-as-counter)</a> | -                   |         |

## SVE extract mask predicate from predicate-as-counter

These instructions are under [SVE Scalar Integer Compare - Predicate-as-counter](#).

|                 |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31              | 30   | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 0 1 0 0 1 0 1 | size | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  |    | opc |    | PNn | 1  | Pd |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction Details                   | Feature     |
|---------------|---------------------------------------|-------------|
| opc           |                                       |             |
| 0xx           | <a href="#">PEXT (predicate)</a>      | FEAT_SVE2p1 |
| 10x           | <a href="#">PEXT (predicate pair)</a> | FEAT_SVE2p1 |
| 11x           | UNALLOCATED                           | -           |

## SVE integer compare scalar count and limit (predicate pair)

These instructions are under [SVE Scalar Integer Compare - Predicate-as-counter](#).

| Decode fields |    |    | Instruction Details                      | Feature     |
|---------------|----|----|------------------------------------------|-------------|
| U             | lt | eq |                                          |             |
| 0             | 0  | 0  | <a href="#">WHILEGE (predicate pair)</a> | FEAT_SVE2p1 |
| 0             | 0  | 1  | <a href="#">WHILEGT (predicate pair)</a> | FEAT_SVE2p1 |
| 0             | 1  | 0  | <a href="#">WHILELT (predicate pair)</a> | FEAT_SVE2p1 |
| 0             | 1  | 1  | <a href="#">WHILELE (predicate pair)</a> | FEAT_SVE2p1 |
| 1             | 0  | 0  | <a href="#">WHILEHS (predicate pair)</a> | FEAT_SVE2p1 |
| 1             | 0  | 1  | <a href="#">WHILEHI (predicate pair)</a> | FEAT_SVE2p1 |
| 1             | 1  | 0  | <a href="#">WHILELO (predicate pair)</a> | FEAT_SVE2p1 |
| 1             | 1  | 1  | <a href="#">WHILELS (predicate pair)</a> | FEAT_SVE2p1 |

## SVE integer compare scalar count and limit (predicate-as-counter)

These instructions are under [SVE Scalar Integer Compare - Predicate-as-counter](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |    |   |   |    |   |   |    |    |   |    |     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|----|---|---|----|----|---|----|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 1 | Rm | 0 | 1 | vl | 0 | U | lt | Rn | 1 | eq | PNd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|----|---|---|----|----|---|----|-----|

| Decode fields |    |    | Instruction Details                            | Feature     |
|---------------|----|----|------------------------------------------------|-------------|
| U             | lt | eq |                                                |             |
| 0             | 0  | 0  | <a href="#">WHILEGE (predicate as counter)</a> | FEAT_SVE2p1 |
| 0             | 0  | 1  | <a href="#">WHILEGT (predicate as counter)</a> | FEAT_SVE2p1 |
| 0             | 1  | 0  | <a href="#">WHILELT (predicate as counter)</a> | FEAT_SVE2p1 |
| 0             | 1  | 1  | <a href="#">WHILELE (predicate as counter)</a> | FEAT_SVE2p1 |
| 1             | 0  | 0  | <a href="#">WHILEHS (predicate as counter)</a> | FEAT_SVE2p1 |
| 1             | 0  | 1  | <a href="#">WHILEHI (predicate as counter)</a> | FEAT_SVE2p1 |
| 1             | 1  | 0  | <a href="#">WHILELO (predicate as counter)</a> | FEAT_SVE2p1 |
| 1             | 1  | 1  | <a href="#">WHILELS (predicate as counter)</a> | FEAT_SVE2p1 |

## SVE Integer Wide Immediate - Unpredicated

These instructions are under [SVE encodings](#).

| Decode fields |     | Instruction details                                                   |
|---------------|-----|-----------------------------------------------------------------------|
| op0           | op1 |                                                                       |
| 00            |     | <a href="#">SVE integer add/subtract immediate (unpredicated)</a>     |
| 01            |     | <a href="#">SVE integer min/max immediate (unpredicated)</a>          |
| 10            |     | <a href="#">SVE integer multiply immediate (unpredicated)</a>         |
| 11            | 0   | <a href="#">SVE broadcast integer immediate (unpredicated)</a>        |
| 11            | 1   | <a href="#">SVE broadcast floating-point immediate (unpredicated)</a> |

### SVE integer add/subtract immediate (unpredicated)

These instructions are under [SVE Integer Wide Immediate - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |      |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|------|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14   | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 0  | opc | 1  | 1  | sh |    | imm8 |    | Zdn |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details               |
|---------------|--|-----------------------------------|
| opc           |  |                                   |
| 000           |  | <a href="#">ADD (immediate)</a>   |
| 001           |  | <a href="#">SUB (immediate)</a>   |
| 010           |  | UNALLOCATED                       |
| 011           |  | <a href="#">SUBR (immediate)</a>  |
| 100           |  | <a href="#">SQADD (immediate)</a> |
| 101           |  | <a href="#">UQADD (immediate)</a> |
| 110           |  | <a href="#">SQSUB (immediate)</a> |
| 111           |  | <a href="#">UQSUB (immediate)</a> |

### SVE integer min/max immediate (unpredicated)

These instructions are under [SVE Integer Wide Immediate - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |      |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|------|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14   | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 1  | opc | 1  | 1  | o2 |    | imm8 |    | Zdn |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |    | Instruction Details              |
|---------------|----|----------------------------------|
| opc           | o2 |                                  |
| 0xx           | 1  | UNALLOCATED                      |
| 000           | 0  | <a href="#">SMAX (immediate)</a> |

| Decode fields |    | Instruction Details              |
|---------------|----|----------------------------------|
| opc           | o2 |                                  |
| 001           | 0  | <a href="#">UMAX (immediate)</a> |
| 010           | 0  | <a href="#">SMIN (immediate)</a> |
| 011           | 0  | <a href="#">UMIN (immediate)</a> |
| 1xx           |    | UNALLOCATED                      |

## SVE integer multiply immediate (unpredicated)

These instructions are under [SVE Integer Wide Immediate - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |     |   |   |   |  |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|------|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |  |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | 1  | 0  | opc | 1  | 1  | o2 | imm8 |    |    |    |    |    |   |   |   |   |   |   | Zdn |   |   |   |  |

| Decode fields |    | Instruction Details             |
|---------------|----|---------------------------------|
| opc           | o2 |                                 |
| 000           | 0  | <a href="#">MUL (immediate)</a> |
| 000           | 1  | UNALLOCATED                     |
| 001           |    | UNALLOCATED                     |
| 01x           |    | UNALLOCATED                     |
| 1xx           |    | UNALLOCATED                     |

## SVE broadcast integer immediate (unpredicated)

These instructions are under [SVE Integer Wide Immediate - Unpredicated](#).

| <b>Decode fields</b> | <b>Instruction Details</b>      |
|----------------------|---------------------------------|
| <b>opc</b>           |                                 |
| 00                   | <a href="#">DUP (immediate)</a> |
| 01                   | UNALLOCATED                     |
| 1x                   | UNALLOCATED                     |

## SVE broadcast floating-point immediate (unpredicated)

These instructions are under [SVE Integer Wide Immediate - Unpredicated](#).

| Decode fields |    | Instruction Details  |
|---------------|----|----------------------|
| opc           | o2 |                      |
| 00            | 0  | <a href="#">FDUP</a> |
| 00            | 1  | UNALLOCATED          |
| 01            |    | UNALLOCATED          |
| 1x            |    | UNALLOCATED          |

## SVE Predicate Count

These instructions are under [SVE encodings](#).

| Decode fields |     | Instruction details                                        |
|---------------|-----|------------------------------------------------------------|
| op0           | op1 |                                                            |
| 000           | 1   | <a href="#">SVE predicate count (predicate-as-counter)</a> |
| != 000        | 1   | UNALLOCATED                                                |
|               | 0   | <a href="#">SVE predicate count</a>                        |

## SVE predicate count (predicate-as-counter)

These instructions are under [SVE Predicate Count](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |     |   |   |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|----|----|----|----|-----|---|---|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 0  | opc | 1  | 0  | 0  | 0  | 0  | v1 | 1  | 8  | PNn |   |   | Rd |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b>                  | <b>Feature</b> |
|----------------------|---------------------------------------------|----------------|
| <b>opc</b>           |                                             |                |
| 000                  | <a href="#">CNTP (predicate as counter)</a> | FEAT_SVE2p1    |
| 001                  | UNALLOCATED                                 | -              |
| 01x                  | UNALLOCATED                                 | -              |
| 1xx                  | UNALLOCATED                                 | -              |

## SVE predicate count

These instructions are under [SVE Predicate Count](#).

| <b>Decode fields</b> | <b>Instruction Details</b> |
|----------------------|----------------------------|
| <b>opc</b>           |                            |

|     |                                  |
|-----|----------------------------------|
| 000 | <a href="#">CNTP (predicate)</a> |
| 001 | UNALLOCATED                      |
| 01x | UNALLOCATED                      |
| 1xx | UNALLOCATED                      |

### SVE Inc/Dec by Predicate Count

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |     |     |    |      |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18  | 17 | 16   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 00100101 |    |    |    |    |    |    |    |    |    |    |    | 101 | op0 |    | 1000 | op1 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction details</b> |
|----------------------|----------------------------|
| <b>op0</b>           | <b>op1</b>                 |

### Instruction details

|   |   |                                                                    |
|---|---|--------------------------------------------------------------------|
| 0 | 0 | <a href="#">SVE saturating inc/dec vector by predicate count</a>   |
| 0 | 1 | <a href="#">SVE saturating inc/dec register by predicate count</a> |
| 1 | 0 | <a href="#">SVE inc/dec vector by predicate count</a>              |
| 1 | 1 | <a href="#">SVE inc/dec register by predicate count</a>            |

### SVE saturating inc/dec vector by predicate count

These instructions are under [SVE Inc/Dec by Predicate Count](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |     |    |   |     |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|-----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 1  | 0  | D  | U  | 1  | 0  | 0  | 0  | 0  | opc | Pm |   | Zdn |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b> |            |
|----------------------|----------------------------|------------|
| <b>D</b>             | <b>U</b>                   | <b>opc</b> |

### Instruction Details

|   |   |    |                                 |
|---|---|----|---------------------------------|
|   |   | 01 | UNALLOCATED                     |
|   |   | 1x | UNALLOCATED                     |
| 0 | 0 | 00 | <a href="#">SQINCP (vector)</a> |
| 0 | 1 | 00 | <a href="#">UQINCP (vector)</a> |
| 1 | 0 | 00 | <a href="#">SQDECP (vector)</a> |
| 1 | 1 | 00 | <a href="#">UQDECP (vector)</a> |

### SVE saturating inc/dec register by predicate count

These instructions are under [SVE Inc/Dec by Predicate Count](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 1  | 0  | D  | U  | 1  | 0  | 0  | 0  | 1  | sf | op | Pm |   | Rdn |   |   |   |   |   |   |   |

| Decode fields |   |    |    | Instruction Details |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|----|----|---------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| D             | U | sf | op |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|   |   |   |   |                                                            |
|---|---|---|---|------------------------------------------------------------|
|   |   |   | 1 | UNALLOCATED                                                |
| 0 | 0 | 0 | 0 | <a href="#">SQINCP (scalar)</a> â€“ <a href="#">32-bit</a> |
| 0 | 0 | 1 | 0 | <a href="#">SQINCP (scalar)</a> â€“ <a href="#">64-bit</a> |
| 0 | 1 | 0 | 0 | <a href="#">UQINCP (scalar)</a> â€“ <a href="#">32-bit</a> |
| 0 | 1 | 1 | 0 | <a href="#">UQINCP (scalar)</a> â€“ <a href="#">64-bit</a> |
| 1 | 0 | 0 | 0 | <a href="#">SQDECP (scalar)</a> â€“ <a href="#">32-bit</a> |
| 1 | 0 | 1 | 0 | <a href="#">SQDECP (scalar)</a> â€“ <a href="#">64-bit</a> |
| 1 | 1 | 0 | 0 | <a href="#">UQDECP (scalar)</a> â€“ <a href="#">32-bit</a> |
| 1 | 1 | 1 | 0 | <a href="#">UQDECP (scalar)</a> â€“ <a href="#">64-bit</a> |

### SVE inc/dec vector by predicate count

These instructions are under [SVE Inc/Dec by Predicate Count](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |      |    |   |     |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|------|----|---|-----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11   | 10 | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 1  | 1  | op | D  | 1  | 0  | 0  | 0  | 0  | opc2 | Pm |   | Zdn |   |   |   |   |   |   |   |   |

| Decode fields |   |      | Instruction Details |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|------|---------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| op            | D | opc2 |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|   |   |    |                               |
|---|---|----|-------------------------------|
| 0 |   | 01 | UNALLOCATED                   |
| 0 |   | 1x | UNALLOCATED                   |
| 0 | 0 | 00 | <a href="#">INCP (vector)</a> |
| 0 | 1 | 00 | <a href="#">DECP (vector)</a> |
| 1 |   |    | UNALLOCATED                   |

### SVE inc/dec register by predicate count

These instructions are under [SVE Inc/Dec by Predicate Count](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |      |    |   |     |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|------|----|---|-----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11   | 10 | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 1  | 1  | op | D  | 1  | 0  | 0  | 0  | 1  | opc2 | Pm |   | Rdn |   |   |   |   |   |   |   |   |

| Decode fields |   |      | Instruction Details |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|------|---------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| op            | D | opc2 |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|   |   |    |                               |
|---|---|----|-------------------------------|
| 0 |   | 01 | UNALLOCATED                   |
| 0 |   | 1x | UNALLOCATED                   |
| 0 | 0 | 00 | <a href="#">INCP (scalar)</a> |

| Decode fields |   |      | Instruction Details           |
|---------------|---|------|-------------------------------|
| op            | D | opc2 |                               |
| 0             | 1 | 00   | <a href="#">DECP (scalar)</a> |
| 1             |   |      | UNALLOCATED                   |

# SVE Write FFR

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |     |    |    |    |     |    |    |    |     |    |    |    |      |    |   |   |     |   |   |   |     |   |   |   |     |  |  |  |  |  |  |  |
|----------|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|-----|----|----|----|------|----|---|---|-----|---|---|---|-----|---|---|---|-----|--|--|--|--|--|--|--|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11   | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3   | 2 | 1 | 0 |     |  |  |  |  |  |  |  |
|          |    |    |    |    |    |    |    |     |    |    |    |     |    |    |    |     |    |    |    |      |    |   |   |     |   |   |   |     |   |   |   |     |  |  |  |  |  |  |  |
| 00100101 |    |    |    |    |    |    |    | 101 |    |    |    | op0 |    |    |    | op1 |    |    |    | 1001 |    |   |   | op2 |   |   |   | op3 |   |   |   | op4 |  |  |  |  |  |  |  |

| Decode fields |       |        |      |          | Instruction details                          |
|---------------|-------|--------|------|----------|----------------------------------------------|
| op0           | op1   | op2    | op3  | op4      |                                              |
| 0             | 00    | 000    |      | 00000    | <a href="#">SVE FFR write from predicate</a> |
| 1             | 00    | 000    | 0000 | 00000    | <a href="#">SVE FFR initialise</a>           |
| 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](#).

| <b>Decode fields</b> | <b>Instruction Details</b> |
|----------------------|----------------------------|
| <b>opc</b>           |                            |
| 00                   | <a href="#">WRFFR</a>      |
| 01                   | UNALLOCATED                |
| 1x                   | UNALLOCATED                |

## SVE FFR initialise

These instructions are under [SVE Write FFR](#).

| <b>Decode fields</b> | <b>Instruction Details</b> |
|----------------------|----------------------------|
| <b>opc</b>           |                            |
| 00                   | <a href="#">SETFFR</a>     |
| 01                   | UNALLOCATED                |
| 1x                   | UNALLOCATED                |

---

## SVE Integer Multiply-Add - Unpredicated

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 01000100 |    |    |    |    |    |    |    | 0  |    |    |    | 0  |    | op0 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| <b>Decode fields</b> | <b>Instruction details</b>                                    |
|----------------------|---------------------------------------------------------------|
| <b>op0</b>           |                                                               |
| 0000x                | <a href="#">SVE integer dot product (unpredicated)</a>        |
| 0001x                | <a href="#">SVE2 saturating multiply-add interleaved long</a> |
| 001xx                | <a href="#">CDOT (vectors)</a>                                |
| 01xxx                | <a href="#">SVE2 complex integer multiply-add</a>             |
| 10xxx                | <a href="#">SVE2 integer multiply-add long</a>                |
| 110xx                | <a href="#">SVE2 saturating multiply-add long</a>             |
| 1110x                | <a href="#">SVE2 saturating multiply-add high</a>             |
| 11110                | <a href="#">SVE mixed sign dot product</a>                    |
| 11111                | UNALLOCATED                                                   |

---

## SVE integer dot product (unpredicated)

These instructions are under [SVE Integer Multiply-Add - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm | 0  | 0  | 0  | 0  | 0  | U  | Zn |    | Zda |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b>            |
|----------------------|---------------------------------------|
| <b>U</b>             |                                       |
| 0                    | <a href="#">SDOT (4-way, vectors)</a> |
| 1                    | <a href="#">UDOT (4-way, vectors)</a> |

---

## SVE2 saturating multiply-add interleaved long

These instructions are under [SVE Integer Multiply-Add - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm | 0  | 0  | 0  | 0  | 1  | S  | Zn | Zda |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields**  
**S**

**Instruction Details**

|   |                           |
|---|---------------------------|
| 0 | <a href="#">SQDMLALBT</a> |
| 1 | <a href="#">SQDMLSLBT</a> |

### SVE2 complex integer multiply-add

These instructions are under [SVE Integer Multiply-Add - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |     |    |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|-----|----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm | 0  | 0  | 1  | op | rot | Zn | Zda |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields**  
**op**

**Instruction Details**

|   |                                    |
|---|------------------------------------|
| 0 | <a href="#">CMLA (vectors)</a>     |
| 1 | <a href="#">QRDCMLAH (vectors)</a> |

### SVE2 integer multiply-add long

These instructions are under [SVE Integer Multiply-Add - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm | 0  | 1  | 0  | S  | U  | T  | Zn | Zda |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields**  
**S    U    T**

**Instruction Details**

|   |   |   |                                   |
|---|---|---|-----------------------------------|
| 0 | 0 | 0 | <a href="#">SMLALB (vectors)</a>  |
| 0 | 0 | 1 | <a href="#">SMLALT (vectors)</a>  |
| 0 | 1 | 0 | <a href="#">UMLALB (vectors)</a>  |
| 0 | 1 | 1 | <a href="#">UMLALT (vectors)</a>  |
| 1 | 0 | 0 | <a href="#">SMLS LB (vectors)</a> |
| 1 | 0 | 1 | <a href="#">SMLS LT (vectors)</a> |
| 1 | 1 | 0 | <a href="#">UMLS LB (vectors)</a> |
| 1 | 1 | 1 | <a href="#">UMLS LT (vectors)</a> |

### SVE2 saturating multiply-add long

These instructions are under [SVE Integer Multiply-Add - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm | 0  | 1  | 1  | 0  | S  | T  | Zn | Zda |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                |
|---------------|---|------------------------------------|
| S             | T |                                    |
| 0             | 0 | <a href="#">SQDMLALB (vectors)</a> |
| 0             | 1 | <a href="#">SQDMLALT (vectors)</a> |
| 1             | 0 | <a href="#">SQDMLSLB (vectors)</a> |
| 1             | 1 | <a href="#">SQDMLSLT (vectors)</a> |

### SVE2 saturating multiply-add high

These instructions are under [SVE Integer Multiply-Add - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm | 0  | 1  | 1  | 1  | 0  | S  | Zn | Zda |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details               |
|---------------|--|-----------------------------------|
| S             |  |                                   |
| 0             |  | <a href="#">QRDMLAH (vectors)</a> |
| 1             |  | <a href="#">QRDMLSH (vectors)</a> |

### SVE mixed sign dot product

These instructions are under [SVE Integer Multiply-Add - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm | 0  | 1  | 1  | 1  | 1  | 0  |    | Zn | Zda |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | size | Instruction Details             | Feature   |
|---------------|------|---------------------------------|-----------|
| 0x            |      | UNALLOCATED                     | -         |
| 10            |      | <a href="#">USDOT (vectors)</a> | FEAT_I8MM |
| 11            |      | UNALLOCATED                     | -         |

### SVE2 Integer - Predicated

These instructions are under [SVE encodings](#).

|          |    |    |     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28  | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01000100 |    | 0  | op0 |    |    | 10 | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction details |
|---------------|---------------------|
|               |                     |

| <b>op0</b> | <b>op1</b> |                                                                          |
|------------|------------|--------------------------------------------------------------------------|
| 0010       | 1          | <a href="#">SVE2 integer pairwise add and accumulate long</a>            |
| 0011       | 1          | UNALLOCATED                                                              |
| 011x       | 1          | UNALLOCATED                                                              |
| 0x0x       | 1          | <a href="#">SVE2 integer unary operations (predicated)</a>               |
| 0xxx       | 0          | <a href="#">SVE2 saturating/rounding bitwise shift left (predicated)</a> |
| 10xx       | 0          | <a href="#">SVE2 integer halving add/subtract (predicated)</a>           |
| 10xx       | 1          | <a href="#">SVE2 integer pairwise arithmetic</a>                         |
| 11xx       | 0          | <a href="#">SVE2 saturating add/subtract</a>                             |
| 11xx       | 1          | UNALLOCATED                                                              |

### SVE2 integer pairwise add and accumulate long

These instructions are under [SVE2 Integer - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 0  | 0  | 1  | 0  | U  | 1  | 0  | 1  | Pg |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b> |
|----------------------|----------------------------|
| <b>U</b>             |                            |
| 0                    | <a href="#">SADALP</a>     |
| 1                    | <a href="#">UADALP</a>     |

### SVE2 integer unary operations (predicated)

These instructions are under [SVE2 Integer - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |     |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|-----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18  | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 0  | Q  | 0  | opc | 1  | 0  | 1  | Pg |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b> |                         |
|----------------------|----------------------------|-------------------------|
| <b>Q</b>             |                            |                         |
| 0                    | 1x                         |                         |
| 0                    | 00                         | <a href="#">URECPE</a>  |
| 0                    | 01                         | <a href="#">URSORTE</a> |
| 1                    | 00                         | <a href="#">SQABS</a>   |
| 1                    | 01                         | <a href="#">SQNEG</a>   |

### SVE2 saturating/rounding bitwise shift left (predicated)

These instructions are under [SVE2 Integer - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 0  | Q  | R  | N  | U  | 1  | 0  | 0  | Pg |    | Zm |    | Zdn |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   |   | Instruction Details             |
|---------------|---|---|---|---------------------------------|
| Q             | R | N | U |                                 |
| 0             |   | 0 |   | UNALLOCATED                     |
| 0             | 0 | 1 | 0 | <a href="#">SRSHL</a>           |
| 0             | 0 | 1 | 1 | <a href="#">URSHL</a>           |
| 0             | 1 | 1 | 0 | <a href="#">SRSHLR</a>          |
| 0             | 1 | 1 | 1 | <a href="#">URSHLR</a>          |
| 1             | 0 | 0 | 0 | <a href="#">SQSHL (vectors)</a> |
| 1             | 0 | 0 | 1 | <a href="#">UQSHL (vectors)</a> |
| 1             | 0 | 1 | 0 | <a href="#">SQRSHL</a>          |
| 1             | 0 | 1 | 1 | <a href="#">UQRSHL</a>          |
| 1             | 1 | 0 | 0 | <a href="#">SQSHLR</a>          |
| 1             | 1 | 0 | 1 | <a href="#">UQSHLR</a>          |
| 1             | 1 | 1 | 0 | <a href="#">SQRSHLR</a>         |
| 1             | 1 | 1 | 1 | <a href="#">UQRSHLR</a>         |

### SVE2 integer halving add/subtract (predicated)

These instructions are under [SVE2 Integer - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 1  | 0  | R  | S  | U  | 1  | 0  | 0  | Pg |    | Zm |    | Zdn |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   | Instruction Details    |
|---------------|---|---|------------------------|
| R             | S | U |                        |
| 0             | 0 | 0 | <a href="#">SHADD</a>  |
| 0             | 0 | 1 | <a href="#">UHADD</a>  |
| 0             | 1 | 0 | <a href="#">SHSUB</a>  |
| 0             | 1 | 1 | <a href="#">UHSUB</a>  |
| 1             | 0 | 0 | <a href="#">SRHADD</a> |
| 1             | 0 | 1 | <a href="#">URHADD</a> |
| 1             | 1 | 0 | <a href="#">SHSUBR</a> |
| 1             | 1 | 1 | <a href="#">UHSUBR</a> |

### SVE2 integer pairwise arithmetic

These instructions are under [SVE2 Integer - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 1  | 0  | opc | U  | 1  | 0  | 1  | Pg | Zm |    | Zdn |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields**      **Instruction Details**  
**opc**      **U**

|    |   |                       |
|----|---|-----------------------|
| 00 | 0 | UNALLOCATED           |
| 00 | 1 | <a href="#">ADDP</a>  |
| 01 |   | UNALLOCATED           |
| 10 | 0 | <a href="#">SMAXP</a> |
| 10 | 1 | <a href="#">UMAXP</a> |
| 11 | 0 | <a href="#">SMINP</a> |
| 11 | 1 | <a href="#">UMINP</a> |

### SVE2 saturating add/subtract

These instructions are under [SVE2 Integer - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | 1  | 1  | op | S  | U  | 1  | 0  | 0  | Pg | Zm |    | Zdn |   |   |   |   |   |   |   |   |   |   |

**Decode fields**      **Instruction Details**  
**op**      **S**      **U**

|   |   |   |                                             |
|---|---|---|---------------------------------------------|
| 0 | 0 | 0 | <a href="#">SQADD (vectors, predicated)</a> |
| 0 | 0 | 1 | <a href="#">UQADD (vectors, predicated)</a> |
| 0 | 1 | 0 | <a href="#">SQSUB (vectors, predicated)</a> |
| 0 | 1 | 1 | <a href="#">UQSUB (vectors, predicated)</a> |
| 1 | 0 | 0 | <a href="#">SUQADD</a>                      |
| 1 | 0 | 1 | <a href="#">USQADD</a>                      |
| 1 | 1 | 0 | <a href="#">SQSUBR</a>                      |
| 1 | 1 | 1 | <a href="#">UQSUBR</a>                      |

### SVE integer clamp

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm |    | 1  | 1  | 0  | 0  | 0  | U  |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |   |

**Decode fields**      **Instruction Details**      **Feature**  
**U**

|   |                        |             |
|---|------------------------|-------------|
| 0 | <a href="#">SCLAMP</a> | FEAT_SVE2p1 |
| 1 | <a href="#">UCLAMP</a> | FEAT_SVE2p1 |

## SVE permute vector elements (quadwords)

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 0  | Zm | 1  | 1  | 1  | opc | Zn |    | Zd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>opc | Instruction Details   | Feature     |
|----------------------|-----------------------|-------------|
| 000                  | <a href="#">ZIPQ1</a> | FEAT_SVE2p1 |
| 001                  | <a href="#">ZIPQ2</a> | FEAT_SVE2p1 |
| 010                  | <a href="#">UZPQ1</a> | FEAT_SVE2p1 |
| 011                  | <a href="#">UZPQ2</a> | FEAT_SVE2p1 |
| 10x                  | UNALLOCATED           | -           |
| 110                  | <a href="#">TBLQ</a>  | FEAT_SVE2p1 |
| 111                  | UNALLOCATED           | -           |

## SVE Multiply - Indexed

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01000100 |    | 1  |    |    |    |    |    |    |    |    |    |    |    | op0 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>op0 | Instruction details                                            |
|----------------------|----------------------------------------------------------------|
| 00000x               | <a href="#">SVE integer dot product (indexed)</a>              |
| 00001x               | <a href="#">SVE2 integer multiply-add (indexed)</a>            |
| 00010x               | <a href="#">SVE2 saturating multiply-add high (indexed)</a>    |
| 00011x               | <a href="#">SVE mixed sign dot product (indexed)</a>           |
| 001xxx               | <a href="#">SVE2 saturating multiply-add (indexed)</a>         |
| 0100xx               | <a href="#">SVE2 complex integer dot product (indexed)</a>     |
| 0101xx               | UNALLOCATED                                                    |
| 0110xx               | <a href="#">SVE2 complex integer multiply-add (indexed)</a>    |
| 0111xx               | <a href="#">SVE2 complex saturating multiply-add (indexed)</a> |
| 10xxxx               | <a href="#">SVE2 integer multiply-add long (indexed)</a>       |
| 110xxx               | <a href="#">SVE2 integer multiply long (indexed)</a>           |
| 1110xx               | <a href="#">SVE2 saturating multiply (indexed)</a>             |
| 11110x               | <a href="#">SVE2 saturating multiply high (indexed)</a>        |
| 111110               | <a href="#">SVE2 integer multiply (indexed)</a>                |
| 111111               | UNALLOCATED                                                    |

## SVE integer dot product (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc | 0  | 0  | 0  | 0  | 0  | U  |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |   |

### Decode fields

size      U

### Instruction Details

|    |   |                                                  |
|----|---|--------------------------------------------------|
| 0x |   | UNALLOCATED                                      |
| 10 | 0 | <a href="#">SDOT (4-way, indexed)</a> â€“ 32-bit |
| 10 | 1 | <a href="#">UDOT (4-way, indexed)</a> â€“ 32-bit |
| 11 | 0 | <a href="#">SDOT (4-way, indexed)</a> â€“ 64-bit |
| 11 | 1 | <a href="#">UDOT (4-way, indexed)</a> â€“ 64-bit |

## SVE2 integer multiply-add (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc | 0  | 0  | 0  | 0  | 1  | S  |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |   |

### Decode fields

size      S

### Instruction Details

|    |   |                                          |
|----|---|------------------------------------------|
| 0x | 0 | <a href="#">MLA (indexed)</a> â€“ 16-bit |
| 0x | 1 | <a href="#">MLS (indexed)</a> â€“ 16-bit |
| 10 | 0 | <a href="#">MLA (indexed)</a> â€“ 32-bit |
| 10 | 1 | <a href="#">MLS (indexed)</a> â€“ 32-bit |
| 11 | 0 | <a href="#">MLA (indexed)</a> â€“ 64-bit |
| 11 | 1 | <a href="#">MLS (indexed)</a> â€“ 64-bit |

## SVE2 saturating multiply-add high (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc | 0  | 0  | 0  | 1  | 0  | S  |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |   |

### Decode fields

size      S

### Instruction Details

|    |   |                                               |
|----|---|-----------------------------------------------|
| 0x | 0 | <a href="#">SQRDMLAH (indexed)</a> â€“ 16-bit |
| 0x | 1 | <a href="#">SQRDMLSH (indexed)</a> â€“ 16-bit |
| 10 | 0 | <a href="#">SQRDMLAH (indexed)</a> â€“ 32-bit |

**Decode fields**  
size      S

**Instruction Details**

|    |   |                                               |
|----|---|-----------------------------------------------|
| 10 | 1 | <a href="#">SQRDMLSH (indexed)</a> â€“ 32-bit |
| 11 | 0 | <a href="#">SQRDMLAH (indexed)</a> â€“ 64-bit |
| 11 | 1 | <a href="#">SQRDMLSH (indexed)</a> â€“ 64-bit |

**SVE mixed sign dot product (indexed)**

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 0  | 0  | 0  | 1  | 1  | U  |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |

**Decode fields**  
size      U

**Instruction Details**

**Feature**

|    |   |                                 |           |
|----|---|---------------------------------|-----------|
| 0x |   | UNALLOCATED                     | -         |
| 10 | 0 | <a href="#">USDOT (indexed)</a> | FEAT_I8MM |
| 10 | 1 | <a href="#">SUDOT</a>           | FEAT_I8MM |
| 11 |   | UNALLOCATED                     | -         |

**SVE2 saturating multiply-add (indexed)**

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 0  | 0  | 1  | S  | il | T  |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |

**Decode fields**  
size      S      T

**Instruction Details**

|    |   |   |                                               |
|----|---|---|-----------------------------------------------|
| 0x |   |   | UNALLOCATED                                   |
| 10 | 0 | 0 | <a href="#">SQDMLALB (indexed)</a> â€“ 32-bit |
| 10 | 0 | 1 | <a href="#">SQDMLALT (indexed)</a> â€“ 32-bit |
| 10 | 1 | 0 | <a href="#">SQDMLSLB (indexed)</a> â€“ 32-bit |
| 10 | 1 | 1 | <a href="#">SQDMLSLT (indexed)</a> â€“ 32-bit |
| 11 | 0 | 0 | <a href="#">SQDMLALB (indexed)</a> â€“ 64-bit |
| 11 | 0 | 1 | <a href="#">SQDMLALT (indexed)</a> â€“ 64-bit |
| 11 | 1 | 0 | <a href="#">SQDMLSLB (indexed)</a> â€“ 64-bit |
| 11 | 1 | 1 | <a href="#">SQDMLSLT (indexed)</a> â€“ 64-bit |

**SVE2 complex integer dot product (indexed)**

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |     |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|-----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 0  | 1  | 0  | 0  | rot |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |   |

**Decode fields**  
**size**

**Instruction Details**

|    |                                           |
|----|-------------------------------------------|
| 0x | UNALLOCATED                               |
| 10 | <a href="#">CDOT (indexed)</a> â€“ 32-bit |
| 11 | <a href="#">CDOT (indexed)</a> â€“ 64-bit |

### SVE2 complex integer multiply-add (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |     |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|-----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 0  | 1  | 1  | 0  | rot |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |   |

**Decode fields**  
**size**

**Instruction Details**

|    |                                           |
|----|-------------------------------------------|
| 0x | UNALLOCATED                               |
| 10 | <a href="#">CMLA (indexed)</a> â€“ 16-bit |
| 11 | <a href="#">CMLA (indexed)</a> â€“ 32-bit |

### SVE2 complex saturating multiply-add (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |     |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|-----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 0  | 1  | 1  | 1  | rot |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |   |

**Decode fields**  
**size**

**Instruction Details**

|    |                                                |
|----|------------------------------------------------|
| 0x | UNALLOCATED                                    |
| 10 | <a href="#">SQRDCMLAH (indexed)</a> â€“ 16-bit |
| 11 | <a href="#">SQRDCMLAH (indexed)</a> â€“ 32-bit |

### SVE2 integer multiply-add long (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 1  | 0  | S  | U  | il | T  |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   |   | Instruction Details                          |
|---------------|---|---|---|----------------------------------------------|
| size          | S | U | T |                                              |
| 0x            |   |   |   | UNALLOCATED                                  |
| 10            | 0 | 0 | 0 | <a href="#">SMLALB (indexed)</a> â€“ 32-bit  |
| 10            | 0 | 0 | 1 | <a href="#">SMLALT (indexed)</a> â€“ 32-bit  |
| 10            | 0 | 1 | 0 | <a href="#">UMLALB (indexed)</a> â€“ 32-bit  |
| 10            | 0 | 1 | 1 | <a href="#">UMLALT (indexed)</a> â€“ 32-bit  |
| 10            | 1 | 0 | 0 | <a href="#">SMLS LB (indexed)</a> â€“ 32-bit |
| 10            | 1 | 0 | 1 | <a href="#">SMLS LT (indexed)</a> â€“ 32-bit |
| 10            | 1 | 1 | 0 | <a href="#">UMLS LB (indexed)</a> â€“ 32-bit |
| 10            | 1 | 1 | 1 | <a href="#">UMLS LT (indexed)</a> â€“ 32-bit |
| 11            | 0 | 0 | 0 | <a href="#">SMLALB (indexed)</a> â€“ 64-bit  |
| 11            | 0 | 0 | 1 | <a href="#">SMLALT (indexed)</a> â€“ 64-bit  |
| 11            | 0 | 1 | 0 | <a href="#">UMLALB (indexed)</a> â€“ 64-bit  |
| 11            | 0 | 1 | 1 | <a href="#">UMLALT (indexed)</a> â€“ 64-bit  |
| 11            | 1 | 0 | 0 | <a href="#">SMLS LB (indexed)</a> â€“ 64-bit |
| 11            | 1 | 0 | 1 | <a href="#">SMLS LT (indexed)</a> â€“ 64-bit |
| 11            | 1 | 1 | 0 | <a href="#">UMLS LB (indexed)</a> â€“ 64-bit |
| 11            | 1 | 1 | 1 | <a href="#">UMLS LT (indexed)</a> â€“ 64-bit |

### SVE2 integer multiply long (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 1  | 1  | 0  | U  | il | T  |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   |  | Instruction Details                         |
|---------------|---|---|--|---------------------------------------------|
| size          | U | T |  |                                             |
| 0x            |   |   |  | UNALLOCATED                                 |
| 10            | 0 | 0 |  | <a href="#">SMULLB (indexed)</a> â€“ 32-bit |
| 10            | 0 | 1 |  | <a href="#">SMULLT (indexed)</a> â€“ 32-bit |
| 10            | 1 | 0 |  | <a href="#">UMULLB (indexed)</a> â€“ 32-bit |
| 10            | 1 | 1 |  | <a href="#">UMULLT (indexed)</a> â€“ 32-bit |
| 11            | 0 | 0 |  | <a href="#">SMULLB (indexed)</a> â€“ 64-bit |
| 11            | 0 | 1 |  | <a href="#">SMULLT (indexed)</a> â€“ 64-bit |
| 11            | 1 | 0 |  | <a href="#">UMULLB (indexed)</a> â€“ 64-bit |
| 11            | 1 | 1 |  | <a href="#">UMULLT (indexed)</a> â€“ 64-bit |

## SVE2 saturating multiply (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 1  | 1  | 1  | 0  | il | T  |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                           |
|---------------|---|-----------------------------------------------|
| size          | T |                                               |
| 0x            |   | UNALLOCATED                                   |
| 10            | 0 | <a href="#">SQDMULLB (indexed)</a> â€“ 32-bit |
| 10            | 1 | <a href="#">SQDMULLT (indexed)</a> â€“ 32-bit |
| 11            | 0 | <a href="#">SQDMULLB (indexed)</a> â€“ 64-bit |
| 11            | 1 | <a href="#">SQDMULLT (indexed)</a> â€“ 64-bit |

## SVE2 saturating multiply high (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 1  | 1  | 1  | 0  | R  |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details                           |
|---------------|---|-----------------------------------------------|
| size          | R |                                               |
| 0x            | 0 | <a href="#">SQDMULH (indexed)</a> â€“ 16-bit  |
| 0x            | 1 | <a href="#">SORDMULH (indexed)</a> â€“ 16-bit |
| 10            | 0 | <a href="#">SQDMULH (indexed)</a> â€“ 32-bit  |
| 10            | 1 | <a href="#">SORDMULH (indexed)</a> â€“ 32-bit |
| 11            | 0 | <a href="#">SQDMULH (indexed)</a> â€“ 64-bit  |
| 11            | 1 | <a href="#">SORDMULH (indexed)</a> â€“ 64-bit |

## SVE2 integer multiply (indexed)

These instructions are under [SVE Multiply - Indexed](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | size | 1  |    | opc |    | 1  | 1  | 1  | 1  | 0  |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                      |
|---------------|--|------------------------------------------|
| size          |  |                                          |
| 0x            |  | <a href="#">MUL (indexed)</a> â€“ 16-bit |
| 10            |  | <a href="#">MUL (indexed)</a> â€“ 32-bit |
| 11            |  | <a href="#">MUL (indexed)</a> â€“ 64-bit |

## SVE two-way dot product

These instructions are under [SVE encodings](#).

|                                                                                       |
|---------------------------------------------------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| 0 1 0 0 0 1 0 0 0 0 0   Zm   1 1 0 0 1   U   Zn   Zda                                 |

| Decode fields<br>U | Instruction Details                   | Feature     |
|--------------------|---------------------------------------|-------------|
| 0                  | <a href="#">SDOT (2-way, vectors)</a> | FEAT_SVE2p1 |
| 1                  | <a href="#">UDOT (2-way, vectors)</a> | FEAT_SVE2p1 |

## SVE two-way dot product (indexed)

These instructions are under [SVE encodings](#).

|                                                                                       |
|---------------------------------------------------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| 0 1 0 0 0 1 0 0 1 0 0   opc   1 1 0 0 1   U   Zn   Zda                                |

| Decode fields<br>U | Instruction Details                   | Feature     |
|--------------------|---------------------------------------|-------------|
| 0                  | <a href="#">SDOT (2-way, indexed)</a> | FEAT_SVE2p1 |
| 1                  | <a href="#">UDOT (2-way, indexed)</a> | FEAT_SVE2p1 |

## SVE2 Widening Integer Arithmetic

These instructions are under [SVE encodings](#).

|                                                                                       |
|---------------------------------------------------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| 01000101   0   0   op0                                                                |

| Decode fields<br>op0 | Instruction details                            |
|----------------------|------------------------------------------------|
| 0x                   | <a href="#">SVE2 integer add/subtract long</a> |
| 10                   | <a href="#">SVE2 integer add/subtract wide</a> |
| 11                   | <a href="#">SVE2 integer multiply long</a>     |

## SVE2 integer add/subtract long

These instructions are under [SVE2 Widening Integer Arithmetic](#).

|                                                                                       |
|---------------------------------------------------------------------------------------|
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |
| 0 1 0 0 0 1 0 1   size   0   Zm   0 0   op   S   U   T   Zn   Zd                      |

| Decode fields |   |   |   | Instruction Details    |
|---------------|---|---|---|------------------------|
| op            | S | U | T |                        |
| 0             | 0 | 0 | 0 | <a href="#">SADDLB</a> |
| 0             | 0 | 0 | 1 | <a href="#">SADDLT</a> |
| 0             | 0 | 1 | 0 | <a href="#">UADDLB</a> |
| 0             | 0 | 1 | 1 | <a href="#">UADDLT</a> |
| 0             | 1 | 0 | 0 | <a href="#">SSUBLB</a> |
| 0             | 1 | 0 | 1 | <a href="#">SSUBLT</a> |
| 0             | 1 | 1 | 0 | <a href="#">USUBLB</a> |
| 0             | 1 | 1 | 1 | <a href="#">USUBLT</a> |
| 1             | 0 |   |   | UNALLOCATED            |
| 1             | 1 | 0 | 0 | <a href="#">SABDLB</a> |
| 1             | 1 | 0 | 1 | <a href="#">SABDLT</a> |
| 1             | 1 | 1 | 0 | <a href="#">UABDLB</a> |
| 1             | 1 | 1 | 1 | <a href="#">UABDLT</a> |

## SVE2 integer add/subtract wide

These instructions are under [SVE2 Widening Integer Arithmetic](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |    |   |   |   |   |   |   |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | Zm | 0 | 1 | 0 | S | U | T | Zn | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|----|----|

| Decode fields |   |   | Instruction Details |
|---------------|---|---|---------------------|
| S             | U | T |                     |
| 0             | 0 | 0 | <u>SADDWB</u>       |
| 0             | 0 | 1 | <u>SADDWT</u>       |
| 0             | 1 | 0 | <u>UADDWB</u>       |
| 0             | 1 | 1 | <u>UADDWT</u>       |
| 1             | 0 | 0 | <u>SSUBWB</u>       |
| 1             | 0 | 1 | <u>SSUBWT</u>       |
| 1             | 1 | 0 | <u>USUBWB</u>       |
| 1             | 1 | 1 | <u>USUBWT</u>       |

## SVE2 integer multiply long

These instructions are under [SVE2 Widening Integer Arithmetic](#).

| Decode fields |    |   |   | Instruction Details                                  | Feature           |
|---------------|----|---|---|------------------------------------------------------|-------------------|
| size          | op | U | T |                                                      |                   |
|               | 0  | 0 | 0 | <a href="#">SQDMULLB (vectors)</a>                   | -                 |
|               | 0  | 0 | 1 | <a href="#">SQDMULLT (vectors)</a>                   | -                 |
|               | 1  | 0 | 0 | <a href="#">SMULLB (vectors)</a>                     | -                 |
|               | 1  | 0 | 1 | <a href="#">SMULLT (vectors)</a>                     | -                 |
|               | 1  | 1 | 0 | <a href="#">UMULLB (vectors)</a>                     | -                 |
|               | 1  | 1 | 1 | <a href="#">UMULLT (vectors)</a>                     | -                 |
| != 00         | 0  | 1 | 0 | <a href="#">PMULLB â€“ 16-bit or 64-bit elements</a> | -                 |
| != 00         | 0  | 1 | 1 | <a href="#">PMULLT â€“ 16-bit or 64-bit elements</a> | -                 |
| 00            | 0  | 1 | 0 | <a href="#">PMULLB â€“ 128-bit element</a>           | FEAT_SVE_PMULL128 |
| 00            | 0  | 1 | 1 | <a href="#">PMULLT â€“ 128-bit element</a>           | FEAT_SVE_PMULL128 |

SVE Misc

These instructions are under [SVE encodings](#).

|          |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
|----------|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--|
| 31       | 30 | 29 | 28 | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  |  |
|          |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |
| 01000101 |    |    |    | opo |    |    |    | 0  |    |    |    |    |    |    |    | 10 |    |    |    | op1 |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |  |

| Decode fields |      | Instruction details                                        |
|---------------|------|------------------------------------------------------------|
| op0           | op1  |                                                            |
| 0             | 10xx | <a href="#">SVE2 bitwise shift left long</a>               |
| 1             | 10xx | UNALLOCATED                                                |
|               | 00xx | <a href="#">SVE2 integer add/subtract interleaved long</a> |
|               | 010x | <a href="#">SVE2 bitwise exclusive-or interleaved</a>      |
|               | 0110 | <a href="#">SVE integer matrix multiply accumulate</a>     |
|               | 0111 | UNALLOCATED                                                |
|               | 11xx | <a href="#">SVE2 bitwise permute</a>                       |

## SVE2 bitwise shift left long

These instructions are under [SVE Misc.](#)

| Decode fields |   | Instruction Details |
|---------------|---|---------------------|
| U             | T |                     |
| 0             | 0 | <u>SSHLLB</u>       |
| 0             | 1 | <u>SSHLLT</u>       |
| 1             | 0 | <u>USHLLB</u>       |
| 1             | 1 | <u>USHLLT</u>       |

## SVE2 integer add/subtract interleaved long

These instructions are under [SVE Misc.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |    |   |   |   |   |   |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | Zm | 1 | 0 | 0 | 0 | S | tb | Zn | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|----|----|----|

| Decode fields |    | Instruction Details     |
|---------------|----|-------------------------|
| S             | tb |                         |
| 0             | 0  | <a href="#">SADDLBT</a> |
| 0             | 1  | UNALLOCATED             |
| 1             | 0  | <a href="#">SSUBLBT</a> |
| 1             | 1  | <a href="#">SSUBLTB</a> |

## SVE2 bitwise exclusive-or interleaved

These instructions are under [SVE Misc.](#)

| <b>Decode fields</b> | <b>tb</b> | <b>Instruction Details</b> |
|----------------------|-----------|----------------------------|
|                      | 0         | <a href="#">EORBT</a>      |
|                      | 1         | <a href="#">EORTB</a>      |

## SVE integer matrix multiply accumulate

These instructions are under [SVE Misc.](#)

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |     |   |    |   |   |   |   |   |   |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|-----|---|----|---|---|---|---|---|---|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | uns | 0 | Zm | 1 | 0 | 0 | 1 | 1 | 0 | Zn | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|-----|---|----|---|---|---|---|---|---|----|----|

| <b>Decode fields</b><br>uns | <b>Instruction Details</b> | <b>Feature</b> |
|-----------------------------|----------------------------|----------------|
| 00                          | <a href="#">SMMLA</a>      | FEAT_I8MM      |
| 01                          | UNALLOCATED                | -              |
| 10                          | <a href="#">USMMLA</a>     | FEAT_I8MM      |
| 11                          | <a href="#">UMMLA</a>      | FEAT_I8MM      |

## SVE2 bitwise permute

These instructions are under [SVE Misc.](#)

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | size | 0  | Zm | 1  | 0  | 1  | 1  | opc | Zn |    | Zd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b><br>opc | <b>Instruction Details</b> | <b>Feature</b>   |
|-----------------------------|----------------------------|------------------|
| 00                          | <a href="#">BEXT</a>       | FEAT_SVE_BitPerm |
| 01                          | <a href="#">BDEP</a>       | FEAT_SVE_BitPerm |
| 10                          | <a href="#">BGRP</a>       | FEAT_SVE_BitPerm |
| 11                          | UNALLOCATED                | -                |

## SVE2 Accumulate

These instructions are under [SVE encodings.](#)

|          |    |    |     |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|-----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28  | 27 | 26 | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01000101 |    | 0  | op0 |    | 11 | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode<br/>fields</b> |            | <b>Instruction details</b>                                           |
|--------------------------|------------|----------------------------------------------------------------------|
| <b>op0</b>               | <b>op1</b> |                                                                      |
| 0000                     | 011        | <a href="#">SVE2 complex integer add</a>                             |
| != 0000                  | 011        | UNALLOCATED                                                          |
|                          | 00x        | <a href="#">SVE2 integer absolute difference and accumulate long</a> |
|                          | 010        | <a href="#">SVE2 integer add/subtract long with carry</a>            |
|                          | 10x        | <a href="#">SVE2 bitwise shift right and accumulate</a>              |
|                          | 110        | <a href="#">SVE2 bitwise shift and insert</a>                        |
|                          | 111        | <a href="#">SVE2 integer absolute difference and accumulate</a>      |

## SVE2 complex integer add

These instructions are under [SVE2 Accumulate](#).

| <b>Decode fields</b> | <b>Instruction Details</b>    |
|----------------------|-------------------------------|
| <b>op</b>            |                               |
| 0                    | <a href="#"><u>CADD</u></a>   |
| 1                    | <a href="#"><u>SQCADD</u></a> |

## SVE2 integer absolute difference and accumulate long

These instructions are under [SVE2 Accumulate](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |    |   |   |   |   |   |   |    |     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|----|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | Zm | 1 | 1 | 0 | 0 | U | T | Zn | Zda |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|----|-----|

| Decode fields |   | Instruction Details |
|---------------|---|---------------------|
| U             | T |                     |
| 0             | 0 | <u>SABALB</u>       |
| 0             | 1 | <u>SABALT</u>       |
| 1             | 0 | <u>UABALB</u>       |
| 1             | 1 | <u>UABALT</u>       |

## SVE2 integer add/subtract long with carry

These instructions are under [SVE2 Accumulate](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |    |   |   |   |   |   |   |    |     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|----|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | Zm | 1 | 1 | 0 | 1 | 0 | T | Zn | Zda |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|----|-----|

| Decode fields |   | Instruction Details |
|---------------|---|---------------------|
| size          | T |                     |
| 0x            | 0 | <u>ADCLB</u>        |
| 0x            | 1 | <u>ADCLT</u>        |
| 1x            | 0 | <u>SBCLB</u>        |
| 1x            | 1 | <u>SBCLT</u>        |

## SVE2 bitwise shift right and accumulate

These instructions are under SVE2 Accumulate.

### Decode fields      Instruction Details

| R | U |                       |
|---|---|-----------------------|
| 0 | 0 | <a href="#">SSRA</a>  |
| 0 | 1 | <a href="#">USRA</a>  |
| 1 | 0 | <a href="#">SRSRA</a> |
| 1 | 1 | <a href="#">URSRA</a> |

### SVE2 bitwise shift and insert

These instructions are under [SVE2 Accumulate](#).

|    |    |    |    |    |    |    |    |      |    |      |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|------|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21   | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | tszh | 0  | tszl | imm3 | 1  | 1  | 1  | 1  | 0  | op |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |   |

### Decode fields      Instruction Details

| op |                     |
|----|---------------------|
| 0  | <a href="#">SRI</a> |
| 1  | <a href="#">SLI</a> |

### SVE2 integer absolute difference and accumulate

These instructions are under [SVE2 Accumulate](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | size | 0  |    | Zm | 1  | 1  | 1  | 1  | 1  | U  |    | Zn |    | Zda |   |   |   |   |   |   |   |   |   |   |

### Decode fields      Instruction Details

| U |                      |
|---|----------------------|
| 0 | <a href="#">SABA</a> |
| 1 | <a href="#">UABA</a> |

### SVE2 Narrowing

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |     |    |    |     |     |    |     |    |     |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|-----|-----|----|-----|----|-----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20  | 19  | 18 | 17  | 16 | 15  | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | op0 | 1  |    | op1 | op2 | 0  | op3 |    | op4 |    | op5 |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode fields

| op0 | op1 | op2 | op3 | op4 | op5 | Instruction details                            |
|-----|-----|-----|-----|-----|-----|------------------------------------------------|
| 0   | 00  | 0   | 10  |     |     | <a href="#">SVE2 saturating extract narrow</a> |

|   |       |   |    |   |   |                                                             |
|---|-------|---|----|---|---|-------------------------------------------------------------|
| 0 | 00    | 1 | 10 | 0 | 0 | <a href="#">SME2 multi-vec extract narrow</a>               |
| 0 | 00    | 1 | 10 | 0 | 1 | UNALLOCATED                                                 |
| 0 | 00    | 1 | 10 | 1 |   | UNALLOCATED                                                 |
| 0 | != 00 |   | 10 |   |   | UNALLOCATED                                                 |
| 0 |       |   | 0x |   |   | <a href="#">SVE2 bitwise shift right narrow</a>             |
| 1 |       |   | 0x | 0 | 0 | <a href="#">SME2 multi-vec shift narrow</a>                 |
| 1 |       |   | 0x | 0 | 1 | UNALLOCATED                                                 |
| 1 |       |   | 0x | 1 |   | UNALLOCATED                                                 |
| 1 |       |   | 10 |   |   | UNALLOCATED                                                 |
|   |       |   | 11 |   |   | <a href="#">SVE2 integer add/ subtract narrow high part</a> |

### SVE2 saturating extract narrow

These instructions are under [SVE2 Narrowing](#).

|    |    |    |    |    |    |    |    |    |      |    |      |    |    |    |    |    |    |     |    |    |    |   |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|------|----|------|----|----|----|----|----|----|-----|----|----|----|---|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | tszh | 1  | tszl | 0  | 0  | 0  | 0  | 1  | 0  | opc | T  |    | Zn |   | Zd |   |   |   |   |   |   |   |   |

| Decode fields |   | Instruction Details     |  |
|---------------|---|-------------------------|--|
| opc           | T |                         |  |
| 00            | 0 | <a href="#">SQXTNB</a>  |  |
| 00            | 1 | <a href="#">SQXTNT</a>  |  |
| 01            | 0 | <a href="#">UQXTNB</a>  |  |
| 01            | 1 | <a href="#">UQXTNT</a>  |  |
| 10            | 0 | <a href="#">SQXTUNB</a> |  |
| 10            | 1 | <a href="#">SQXTUNT</a> |  |
| 11            |   | UNALLOCATED             |  |

### SME2 multi-vec extract narrow

These instructions are under [SVE2 Narrowing](#).

|    |    |    |    |    |    |    |    |    |      |    |      |    |    |    |    |    |    |     |    |    |    |   |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|------|----|------|----|----|----|----|----|----|-----|----|----|----|---|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | tszh | 1  | tszl | 0  | 0  | 1  | 0  | 1  | 0  | opc | 0  |    | Zn | 0 | Zd |   |   |   |   |   |   |   |   |

| Decode fields |      |     | Instruction Details    |  | Feature     |
|---------------|------|-----|------------------------|--|-------------|
| tszh          | tszl | opc |                        |  |             |
| 0             | 0x   |     | UNALLOCATED            |  | -           |
| 0             | 10   | 00  | <a href="#">SQCVTN</a> |  | FEAT_SVE2p1 |

| Decode fields |      |     | Instruction Details     | Feature     |
|---------------|------|-----|-------------------------|-------------|
| tszh          | tszl | opc |                         |             |
| 0             | 10   | 01  | <a href="#">UQCVTN</a>  | FEAT_SVE2p1 |
| 0             | 10   | 10  | <a href="#">SQCVTUN</a> | FEAT_SVE2p1 |
| 0             | 10   | 11  | UNALLOCATED             | -           |
| 0             | 11   |     | UNALLOCATED             | -           |
| 1             |      |     | UNALLOCATED             | -           |

## SVE2 bitwise shift right narrow

These instructions are under [SVE2 Narrowing](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |      |   |      |      |   |   |    |   |   |   |  |    |  |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------|---|------|------|---|---|----|---|---|---|--|----|--|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | tszh | 1 | tszl | imm3 | 0 | 0 | op | U | R | T |  | Zn |  | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------|---|------|------|---|---|----|---|---|---|--|----|--|----|

| Decode fields |   |   |   | Instruction Details       |
|---------------|---|---|---|---------------------------|
| op            | U | R | T |                           |
| 0             | 0 | 0 | 0 | <a href="#">SQSHRUNB</a>  |
| 0             | 0 | 0 | 1 | <a href="#">SQSHRUNT</a>  |
| 0             | 0 | 1 | 0 | <a href="#">SQRSHRUNB</a> |
| 0             | 0 | 1 | 1 | <a href="#">SQRSHRUNT</a> |
| 0             | 1 | 0 | 0 | <a href="#">SHRNB</a>     |
| 0             | 1 | 0 | 1 | <a href="#">SHRNT</a>     |
| 0             | 1 | 1 | 0 | <a href="#">RSHRNB</a>    |
| 0             | 1 | 1 | 1 | <a href="#">RSHRNT</a>    |
| 1             | 0 | 0 | 0 | <a href="#">SQSHRNB</a>   |
| 1             | 0 | 0 | 1 | <a href="#">SQSHRNT</a>   |
| 1             | 0 | 1 | 0 | <a href="#">SQRSHRNB</a>  |
| 1             | 0 | 1 | 1 | <a href="#">SQRSHRNT</a>  |
| 1             | 1 | 0 | 0 | <a href="#">UQSHRNB</a>   |
| 1             | 1 | 0 | 1 | <a href="#">UQSHRNT</a>   |
| 1             | 1 | 1 | 0 | <a href="#">UQRSHRNB</a>  |
| 1             | 1 | 1 | 1 | <a href="#">UQRSHRNT</a>  |

## SME2 multi-vec shift narrow

These instructions are under [SVE2 Narrowing](#).

| Decode fields |      |    |   |   | Instruction Details      | Feature     |
|---------------|------|----|---|---|--------------------------|-------------|
| tszh          | tszl | op | U | R |                          |             |
| 0             | 0    |    |   |   | UNALLOCATED              | -           |
| 0             | 1    | 0  | 0 | 0 | UNALLOCATED              | -           |
| 0             | 1    | 0  | 0 | 1 | <a href="#">SQRSHRUN</a> | FEAT_SVE2p1 |
| 0             | 1    | 0  | 1 |   | UNALLOCATED              | -           |
| 0             | 1    | 1  |   | 0 | UNALLOCATED              | -           |
| 0             | 1    | 1  | 0 | 1 | <a href="#">SQRSHRN</a>  | FEAT_SVE2p1 |
| 0             | 1    | 1  | 1 | 1 | <a href="#">UQRSHRN</a>  | FEAT_SVE2p1 |
| 1             |      |    |   |   | UNALLOCATED              | -           |

### SVE2 integer add/subtract narrow high part

These instructions are under [SVE2 Narrowing](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | Zm | 0  | 1  | 1  | S  | R  | T  | Zn |    | Zd |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   | Instruction Details     |
|---------------|---|---|-------------------------|
| S             | R | T |                         |
| 0             | 0 | 0 | <a href="#">ADDHNB</a>  |
| 0             | 0 | 1 | <a href="#">ADDHNT</a>  |
| 0             | 1 | 0 | <a href="#">RADDHNB</a> |
| 0             | 1 | 1 | <a href="#">RADDHNT</a> |
| 1             | 0 | 0 | <a href="#">SUBHNB</a>  |
| 1             | 0 | 1 | <a href="#">SUBHNT</a>  |
| 1             | 1 | 0 | <a href="#">RSUBHNB</a> |
| 1             | 1 | 1 | <a href="#">RSUBHNT</a> |

### SVE2 character match

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | Zm | 1  | 0  | 0  | Pg |    | Zn | op | Pd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details    |
|---------------|--|------------------------|
| op            |  |                        |
| 0             |  | <a href="#">MATCH</a>  |
| 1             |  | <a href="#">NMATCH</a> |

## SVE2 Histogram Computation - Segment

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01000101 |    |    |    |    |    |    | 1  |    |    |    |    | 101 |    | op0 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>op0 | Instruction details     |
|----------------------|-------------------------|
| 000                  | <a href="#">HISTSEG</a> |
| != 000               | UNALLOCATED             |

## SVE2 Crypto Extensions

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |     |     |     |     |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|-----|-----|-----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01000101 |    |    |    |    |    |    | 1  | op0 | op1 | 111 | op2 |    |    | op3 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| op0    | Decode fields |     |          | Instruction details                                        |  |  |  |  |  |  |  |  |  |
|--------|---------------|-----|----------|------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
|        | op1           | op2 | op3      |                                                            |  |  |  |  |  |  |  |  |  |
| 000    | 00            | 00  | 00000    | <a href="#">SVE2 crypto unary operations</a>               |  |  |  |  |  |  |  |  |  |
| 000    | 00            | 00  | != 00000 | UNALLOCATED                                                |  |  |  |  |  |  |  |  |  |
| 000    | 00            | x1  |          | UNALLOCATED                                                |  |  |  |  |  |  |  |  |  |
| 000    | 01            | 0x  |          | UNALLOCATED                                                |  |  |  |  |  |  |  |  |  |
| 000    | 01            | 11  |          | UNALLOCATED                                                |  |  |  |  |  |  |  |  |  |
| 000    | 1x            | 00  |          | <a href="#">SVE2 crypto destructive binary operations</a>  |  |  |  |  |  |  |  |  |  |
| 000    | 1x            | x1  |          | UNALLOCATED                                                |  |  |  |  |  |  |  |  |  |
| != 000 |               | 0x  |          | UNALLOCATED                                                |  |  |  |  |  |  |  |  |  |
| != 000 |               | 11  |          | UNALLOCATED                                                |  |  |  |  |  |  |  |  |  |
|        |               | 10  |          | <a href="#">SVE2 crypto constructive binary operations</a> |  |  |  |  |  |  |  |  |  |

## SVE2 crypto unary operations

These instructions are under [SVE2 Crypto Extensions](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | op | 0  | 0  | 0 | 0 | Zdn |   |   |   |   |   |   |   |

| Decode fields |    | Instruction Details    |  | Feature      |
|---------------|----|------------------------|--|--------------|
| size          | op |                        |  |              |
| 00            | 0  | <a href="#">AESMC</a>  |  | FEAT_SVE_AES |
| 00            | 1  | <a href="#">AESIMC</a> |  | FEAT_SVE_AES |
| 01            |    | UNALLOCATED            |  | -            |
| 1x            |    | UNALLOCATED            |  | -            |

### SVE2 crypto destructive binary operations

These instructions are under [SVE2 Crypto Extensions](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |     |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|-----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  | 0  | 0  | 0  | 1  | op | 1  | 1  | 1  | 0  | 0  | o2 | Zm |   | Zdn |   |   |   |   |   |   |   |   |

| Decode fields |    |    | Instruction Details  |  | Feature      |
|---------------|----|----|----------------------|--|--------------|
| size          | op | o2 |                      |  |              |
| 00            | 0  | 0  | <a href="#">AESE</a> |  | FEAT_SVE_AES |
| 00            | 0  | 1  | <a href="#">AESD</a> |  | FEAT_SVE_AES |
| 00            | 1  | 0  | <a href="#">SM4E</a> |  | FEAT_SVE_SM4 |
| 00            | 1  | 1  | UNALLOCATED          |  | -            |
| 01            |    |    | UNALLOCATED          |  | -            |
| 1x            |    |    | UNALLOCATED          |  | -            |

### SVE2 crypto constructive binary operations

These instructions are under [SVE2 Crypto Extensions](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 0  | 1  | 0  | 1  | size | 1  |    | Zm |    | 1  | 1  | 1  | 1  | 0  | op |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |

| Decode fields |    | Instruction Details     |  | Feature       |
|---------------|----|-------------------------|--|---------------|
| size          | op |                         |  |               |
| 00            | 0  | <a href="#">SM4EKEY</a> |  | FEAT_SVE_SM4  |
| 00            | 1  | <a href="#">RAX1</a>    |  | FEAT_SVE_SHA3 |
| 01            |    | UNALLOCATED             |  | -             |
| 1x            |    | UNALLOCATED             |  | -             |

### SVE floating-point convert precision odd elements

These instructions are under [SVE encodings](#).

| Decode fields |      | Instruction Details                                                           | Feature   |
|---------------|------|-------------------------------------------------------------------------------|-----------|
| opc           | opc2 |                                                                               |           |
| x0            | 11   | UNALLOCATED                                                                   | -         |
| 00            | 0x   | UNALLOCATED                                                                   | -         |
| 00            | 10   | <a href="#">FCVTXNT</a>                                                       | -         |
| 01            |      | UNALLOCATED                                                                   | -         |
| 10            | 00   | <a href="#">FCVTNT</a> " <a href="#">single-precision to half-precision</a>   | -         |
| 10            | 01   | <a href="#">FCVTLT</a> " <a href="#">half-precision to single-precision</a>   | -         |
| 10            | 10   | <a href="#">BFCVTNT</a>                                                       | FEAT_BF16 |
| 11            | 0x   | UNALLOCATED                                                                   | -         |
| 11            | 10   | <a href="#">FCVTNT</a> " <a href="#">double-precision to single-precision</a> | -         |
| 11            | 11   | <a href="#">FCVTLT</a> " <a href="#">single-precision to double-precision</a> | -         |

## SVE2 floating-point pairwise operations

These instructions are under [SVE encodings](#).

| <b>Decode fields</b> | <b>Instruction Details</b>     |
|----------------------|--------------------------------|
| <b>opc</b>           |                                |
| 000                  | <a href="#"><u>FADDP</u></a>   |
| 001                  | UNALLOCATED                    |
| 01x                  | UNALLOCATED                    |
| 100                  | <a href="#"><u>FMAXNMP</u></a> |
| 101                  | <a href="#"><u>FMINNMP</u></a> |
| 110                  | <a href="#"><u>FMAXP</u></a>   |
| 111                  | <a href="#"><u>FMINP</u></a>   |

## SVE floating-point recursive reduction (quadwords)

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |   |   |     |   |   |   |    |  |    |  |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|--|----|--|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | 1 | 0 | opc | 1 | 0 | 1 | Pg |  | Zn |  | Vd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|--|----|--|----|

| <b>Decode fields<br/>opc</b> | <b>Instruction Details</b>      | <b>Feature</b> |
|------------------------------|---------------------------------|----------------|
| 000                          | <a href="#"><u>FADDQV</u></a>   | FEAT_SVE2p1    |
| 001                          | UNALLOCATED                     | -              |
| 01x                          | UNALLOCATED                     | -              |
| 100                          | <a href="#"><u>FMAXNMQV</u></a> | FEAT_SVE2p1    |
| 101                          | <a href="#"><u>FMINNMQV</u></a> | FEAT_SVE2p1    |
| 110                          | <a href="#"><u>FMAXQV</u></a>   | FEAT_SVE2p1    |
| 111                          | <a href="#"><u>FMINQV</u></a>   | FEAT_SVE2p1    |

## SVE floating-point multiply-add (indexed)

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |     |   |   |   |   |      |    |     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|-----|---|---|---|---|------|----|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 1 | opc | 0 | 0 | 0 | 0 | o2op | Zn | Zda |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|-----|---|---|---|---|------|----|-----|

| Decode fields |    |    | Instruction Details                                                 | Feature         |
|---------------|----|----|---------------------------------------------------------------------|-----------------|
| size          | o2 | op |                                                                     |                 |
| 0x            | 0  | 0  | <a href="#">FMLA (indexed)</a> â€“ <a href="#">half-precision</a>   | -               |
| 0x            | 0  | 1  | <a href="#">FMLS (indexed)</a> â€“ <a href="#">half-precision</a>   | -               |
| 0x            | 1  | 0  | <a href="#">BFMLA (indexed)</a>                                     | FEAT_SVE_B16B16 |
| 0x            | 1  | 1  | <a href="#">BFMLS (indexed)</a>                                     | FEAT_SVE_B16B16 |
| 1x            | 1  |    | UNALLOCATED                                                         | -               |
| 10            | 0  | 0  | <a href="#">FMLA (indexed)</a> â€“ <a href="#">single-precision</a> | -               |
| 10            | 0  | 1  | <a href="#">FMLS (indexed)</a> â€“ <a href="#">single-precision</a> | -               |
| 11            | 0  | 0  | <a href="#">FMLA (indexed)</a> â€“ <a href="#">double-precision</a> | -               |
| 11            | 0  | 1  | <a href="#">FMLS (indexed)</a> â€“ <a href="#">double-precision</a> | -               |

## SVE floating-point complex multiply-add (indexed)

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |     |   |   |   |   |     |    |  |     |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|-----|---|---|---|---|-----|----|--|-----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 1 | opc | 0 | 0 | 0 | 1 | rot | Zn |  | Zda |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|-----|---|---|---|---|-----|----|--|-----|

| <b>Decode fields</b> | <b>Instruction Details</b>                                           |
|----------------------|----------------------------------------------------------------------|
| size                 |                                                                      |
| 0x                   | UNALLOCATED                                                          |
| 10                   | <a href="#">FCMLA (indexed)</a> â€“ <a href="#">half-precision</a>   |
| 11                   | <a href="#">FCMLA (indexed)</a> â€“ <a href="#">single-precision</a> |

## SVE floating-point multiply (indexed)

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |     |   |   |   |   |    |   |   |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|-----|---|---|---|---|----|---|---|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 1 | opc | 0 | 0 | 1 | 0 | 02 | 0 | 0 | Zn | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|-----|---|---|---|---|----|---|---|----|----|

| Decode fields |    | Instruction Details                                                 | Feature         |
|---------------|----|---------------------------------------------------------------------|-----------------|
| size          | o2 |                                                                     |                 |
| 0x            | 0  | <a href="#">FMUL (indexed)</a> â€“ <a href="#">half-precision</a>   | -               |
| 0x            | 1  | <a href="#">BFMUL (indexed)</a>                                     | FEAT_SVE_B16B16 |
| 1x            | 1  | UNALLOCATED                                                         | -               |
| 10            | 0  | <a href="#">FMUL (indexed)</a> â€“ <a href="#">single-precision</a> | -               |
| 11            | 0  | <a href="#">FMUL (indexed)</a> â€“ <a href="#">double-precision</a> | -               |

# SVE FP clamp

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |    |   |   |   |   |   |   |   |   |   |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|---|---|---|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 1 | Zm | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | Zn | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|----|---|---|---|---|---|---|---|---|---|----|----|

| <b>Decode fields</b><br><b>size</b> | <b>Instruction Details</b> | <b>Feature</b>  |
|-------------------------------------|----------------------------|-----------------|
| != 00                               | <a href="#">FCLAMP</a>     | FEAT_SVE2p1     |
| 00                                  | <a href="#">BFCLAMP</a>    | FEAT_SVE_B16B16 |

## SVE Floating Point Widening Multiply-Add - Indexed

These instructions are under [SVE encodings](#).

|          |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01100100 |    |    |    | opb | 1  |    |    |    |    | 01 |    |    |    | op | 10 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     | Instruction details                                               |
|---------------|-----|-------------------------------------------------------------------|
| op0           | op1 |                                                                   |
| 0             | 0   | <a href="#">SVE BFLOAT16 floating-point dot product (indexed)</a> |
| 0             | 1   | UNALLOCATED                                                       |
| 1             |     | <a href="#">SVE floating-point multiply-add long (indexed)</a>    |

### SVE BFLOAT16 floating-point dot product (indexed)

These instructions are under [SVE Floating Point Widening Multiply-Add - Indexed](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | op | 1  | i2 | Zm | 0  | 1  | 0  | 0  | opc2 | Zn |    | Zda |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |      | Instruction Details             | Feature     |
|---------------|------|---------------------------------|-------------|
| op            | opc2 |                                 |             |
|               | 01   | UNALLOCATED                     | -           |
|               | 1x   | UNALLOCATED                     | -           |
| 0             | 00   | <a href="#">FDOT (indexed)</a>  | FEAT_SVE2p1 |
| 1             | 00   | <a href="#">BFDOT (indexed)</a> | FEAT_BF16   |

### SVE floating-point multiply-add long (indexed)

These instructions are under [SVE Floating Point Widening Multiply-Add - Indexed](#).

|    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |     |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|-----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | 1  | o2 | 1  | i3h | Zm | 0  | 1  | op | 0  | i3l | T  | Zn |    | Zda |   |   |   |   |   |   |   |   |   |   |

| Decode fields |    |   | Instruction Details               | Feature     |
|---------------|----|---|-----------------------------------|-------------|
| o2            | op | T |                                   |             |
| 0             | 0  | 0 | <a href="#">FMLALB (indexed)</a>  | -           |
| 0             | 0  | 1 | <a href="#">FMLALT (indexed)</a>  | -           |
| 0             | 1  | 0 | <a href="#">FMLSLB (indexed)</a>  | -           |
| 0             | 1  | 1 | <a href="#">FMLSLT (indexed)</a>  | -           |
| 1             | 0  | 0 | <a href="#">BFMLALB (indexed)</a> | FEAT_BF16   |
| 1             | 0  | 1 | <a href="#">BFMLALT (indexed)</a> | FEAT_BF16   |
| 1             | 1  | 0 | <a href="#">BFMLSLB (indexed)</a> | FEAT_SVE2p1 |
| 1             | 1  | 1 | <a href="#">BFMLSLT (indexed)</a> | FEAT_SVE2p1 |

## SVE Floating Point Widening Multiply-Add

These instructions are under [SVE encodings](#).

|          |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31       | 30 | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14    | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 01100100 |    | op0 | 1  |    |    |    |    |    |    |    |    |    |    |    |    | 10 | op100 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Decode fields |     | Instruction details                                  |  |  |
|---------------|-----|------------------------------------------------------|--|--|
| op0           | op1 | <a href="#">SVE BF16 floating-point dot product</a>  |  |  |
| 0             | 0   | UNALLOCATED                                          |  |  |
| 1             |     | <a href="#">SVE floating-point multiply-add long</a> |  |  |

### SVE BF16 floating-point dot product

These instructions are under [SVE Floating Point Widening Multiply-Add](#).

|    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | op1 | Zm | 1  | 0  | 0  | 0  | 0  | o2 | Zn | Zda |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |    | Instruction Details             |  | Feature     |
|---------------|----|---------------------------------|--|-------------|
| op            | o2 |                                 |  |             |
|               | 1  | UNALLOCATED                     |  | -           |
| 0             | 0  | <a href="#">FDOT (vectors)</a>  |  | FEAT_SVE2p1 |
| 1             | 0  | <a href="#">BFDOT (vectors)</a> |  | FEAT_BF16   |

### SVE floating-point multiply-add long

These instructions are under [SVE Floating Point Widening Multiply-Add](#).

|    |    |    |    |    |    |    |    |    |     |    |    |    |     |    |    |    |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20 | 19 | 18  | 17 | 16 | 15 | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | 1  | o21 | Zm | 1  | 0  | op0 | 0  | 0  | T  | Zn | Zda |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |    |   | Instruction Details               |  | Feature     |
|---------------|----|---|-----------------------------------|--|-------------|
| o2            | op | T |                                   |  |             |
| 0             | 0  | 0 | <a href="#">FMLALB (vectors)</a>  |  | -           |
| 0             | 0  | 1 | <a href="#">FMLALT (vectors)</a>  |  | -           |
| 0             | 1  | 0 | <a href="#">FMLSLB (vectors)</a>  |  | -           |
| 0             | 1  | 1 | <a href="#">FMLSLT (vectors)</a>  |  | -           |
| 1             | 0  | 0 | <a href="#">BFMLALB (vectors)</a> |  | FEAT_BF16   |
| 1             | 0  | 1 | <a href="#">BFMLALT (vectors)</a> |  | FEAT_BF16   |
| 1             | 1  | 0 | <a href="#">BFMLSLB (vectors)</a> |  | FEAT_SVE2p1 |
| 1             | 1  | 1 | <a href="#">BFMLSLT (vectors)</a> |  | FEAT_SVE2p1 |

## SVE floating point matrix multiply accumulate

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | opc | 1  | Zm |    | 1  | 1  | 1  | 0  | 0  | 1  | Zn |    | Zda |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>opc | Instruction Details                      | Feature    |
|----------------------|------------------------------------------|------------|
| 00                   | UNALLOCATED                              | -          |
| 01                   | <a href="#">BFMMLA</a>                   | FEAT_BF16  |
| 10                   | <a href="#">FMMLA</a> â€“ 32-bit element | FEAT_F32MM |
| 11                   | <a href="#">FMMLA</a> â€“ 64-bit element | FEAT_F64MM |

## SVE floating-point compare vectors

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 0  | Zm | op | 1  | 0  | 2  | Pg |    | Zn | o3 | Pd |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>op | o2 | o3 | Instruction Details                                               |
|---------------------|----|----|-------------------------------------------------------------------|
| 0                   | 0  | 0  | <a href="#">FCM&lt;cc&gt;</a> (vectors) â€“ <a href="#">FCMGE</a> |
| 0                   | 0  | 1  | <a href="#">FCM&lt;cc&gt;</a> (vectors) â€“ <a href="#">FCMGT</a> |
| 0                   | 1  | 0  | <a href="#">FCM&lt;cc&gt;</a> (vectors) â€“ <a href="#">FCMEO</a> |
| 0                   | 1  | 1  | <a href="#">FCM&lt;cc&gt;</a> (vectors) â€“ <a href="#">FCMNE</a> |
| 1                   | 0  | 0  | <a href="#">FCM&lt;cc&gt;</a> (vectors) â€“ <a href="#">FCMUO</a> |
| 1                   | 0  | 1  | <a href="#">FAC&lt;cc&gt;</a> â€“ <a href="#">FACGE</a>           |
| 1                   | 1  | 0  | UNALLOCATED                                                       |
| 1                   | 1  | 1  | <a href="#">FAC&lt;cc&gt;</a> â€“ <a href="#">FACGT</a>           |

## SVE floating-point arithmetic (unpredicated)

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 0  | Zm | 0  | 0  | 0  | opc |    | Zn |    | Zd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>size | opc | Instruction Details    | Feature |
|-----------------------|-----|------------------------|---------|
|                       | 011 | <a href="#">FTSMUL</a> | -       |

| Decode fields |     | Instruction Details                           |  | Feature         |
|---------------|-----|-----------------------------------------------|--|-----------------|
| size          | opc |                                               |  |                 |
|               | 10x | UNALLOCATED                                   |  | -               |
|               | 110 | <a href="#">FRECPS</a>                        |  | -               |
|               | 111 | <a href="#">FRSQRTS</a>                       |  | -               |
| != 00         | 000 | <a href="#">FADD (vectors, unpredicated)</a>  |  | -               |
| != 00         | 001 | <a href="#">FSUB (vectors, unpredicated)</a>  |  | -               |
| != 00         | 010 | <a href="#">FMUL (vectors, unpredicated)</a>  |  | -               |
| 00            | 000 | <a href="#">BFADD (unpredicated)</a>          |  | FEAT_SVE_B16B16 |
| 00            | 001 | <a href="#">BFSUB (unpredicated)</a>          |  | FEAT_SVE_B16B16 |
| 00            | 010 | <a href="#">BFMUL (vectors, unpredicated)</a> |  | FEAT_SVE_B16B16 |

## SVE Floating Point Arithmetic - Predicated

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |     |     |    |     |    |     |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|-----|-----|----|-----|----|-----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25  | 24  | 23 | 22  | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01100101 |    |    |    | 0  |    | op0 | 100 |    | op1 |    | op2 |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |        |         | Instruction details                                                       |  |
|---------------|--------|---------|---------------------------------------------------------------------------|--|
| op0           | op1    | op2     |                                                                           |  |
| 0x            |        |         | <a href="#">SVE floating-point arithmetic (predicated)</a>                |  |
| 10            | 000    |         | <a href="#">FTMAD</a>                                                     |  |
| 10            | != 000 |         | UNALLOCATED                                                               |  |
| 11            |        | 0000    | <a href="#">SVE floating-point arithmetic with immediate (predicated)</a> |  |
| 11            |        | != 0000 | UNALLOCATED                                                               |  |

## SVE floating-point arithmetic (predicated)

These instructions are under [SVE Floating Point Arithmetic - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |     |    |    |    |    |    |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|----|----|----|----|----|----|----|----|------|----|----|-----|----|----|----|----|----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20  | 19 | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 0  | 0  | opc | 1  | 0  | 0  | Pg | Zm | Zdn |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Decode fields |      | Instruction Details             |  | Feature |
|---------------|------|---------------------------------|--|---------|
| size          | opc  |                                 |  |         |
|               | 0011 | <a href="#">FSUBR (vectors)</a> |  | -       |
|               | 1000 | <a href="#">FABD</a>            |  | -       |
|               | 1001 | <a href="#">FSCALE</a>          |  | -       |

| Decode fields |      | Instruction Details                         | Feature         |
|---------------|------|---------------------------------------------|-----------------|
| size          | opc  |                                             |                 |
|               | 1010 | <a href="#">FMULX</a>                       | -               |
|               | 1011 | UNALLOCATED                                 | -               |
|               | 1100 | <a href="#">FDIVR</a>                       | -               |
|               | 1101 | <a href="#">FDIV</a>                        | -               |
|               | 111x | UNALLOCATED                                 | -               |
| != 00         | 0000 | <a href="#">FADD (vectors, predicated)</a>  | -               |
| != 00         | 0001 | <a href="#">FSUB (vectors, predicated)</a>  | -               |
| != 00         | 0010 | <a href="#">FMUL (vectors, predicated)</a>  | -               |
| != 00         | 0100 | <a href="#">FMAXNM (vectors)</a>            | -               |
| != 00         | 0101 | <a href="#">FMINNM (vectors)</a>            | -               |
| != 00         | 0110 | <a href="#">FMAX (vectors)</a>              | -               |
| != 00         | 0111 | <a href="#">FMIN (vectors)</a>              | -               |
| 00            | 0000 | <a href="#">BFADD (predicated)</a>          | FEAT_SVE_B16B16 |
| 00            | 0001 | <a href="#">BFSUB (predicated)</a>          | FEAT_SVE_B16B16 |
| 00            | 0010 | <a href="#">BFMUL (vectors, predicated)</a> | FEAT_SVE_B16B16 |
| 00            | 0100 | <a href="#">BFMAXNM</a>                     | FEAT_SVE_B16B16 |
| 00            | 0101 | <a href="#">BFMINNM</a>                     | FEAT_SVE_B16B16 |
| 00            | 0110 | <a href="#">BFMAX</a>                       | FEAT_SVE_B16B16 |
| 00            | 0111 | <a href="#">BFMIN</a>                       | FEAT_SVE_B16B16 |

### SVE floating-point arithmetic with immediate (predicated)

These instructions are under [SVE Floating Point Arithmetic - Predicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 0  | 1  | 1  | opc | 1  | 0  | 0  | Pg | 0  | 0  | 0  | 0  | i1 | Zdn |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                |
|---------------|--|------------------------------------|
| opc           |  |                                    |
| 000           |  | <a href="#">FADD (immediate)</a>   |
| 001           |  | <a href="#">FSUB (immediate)</a>   |
| 010           |  | <a href="#">FMUL (immediate)</a>   |
| 011           |  | <a href="#">FSUBR (immediate)</a>  |
| 100           |  | <a href="#">FMAXNM (immediate)</a> |
| 101           |  | <a href="#">FMINNM (immediate)</a> |
| 110           |  | <a href="#">FMAX (immediate)</a>   |
| 111           |  | <a href="#">FMIN (immediate)</a>   |

## SVE Floating Point Unary Operations - Predicated

These instructions are under [SVE encodings](#).

|          |    |    |    |       |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|-------|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27    | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01100101 |    |    |    | 0 op0 |    |    |    | 101 |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction details</b>                                 |
|----------------------|------------------------------------------------------------|
| <b>op0</b>           |                                                            |
| 00x                  | <a href="#">SVE floating-point round to integral value</a> |
| 010                  | <a href="#">SVE floating-point convert precision</a>       |
| 011                  | <a href="#">SVE floating-point unary operations</a>        |
| 10x                  | <a href="#">SVE integer convert to floating-point</a>      |
| 11x                  | <a href="#">SVE floating-point convert to integer</a>      |

## SVE floating-point round to integral value

These instructions are under [SVE Floating Point Unary Operations - Predicated](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |      |   |   |   |     |   |   |   |    |  |    |  |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|--|----|--|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | size | 0 | 0 | 0 | opc | 1 | 0 | 1 | Pq |  | Zn |  | Zd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|---|---|---|-----|---|---|---|----|--|----|--|----|

| Decode fields |                                | Instruction Details               |
|---------------|--------------------------------|-----------------------------------|
| opc           |                                |                                   |
| 000           | <a href="#">FRINT&lt;r&gt;</a> | "nearest with ties to even"       |
| 001           | <a href="#">FRINT&lt;r&gt;</a> | "toward plus infinity"            |
| 010           | <a href="#">FRINT&lt;r&gt;</a> | "toward minus infinity"           |
| 011           | <a href="#">FRINT&lt;r&gt;</a> | "toward zero"                     |
| 100           | <a href="#">FRINT&lt;r&gt;</a> | "nearest with ties to away"       |
| 101           | UNALLOCATED                    |                                   |
| 110           | <a href="#">FRINT&lt;r&gt;</a> | "current mode signalling inexact" |
| 111           | <a href="#">FRINT&lt;r&gt;</a> | "current mode"                    |

## SVE floating-point convert precision

These instructions are under [SVE Floating Point Unary Operations - Predicated](#).

| Decode fields |      | Instruction Details                                                         | Feature   |
|---------------|------|-----------------------------------------------------------------------------|-----------|
| opc           | opc2 |                                                                             |           |
| x0            | 11   | UNALLOCATED                                                                 | -         |
| 00            | 0x   | UNALLOCATED                                                                 | -         |
| 00            | 10   | <a href="#">FCVTX</a>                                                       | -         |
| 01            |      | UNALLOCATED                                                                 | -         |
| 10            | 00   | <a href="#">FCVT</a> " <a href="#">single-precision to half-precision</a>   | -         |
| 10            | 01   | <a href="#">FCVT</a> " <a href="#">half-precision to single-precision</a>   | -         |
| 10            | 10   | <a href="#">BFCVT</a>                                                       | FEAT_BF16 |
| 11            | 00   | <a href="#">FCVT</a> " <a href="#">double-precision to half-precision</a>   | -         |
| 11            | 01   | <a href="#">FCVT</a> " <a href="#">half-precision to double-precision</a>   | -         |
| 11            | 10   | <a href="#">FCVT</a> " <a href="#">double-precision to single-precision</a> | -         |
| 11            | 11   | <a href="#">FCVT</a> " <a href="#">single-precision to double-precision</a> | -         |

## SVE floating-point unary operations

These instructions are under [SVE Floating Point Unary Operations - Predicated](#).

| <b>Decode fields</b> | <b>Instruction Details</b> |
|----------------------|----------------------------|
| <b>opc</b>           |                            |
| 00                   | <a href="#">FRECPX</a>     |
| 01                   | <a href="#">FSQRT</a>      |
| 1x                   | UNALLOCATED                |

## SVE integer convert to floating-point

These instructions are under [SVE Floating Point Unary Operations - Predicated](#).

| Decode fields |      |   | Instruction Details                                  |
|---------------|------|---|------------------------------------------------------|
| opc           | opc2 | U |                                                      |
| 00            |      |   | UNALLOCATED                                          |
| 01            | 00   |   | UNALLOCATED                                          |
| 01            | 01   | 0 | <a href="#">SCVTF</a> â€“ 16-bit to half-precision   |
| 01            | 01   | 1 | <a href="#">UCVTF</a> â€“ 16-bit to half-precision   |
| 01            | 10   | 0 | <a href="#">SCVTF</a> â€“ 32-bit to half-precision   |
| 01            | 10   | 1 | <a href="#">UCVTF</a> â€“ 32-bit to half-precision   |
| 01            | 11   | 0 | <a href="#">SCVTF</a> â€“ 64-bit to half-precision   |
| 01            | 11   | 1 | <a href="#">UCVTF</a> â€“ 64-bit to half-precision   |
| 10            | 0x   |   | UNALLOCATED                                          |
| 10            | 10   | 0 | <a href="#">SCVTF</a> â€“ 32-bit to single-precision |
| 10            | 10   | 1 | <a href="#">UCVTF</a> â€“ 32-bit to single-precision |
| 10            | 11   |   | UNALLOCATED                                          |
| 11            | 00   | 0 | <a href="#">SCVTF</a> â€“ 32-bit to double-precision |
| 11            | 00   | 1 | <a href="#">UCVTF</a> â€“ 32-bit to double-precision |
| 11            | 01   |   | UNALLOCATED                                          |
| 11            | 10   | 0 | <a href="#">SCVTF</a> â€“ 64-bit to single-precision |
| 11            | 10   | 1 | <a href="#">UCVTF</a> â€“ 64-bit to single-precision |
| 11            | 11   | 0 | <a href="#">SCVTF</a> â€“ 64-bit to double-precision |
| 11            | 11   | 1 | <a href="#">UCVTF</a> â€“ 64-bit to double-precision |

### SVE floating-point convert to integer

These instructions are under [SVE Floating Point Unary Operations - Predicated](#).

|    |    |    |    |    |    |    |    |     |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | opc | 0  | 1  | 1  | opc2 | U  | 1  | 0  | 1  | Pg |    | Zn |    | Zd |   |   |   |   |   |   |   |   |   |   |

| Decode fields |      |   | Instruction Details                                 |
|---------------|------|---|-----------------------------------------------------|
| opc           | opc2 | U |                                                     |
| 00            |      | 0 | <a href="#">FLOGB</a>                               |
| 00            |      | 1 | UNALLOCATED                                         |
| 01            | 00   |   | UNALLOCATED                                         |
| 01            | 01   | 0 | <a href="#">FCVTZS</a> â€“ half-precision to 16-bit |
| 01            | 01   | 1 | <a href="#">FCVTZU</a> â€“ half-precision to 16-bit |
| 01            | 10   | 0 | <a href="#">FCVTZS</a> â€“ half-precision to 32-bit |
| 01            | 10   | 1 | <a href="#">FCVTZU</a> â€“ half-precision to 32-bit |
| 01            | 11   | 0 | <a href="#">FCVTZS</a> â€“ half-precision to 64-bit |

| Decode fields |      |   | Instruction Details                                   |
|---------------|------|---|-------------------------------------------------------|
| opc           | opc2 | U |                                                       |
| 01            | 11   | 1 | <a href="#">FCVTZU</a> â€“ half-precision to 64-bit   |
| 10            | 0x   |   | UNALLOCATED                                           |
| 10            | 10   | 0 | <a href="#">FCVTZS</a> â€“ single-precision to 32-bit |
| 10            | 10   | 1 | <a href="#">FCVTZU</a> â€“ single-precision to 32-bit |
| 10            | 11   |   | UNALLOCATED                                           |
| 11            | 00   | 0 | <a href="#">FCVTZS</a> â€“ double-precision to 32-bit |
| 11            | 00   | 1 | <a href="#">FCVTZU</a> â€“ double-precision to 32-bit |
| 11            | 01   |   | UNALLOCATED                                           |
| 11            | 10   | 0 | <a href="#">FCVTZS</a> â€“ single-precision to 64-bit |
| 11            | 10   | 1 | <a href="#">FCVTZU</a> â€“ single-precision to 64-bit |
| 11            | 11   | 0 | <a href="#">FCVTZS</a> â€“ double-precision to 64-bit |
| 11            | 11   | 1 | <a href="#">FCVTZU</a> â€“ double-precision to 64-bit |

### SVE floating-point recursive reduction

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 0  | 0  | 0  | opc | 0  | 0  | 1  | Pg |    | Zn |    | Vd |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details     |
|---------------|--|-------------------------|
| opc           |  |                         |
| 000           |  | <a href="#">FADDV</a>   |
| 001           |  | UNALLOCATED             |
| 01x           |  | UNALLOCATED             |
| 100           |  | <a href="#">FMAXNMV</a> |
| 101           |  | <a href="#">FMINNMV</a> |
| 110           |  | <a href="#">FMAXV</a>   |
| 111           |  | <a href="#">FMINV</a>   |

### SVE Floating Point Unary Operations - Unpredicated

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |     |    |     |    |      |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|-----|----|-----|----|------|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21  | 20 | 19   | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | 001 |    | op0 |    | 0011 |    | op1 |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Decode fields |     | Instruction details |
|---------------|-----|---------------------|
| op0           | op1 |                     |
| 0x            |     | UNALLOCATED         |

|    |       |                                                                       |
|----|-------|-----------------------------------------------------------------------|
| 10 |       | UNALLOCATED                                                           |
| 11 | 00    | <a href="#">SVE floating-point reciprocal estimate (unpredicated)</a> |
| 11 | != 00 | UNALLOCATED                                                           |

---

### SVE floating-point reciprocal estimate (unpredicated)

These instructions are under [SVE Floating Point Unary Operations - Unpredicated](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 0  | 0  | 1  | 1  | 1  | op | 0  | 0  | 1  | 1  | 0  | 0  | Zn |   | Zd |   |   |   |   |   |   |   |   |

| Decode fields<br>op | Instruction Details     |
|---------------------|-------------------------|
| 0                   | <a href="#">FRECPE</a>  |
| 1                   | <a href="#">FRSQRTE</a> |

---

### SVE Floating Point Compare - with Zero

These instructions are under [SVE encodings](#).

|    |    |    |    |    |    |    |    |          |    |     |     |    |     |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|----------|----|-----|-----|----|-----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23       | 22 | 21  | 20  | 19 | 18  | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | 01100101 |    | 010 | op0 |    | 001 |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Decode fields<br>op0 | Instruction details                                  |
|----------------------|------------------------------------------------------|
| 0                    | <a href="#">SVE floating-point compare with zero</a> |
| 1                    | UNALLOCATED                                          |

---

### SVE floating-point compare with zero

These instructions are under [SVE Floating Point Compare - with Zero](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 0  | 1  | 0  | 0  | eq | lt | 0  | 0  | 1  | Pg |    | Zn | ne | Pd |   |   |   |   |   |   |   |   |   |

| Decode fields<br>eq | lt | ne | Instruction Details                            |
|---------------------|----|----|------------------------------------------------|
| 0                   | 0  | 0  | <a href="#">FCM&lt;cc&gt; (zero) â€” FCMGE</a> |
| 0                   | 0  | 1  | <a href="#">FCM&lt;cc&gt; (zero) â€” FCMGT</a> |
| 0                   | 1  | 0  | <a href="#">FCM&lt;cc&gt; (zero) â€” FCMLT</a> |
| 0                   | 1  | 1  | <a href="#">FCM&lt;cc&gt; (zero) â€” FCMLE</a> |
| 1                   |    | 1  | UNALLOCATED                                    |

| Decode fields |    |    | Instruction Details    |  |
|---------------|----|----|------------------------|--|
| eq            | lt | ne |                        |  |
| 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](#).

|          |    |    |    |    |    |    |    |     |     |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|-----|-----|----|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01100101 |    |    |    |    |    |    |    | 011 | op0 |    |    | 001 |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction details                                              |  |
|---------------|--|------------------------------------------------------------------|--|
| op0           |  |                                                                  |  |
| 0             |  | <a href="#">SVE floating-point serial reduction (predicated)</a> |  |
| 1             |  | UNALLOCATED                                                      |  |

---

## SVE floating-point serial reduction (predicated)

These instructions are under [SVE Floating Point Accumulating Reduction](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |     |    |    |    |    |    |    |    |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|-----|----|----|----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18  | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 0  | 1  | 1  | 0  | opc | 0  | 0  | 1  | Pg |    | Zm |    | Vdn |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details   |  |
|---------------|--|-----------------------|--|
| opc           |  |                       |  |
| 00            |  | <a href="#">FADDA</a> |  |
| 01            |  | UNALLOCATED           |  |
| 1x            |  | UNALLOCATED           |  |

---

## SVE Floating Point Multiply-Add

These instructions are under [SVE encodings](#).

|          |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 01100101 |    |    |    |    |    |    |    | 1  |    |    |    | op0 |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction details                                                         |  |
|---------------|--|-----------------------------------------------------------------------------|--|
| op0           |  |                                                                             |  |
| 0             |  | <a href="#">SVE floating-point multiply-accumulate writing addend</a>       |  |
| 1             |  | <a href="#">SVE floating-point multiply-accumulate writing multiplicand</a> |  |

---

## SVE floating-point multiply-accumulate writing addend

These instructions are under [SVE Floating Point Multiply-Add](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | Zm | 0  | opc | Pg |    | Zn |    | Zda |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     | Instruction Details             |  | Feature         |
|---------------|-----|---------------------------------|--|-----------------|
| size          | opc |                                 |  |                 |
|               | 10  | <a href="#">FNMLA</a>           |  | -               |
|               | 11  | <a href="#">FNMLS</a>           |  | -               |
| != 00         | 00  | <a href="#">FMLA (vectors)</a>  |  | -               |
| != 00         | 01  | <a href="#">FMLS (vectors)</a>  |  | -               |
| 00            | 00  | <a href="#">BFMLA (vectors)</a> |  | FEAT_SVE_B16B16 |
| 00            | 01  | <a href="#">BFMLS (vectors)</a> |  | FEAT_SVE_B16B16 |

## SVE floating-point multiply-accumulate writing multiplicand

These instructions are under [SVE Floating Point Multiply-Add](#).

|    |    |    |    |    |    |    |    |      |    |    |    |     |    |    |    |    |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|-----|----|----|----|----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  | size | 1  | Za | 1  | opc | Pg |    | Zm |    | Zdn |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details   |  |
|---------------|--|-----------------------|--|
| opc           |  |                       |  |
| 00            |  | <a href="#">FMAD</a>  |  |
| 01            |  | <a href="#">FMSB</a>  |  |
| 10            |  | <a href="#">FNMAD</a> |  |
| 11            |  | <a href="#">FNMSB</a> |  |

## SVE Memory - 32-bit Gather and Unsized Contiguous

These instructions are under [SVE encodings](#).

|         |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |   |   |     |   |   |
|---------|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|-----|---|---|
| 31      | 30  | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2   | 1 | 0 |
| 1000010 | op0 | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | op2 |   |   | op3 |   |   |

| Decode fields |     |     |     | Instruction details                                                                  |
|---------------|-----|-----|-----|--------------------------------------------------------------------------------------|
| op0           | op1 | op2 | op3 |                                                                                      |
| 00            | x1  | 0xx | 0   | <a href="#">SVE 32-bit gather prefetch (scalar plus 32-bit scaled offsets)</a>       |
| 00            | x1  | 0xx | 1   | UNALLOCATED                                                                          |
| 01            | x1  | 0xx |     | <a href="#">SVE 32-bit gather load halfwords (scalar plus 32-bit scaled offsets)</a> |

|       |    |     |   |                                                                                  |
|-------|----|-----|---|----------------------------------------------------------------------------------|
| 10    | x1 | 0xx |   | <a href="#">SVE 32-bit gather load words (scalar plus 32-bit scaled offsets)</a> |
| 11    | 0x | 000 | 0 | <a href="#">LDR (predicate)</a>                                                  |
| 11    | 0x | 000 | 1 | UNALLOCATED                                                                      |
| 11    | 0x | 010 |   | <a href="#">LDR (vector)</a>                                                     |
| 11    | 0x | 0x1 |   | UNALLOCATED                                                                      |
| 11    | 1x | 0xx | 0 | <a href="#">SVE contiguous prefetch (scalar plus immediate)</a>                  |
| 11    | 1x | 0xx | 1 | UNALLOCATED                                                                      |
| != 11 | x0 | 0xx |   | <a href="#">SVE 32-bit gather load (scalar plus 32-bit unscaled offsets)</a>     |
|       | 00 | 10x |   | <a href="#">SVE2 32-bit gather non-temporal load (vector plus scalar)</a>        |
|       | 00 | 110 | 0 | <a href="#">SVE contiguous prefetch (scalar plus scalar)</a>                     |
|       | 00 | 111 | 0 | <a href="#">SVE 32-bit gather prefetch (vector plus immediate)</a>               |
|       | 00 | 11x | 1 | UNALLOCATED                                                                      |
|       | 01 | 1xx |   | <a href="#">SVE 32-bit gather load (vector plus immediate)</a>                   |
|       | 1x | 1xx |   | <a href="#">SVE load and broadcast element</a>                                   |

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

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

| <b>Decode fields</b> | <b>Instruction Details</b>                |
|----------------------|-------------------------------------------|
| <b>msz</b>           |                                           |
| 00                   | <a href="#">PRFB (scalar plus vector)</a> |
| 01                   | <a href="#">PRFH (scalar plus vector)</a> |
| 10                   | <a href="#">PRFW (scalar plus vector)</a> |
| 11                   | <a href="#">PRFD (scalar plus vector)</a> |

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

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

| Decode fields |    | Instruction Details                          |
|---------------|----|----------------------------------------------|
| U             | ff |                                              |
| 0             | 0  | <a href="#">LD1SH (scalar plus vector)</a>   |
| 0             | 1  | <a href="#">LDFF1SH (scalar plus vector)</a> |
| 1             | 0  | <a href="#">LD1H (scalar plus vector)</a>    |
| 1             | 1  | <a href="#">LDFF1H (scalar plus vector)</a>  |

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

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | xs | 1  | Zm | 0  | U  | ff | Pg |    | Rn |    | Zt |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |    | Instruction Details                         |
|---------------|----|---------------------------------------------|
| U             | ff |                                             |
| 0             |    | UNALLOCATED                                 |
| 1             | 0  | <a href="#">LD1W (scalar plus vector)</a>   |
| 1             | 1  | <a href="#">LDFF1W (scalar plus vector)</a> |

### SVE contiguous prefetch (scalar plus immediate)

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

|    |    |    |    |    |    |    |    |    |    |      |    |     |    |    |    |    |       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|------|----|-----|----|----|----|----|-------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21   | 20 | 19  | 18 | 17 | 16 | 15 | 14    | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 1  | imm6 | 0  | msz | Pg |    | Rn | 0  | prfop |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                          |
|---------------|--|----------------------------------------------|
| msz           |  |                                              |
| 00            |  | <a href="#">PRFB (scalar plus immediate)</a> |
| 01            |  | <a href="#">PRFH (scalar plus immediate)</a> |
| 10            |  | <a href="#">PRFW (scalar plus immediate)</a> |
| 11            |  | <a href="#">PRFD (scalar plus immediate)</a> |

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

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

|    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   |
|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24       | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 1  | 0  | !=<br>11 | xs | 0  |    | Zm | 0  | U  | ff | Pg |    | Rn |    | Zt |    |    |   |   |   |   |   |   |   | opc |   |   |

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

| Decode fields |   |    | Instruction Details                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|----|----------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| opc           | U | ff |                                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 0 | 0  | <a href="#">LD1SB (scalar plus vector)</a>   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 0 | 1  | <a href="#">LDFF1SB (scalar plus vector)</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 1 | 0  | <a href="#">LD1B (scalar plus vector)</a>    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 1 | 1  | <a href="#">LDFF1B (scalar plus vector)</a>  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 0 | 0  | <a href="#">LD1SH (scalar plus vector)</a>   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 0 | 1  | <a href="#">LDFF1SH (scalar plus vector)</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 1 | 0  | <a href="#">LD1H (scalar plus vector)</a>    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 1 | 1  | <a href="#">LDFF1H (scalar plus vector)</a>  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10            | 0 |    | UNALLOCATED                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10            | 1 | 0  | <a href="#">LD1W (scalar plus vector)</a>    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10            | 1 | 1  | <a href="#">LDFF1W (scalar plus vector)</a>  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### SVE2 32-bit gather non-temporal load (vector plus scalar)

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 1  | 0  | msz | 0  | 0  |    | Rm | 1  | 0  | U  | Pg |    | Rn |    | Zn |    | Zt |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |  | Instruction Details                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------|---|--|---------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| msz           | U |  |                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 0 |  | <a href="#">LDNT1SB</a>                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 00            | 1 |  | <a href="#">LDNT1B (vector plus scalar)</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 0 |  | <a href="#">LDNT1SH</a>                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 01            | 1 |  | <a href="#">LDNT1H (vector plus scalar)</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10            | 0 |  | UNALLOCATED                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 10            | 1 |  | <a href="#">LDNT1W (vector plus scalar)</a> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 11            |   |  | UNALLOCATED                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### SVE contiguous prefetch (scalar plus scalar)

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |       |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13    | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 1  | 0  | msz | 0  | 0  | Rm | 1  | 1  | 0  | Pg |    | Rn | 0  | prfop |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction Details                       |
|---------------|-------------------------------------------|
| msz           |                                           |
| 00            | <a href="#">PRFB (scalar plus scalar)</a> |
| 01            | <a href="#">PRFH (scalar plus scalar)</a> |
| 10            | <a href="#">PRFW (scalar plus scalar)</a> |
| 11            | <a href="#">PRFD (scalar plus scalar)</a> |

### SVE 32-bit gather prefetch (vector plus immediate)

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

|    |    |    |    |    |    |    |     |    |    |      |    |    |    |    |    |    |    |       |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|------|----|----|----|----|----|----|----|-------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13    | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 1  | 0  | msz | 0  | 0  | imm5 | 1  | 1  | 1  | Pg |    | Zn | 0  | prfop |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction Details                          |
|---------------|----------------------------------------------|
| msz           |                                              |
| 00            | <a href="#">PRFB (vector plus immediate)</a> |
| 01            | <a href="#">PRFH (vector plus immediate)</a> |
| 10            | <a href="#">PRFW (vector plus immediate)</a> |
| 11            | <a href="#">PRFD (vector plus immediate)</a> |

### SVE 32-bit gather load (vector plus immediate)

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

|    |    |    |    |    |    |    |     |    |    |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 0  | 0  | 0  | 1  | 0  | msz | 0  | 1  | imm5 | 1  | U  | ff | Pg |    | Zn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction Details                             |
|---------------|-------------------------------------------------|
| msz           |                                                 |
| U             |                                                 |
| ff            |                                                 |
| 00            | <a href="#">LD1SB (vector plus immediate)</a>   |
| 00            | <a href="#">LDFF1SB (vector plus immediate)</a> |
| 00            | <a href="#">LD1B (vector plus immediate)</a>    |
| 00            | <a href="#">LDFF1B (vector plus immediate)</a>  |
| 01            | <a href="#">LD1SH (vector plus immediate)</a>   |
| 01            | <a href="#">LDFF1SH (vector plus immediate)</a> |

| Decode fields |   |    | Instruction Details                            |
|---------------|---|----|------------------------------------------------|
| msz           | U | ff |                                                |
| 01            | 1 | 0  | <a href="#">LD1H (vector plus immediate)</a>   |
| 01            | 1 | 1  | <a href="#">LDFF1H (vector plus immediate)</a> |
| 10            | 0 |    | UNALLOCATED                                    |
| 10            | 1 | 0  | <a href="#">LD1W (vector plus immediate)</a>   |
| 10            | 1 | 1  | <a href="#">LDFF1W (vector plus immediate)</a> |
| 11            |   |    | UNALLOCATED                                    |

## SVE load and broadcast element

These instructions are under [SVE Memory - 32-bit Gather and Unsized Contiguous](#).

```
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
| 1 0 0 0 0 1 0 | dtype: h   | imm6 | 1 | dtype: l | Pg |     | Rn |     | Zt |
```

| Decode fields |        | Instruction Details                       |
|---------------|--------|-------------------------------------------|
| dtypeh        | dtypel |                                           |
| 00            | 00     | <a href="#">LD1RB</a> â€“ 8-bit element   |
| 00            | 01     | <a href="#">LD1RB</a> â€“ 16-bit element  |
| 00            | 10     | <a href="#">LD1RB</a> â€“ 32-bit element  |
| 00            | 11     | <a href="#">LD1RB</a> â€“ 64-bit element  |
| 01            | 00     | <a href="#">LD1RSW</a>                    |
| 01            | 01     | <a href="#">LD1RH</a> â€“ 16-bit element  |
| 01            | 10     | <a href="#">LD1RH</a> â€“ 32-bit element  |
| 01            | 11     | <a href="#">LD1RH</a> â€“ 64-bit element  |
| 10            | 00     | <a href="#">LD1RSW</a> â€“ 64-bit element |
| 10            | 01     | <a href="#">LD1RSW</a> â€“ 32-bit element |
| 10            | 10     | <a href="#">LD1RW</a> â€“ 32-bit element  |
| 10            | 11     | <a href="#">LD1RW</a> â€“ 64-bit element  |
| 11            | 00     | <a href="#">LD1RSB</a> â€“ 64-bit element |
| 11            | 01     | <a href="#">LD1RSB</a> â€“ 32-bit element |
| 11            | 10     | <a href="#">LD1RSB</a> â€“ 16-bit element |
| 11            | 11     | <a href="#">LD1RD</a>                     |

## SVE Memory - Contiguous Load

These instructions are under [SVE encodings](#).

| Decode fields |     |     | Instruction details                                                             |
|---------------|-----|-----|---------------------------------------------------------------------------------|
| op0           | op1 | op2 |                                                                                 |
| 00            | 0   | 111 | <a href="#">SVE contiguous non-temporal load (scalar plus immediate)</a>        |
| 00            | 1   | 001 | <a href="#">SVE contiguous load (quadwords, scalar plus immediate)</a>          |
| 00            | 1   | 111 | <a href="#">SVE load multiple structures (quadwords, scalar plus immediate)</a> |
| 00            |     | 100 | <a href="#">SVE contiguous load (quadwords, scalar plus scalar)</a>             |
| 00            |     | 110 | <a href="#">SVE contiguous non-temporal load (scalar plus scalar)</a>           |
| 01            |     | 100 | <a href="#">SVE load multiple structures (quadwords, scalar plus scalar)</a>    |
| 1x            |     | 100 | UNALLOCATED                                                                     |
| != 00         | 0   | 111 | <a href="#">SVE load multiple structures (scalar plus immediate)</a>            |
| != 00         | 1   | 001 | UNALLOCATED                                                                     |
| != 00         | 1   | 111 | UNALLOCATED                                                                     |
| != 00         |     | 110 | <a href="#">SVE load multiple structures (scalar plus scalar)</a>               |
|               | 0   | 001 | <a href="#">SVE load and broadcast quadword (scalar plus immediate)</a>         |
|               | 0   | 101 | <a href="#">SVE contiguous load (scalar plus immediate)</a>                     |
|               | 1   | 101 | <a href="#">SVE contiguous non-fault load (scalar plus immediate)</a>           |
|               |     | 000 | <a href="#">SVE load and broadcast quadword (scalar plus scalar)</a>            |
|               |     | 010 | <a href="#">SVE contiguous load (scalar plus scalar)</a>                        |
|               |     | 011 | <a href="#">SVE contiguous first-fault load (scalar plus scalar)</a>            |

### SVE contiguous non-temporal load (scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |     |    |    |    |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  | msz | 0  | 0  | 0  | imm4 | 1  | 1  | 1  | Pg |    | Rn |    | Zt |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                                             |
|---------------|--|-----------------------------------------------------------------|
| msz           |  |                                                                 |
| 00            |  | <a href="#">LDNT1B (scalar plus immediate, single register)</a> |
| 01            |  | <a href="#">LDNT1H (scalar plus immediate, single register)</a> |
| 10            |  | <a href="#">LDNT1W (scalar plus immediate, single register)</a> |

| Decode fields<br>msz | Instruction Details                                             |
|----------------------|-----------------------------------------------------------------|
| 11                   | <a href="#">LDNT1D (scalar plus immediate, single register)</a> |

## SVE contiguous load (quadwords, scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |        |    |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|--------|----|----|----|----|------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23 | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  | dtype= |    | 0  | 0  | 1  | imm4 |    | 0  | 0  | 1  | Pg |    | Rn |    | Zt |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b>                                    | <b>Feature</b> |
|----------------------|---------------------------------------------------------------|----------------|
| <b>dtype</b>         |                                                               |                |
| 0x                   | UNALLOCATED                                                   | -              |
| 10                   | <a href="#">LD1W (scalar plus immediate, single register)</a> | FEAT_SVE2p1    |
| 11                   | <a href="#">LD1D (scalar plus immediate, single register)</a> | FEAT_SVE2p1    |

## SVE load multiple structures (quadwords, scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Load](#).

| <b>Decode fields</b> | <b>Instruction Details</b>                   | <b>Feature</b> |
|----------------------|----------------------------------------------|----------------|
| <b>num</b>           |                                              |                |
| 00                   | UNALLOCATED                                  | -              |
| 01                   | <a href="#">LD2Q (scalar plus immediate)</a> | FEAT_SVE2p1    |
| 10                   | <a href="#">LD3Q (scalar plus immediate)</a> | FEAT_SVE2p1    |
| 11                   | <a href="#">LD4Q (scalar plus immediate)</a> | FEAT_SVE2p1    |

## SVE contiguous load (quadwords, scalar plus scalar)

These instructions are under [SVE Memory - Contiguous Load](#).

```
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
| 1 0 1 0 0 1 0 | dtype<=0 0 | Rm | 1 0 0 | Pg | 9 | Rn | Zt
```

| Decode fields<br>dtype | Instruction Details                                        | Feature     |
|------------------------|------------------------------------------------------------|-------------|
| 0x                     | UNALLOCATED                                                | -           |
| 10                     | <a href="#">LD1W (scalar plus scalar, single register)</a> | FEAT_SVE2p1 |
| 11                     | <a href="#">LD1D (scalar plus scalar, single register)</a> | FEAT_SVE2p1 |

### SVE contiguous non-temporal load (scalar plus scalar)

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  | msz | 0  | 0  | Rm | 1  | 1  | 0  | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>msz | Instruction Details                                          |
|----------------------|--------------------------------------------------------------|
| 00                   | <a href="#">LDNT1B (scalar plus scalar, single register)</a> |
| 01                   | <a href="#">LDNT1H (scalar plus scalar, single register)</a> |
| 10                   | <a href="#">LDNT1W (scalar plus scalar, single register)</a> |
| 11                   | <a href="#">LDNT1D (scalar plus scalar, single register)</a> |

### SVE load multiple structures (quadwords, scalar plus scalar)

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  | num | 0  | 1  | Rm | 1  | 0  | 0  | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>num | Instruction Details                       | Feature     |
|----------------------|-------------------------------------------|-------------|
| 00                   | UNALLOCATED                               | -           |
| 01                   | <a href="#">LD2Q (scalar plus scalar)</a> | FEAT_SVE2p1 |
| 10                   | <a href="#">LD3Q (scalar plus scalar)</a> | FEAT_SVE2p1 |
| 11                   | <a href="#">LD4Q (scalar plus scalar)</a> | FEAT_SVE2p1 |

### SVE load multiple structures (scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Load](#).

The following constraints also apply to this encoding:  $\text{opc} \neq 00 \text{ \&& } \text{opc} \neq 00$

| Decode fields |     | Instruction Details                          |
|---------------|-----|----------------------------------------------|
| msz           | opc |                                              |
| 00            | 01  | <a href="#">LD2B (scalar plus immediate)</a> |
| 00            | 10  | <a href="#">LD3B (scalar plus immediate)</a> |
| 00            | 11  | <a href="#">LD4B (scalar plus immediate)</a> |
| 01            | 01  | <a href="#">LD2H (scalar plus immediate)</a> |
| 01            | 10  | <a href="#">LD3H (scalar plus immediate)</a> |
| 01            | 11  | <a href="#">LD4H (scalar plus immediate)</a> |
| 10            | 01  | <a href="#">LD2W (scalar plus immediate)</a> |
| 10            | 10  | <a href="#">LD3W (scalar plus immediate)</a> |
| 10            | 11  | <a href="#">LD4W (scalar plus immediate)</a> |
| 11            | 01  | <a href="#">LD2D (scalar plus immediate)</a> |
| 11            | 10  | <a href="#">LD3D (scalar plus immediate)</a> |
| 11            | 11  | <a href="#">LD4D (scalar plus immediate)</a> |

## SVE load multiple structures (scalar plus scalar)

These instructions are under [SVE Memory - Contiguous Load](#).

The following constraints also apply to this encoding:  $\text{opc} \neq 00 \text{ \&& } \text{opc} \neq 00$

| Decode fields |     | Instruction Details                       |
|---------------|-----|-------------------------------------------|
| msz           | opc |                                           |
| 00            | 01  | <a href="#">LD2B (scalar plus scalar)</a> |
| 00            | 10  | <a href="#">LD3B (scalar plus scalar)</a> |
| 00            | 11  | <a href="#">LD4B (scalar plus scalar)</a> |
| 01            | 01  | <a href="#">LD2H (scalar plus scalar)</a> |
| 01            | 10  | <a href="#">LD3H (scalar plus scalar)</a> |
| 01            | 11  | <a href="#">LD4H (scalar plus scalar)</a> |

| Decode fields |     | Instruction Details                       |  |
|---------------|-----|-------------------------------------------|--|
| msz           | opc |                                           |  |
| 10            | 01  | <a href="#">LD2W (scalar plus scalar)</a> |  |
| 10            | 10  | <a href="#">LD3W (scalar plus scalar)</a> |  |
| 10            | 11  | <a href="#">LD4W (scalar plus scalar)</a> |  |
| 11            | 01  | <a href="#">LD2D (scalar plus scalar)</a> |  |
| 11            | 10  | <a href="#">LD3D (scalar plus scalar)</a> |  |
| 11            | 11  | <a href="#">LD4D (scalar plus scalar)</a> |  |

### SVE load and broadcast quadword (scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |     |     |    |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|-----|----|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  | msz | ssz | 0  | imm4 | 0  | 0  | 1  | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     | Instruction Details                            |  | Feature    |
|---------------|-----|------------------------------------------------|--|------------|
| msz           | ssz |                                                |  |            |
|               | 1x  | UNALLOCATED                                    |  | -          |
| 00            | 00  | <a href="#">LD1RQB (scalar plus immediate)</a> |  | -          |
| 00            | 01  | <a href="#">LD1ROB (scalar plus immediate)</a> |  | FEAT_F64MM |
| 01            | 00  | <a href="#">LD1RQH (scalar plus immediate)</a> |  | -          |
| 01            | 01  | <a href="#">LD1ROH (scalar plus immediate)</a> |  | FEAT_F64MM |
| 10            | 00  | <a href="#">LD1RQW (scalar plus immediate)</a> |  | -          |
| 10            | 01  | <a href="#">LD1ROW (scalar plus immediate)</a> |  | FEAT_F64MM |
| 11            | 00  | <a href="#">LD1RQD (scalar plus immediate)</a> |  | -          |
| 11            | 01  | <a href="#">LD1ROD (scalar plus immediate)</a> |  | FEAT_F64MM |

### SVE contiguous load (scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |       |    |      |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-------|----|------|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23 | 22   | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  | dtype | 0  | imm4 | 1  | 0  | 1  | Pg |    | Rn |    | Zt |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details                                                              |
|---------------|--|----------------------------------------------------------------------------------|
| dtype         |  |                                                                                  |
| 0000          |  | <a href="#">LD1B (scalar plus immediate, single register) â€” 8-bit element</a>  |
| 0001          |  | <a href="#">LD1B (scalar plus immediate, single register) â€” 16-bit element</a> |

| <b>Decode fields</b> | <b>Instruction Details</b>                                                       |
|----------------------|----------------------------------------------------------------------------------|
| <b>dtype</b>         |                                                                                  |
| 0010                 | <a href="#">LD1B (scalar plus immediate, single register) â€“ 32-bit element</a> |
| 0011                 | <a href="#">LD1B (scalar plus immediate, single register) â€“ 64-bit element</a> |
| 0100                 | <a href="#">LD1SW (scalar plus immediate)</a>                                    |
| 0101                 | <a href="#">LD1H (scalar plus immediate, single register) â€“ 16-bit element</a> |
| 0110                 | <a href="#">LD1H (scalar plus immediate, single register) â€“ 32-bit element</a> |
| 0111                 | <a href="#">LD1H (scalar plus immediate, single register) â€“ 64-bit element</a> |
| 1000                 | <a href="#">LD1SH (scalar plus immediate) â€“ 64-bit element</a>                 |
| 1001                 | <a href="#">LD1SH (scalar plus immediate) â€“ 32-bit element</a>                 |
| 1010                 | <a href="#">LD1W (scalar plus immediate, single register) â€“ 32-bit element</a> |
| 1011                 | <a href="#">LD1W (scalar plus immediate, single register) â€“ 64-bit element</a> |
| 1100                 | <a href="#">LD1SB (scalar plus immediate) â€“ 64-bit element</a>                 |
| 1101                 | <a href="#">LD1SB (scalar plus immediate) â€“ 32-bit element</a>                 |
| 1110                 | <a href="#">LD1SB (scalar plus immediate) â€“ 16-bit element</a>                 |
| 1111                 | <a href="#">LD1D (scalar plus immediate, single register)</a>                    |

### SVE contiguous non-fault load (scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Zt |   |

| <b>Decode fields</b> | <b>Instruction Details</b>                 |
|----------------------|--------------------------------------------|
| <b>dtype</b>         |                                            |
| 0000                 | <a href="#">LDNF1B â€“ 8-bit element</a>   |
| 0001                 | <a href="#">LDNF1B â€“ 16-bit element</a>  |
| 0010                 | <a href="#">LDNF1B â€“ 32-bit element</a>  |
| 0011                 | <a href="#">LDNF1B â€“ 64-bit element</a>  |
| 0100                 | <a href="#">LDNF1SW</a>                    |
| 0101                 | <a href="#">LDNF1H â€“ 16-bit element</a>  |
| 0110                 | <a href="#">LDNF1H â€“ 32-bit element</a>  |
| 0111                 | <a href="#">LDNF1H â€“ 64-bit element</a>  |
| 1000                 | <a href="#">LDNF1SH â€“ 64-bit element</a> |
| 1001                 | <a href="#">LDNF1SH â€“ 32-bit element</a> |

**Decode fields**  
**dtype**

**Instruction Details**

|      |                                            |
|------|--------------------------------------------|
| 1010 | <a href="#">LDNF1W</a> â€“ 32-bit element  |
| 1011 | <a href="#">LDNF1W</a> â€“ 64-bit element  |
| 1100 | <a href="#">LDNF1SB</a> â€“ 64-bit element |
| 1101 | <a href="#">LDNF1SB</a> â€“ 32-bit element |
| 1110 | <a href="#">LDNF1SB</a> â€“ 16-bit element |
| 1111 | <a href="#">LDNF1D</a>                     |

**SVE load and broadcast quadword (scalar plus scalar)**

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  | msz | ssz |    | Rm | 0  | 0  | 0  | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields**  
**msz**      **ssz**

**Instruction Details**

**Feature**

|    |    |                                             |            |
|----|----|---------------------------------------------|------------|
|    | 1x | UNALLOCATED                                 | -          |
| 00 | 00 | <a href="#">LD1RQB (scalar plus scalar)</a> | -          |
| 00 | 01 | <a href="#">LD1ROB (scalar plus scalar)</a> | FEAT_F64MM |
| 01 | 00 | <a href="#">LD1RQH (scalar plus scalar)</a> | -          |
| 01 | 01 | <a href="#">LD1ROH (scalar plus scalar)</a> | FEAT_F64MM |
| 10 | 00 | <a href="#">LD1RQW (scalar plus scalar)</a> | -          |
| 10 | 01 | <a href="#">LD1ROW (scalar plus scalar)</a> | FEAT_F64MM |
| 11 | 00 | <a href="#">LD1RQD (scalar plus scalar)</a> | -          |
| 11 | 01 | <a href="#">LD1ROD (scalar plus scalar)</a> | FEAT_F64MM |

**SVE contiguous load (scalar plus scalar)**

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  | dtype |    | Rm | 0  | 1  | 0  | Pg |    | Rn |    | Zt |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode  
fields**  
**dtype**

**Instruction Details**

|      |                                                                               |
|------|-------------------------------------------------------------------------------|
| 0000 | <a href="#">LD1B (scalar plus scalar, single register)</a> â€“ 8-bit element  |
| 0001 | <a href="#">LD1B (scalar plus scalar, single register)</a> â€“ 16-bit element |

| Decode fields |  | Instruction Details                                                           |
|---------------|--|-------------------------------------------------------------------------------|
| dtype         |  |                                                                               |
| 0010          |  | <a href="#">LD1B (scalar plus scalar, single register) â€“ 32-bit element</a> |
| 0011          |  | <a href="#">LD1B (scalar plus scalar, single register) â€“ 64-bit element</a> |
| 0100          |  | <a href="#">LD1SW (scalar plus scalar)</a>                                    |
| 0101          |  | <a href="#">LD1H (scalar plus scalar, single register) â€“ 16-bit element</a> |
| 0110          |  | <a href="#">LD1H (scalar plus scalar, single register) â€“ 32-bit element</a> |
| 0111          |  | <a href="#">LD1H (scalar plus scalar, single register) â€“ 64-bit element</a> |
| 1000          |  | <a href="#">LD1SH (scalar plus scalar) â€“ 64-bit element</a>                 |
| 1001          |  | <a href="#">LD1SH (scalar plus scalar) â€“ 32-bit element</a>                 |
| 1010          |  | <a href="#">LD1W (scalar plus scalar, single register) â€“ 32-bit element</a> |
| 1011          |  | <a href="#">LD1W (scalar plus scalar, single register) â€“ 64-bit element</a> |
| 1100          |  | <a href="#">LD1SB (scalar plus scalar) â€“ 64-bit element</a>                 |
| 1101          |  | <a href="#">LD1SB (scalar plus scalar) â€“ 32-bit element</a>                 |
| 1110          |  | <a href="#">LD1SB (scalar plus scalar) â€“ 16-bit element</a>                 |
| 1111          |  | <a href="#">LD1D (scalar plus scalar, single register)</a>                    |

### SVE contiguous first-fault load (scalar plus scalar)

These instructions are under [SVE Memory - Contiguous Load](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| 1  | 0  | 1  | 0  | 0  | 1  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Zt |   |

| Decode fields |  | Instruction Details                                             |
|---------------|--|-----------------------------------------------------------------|
| dtype         |  |                                                                 |
| 0000          |  | <a href="#">LDFF1B (scalar plus scalar) â€“ 8-bit element</a>   |
| 0001          |  | <a href="#">LDFF1B (scalar plus scalar) â€“ 16-bit element</a>  |
| 0010          |  | <a href="#">LDFF1B (scalar plus scalar) â€“ 32-bit element</a>  |
| 0011          |  | <a href="#">LDFF1B (scalar plus scalar) â€“ 64-bit element</a>  |
| 0100          |  | <a href="#">LDFF1SW (scalar plus scalar)</a>                    |
| 0101          |  | <a href="#">LDFF1H (scalar plus scalar) â€“ 16-bit element</a>  |
| 0110          |  | <a href="#">LDFF1H (scalar plus scalar) â€“ 32-bit element</a>  |
| 0111          |  | <a href="#">LDFF1H (scalar plus scalar) â€“ 64-bit element</a>  |
| 1000          |  | <a href="#">LDFF1SH (scalar plus scalar) â€“ 64-bit element</a> |
| 1001          |  | <a href="#">LDFF1SH (scalar plus scalar) â€“ 32-bit element</a> |

| Decode fields |  | Instruction Details                                             |
|---------------|--|-----------------------------------------------------------------|
| dtype         |  |                                                                 |
| 1010          |  | <a href="#">LDFF1W (scalar plus scalar)</a> â€“ 32-bit element  |
| 1011          |  | <a href="#">LDFF1W (scalar plus scalar)</a> â€“ 64-bit element  |
| 1100          |  | <a href="#">LDFF1SB (scalar plus scalar)</a> â€“ 64-bit element |
| 1101          |  | <a href="#">LDFF1SB (scalar plus scalar)</a> â€“ 32-bit element |
| 1110          |  | <a href="#">LDFF1SB (scalar plus scalar)</a> â€“ 16-bit element |
| 1111          |  | <a href="#">LDFF1D (scalar plus scalar)</a>                     |

## SVE Memory - 64-bit Gather

These instructions are under [SVE encodings](#).

|         |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |     |   |   |   |     |   |
|---------|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|-----|---|
| 31      | 30 | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1   | 0 |
| 1100010 |    | op0 | op1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | op2 |   |   |   | op3 |   |

| Decode fields |     |     |     | Instruction details                                                                     | Feature     |
|---------------|-----|-----|-----|-----------------------------------------------------------------------------------------|-------------|
| op0           | op1 | op2 | op3 |                                                                                         |             |
| 00            | 00  | 101 |     | <a href="#">LD1Q</a>                                                                    | FEAT_SVE2p1 |
| 00            | 01  | 0xx | 1   | UNALLOCATED                                                                             | -           |
| 00            | 11  | 1xx | 0   | <a href="#">SVE 64-bit gather prefetch (scalar plus 64-bit scaled offsets)</a>          | -           |
| 00            | 11  |     | 1   | UNALLOCATED                                                                             | -           |
| 00            | x1  | 0xx | 0   | <a href="#">SVE 64-bit gather prefetch (scalar plus unpacked 32-bit scaled offsets)</a> | -           |
| != 00         | 00  | 101 |     | UNALLOCATED                                                                             | -           |
| != 00         | 11  | 1xx |     | <a href="#">SVE 64-bit gather load (scalar plus 64-bit scaled offsets)</a>              | -           |
| != 00         | x1  | 0xx |     | <a href="#">SVE 64-bit gather load (scalar plus 32-bit unpacked scaled offsets)</a>     | -           |
|               | 00  | 111 | 0   | <a href="#">SVE 64-bit gather prefetch (vector plus immediate)</a>                      | -           |
|               | 00  | 111 | 1   | UNALLOCATED                                                                             | -           |
|               | 00  | 1x0 |     | <a href="#">SVE2 64-bit gather non-temporal load (vector plus scalar)</a>               | -           |
|               | 01  | 1xx |     | <a href="#">SVE 64-bit gather load (vector plus immediate)</a>                          | -           |

|  |    |     |  |                                                                                                |   |
|--|----|-----|--|------------------------------------------------------------------------------------------------|---|
|  | 10 | 1xx |  | <a href="#">SVE 64-bit gather load<br/>(scalar plus 64-bit<br/>unscaled offsets)</a>           | - |
|  | x0 | 0xx |  | <a href="#">SVE 64-bit gather load<br/>(scalar plus unpacked 32-<br/>bit unscaled offsets)</a> | - |

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

These instructions are under [SVE Memory - 64-bit Gather](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |       |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|-------|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 | 15 | 14 | 13    | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 1  | Zm | 1  | msz | Pg |    | Rn | 0  | prfop |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b>                |
|----------------------|-------------------------------------------|
| <b>msz</b>           |                                           |
| 00                   | <a href="#">PRFB (scalar plus vector)</a> |
| 01                   | <a href="#">PRFH (scalar plus vector)</a> |
| 10                   | <a href="#">PRFW (scalar plus vector)</a> |
| 11                   | <a href="#">PRFD (scalar plus vector)</a> |

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

These instructions are under [SVE Memory - 64-bit Gather](#).

| <b>Decode fields</b> | <b>Instruction Details</b>                |
|----------------------|-------------------------------------------|
| <b>msz</b>           |                                           |
| 00                   | <a href="#">PRFB (scalar plus vector)</a> |
| 01                   | <a href="#">PRFH (scalar plus vector)</a> |
| 10                   | <a href="#">PRFW (scalar plus vector)</a> |
| 11                   | <a href="#">PRFD (scalar plus vector)</a> |

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

These instructions are under [SVE Memory - 64-bit Gather](#).

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

| Decode fields |   |    | Instruction Details                          |
|---------------|---|----|----------------------------------------------|
| opc           | U | ff |                                              |
| 01            | 0 | 0  | <a href="#">LD1SH (scalar plus vector)</a>   |
| 01            | 0 | 1  | <a href="#">LDFF1SH (scalar plus vector)</a> |
| 01            | 1 | 0  | <a href="#">LD1H (scalar plus vector)</a>    |
| 01            | 1 | 1  | <a href="#">LDFF1H (scalar plus vector)</a>  |
| 10            | 0 | 0  | <a href="#">LD1SW (scalar plus vector)</a>   |
| 10            | 0 | 1  | <a href="#">LDFF1SW (scalar plus vector)</a> |
| 10            | 1 | 0  | <a href="#">LD1W (scalar plus vector)</a>    |
| 10            | 1 | 1  | <a href="#">LDFF1W (scalar plus vector)</a>  |
| 11            | 0 |    | UNALLOCATED                                  |
| 11            | 1 | 0  | <a href="#">LD1D (scalar plus vector)</a>    |
| 11            | 1 | 1  | <a href="#">LDFF1D (scalar plus vector)</a>  |

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

These instructions are under [SVE Memory - 64-bit Gather](#).

|    |    |    |    |    |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24       | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 1  | 0  | !=<br>00 | xs | 1  | Zm | 0  | U  | ff | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

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

| Decode fields |   |    | Instruction Details                          |
|---------------|---|----|----------------------------------------------|
| opc           | U | ff |                                              |
| 01            | 0 | 0  | <a href="#">LD1SH (scalar plus vector)</a>   |
| 01            | 0 | 1  | <a href="#">LDFF1SH (scalar plus vector)</a> |
| 01            | 1 | 0  | <a href="#">LD1H (scalar plus vector)</a>    |
| 01            | 1 | 1  | <a href="#">LDFF1H (scalar plus vector)</a>  |
| 10            | 0 | 0  | <a href="#">LD1SW (scalar plus vector)</a>   |
| 10            | 0 | 1  | <a href="#">LDFF1SW (scalar plus vector)</a> |
| 10            | 1 | 0  | <a href="#">LD1W (scalar plus vector)</a>    |
| 10            | 1 | 1  | <a href="#">LDFF1W (scalar plus vector)</a>  |
| 11            | 0 |    | UNALLOCATED                                  |
| 11            | 1 | 0  | <a href="#">LD1D (scalar plus vector)</a>    |

| Decode fields |   |    | Instruction Details                         |
|---------------|---|----|---------------------------------------------|
| opc           | U | ff |                                             |
| 11            | 1 | 1  | <a href="#">LDFF1D (scalar plus vector)</a> |

## SVE 64-bit gather prefetch (vector plus immediate)

These instructions are under [SVE Memory - 64-bit Gather](#).

| <b>Decode fields</b> | <b>Instruction Details</b>                   |
|----------------------|----------------------------------------------|
| msz                  |                                              |
| 00                   | <a href="#">PRFB (vector plus immediate)</a> |
| 01                   | <a href="#">PRFH (vector plus immediate)</a> |
| 10                   | <a href="#">PRFW (vector plus immediate)</a> |
| 11                   | <a href="#">PRFD (vector plus immediate)</a> |

## SVE2 64-bit gather non-temporal load (vector plus scalar)

These instructions are under [SVE Memory - 64-bit Gather](#).

| Decode fields |   | Instruction Details                         |
|---------------|---|---------------------------------------------|
| msz           | U |                                             |
| 00            | 0 | <a href="#">LDNT1SB</a>                     |
| 00            | 1 | <a href="#">LDNT1B (vector plus scalar)</a> |
| 01            | 0 | <a href="#">LDNT1SH</a>                     |
| 01            | 1 | <a href="#">LDNT1H (vector plus scalar)</a> |
| 10            | 0 | <a href="#">LDNT1SW</a>                     |
| 10            | 1 | <a href="#">LDNT1W (vector plus scalar)</a> |
| 11            | 0 | UNALLOCATED                                 |
| 11            | 1 | <a href="#">LDNT1D (vector plus scalar)</a> |

## SVE 64-bit gather load (vector plus immediate)

These instructions are under [SVE Memory - 64-bit Gather](#).

| Decode fields |   |    | Instruction Details                             |
|---------------|---|----|-------------------------------------------------|
| msz           | U | ff |                                                 |
| 00            | 0 | 0  | <a href="#">LD1SB (vector plus immediate)</a>   |
| 00            | 0 | 1  | <a href="#">LDFF1SB (vector plus immediate)</a> |
| 00            | 1 | 0  | <a href="#">LD1B (vector plus immediate)</a>    |
| 00            | 1 | 1  | <a href="#">LDFF1B (vector plus immediate)</a>  |
| 01            | 0 | 0  | <a href="#">LD1SH (vector plus immediate)</a>   |
| 01            | 0 | 1  | <a href="#">LDFF1SH (vector plus immediate)</a> |
| 01            | 1 | 0  | <a href="#">LD1H (vector plus immediate)</a>    |
| 01            | 1 | 1  | <a href="#">LDFF1H (vector plus immediate)</a>  |
| 10            | 0 | 0  | <a href="#">LD1SW (vector plus immediate)</a>   |
| 10            | 0 | 1  | <a href="#">LDFF1SW (vector plus immediate)</a> |
| 10            | 1 | 0  | <a href="#">LD1W (vector plus immediate)</a>    |
| 10            | 1 | 1  | <a href="#">LDFF1W (vector plus immediate)</a>  |
| 11            | 0 |    | UNALLOCATED                                     |
| 11            | 1 | 0  | <a href="#">LD1D (vector plus immediate)</a>    |
| 11            | 1 | 1  | <a href="#">LDFF1D (vector plus immediate)</a>  |

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

These instructions are under [SVE Memory - 64-bit Gather](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 1  | 0  | msz | 1  | 0  | Zm | 1  | U  | ff | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |    | Instruction Details                          |
|---------------|---|----|----------------------------------------------|
| msz           | U | ff |                                              |
| 00            | 0 | 0  | <a href="#">LD1SB (scalar plus vector)</a>   |
| 00            | 0 | 1  | <a href="#">LDFF1SB (scalar plus vector)</a> |
| 00            | 1 | 0  | <a href="#">LD1B (scalar plus vector)</a>    |
| 00            | 1 | 1  | <a href="#">LDFF1B (scalar plus vector)</a>  |
| 01            | 0 | 0  | <a href="#">LD1SH (scalar plus vector)</a>   |
| 01            | 0 | 1  | <a href="#">LDFF1SH (scalar plus vector)</a> |
| 01            | 1 | 0  | <a href="#">LD1H (scalar plus vector)</a>    |
| 01            | 1 | 1  | <a href="#">LDFF1H (scalar plus vector)</a>  |
| 10            | 0 | 0  | <a href="#">LD1SW (scalar plus vector)</a>   |
| 10            | 0 | 1  | <a href="#">LDFF1SW (scalar plus vector)</a> |
| 10            | 1 | 0  | <a href="#">LD1W (scalar plus vector)</a>    |
| 10            | 1 | 1  | <a href="#">LDFF1W (scalar plus vector)</a>  |
| 11            | 0 |    | UNALLOCATED                                  |

| Decode fields |   |    | Instruction Details                         |
|---------------|---|----|---------------------------------------------|
| msz           | U | ff |                                             |
| 11            | 1 | 0  | <a href="#">LD1D (scalar plus vector)</a>   |
| 11            | 1 | 1  | <a href="#">LDFF1D (scalar plus vector)</a> |

---

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

These instructions are under [SVE Memory - 64-bit Gather](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 0  | 1  | 0  | msz | xs | 0  | Zm | 0  | U  | ff | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |    | Instruction Details                          |
|---------------|---|----|----------------------------------------------|
| msz           | U | ff |                                              |
| 00            | 0 | 0  | <a href="#">LD1SB (scalar plus vector)</a>   |
| 00            | 0 | 1  | <a href="#">LDFF1SB (scalar plus vector)</a> |
| 00            | 1 | 0  | <a href="#">LD1B (scalar plus vector)</a>    |
| 00            | 1 | 1  | <a href="#">LDFF1B (scalar plus vector)</a>  |
| 01            | 0 | 0  | <a href="#">LD1SH (scalar plus vector)</a>   |
| 01            | 0 | 1  | <a href="#">LDFF1SH (scalar plus vector)</a> |
| 01            | 1 | 0  | <a href="#">LD1H (scalar plus vector)</a>    |
| 01            | 1 | 1  | <a href="#">LDFF1H (scalar plus vector)</a>  |
| 10            | 0 | 0  | <a href="#">LD1SW (scalar plus vector)</a>   |
| 10            | 0 | 1  | <a href="#">LDFF1SW (scalar plus vector)</a> |
| 10            | 1 | 0  | <a href="#">LD1W (scalar plus vector)</a>    |
| 10            | 1 | 1  | <a href="#">LDFF1W (scalar plus vector)</a>  |
| 11            | 0 |    | UNALLOCATED                                  |
| 11            | 1 | 0  | <a href="#">LD1D (scalar plus vector)</a>    |
| 11            | 1 | 1  | <a href="#">LDFF1D (scalar plus vector)</a>  |

---

### SVE Memory - Contiguous Store and Unsized Contiguous

These instructions are under [SVE encodings](#).

|         |    |     |     |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
|---------|----|-----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|---|---|---|---|
| 31      | 30 | 29  | 28  | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3 | 2 | 1 | 0 |
| 1110010 |    | op0 | op1 |    |    | 0  | op2 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | op3 |   |   |   |   |

| Decode fields |     |     |     | Instruction details                                                                  |
|---------------|-----|-----|-----|--------------------------------------------------------------------------------------|
| op0           | op1 | op2 | op3 |                                                                                      |
| 0xx           | 00  | 0   |     | <a href="#">SVE store multiple structures<br/>(quadwords, scalar plus immediate)</a> |
| 0xx           | 01  | 0   |     | UNALLOCATED                                                                          |

|           |    |   |   |                                                                               |
|-----------|----|---|---|-------------------------------------------------------------------------------|
| 0xx       | 1x | 0 |   | <a href="#">SVE store multiple structures (quadwords, scalar plus scalar)</a> |
| 10x       |    | 0 |   | UNALLOCATED                                                                   |
| 110       |    | 0 | 0 | <a href="#">STR (predicate)</a>                                               |
| 110       |    | 0 | 1 | UNALLOCATED                                                                   |
| 110       |    | 1 |   | <a href="#">STR (vector)</a>                                                  |
| 111       |    | 0 |   | UNALLOCATED                                                                   |
| !=<br>110 |    | 1 |   | <a href="#">SVE contiguous store (scalar plus scalar)</a>                     |

### SVE store multiple structures (quadwords, scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Store and Unsized Contiguous](#).

|    |    |    |    |    |    |    |    |     |    |    |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | num | 0  | 0  | imm4 | 0  | 0  | 0  | Pg |    | Rn |    | Zt |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>num | Instruction Details                          | Feature     |
|----------------------|----------------------------------------------|-------------|
| 00                   | UNALLOCATED                                  | -           |
| 01                   | <a href="#">ST2Q (scalar plus immediate)</a> | FEAT_SVE2p1 |
| 10                   | <a href="#">ST3Q (scalar plus immediate)</a> | FEAT_SVE2p1 |
| 11                   | <a href="#">ST4Q (scalar plus immediate)</a> | FEAT_SVE2p1 |

### SVE store multiple structures (quadwords, scalar plus scalar)

These instructions are under [SVE Memory - Contiguous Store and Unsized Contiguous](#).

|    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | num | 1  |    | Rm | 0  | 0  | 0  | Pg |    | Rn |    | Zt |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>num | Instruction Details                       | Feature     |
|----------------------|-------------------------------------------|-------------|
| 00                   | UNALLOCATED                               | -           |
| 01                   | <a href="#">ST2Q (scalar plus scalar)</a> | FEAT_SVE2p1 |
| 10                   | <a href="#">ST3Q (scalar plus scalar)</a> | FEAT_SVE2p1 |
| 11                   | <a href="#">ST4Q (scalar plus scalar)</a> | FEAT_SVE2p1 |

### SVE contiguous store (scalar plus scalar)

These instructions are under [SVE Memory - Contiguous Store and Unsized Contiguous](#).

|    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | != 110 | o2 | Rm | 0  | 1  | 0  | Pg |    | Rn |    | Zt |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

opc

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

| Decode fields |    | Instruction Details                                                 |  | Feature     |
|---------------|----|---------------------------------------------------------------------|--|-------------|
| opc           | o2 |                                                                     |  |             |
| 00x           |    | <a href="#">ST1B (scalar plus scalar, single register)</a>          |  | -           |
| 01x           |    | <a href="#">ST1H (scalar plus scalar, single register)</a>          |  | -           |
| 100           | 0  | <a href="#">ST1W (scalar plus scalar, single register) â€“ SVE2</a> |  | FEAT_SVE2p1 |
| 101           |    | <a href="#">ST1W (scalar plus scalar, single register) â€“ SVE</a>  |  | -           |
| 111           | 0  | <a href="#">ST1D (scalar plus scalar, single register) â€“ SVE2</a> |  | FEAT_SVE2p1 |
| 111           | 1  | <a href="#">ST1D (scalar plus scalar, single register) â€“ SVE</a>  |  | -           |

## SVE Memory - Non-temporal and Quadword Scatter Store

These instructions are under [SVE encodings](#).

|         |    |     |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31      | 30 | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1110010 |    | op0 | op1 |    |    |    |    |    |    |    |    |    |    |    |    | 001 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     | Instruction details                                                         |  | Feature     |
|---------------|-----|-----------------------------------------------------------------------------|--|-------------|
| op0           | op1 |                                                                             |  |             |
| 000           | 1   | <a href="#">ST1Q</a>                                                        |  | FEAT_SVE2p1 |
| != 000        | 1   | UNALLOCATED                                                                 |  | -           |
| xx0           | 0   | <a href="#">SVE2 64-bit scatter non-temporal store (vector plus scalar)</a> |  | -           |
| xx1           | 0   | <a href="#">SVE2 32-bit scatter non-temporal store (vector plus scalar)</a> |  | -           |

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

These instructions are under [SVE Memory - Non-temporal and Quadword Scatter Store](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 0  | 0  | Rm | 0  | 0  | 1  | Pg | Zn |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Zt |   |

### Decode fields

msz

### Instruction Details

|    |                                             |
|----|---------------------------------------------|
| 00 | <a href="#">STNT1B (vector plus scalar)</a> |
| 01 | <a href="#">STNT1H (vector plus scalar)</a> |
| 10 | <a href="#">STNT1W (vector plus scalar)</a> |
| 11 | <a href="#">STNT1D (vector plus scalar)</a> |

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

These instructions are under [SVE Memory - Non-temporal and Quadword Scatter Store](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 1  | 0  | Rm | 0  | 0  | 1  | Pg | Zn |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Zt |   |

### Decode fields

msz

### Instruction Details

|    |                                             |
|----|---------------------------------------------|
| 00 | <a href="#">STNT1B (vector plus scalar)</a> |
| 01 | <a href="#">STNT1H (vector plus scalar)</a> |
| 10 | <a href="#">STNT1W (vector plus scalar)</a> |
| 11 | UNALLOCATED                                 |

## SVE Memory - Non-temporal and Multi-register Contiguous Store

These instructions are under [SVE encodings](#).

|         |    |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31      | 30 | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1110010 |    | op0 |    |    |    |    |    |    |    |    |    |    |    |    | 011 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

### Decode

fields

op0

### Instruction details

|       |                                                                        |
|-------|------------------------------------------------------------------------|
| 00    | <a href="#">SVE contiguous non-temporal store (scalar plus scalar)</a> |
| != 00 | <a href="#">SVE store multiple structures (scalar plus scalar)</a>     |

## SVE contiguous non-temporal store (scalar plus scalar)

These instructions are under [SVE Memory - Non-temporal and Multi-register Contiguous Store](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 0  | 0  | Rm | 0  | 1  | 1  | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields</b> | <b>Instruction Details</b>                                   |
|----------------------|--------------------------------------------------------------|
| <b>msz</b>           |                                                              |
| 00                   | <a href="#">STNT1B (scalar plus scalar, single register)</a> |
| 01                   | <a href="#">STNT1H (scalar plus scalar, single register)</a> |
| 10                   | <a href="#">STNT1W (scalar plus scalar, single register)</a> |
| 11                   | <a href="#">STNT1D (scalar plus scalar, single register)</a> |

## SVE store multiple structures (scalar plus scalar)

These instructions are under [SVE Memory - Non-temporal and Multi-register Contiguous Store](#).

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

| Decode fields |     | Instruction Details                       |
|---------------|-----|-------------------------------------------|
| msz           | opc |                                           |
| 00            | 01  | <a href="#">ST2B (scalar plus scalar)</a> |
| 00            | 10  | <a href="#">ST3B (scalar plus scalar)</a> |
| 00            | 11  | <a href="#">ST4B (scalar plus scalar)</a> |
| 01            | 01  | <a href="#">ST2H (scalar plus scalar)</a> |
| 01            | 10  | <a href="#">ST3H (scalar plus scalar)</a> |
| 01            | 11  | <a href="#">ST4H (scalar plus scalar)</a> |
| 10            | 01  | <a href="#">ST2W (scalar plus scalar)</a> |
| 10            | 10  | <a href="#">ST3W (scalar plus scalar)</a> |
| 10            | 11  | <a href="#">ST4W (scalar plus scalar)</a> |
| 11            | 01  | <a href="#">ST2D (scalar plus scalar)</a> |
| 11            | 10  | <a href="#">ST3D (scalar plus scalar)</a> |
| 11            | 11  | <a href="#">ST4D (scalar plus scalar)</a> |

## SVE Memory - Scatter with Optional Sign Extend

These instructions are under [SVE encodings](#).

**Decode fields**  
**op0**

**Instruction details**

|    |                                                                                         |
|----|-----------------------------------------------------------------------------------------|
| 00 | <a href="#">SVE 64-bit scatter store (scalar plus unpacked 32-bit unscaled offsets)</a> |
| 01 | <a href="#">SVE 64-bit scatter store (scalar plus unpacked 32-bit scaled offsets)</a>   |
| 10 | <a href="#">SVE 32-bit scatter store (scalar plus 32-bit unscaled offsets)</a>          |
| 11 | <a href="#">SVE 32-bit scatter store (scalar plus 32-bit scaled offsets)</a>            |

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

These instructions are under [SVE Memory - Scatter with Optional Sign Extend](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 0  | 0  | Zm | 1  | xs | 0  | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

**Decode fields**  
**msz**

**Instruction Details**

|    |                                           |
|----|-------------------------------------------|
| 00 | <a href="#">ST1B (scalar plus vector)</a> |
| 01 | <a href="#">ST1H (scalar plus vector)</a> |
| 10 | <a href="#">ST1W (scalar plus vector)</a> |
| 11 | <a href="#">ST1D (scalar plus vector)</a> |

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

These instructions are under [SVE Memory - Scatter with Optional Sign Extend](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 0  | 1  | Zm | 1  | xs | 0  | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |

**Decode fields**  
**msz**

**Instruction Details**

|    |                                           |
|----|-------------------------------------------|
| 00 | UNALLOCATED                               |
| 01 | <a href="#">ST1H (scalar plus vector)</a> |
| 10 | <a href="#">ST1W (scalar plus vector)</a> |
| 11 | <a href="#">ST1D (scalar plus vector)</a> |

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

These instructions are under [SVE Memory - Scatter with Optional Sign Extend](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 1  | 0  | Zm | 1  | xs | 0  | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>msz | Instruction Details                       |
|----------------------|-------------------------------------------|
| 00                   | <a href="#">ST1B (scalar plus vector)</a> |
| 01                   | <a href="#">ST1H (scalar plus vector)</a> |
| 10                   | <a href="#">ST1W (scalar plus vector)</a> |
| 11                   | UNALLOCATED                               |

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

These instructions are under [SVE Memory - Scatter with Optional Sign Extend](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 1  | 1  | Zm | 1  | xs | 0  | Pg |    | Rn |    | Zt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>msz | Instruction Details                       |
|----------------------|-------------------------------------------|
| 00                   | UNALLOCATED                               |
| 01                   | <a href="#">ST1H (scalar plus vector)</a> |
| 10                   | <a href="#">ST1W (scalar plus vector)</a> |
| 11                   | UNALLOCATED                               |

### SVE Memory - Scatter

These instructions are under [SVE encodings](#).

|         |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31      | 30 | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1110010 |    | op0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode<br>fields<br>op0 | Instruction details                                                            |
|-------------------------|--------------------------------------------------------------------------------|
| 00                      | <a href="#">SVE 64-bit scatter store (scalar plus 64-bit unscaled offsets)</a> |
| 01                      | <a href="#">SVE 64-bit scatter store (scalar plus 64-bit scaled offsets)</a>   |
| 10                      | <a href="#">SVE 64-bit scatter store (vector plus immediate)</a>               |

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

These instructions are under [SVE Memory - Scatter](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 0  | 0  | Zm | 1  | 0  | 1  | Pg | Rn |    | Zt |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

**Decode fields****msz****Instruction Details**

|    |                                           |
|----|-------------------------------------------|
| 00 | <a href="#">ST1B (scalar plus vector)</a> |
| 01 | <a href="#">ST1H (scalar plus vector)</a> |
| 10 | <a href="#">ST1W (scalar plus vector)</a> |
| 11 | <a href="#">ST1D (scalar plus vector)</a> |

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

These instructions are under [SVE Memory - Scatter](#).

|    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 0  | 1  | Zm | 1  | 0  | 1  | Pg | Rn |    | Zt |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

**Decode fields****msz****Instruction Details**

|    |                                           |
|----|-------------------------------------------|
| 00 | UNALLOCATED                               |
| 01 | <a href="#">ST1H (scalar plus vector)</a> |
| 10 | <a href="#">ST1W (scalar plus vector)</a> |
| 11 | <a href="#">ST1D (scalar plus vector)</a> |

**SVE 64-bit scatter store (vector plus immediate)**

These instructions are under [SVE Memory - Scatter](#).

|    |    |    |    |    |    |    |     |    |    |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|-----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 1  | 0  | imm5 | 1  | 0  | 1  | Pg | Zn |    | Zt |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

**Decode fields****msz****Instruction Details**

|    |                                              |
|----|----------------------------------------------|
| 00 | <a href="#">ST1B (vector plus immediate)</a> |
| 01 | <a href="#">ST1H (vector plus immediate)</a> |
| 10 | <a href="#">ST1W (vector plus immediate)</a> |
| 11 | <a href="#">ST1D (vector plus immediate)</a> |

## SVE 32-bit scatter store (vector plus immediate)

These instructions are under [SVE Memory - Scatter](#).

|    |    |    |    |    |    |    |     |    |    |    |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 1  | 1  |    | imm5 | 1  | 0  | 1  | Pg |    | Zn |    | Zt |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction Details                          |
|---------------|----------------------------------------------|
| msz           |                                              |
| 00            | <a href="#">ST1B (vector plus immediate)</a> |
| 01            | <a href="#">ST1H (vector plus immediate)</a> |
| 10            | <a href="#">ST1W (vector plus immediate)</a> |
| 11            | UNALLOCATED                                  |

## SVE Memory - Contiguous Store with Immediate Offset

These instructions are under [SVE encodings](#).

|         |    |    |    |    |    |    |     |     |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---------|----|----|----|----|----|----|-----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1110010 |    |    |    |    |    |    | op0 | op1 |    |    |    | 111 |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction details                                                       |
|---------------|---------------------------------------------------------------------------|
| op0           |                                                                           |
| op1           |                                                                           |
| 00            | <a href="#">SVE contiguous non-temporal store (scalar plus immediate)</a> |
| != 00         | <a href="#">SVE store multiple structures (scalar plus immediate)</a>     |
| 0             | <a href="#">SVE contiguous store (scalar plus immediate)</a>              |

## SVE contiguous non-temporal store (scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Store with Immediate Offset](#).

|    |    |    |    |    |    |    |     |    |    |    |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | 0  | 0  | 1  | imm4 | 1  | 1  | 1  | Pg |    | Rn |    | Zt |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction Details                                             |
|---------------|-----------------------------------------------------------------|
| msz           |                                                                 |
| 00            | <a href="#">STNT1B (scalar plus immediate, single register)</a> |
| 01            | <a href="#">STNT1H (scalar plus immediate, single register)</a> |
| 10            | <a href="#">STNT1W (scalar plus immediate, single register)</a> |
| 11            | <a href="#">STNT1D (scalar plus immediate, single register)</a> |

## SVE store multiple structures (scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Store with Immediate Offset](#).

|    |    |    |    |    |    |    |     |     |          |    |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|-----|----------|----|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23  | 22       | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | opc | !=<br>00 | 1  | imm4 | 1  | 1  | 1  | Pg | Rn | Zt |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

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

| Decode fields |     | Instruction Details                          |
|---------------|-----|----------------------------------------------|
| msz           | opc |                                              |
| 00            | 01  | <a href="#">ST2B (scalar plus immediate)</a> |
| 00            | 10  | <a href="#">ST3B (scalar plus immediate)</a> |
| 00            | 11  | <a href="#">ST4B (scalar plus immediate)</a> |
| 01            | 01  | <a href="#">ST2H (scalar plus immediate)</a> |
| 01            | 10  | <a href="#">ST3H (scalar plus immediate)</a> |
| 01            | 11  | <a href="#">ST4H (scalar plus immediate)</a> |
| 10            | 01  | <a href="#">ST2W (scalar plus immediate)</a> |
| 10            | 10  | <a href="#">ST3W (scalar plus immediate)</a> |
| 10            | 11  | <a href="#">ST4W (scalar plus immediate)</a> |
| 11            | 01  | <a href="#">ST2D (scalar plus immediate)</a> |
| 11            | 10  | <a href="#">ST3D (scalar plus immediate)</a> |
| 11            | 11  | <a href="#">ST4D (scalar plus immediate)</a> |

## SVE contiguous store (scalar plus immediate)

These instructions are under [SVE Memory - Contiguous Store with Immediate Offset](#).

|    |    |    |    |    |    |    |     |     |    |      |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|-----|----|------|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 1  | 0  | 0  | 1  | 0  | msz | opc | 0  | imm4 | 1  | 1  | 1  | Pg | Rn | Zt |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     | Instruction Details                                           | Feature |
|---------------|-----|---------------------------------------------------------------|---------|
| msz           | opc |                                                               |         |
| 00            |     | <a href="#">ST1B (scalar plus immediate, single register)</a> | -       |
| 01            |     | <a href="#">ST1H (scalar plus immediate, single register)</a> | -       |

| Decode fields |     | Instruction Details                                                    | Feature     |
|---------------|-----|------------------------------------------------------------------------|-------------|
| msz           | opc |                                                                        |             |
| 10            | 00  | <a href="#">ST1W (scalar plus immediate, single register) â€“ SVE2</a> | FEAT_SVE2p1 |
| 10            | 01  | UNALLOCATED                                                            | -           |
| 10            | 1x  | <a href="#">ST1W (scalar plus immediate, single register) â€“ SVE</a>  | -           |
| 11            | 0x  | UNALLOCATED                                                            | -           |
| 11            | 10  | <a href="#">ST1D (scalar plus immediate, single register) â€“ SVE2</a> | FEAT_SVE2p1 |
| 11            | 11  | <a href="#">ST1D (scalar plus immediate, single register) â€“ SVE</a>  | -           |

## Data Processing -- Immediate

These instructions are under the [top-level](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields | Instruction details                                 |
|---------------|-----------------------------------------------------|
| op0           |                                                     |
| 00xx          | <a href="#">PC-rel. addressing</a>                  |
| 010x          | <a href="#">Add/Subtract (immediate)</a>            |
| 0110          | <a href="#">Add/Subtract (immediate, with tags)</a> |
| 0111          | <a href="#">Min/Max (immediate)</a>                 |
| 100x          | <a href="#">Logical (immediate)</a>                 |
| 101x          | <a href="#">Move wide (immediate)</a>               |
| 110x          | <a href="#">Bitfield</a>                            |
| 111x          | <a href="#">Extract</a>                             |

## PC-rel. addressing

These instructions are under [Data Processing -- Immediate](#).

|    |      |      |    |    |    |    |    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|----|------|------|----|----|----|----|----|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 31 | 30   | 29   | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| op | imm1 | imm0 | 1  | 0  | 0  | 0  | 0  | immhi |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Rd |   |

| Decode fields | Instruction Details  |
|---------------|----------------------|
| op            |                      |
| 0             | <a href="#">ADR</a>  |
| 1             | <a href="#">ADRP</a> |

## Add/subtract (immediate)

These instructions are under [Data Processing -- Immediate](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |   |   |   |    |   |   |    |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|---|---|---|----|---|---|----|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8 | 7 | 6 | 5  | 4 | 3 | 2  | 1 | 0 |
| s  | f  | o  | p  | S  | 1  | 0  | 0  | 0  | 1  | 0  | sh |    |    |    |    |    |    |    |    |    |    | imm12 |   |   |   | Rn |   |   | Rd |   |   |

| Decode fields |    |   | Instruction Details                |
|---------------|----|---|------------------------------------|
| sf            | op | S |                                    |
| 0             | 0  | 0 | <u>ADD (immediate)</u> â€“ 32-bit  |
| 0             | 0  | 1 | <u>ADDS (immediate)</u> â€“ 32-bit |
| 0             | 1  | 0 | <u>SUB (immediate)</u> â€“ 32-bit  |
| 0             | 1  | 1 | <u>SUBS (immediate)</u> â€“ 32-bit |
| 1             | 0  | 0 | <u>ADD (immediate)</u> â€“ 64-bit  |
| 1             | 0  | 1 | <u>ADDS (immediate)</u> â€“ 64-bit |
| 1             | 1  | 0 | <u>SUB (immediate)</u> â€“ 64-bit  |
| 1             | 1  | 1 | <u>SUBS (immediate)</u> â€“ 64-bit |

## Add/subtract (immediate, with tags)

These instructions are under [Data Processing -- Immediate](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |    |    |   |    |   |    |    |   |    |  |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----|----|---|---|---|---|---|---|---|---|----|----|---|----|---|----|----|---|----|--|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | sf | op | S | 1 | 0 | 0 | 0 | 1 | 1 | 0 | ui | mm | 6 | op | 3 | ui | mm | 4 | Rn |  | Rd |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|----|----|---|---|---|---|---|---|---|---|----|----|---|----|---|----|----|---|----|--|----|

| Decode fields |    |   | Instruction Details  | Feature  |
|---------------|----|---|----------------------|----------|
| sf            | op | S |                      |          |
| 0             |    |   | UNALLOCATED          | -        |
| 1             |    | 1 | UNALLOCATED          | -        |
| 1             | 0  | 0 | <a href="#">ADDG</a> | FEAT_MTE |
| 1             | 1  | 0 | <a href="#">SUBG</a> | FEAT_MTE |

## Min/max (immediate)

These instructions are under Data Processing -- Immediate.

| Decode fields |    |   |      | Instruction Details | Feature |
|---------------|----|---|------|---------------------|---------|
| sf            | op | S | opc  |                     |         |
|               | 0  |   | 01xx | UNALLOCATED         | -       |
|               | 0  |   | 1xxx | UNALLOCATED         | -       |

| Decode fields |    |   |      | Instruction Details                         | Feature   |
|---------------|----|---|------|---------------------------------------------|-----------|
| sf            | op | S | opc  |                                             |           |
|               | 0  | 1 | 00xx | UNALLOCATED                                 | -         |
|               | 1  |   |      | UNALLOCATED                                 | -         |
| 0             | 0  | 0 | 0000 | <a href="#">SMAX (immediate)</a> â€“ 32-bit | FEAT_CSSC |
| 0             | 0  | 0 | 0001 | <a href="#">UMAX (immediate)</a> â€“ 32-bit | FEAT_CSSC |
| 0             | 0  | 0 | 0010 | <a href="#">SMIN (immediate)</a> â€“ 32-bit | FEAT_CSSC |
| 0             | 0  | 0 | 0011 | <a href="#">UMIN (immediate)</a> â€“ 32-bit | FEAT_CSSC |
| 1             | 0  | 0 | 0000 | <a href="#">SMAX (immediate)</a> â€“ 64-bit | FEAT_CSSC |
| 1             | 0  | 0 | 0001 | <a href="#">UMAX (immediate)</a> â€“ 64-bit | FEAT_CSSC |
| 1             | 0  | 0 | 0010 | <a href="#">SMIN (immediate)</a> â€“ 64-bit | FEAT_CSSC |
| 1             | 0  | 0 | 0011 | <a href="#">UMIN (immediate)</a> â€“ 64-bit | FEAT_CSSC |

### Logical (immediate)

These instructions are under [Data Processing -- Immediate](#).

|    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |    |   |    |   |   |   |
|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----|---|----|---|---|---|
| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4 | 3  | 2 | 1 | 0 |
| sf | opc | 1  | 0  | 0  | 1  | 0  | 0  | N  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Rn |   | Rd |   |   |   |

| Decode fields |     |   | Instruction Details                         |
|---------------|-----|---|---------------------------------------------|
| sf            | opc | N |                                             |
| 0             |     | 1 | UNALLOCATED                                 |
| 0             | 00  | 0 | <a href="#">AND (immediate)</a> â€“ 32-bit  |
| 0             | 01  | 0 | <a href="#">ORR (immediate)</a> â€“ 32-bit  |
| 0             | 10  | 0 | <a href="#">EOR (immediate)</a> â€“ 32-bit  |
| 0             | 11  | 0 | <a href="#">ANDS (immediate)</a> â€“ 32-bit |
| 1             | 00  |   | <a href="#">AND (immediate)</a> â€“ 64-bit  |
| 1             | 01  |   | <a href="#">ORR (immediate)</a> â€“ 64-bit  |
| 1             | 10  |   | <a href="#">EOR (immediate)</a> â€“ 64-bit  |
| 1             | 11  |   | <a href="#">ANDS (immediate)</a> â€“ 64-bit |

### Move wide (immediate)

These instructions are under [Data Processing -- Immediate](#).

|    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |    |   |   |   |   |   |
|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----|---|---|---|---|---|
| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
| sf | opc | 1  | 0  | 0  | 1  | 0  | 1  | hw |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Rd |   |   |   |   |   |

| Decode fields |     |    | Instruction Details |
|---------------|-----|----|---------------------|
| sf            | opc | hw |                     |
|               | 01  |    | UNALLOCATED         |

| Decode fields |     |    | Instruction Details |  |  |  |  |  |  |                                                 |
|---------------|-----|----|---------------------|--|--|--|--|--|--|-------------------------------------------------|
| sf            | opc | hw |                     |  |  |  |  |  |  |                                                 |
| 0             |     | 1x |                     |  |  |  |  |  |  | UNALLOCATED                                     |
| 0             | 00  | 0x |                     |  |  |  |  |  |  | <a href="#">MOVN</a> â€“ <a href="#">32-bit</a> |
| 0             | 10  | 0x |                     |  |  |  |  |  |  | <a href="#">MOVZ</a> â€“ <a href="#">32-bit</a> |
| 0             | 11  | 0x |                     |  |  |  |  |  |  | <a href="#">MOVK</a> â€“ <a href="#">32-bit</a> |
| 1             | 00  |    |                     |  |  |  |  |  |  | <a href="#">MOVN</a> â€“ <a href="#">64-bit</a> |
| 1             | 10  |    |                     |  |  |  |  |  |  | <a href="#">MOVZ</a> â€“ <a href="#">64-bit</a> |
| 1             | 11  |    |                     |  |  |  |  |  |  | <a href="#">MOVK</a> â€“ <a href="#">64-bit</a> |

---

## Bitfield

These instructions are under [Data Processing -- Immediate](#).

|    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    |   |    |   |
|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----|---|----|---|
| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1  | 0 |
| sf | opc | 1  | 0  | 0  | 1  | 1  | 0  | N  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | Rn |   | Rd |   |

| Decode fields |     |   | Instruction Details |  |  |  |  |  |  |                                                 |
|---------------|-----|---|---------------------|--|--|--|--|--|--|-------------------------------------------------|
| sf            | opc | N |                     |  |  |  |  |  |  |                                                 |
|               | 11  |   |                     |  |  |  |  |  |  | UNALLOCATED                                     |
| 0             |     | 1 |                     |  |  |  |  |  |  | UNALLOCATED                                     |
| 0             | 00  | 0 |                     |  |  |  |  |  |  | <a href="#">SBFM</a> â€“ <a href="#">32-bit</a> |
| 0             | 01  | 0 |                     |  |  |  |  |  |  | <a href="#">BFM</a> â€“ <a href="#">32-bit</a>  |
| 0             | 10  | 0 |                     |  |  |  |  |  |  | <a href="#">UBFM</a> â€“ <a href="#">32-bit</a> |
| 1             |     | 0 |                     |  |  |  |  |  |  | UNALLOCATED                                     |
| 1             | 00  | 1 |                     |  |  |  |  |  |  | <a href="#">SBFM</a> â€“ <a href="#">64-bit</a> |
| 1             | 01  | 1 |                     |  |  |  |  |  |  | <a href="#">BFM</a> â€“ <a href="#">64-bit</a>  |
| 1             | 10  | 1 |                     |  |  |  |  |  |  | <a href="#">UBFM</a> â€“ <a href="#">64-bit</a> |

---

## Extract

These instructions are under [Data Processing -- Immediate](#).

|    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |    |   |      |   |    |   |    |  |
|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|----|---|------|---|----|---|----|--|
| 31 | 30   | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4 | 3    | 2 | 1  | 0 |    |  |
| sf | op21 | 1  | 0  | 0  | 1  | 1  | 1  | N  | 00 |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | Rm |   | imms |   | Rn |   | Rd |  |

| Decode fields |      |   |    |        | Instruction Details |  |  |  |  |             |
|---------------|------|---|----|--------|---------------------|--|--|--|--|-------------|
| sf            | op21 | N | o0 | imms   |                     |  |  |  |  |             |
|               | x1   |   |    |        |                     |  |  |  |  | UNALLOCATED |
|               | 00   |   | 1  |        |                     |  |  |  |  | UNALLOCATED |
|               | 1x   |   |    |        |                     |  |  |  |  | UNALLOCATED |
| 0             |      |   |    | 1xxxxx |                     |  |  |  |  | UNALLOCATED |

| Decode fields |      |   |    |         | Instruction Details           |
|---------------|------|---|----|---------|-------------------------------|
| sf            | op21 | N | o0 | imms    |                               |
| 0             |      | 1 |    |         | UNALLOCATED                   |
| 0             | 00   | 0 | 0  | 0xxxxxx | <a href="#">EXTR “ 32-bit</a> |
| 1             |      | 0 |    |         | UNALLOCATED                   |
| 1             | 00   | 1 | 0  |         | <a href="#">EXTR “ 64-bit</a> |

## Branches, Exception Generating and System instructions

These instructions are under the [top-level](#).

|     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |     |   |   |
|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|-----|---|---|
| 31  | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1 | 0 |
| op0 | 101 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | op2 |   |   |

| Decode fields |                  |       | Instruction details                                        |
|---------------|------------------|-------|------------------------------------------------------------|
| op0           | op1              | op2   |                                                            |
| 010           | 0xxxxxxxxxxxxxxx |       | <a href="#">Conditional branch (immediate)</a>             |
| 110           | 00xxxxxxxxxxxxxx |       | <a href="#">Exception generation</a>                       |
| 110           | 01000000110001   |       | <a href="#">System instructions with register argument</a> |
| 110           | 01000000110010   | 11111 | <a href="#">Hints</a>                                      |
| 110           | 01000000110011   |       | <a href="#">Barriers</a>                                   |
| 110           | 0100000xxx0100   |       | <a href="#">PSTATE</a>                                     |
| 110           | 0100100xxxxxxx   |       | <a href="#">System with result</a>                         |
| 110           | 0100x01xxxxxxx   |       | <a href="#">System instructions</a>                        |
| 110           | 0100x1xxxxxxx    |       | <a href="#">System register move</a>                       |
| 110           | 0101x01xxxxxxx   |       | <a href="#">System pair instructions</a>                   |
| 110           | 0101x1xxxxxxx    |       | <a href="#">System register pair move</a>                  |
| 110           | 1xxxxxxxxxxxxxx  |       | <a href="#">Unconditional branch (register)</a>            |
| x00           |                  |       | <a href="#">Unconditional branch (immediate)</a>           |
| x01           | 0xxxxxxxxxxxxxx  |       | <a href="#">Compare and branch (immediate)</a>             |
| x01           | 1xxxxxxxxxxxxxx  |       | <a href="#">Test and branch (immediate)</a>                |

### Conditional branch (immediate)

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |       |    |      |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|-------|----|------|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4  | 3    | 2 | 1 | 0 |
| 0  | 1  | 0  | 1  | 0  | 1  | 0  | 01 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   | imm19 | o0 | cond |   |   |   |

| Decode fields |    | Instruction Details     | Feature  |
|---------------|----|-------------------------|----------|
| o1            | o0 |                         |          |
| 0             | 0  | <a href="#">B.cond</a>  | -        |
| 0             | 1  | <a href="#">BC.cond</a> | FEAT_HBC |
| 1             |    | UNALLOCATED             | -        |

---

### Exception generation

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |     |    |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|----|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3  | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | opc |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | op2 | LL |   |   |   |

| Decode fields |     |    | Instruction Details     | Feature  |
|---------------|-----|----|-------------------------|----------|
| opc           | op2 | LL |                         |          |
|               | 001 |    | UNALLOCATED             | -        |
|               | 01x |    | UNALLOCATED             | -        |
|               | 1xx |    | UNALLOCATED             | -        |
| 000           | 000 | 00 | UNALLOCATED             | -        |
| 000           | 000 | 01 | <a href="#">SVC</a>     | -        |
| 000           | 000 | 10 | <a href="#">HVC</a>     | -        |
| 000           | 000 | 11 | <a href="#">SMC</a>     | -        |
| 001           | 000 | x1 | UNALLOCATED             | -        |
| 001           | 000 | 00 | <a href="#">BRK</a>     | -        |
| 001           | 000 | 1x | UNALLOCATED             | -        |
| 010           | 000 | x1 | UNALLOCATED             | -        |
| 010           | 000 | 00 | <a href="#">HLT</a>     | -        |
| 010           | 000 | 1x | UNALLOCATED             | -        |
| 011           | 000 | 00 | <a href="#">TCANCEL</a> | FEAT_TME |
| 011           | 000 | 01 | UNALLOCATED             | -        |
| 011           | 000 | 1x | UNALLOCATED             | -        |
| 100           | 000 |    | UNALLOCATED             | -        |
| 101           | 000 | 00 | UNALLOCATED             | -        |
| 101           | 000 | 01 | <a href="#">DCPS1</a>   | -        |
| 101           | 000 | 10 | <a href="#">DCPS2</a>   | -        |
| 101           | 000 | 11 | <a href="#">DCPS3</a>   | -        |
| 110           | 000 |    | UNALLOCATED             | -        |
| 111           | 000 |    | UNALLOCATED             | -        |

---

## System instructions with register argument

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | CRm | op2 | Rt |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     | Instruction Details  |  | Feature   |
|---------------|-----|----------------------|--|-----------|
| CRm           | op2 |                      |  |           |
| != 0000       |     | UNALLOCATED          |  | -         |
| 0000          | 000 | <a href="#">WFET</a> |  | FEAT_WFxT |
| 0000          | 001 | <a href="#">WFIT</a> |  | FEAT_WFxT |
| 0000          | 01x | UNALLOCATED          |  | -         |
| 0000          | 1xx | UNALLOCATED          |  | -         |

## Hints

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 0  | CRm | op2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |   |

| Decode fields |     | Instruction Details                                                                     |  | Feature    |
|---------------|-----|-----------------------------------------------------------------------------------------|--|------------|
| CRm           | op2 |                                                                                         |  |            |
|               |     | <a href="#">HINT</a>                                                                    |  | -          |
| 0000          | 000 | <a href="#">NOP</a>                                                                     |  | -          |
| 0000          | 001 | <a href="#">YIELD</a>                                                                   |  | -          |
| 0000          | 010 | <a href="#">WFE</a>                                                                     |  | -          |
| 0000          | 011 | <a href="#">WFI</a>                                                                     |  | -          |
| 0000          | 100 | <a href="#">SEV</a>                                                                     |  | -          |
| 0000          | 101 | <a href="#">SEVL</a>                                                                    |  | -          |
| 0000          | 110 | <a href="#">DGH</a>                                                                     |  | FEAT_DGH   |
| 0000          | 111 | <a href="#">XPACD, XPACI, XPACLRI</a>                                                   |  | FEAT_PAuth |
| 0001          | 000 | <a href="#">PACIA, PACIA1716, PACIASP, PACIAZ, PACIZA</a> â€” <a href="#">PACIA1716</a> |  | FEAT_PAuth |
| 0001          | 010 | <a href="#">PACIB, PACIB1716, PACIBSP, PACIBZ, PACIZB</a> â€” <a href="#">PACIB1716</a> |  | FEAT_PAuth |
| 0001          | 100 | <a href="#">AUTIA, AUTIA1716, AUTIASP, AUTIAZ, AUTIZA</a> â€” <a href="#">AUTIA1716</a> |  | FEAT_PAuth |
| 0001          | 110 | <a href="#">AUTIB, AUTIB1716, AUTIBSP, AUTIBZ, AUTIZB</a> â€” <a href="#">AUTIB1716</a> |  | FEAT_PAuth |

| Decode fields |     | Instruction Details                                                                   |  | Feature     |
|---------------|-----|---------------------------------------------------------------------------------------|--|-------------|
| CRm           | op2 |                                                                                       |  |             |
| 0010          | 000 | <a href="#">ESB</a>                                                                   |  | FEAT_RAS    |
| 0010          | 001 | <a href="#">PSB CSYNC</a>                                                             |  | FEAT_SPE    |
| 0010          | 010 | <a href="#">TSB CSYNC</a>                                                             |  | FEAT_TRF    |
| 0010          | 011 | <a href="#">GCSB DSYNC</a>                                                            |  | FEAT_GCS    |
| 0010          | 100 | <a href="#">CSDB</a>                                                                  |  | -           |
| 0010          | 110 | <a href="#">CLRBHB</a>                                                                |  | FEAT_CLRBHB |
| 0011          | 000 | <a href="#">PACIA, PACIA1716, PACIASP, PACIAZ, PACIZA</a> â€” <a href="#">PACIAZ</a>  |  | FEAT_PAuth  |
| 0011          | 001 | <a href="#">PACIA, PACIA1716, PACIASP, PACIAZ, PACIZA</a> â€” <a href="#">PACIASP</a> |  | FEAT_PAuth  |
| 0011          | 010 | <a href="#">PACIB, PACIB1716, PACIBSP, PACIBZ, PACIZB</a> â€” <a href="#">PACIBZ</a>  |  | FEAT_PAuth  |
| 0011          | 011 | <a href="#">PACIB, PACIB1716, PACIBSP, PACIBZ, PACIZB</a> â€” <a href="#">PACIBSP</a> |  | FEAT_PAuth  |
| 0011          | 100 | <a href="#">AUTIA, AUTIA1716, AUTIASP, AUTIAZ, AUTIZA</a> â€” <a href="#">AUTIAZ</a>  |  | FEAT_PAuth  |
| 0011          | 101 | <a href="#">AUTIA, AUTIA1716, AUTIASP, AUTIAZ, AUTIZA</a> â€” <a href="#">AUTIASP</a> |  | FEAT_PAuth  |
| 0011          | 110 | <a href="#">AUTIB, AUTIB1716, AUTIBSP, AUTIBZ, AUTIZB</a> â€” <a href="#">AUTIBZ</a>  |  | FEAT_PAuth  |
| 0011          | 111 | <a href="#">AUTIB, AUTIB1716, AUTIBSP, AUTIBZ, AUTIZB</a> â€” <a href="#">AUTIBSP</a> |  | FEAT_PAuth  |
| 0100          | xx0 | <a href="#">BTI</a>                                                                   |  | FEAT_BTI    |
| 0101          | 000 | <a href="#">CHKFEAT</a>                                                               |  | FEAT_CHK    |

## Barriers

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 1  | CRm | op2 | Rt |   |   |   |   |   |   |   |   |

| Decode fields |     |          | Instruction Details                                    |  | Feature |
|---------------|-----|----------|--------------------------------------------------------|--|---------|
| CRm           | op2 | Rt       |                                                        |  |         |
|               | 000 |          | UNALLOCATED                                            |  | -       |
|               | 001 | != 11111 | UNALLOCATED                                            |  | -       |
|               | 010 | 11111    | <a href="#">CLREX</a>                                  |  | -       |
|               | 100 | 11111    | <a href="#">DSB</a> â€” <a href="#">memory barrier</a> |  | -       |
|               | 101 | 11111    | <a href="#">DMB</a>                                    |  | -       |
|               | 110 | 11111    | <a href="#">ISB</a>                                    |  | -       |

| Decode fields |     |              | Instruction Details                                        |  | Feature  |
|---------------|-----|--------------|------------------------------------------------------------|--|----------|
| CRm           | op2 | Rt           |                                                            |  |          |
|               | 111 | $\neq 11111$ | UNALLOCATED                                                |  | -        |
|               | 111 | 11111        | <a href="#">SB</a>                                         |  | FEAT_SB  |
| xx0x          | 001 | 11111        | UNALLOCATED                                                |  | -        |
| xx10          | 001 | 11111        | <a href="#">DSB</a> â€“ <a href="#">Memory nXS barrier</a> |  | FEAT_XS  |
| xx11          | 001 | 11111        | UNALLOCATED                                                |  | -        |
| 0000          | 011 | 11111        | <a href="#">TCOMMIT</a>                                    |  | FEAT_TME |
| 0001          | 011 |              | UNALLOCATED                                                |  | -        |
| 001x          | 011 |              | UNALLOCATED                                                |  | -        |
| 01xx          | 011 |              | UNALLOCATED                                                |  | -        |
| 1xxx          | 011 |              | UNALLOCATED                                                |  | -        |

## PSTATE

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10  | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | CRm | op2 | Rt |   |   |   |   |   |   |   |   |   |

| Decode fields |     |              | Instruction Details             |  | Feature     |
|---------------|-----|--------------|---------------------------------|--|-------------|
| op1           | op2 | Rt           |                                 |  |             |
|               |     | $\neq 11111$ | UNALLOCATED                     |  | -           |
|               |     | 11111        | <a href="#">MSR (immediate)</a> |  | -           |
| 000           | 000 | 11111        | <a href="#">CFINV</a>           |  | FEAT_FlagM  |
| 000           | 001 | 11111        | <a href="#">XAFLAG</a>          |  | FEAT_FlagM2 |
| 000           | 010 | 11111        | <a href="#">AXFLAG</a>          |  | FEAT_FlagM2 |

## System with result

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |     |     |    |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|----|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10  | 9   | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | CRn | CRm | op2 | Rt |   |   |   |   |   |   |   |   |

| Decode fields |             |     |            | Instruction Details |  | Feature |
|---------------|-------------|-----|------------|---------------------|--|---------|
| op1           | CRn         | CRm | op2        |                     |  |         |
| $\neq 011$    |             |     |            | UNALLOCATED         |  | -       |
| 011           | $\neq 0011$ |     |            | UNALLOCATED         |  | -       |
| 011           | 0011        |     | $\neq 011$ | UNALLOCATED         |  | -       |

| op1 | Decode fields |         |     | op2 | Instruction Details    | Feature  |
|-----|---------------|---------|-----|-----|------------------------|----------|
|     | CRn           | CRm     |     |     |                        |          |
| 011 | 0011          | != 000x | 011 |     | UNALLOCATED            | -        |
| 011 | 0011          | 0000    | 011 |     | <a href="#">TSTART</a> | FEAT_TME |
| 011 | 0011          | 0001    | 011 |     | <a href="#">TTEST</a>  | FEAT_TME |

## System instructions

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |     |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|-----|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16  | 15 | 14  | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | L  | 0  | 1  | op1 |    | CRn |    | CRm |    | op2 |    | Rt |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details  |
|---------------|--|----------------------|
| L             |  |                      |
| 0             |  | <a href="#">SYS</a>  |
| 1             |  | <a href="#">SYSL</a> |

## System register move

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |     |    |     |    |    |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|-----|----|-----|----|----|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15  | 14 | 13  | 12 | 11  | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | L  | 1  | 0  | 0  | op1 |    | CRn |    | CRm |    | op2 |    | Rt |   |   |   |   |   |   |   |   |   |  |

| Decode fields |  | Instruction Details            |
|---------------|--|--------------------------------|
| L             |  |                                |
| 0             |  | <a href="#">MSR (register)</a> |
| 1             |  | <a href="#">MRS</a>            |

## System pair instructions

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |     |    |     |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|-----|----|-----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16  | 15 | 14  | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | L  | 0  | 1  | op1 |    | CRn |    | CRm |    | op2 |    | Rt |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details  | Feature          |
|---------------|--|----------------------|------------------|
| L             |  |                      |                  |
| 0             |  | <a href="#">SYSP</a> | FEAT_SYSINSTR128 |
| 1             |  | UNALLOCATED          | -                |

## System register pair move

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |     |    |     |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|-----|----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 17  | 16 | 15  | 14 | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | L  | 1  | 0  | 0  | op1 |    | CRn |    | CRm |    | op2 |    | Rt |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>L | Instruction Details  | Feature        |
|--------------------|----------------------|----------------|
| 0                  | <a href="#">MSRR</a> | FEAT_SYSREG128 |
| 1                  | <a href="#">MRRS</a> | FEAT_SYSREG128 |

## Unconditional branch (register)

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |     |    |     |    |     |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|-----|----|-----|----|-----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22  | 21 | 20  | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 1  | opc |    | op2 |    | op3 |    | Rn |    | op4 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>opc | Decode fields<br>op2 | Decode fields<br>op3 | Rn | op4         | Instruction Details                                               | Feature    |
|----------------------|----------------------|----------------------|----|-------------|-------------------------------------------------------------------|------------|
|                      | !=<br>11111          |                      |    |             | UNALLOCATED                                                       | -          |
| 0000                 | 11111                | 000000               |    | !=<br>00000 | UNALLOCATED                                                       | -          |
| 0000                 | 11111                | 000000               |    | 00000       | <a href="#">BR</a>                                                | -          |
| 0000                 | 11111                | 000001               |    |             | UNALLOCATED                                                       | -          |
| 0000                 | 11111                | 000010               |    | !=<br>11111 | UNALLOCATED                                                       | -          |
| 0000                 | 11111                | 000010               |    | 11111       | <a href="#">BRAA, BRAAZ, BRAB, BRABZ</a> â€” key A, zero modifier | FEAT_PAuth |
| 0000                 | 11111                | 000011               |    | !=<br>11111 | UNALLOCATED                                                       | -          |
| 0000                 | 11111                | 000011               |    | 11111       | <a href="#">BRAA, BRAAZ, BRAB, BRABZ</a> â€” key B, zero modifier | FEAT_PAuth |
| 0000                 | 11111                | 0001xx               |    |             | UNALLOCATED                                                       | -          |
| 0000                 | 11111                | 001xxx               |    |             | UNALLOCATED                                                       | -          |
| 0000                 | 11111                | 01xxxx               |    |             | UNALLOCATED                                                       | -          |
| 0000                 | 11111                | 1xxxxx               |    |             | UNALLOCATED                                                       | -          |

| Decode fields |       |        |             |             | Instruction Details                                                               | Feature    |
|---------------|-------|--------|-------------|-------------|-----------------------------------------------------------------------------------|------------|
| opc           | op2   | op3    | Rn          | op4         |                                                                                   |            |
| 0001          | 11111 | 000000 |             | !=<br>00000 | UNALLOCATED                                                                       | -          |
| 0001          | 11111 | 000000 |             | 00000       | <a href="#">BLR</a>                                                               | -          |
| 0001          | 11111 | 000001 |             |             | UNALLOCATED                                                                       | -          |
| 0001          | 11111 | 000010 |             | !=<br>11111 | UNALLOCATED                                                                       | -          |
| 0001          | 11111 | 000010 |             | 11111       | <a href="#">BLRAA, BLRAAZ,<br/>BLRAB, BLRABZ<br/>â€” key A, zero<br/>modifier</a> | FEAT_PAuth |
| 0001          | 11111 | 000011 |             | !=<br>11111 | UNALLOCATED                                                                       | -          |
| 0001          | 11111 | 000011 |             | 11111       | <a href="#">BLRAA, BLRAAZ,<br/>BLRAB, BLRABZ<br/>â€” key B, zero<br/>modifier</a> | FEAT_PAuth |
| 0001          | 11111 | 0001xx |             |             | UNALLOCATED                                                                       | -          |
| 0001          | 11111 | 001xxx |             |             | UNALLOCATED                                                                       | -          |
| 0001          | 11111 | 01xxxx |             |             | UNALLOCATED                                                                       | -          |
| 0001          | 11111 | 1xxxxx |             |             | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 000000 |             | !=<br>00000 | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 000000 |             | 00000       | <a href="#">RET</a>                                                               | -          |
| 0010          | 11111 | 000001 |             |             | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 000010 | !=<br>11111 | !=<br>11111 | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 000010 | !=<br>11111 | 11111       | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 000010 | 11111       | !=<br>11111 | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 000010 | 11111       | 11111       | <a href="#">RETAAC, RETAB â€”<br/>RETAAC</a>                                      | FEAT_PAuth |
| 0010          | 11111 | 000011 | !=<br>11111 | !=<br>11111 | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 000011 | !=<br>11111 | 11111       | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 000011 | 11111       | !=<br>11111 | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 000011 | 11111       | 11111       | <a href="#">RETAAC, RETAB â€”<br/>RETAB</a>                                       | FEAT_PAuth |
| 0010          | 11111 | 0001xx |             |             | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 001xxx |             |             | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 01xxxx |             |             | UNALLOCATED                                                                       | -          |
| 0010          | 11111 | 1xxxxx |             |             | UNALLOCATED                                                                       | -          |

| Decode fields |       |              |             |             | Instruction Details                                                                            | Feature    |
|---------------|-------|--------------|-------------|-------------|------------------------------------------------------------------------------------------------|------------|
| opc           | op2   | op3          | Rn          | op4         |                                                                                                |            |
| 0011          | 11111 |              |             |             | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000000       | !=<br>11111 | !=<br>00000 | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000000       | !=<br>11111 | 00000       | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000000       | 11111       | !=<br>00000 | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000000       | 11111       | 00000       | <a href="#">ERET</a>                                                                           | -          |
| 0100          | 11111 | 000001       |             |             | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000010       | !=<br>11111 | !=<br>11111 | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000010       | !=<br>11111 | 11111       | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000010       | 11111       | !=<br>11111 | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000010       | 11111       | 11111       | <a href="#">ERETAA, ERETAB</a><br>â€” <a href="#">ERETAA</a>                                   | FEAT_PAuth |
| 0100          | 11111 | 000011       | !=<br>11111 | !=<br>11111 | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000011       | !=<br>11111 | 11111       | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000011       | 11111       | !=<br>11111 | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 000011       | 11111       | 11111       | <a href="#">ERETAA, ERETAB</a><br>â€” <a href="#">ERETAB</a>                                   | FEAT_PAuth |
| 0100          | 11111 | 0001xx       |             |             | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 001xxx       |             |             | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 01xxxx       |             |             | UNALLOCATED                                                                                    | -          |
| 0100          | 11111 | 1xxxxx       |             |             | UNALLOCATED                                                                                    | -          |
| 0101          | 11111 | !=<br>000000 |             |             | UNALLOCATED                                                                                    | -          |
| 0101          | 11111 | 000000       | !=<br>11111 | !=<br>00000 | UNALLOCATED                                                                                    | -          |
| 0101          | 11111 | 000000       | !=<br>11111 | 00000       | UNALLOCATED                                                                                    | -          |
| 0101          | 11111 | 000000       | 11111       | !=<br>00000 | UNALLOCATED                                                                                    | -          |
| 0101          | 11111 | 000000       | 11111       | 00000       | <a href="#">DRPS</a>                                                                           | -          |
| 011x          | 11111 |              |             |             | UNALLOCATED                                                                                    | -          |
| 1000          | 11111 | 00000x       |             |             | UNALLOCATED                                                                                    | -          |
| 1000          | 11111 | 000010       |             |             | <a href="#">BRAA, BRAAZ,</a><br><a href="#">BRAB, BRABZ</a> â€”<br>key A, register<br>modifier | FEAT_PAuth |

| Decode fields |       |        |    |     | Instruction Details                                                                                                             | Feature    |
|---------------|-------|--------|----|-----|---------------------------------------------------------------------------------------------------------------------------------|------------|
| opc           | op2   | op3    | Rn | op4 |                                                                                                                                 |            |
| 1000          | 11111 | 000011 |    |     | <a href="#">BRAA</a> , <a href="#">BRAAZ</a> ,<br><a href="#">BRAB</a> , <a href="#">BRABZ</a> â€“ key B, register modifier     | FEAT_PAuth |
| 1000          | 11111 | 0001xx |    |     | UNALLOCATED                                                                                                                     | -          |
| 1000          | 11111 | 001xxx |    |     | UNALLOCATED                                                                                                                     | -          |
| 1000          | 11111 | 01xxxx |    |     | UNALLOCATED                                                                                                                     | -          |
| 1000          | 11111 | 1xxxxx |    |     | UNALLOCATED                                                                                                                     | -          |
| 1001          | 11111 | 00000x |    |     | UNALLOCATED                                                                                                                     | -          |
| 1001          | 11111 | 000010 |    |     | <a href="#">BLRAA</a> , <a href="#">BLRAAZ</a> ,<br><a href="#">BLRAB</a> , <a href="#">BLRABZ</a> â€“ key A, register modifier | FEAT_PAuth |
| 1001          | 11111 | 000011 |    |     | <a href="#">BLRAA</a> , <a href="#">BLRAAZ</a> ,<br><a href="#">BLRAB</a> , <a href="#">BLRABZ</a> â€“ key B, register modifier | FEAT_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](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |       |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|-------|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |       |
| op | 0  | 0  | 1  | 0  | 1  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  | imm26 |

| Decode fields |  | Instruction Details |
|---------------|--|---------------------|
| op            |  |                     |
| 0             |  | <a href="#">B</a>   |
| 1             |  | <a href="#">BL</a>  |

### Compare and branch (immediate)

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |    |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| sf | 0  | 1  | 1  | 0  | 1  | 0  | op |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | Rt |   |   |

| Decode fields |    | Instruction Details |
|---------------|----|---------------------|
| sf            | op |                     |

|   |   |                                 |
|---|---|---------------------------------|
| 0 | 0 | <a href="#">CBZ</a> â€“ 32-bit  |
| 0 | 1 | <a href="#">CBNZ</a> â€“ 32-bit |
| 1 | 0 | <a href="#">CBZ</a> â€“ 64-bit  |
| 1 | 1 | <a href="#">CBNZ</a> â€“ 64-bit |

### Test and branch (immediate)

These instructions are under [Branches, Exception Generating and System instructions](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |    |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| b5 | 0  | 1  | 1  | 0  | 1  | 1  | op |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | Rt |   |   |

| Decode fields |  | Instruction Details |
|---------------|--|---------------------|
| op            |  |                     |

|   |                      |
|---|----------------------|
| 0 | <a href="#">TBZ</a>  |
| 1 | <a href="#">TBNZ</a> |

### Loads and Stores

These instructions are under the [top-level](#).

|     |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31  | 30 | 29  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| op0 | 1  | op1 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     |                   | Instruction details                                                         |
|---------------|-----|-------------------|-----------------------------------------------------------------------------|
| op0           | op1 | op2               |                                                                             |
| 0x00          | 0   | 00xxxxxxxxxxxxxx  | <a href="#">Compare and swap pair</a>                                       |
| 0x00          | 1   | 00x000000xxxxxx   | <a href="#">Advanced SIMD load/store multiple structures</a>                |
| 0x00          | 1   | 00xxxxxx1xxxxxxx  | UNALLOCATED                                                                 |
| 0x00          | 1   | 01x0xxxxxxxxxxxxx | <a href="#">Advanced SIMD load/store multiple structures (post-indexed)</a> |
| 0x00          | 1   | 0xx1xxxxxxxxxxxxx | UNALLOCATED                                                                 |
| 0x00          | 1   | 10xx0000xxxxxxx   | <a href="#">Advanced SIMD load/store single structure</a>                   |
| 0x00          | 1   | 11xxxxxxxxxxxxxx  | <a href="#">Advanced SIMD load/store single structure (post-indexed)</a>    |
| 0x00          | 1   | x0xx1xxxxxxxxxxx  | UNALLOCATED                                                                 |
| 0x00          | 1   | x0xx1xxxxxxxxxxx  | UNALLOCATED                                                                 |

|      |   |                   |                                                              |
|------|---|-------------------|--------------------------------------------------------------|
| 0x00 | 1 | x0xxxx1xxxxxxxxx  | UNALLOCATED                                                  |
| 0x00 | 1 | x0xxxx1xxxxxxxxx  | UNALLOCATED                                                  |
| 0x01 | 0 | 1xx1xxxx000010    | <a href="#">RCW compare and swap</a>                         |
| 0x01 | 0 | 1xx1xxxx000011    | <a href="#">RCW compare and swap pair</a>                    |
| 0x01 | 0 | 1xx1xxxxxxxxx00   | <a href="#">128-bit atomic memory operations</a>             |
| 1101 | 0 | 1000111110xxx11   | <a href="#">GCS load/store</a>                               |
| 1101 | 0 | 1xx1xxxxxxxxxxxxx | <a href="#">Load/store memory tags</a>                       |
| 1x00 | 0 | 00x1xxxxxxxxxxxxx | <a href="#">Load/store exclusive pair</a>                    |
| 1x00 | 1 |                   | UNALLOCATED                                                  |
| xx00 | 0 | 00x0xxxxxxxxxxxxx | <a href="#">Load/store exclusive register</a>                |
| xx00 | 0 | 01x0xxxxxxxxxxxxx | <a href="#">Load/store ordered</a>                           |
| xx00 | 0 | 01x1xxxxxxxxxxxxx | <a href="#">Compare and swap</a>                             |
| xx01 | 0 | 10x0xxxxxxxxxx10  | <a href="#">LDIAPP/STILP</a>                                 |
| xx01 | 0 | 11x000000000010   | <a href="#">LDAPR/STLR (writeback)</a>                       |
| xx01 | 0 | 1xx0xxxxxxxxxx00  | <a href="#">LDAPR/STLR (unscaled immediate)</a>              |
| xx01 | 1 | 1xx0xxxxxxxxxx10  | <a href="#">LDAPR/STLR (SIMD&amp;FP)</a>                     |
| xx01 |   | 0xxxxxxxxxxxxxx   | <a href="#">Load register (literal)</a>                      |
| xx01 |   | 1xx0xxxxxxxxxx01  | <a href="#">Memory Copy and Memory Set</a>                   |
| xx10 |   | 0xxxxxxxxxxxxxx   | <a href="#">Load/store no-allocate pair (offset)</a>         |
| xx10 |   | 01xxxxxxxxxxxxxx  | <a href="#">Load/store register pair (post-indexed)</a>      |
| xx10 |   | 10xxxxxxxxxxxxxx  | <a href="#">Load/store register pair (offset)</a>            |
| xx10 |   | 11xxxxxxxxxxxxxx  | <a href="#">Load/store register pair (pre-indexed)</a>       |
| xx11 |   | 0xx0xxxxxxxxxx00  | <a href="#">Load/store register (unscaled immediate)</a>     |
| xx11 |   | 0xx0xxxxxxxxxx01  | <a href="#">Load/store register (immediate post-indexed)</a> |
| xx11 |   | 0xx0xxxxxxxxxx10  | <a href="#">Load/store register (unprivileged)</a>           |
| xx11 |   | 0xx0xxxxxxxxxx11  | <a href="#">Load/store register (immediate pre-indexed)</a>  |
| xx11 |   | 0xx1xxxxxxxxxx00  | <a href="#">Atomic memory operations</a>                     |
| xx11 |   | 0xx1xxxxxxxxxx10  | <a href="#">Load/store register (register offset)</a>        |
| xx11 |   | 0xx1xxxxxxxxxx11  | <a href="#">Load/store register (pac)</a>                    |
| xx11 |   | 1xxxxxxxxxxxxxx   | <a href="#">Load/store register (unsigned immediate)</a>     |

## Compare and swap pair

These instructions are under [Loads and Stores](#).

| Decode fields |   |    |             | Instruction Details                                                             | Feature  |
|---------------|---|----|-------------|---------------------------------------------------------------------------------|----------|
| sz            | L | o0 | Rt2         |                                                                                 |          |
|               |   |    | !=<br>11111 | UNALLOCATED                                                                     | -        |
| 0             | 0 | 0  | 11111       | <a href="#">CASP, CASPA, CASPAL, CASPL</a><br>â€” <a href="#">32-bit CASP</a>   | FEAT_LSE |
| 0             | 0 | 1  | 11111       | <a href="#">CASP, CASPA, CASPAL, CASPL</a><br>â€” <a href="#">32-bit CASPL</a>  | FEAT_LSE |
| 0             | 1 | 0  | 11111       | <a href="#">CASP, CASPA, CASPAL, CASPL</a><br>â€” <a href="#">32-bit CASPA</a>  | FEAT_LSE |
| 0             | 1 | 1  | 11111       | <a href="#">CASP, CASPA, CASPAL, CASPL</a><br>â€” <a href="#">32-bit CASPAL</a> | FEAT_LSE |
| 1             | 0 | 0  | 11111       | <a href="#">CASP, CASPA, CASPAL, CASPL</a><br>â€” <a href="#">64-bit CASP</a>   | FEAT_LSE |
| 1             | 0 | 1  | 11111       | <a href="#">CASP, CASPA, CASPAL, CASPL</a><br>â€” <a href="#">64-bit CASPL</a>  | FEAT_LSE |
| 1             | 1 | 0  | 11111       | <a href="#">CASP, CASPA, CASPAL, CASPL</a><br>â€” <a href="#">64-bit CASPA</a>  | FEAT_LSE |
| 1             | 1 | 1  | 11111       | <a href="#">CASP, CASPA, CASPAL, CASPL</a><br>â€” <a href="#">64-bit CASPAL</a> | FEAT_LSE |

### Advanced SIMD load/store multiple structures

These instructions are under [Loads and Stores](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16     | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | L  | 0  | 0  | 0  | 0  | 0  | opcode | size | Rn | Rt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |        | Instruction Details                                                           |
|---------------|--------|-------------------------------------------------------------------------------|
| L             | opcode |                                                                               |
| 0             | 0000   | <a href="#">ST4 (multiple structures)</a>                                     |
| 0             | 0001   | UNALLOCATED                                                                   |
| 0             | 0010   | <a href="#">ST1 (multiple structures)</a> â€” <a href="#">four registers</a>  |
| 0             | 0011   | UNALLOCATED                                                                   |
| 0             | 0100   | <a href="#">ST3 (multiple structures)</a>                                     |
| 0             | 0101   | UNALLOCATED                                                                   |
| 0             | 0110   | <a href="#">ST1 (multiple structures)</a> â€” <a href="#">three registers</a> |
| 0             | 0111   | <a href="#">ST1 (multiple structures)</a> â€” <a href="#">one register</a>    |
| 0             | 1000   | <a href="#">ST2 (multiple structures)</a>                                     |
| 0             | 1001   | UNALLOCATED                                                                   |
| 0             | 1010   | <a href="#">ST1 (multiple structures)</a> â€” <a href="#">two registers</a>   |
| 0             | 1011   | UNALLOCATED                                                                   |
| 0             | 11xx   | UNALLOCATED                                                                   |

| Decode fields |        | Instruction Details                                                           |
|---------------|--------|-------------------------------------------------------------------------------|
| L             | opcode |                                                                               |
| 1             | 0000   | <a href="#">LD4 (multiple structures)</a>                                     |
| 1             | 0001   | UNALLOCATED                                                                   |
| 1             | 0010   | <a href="#">LD1 (multiple structures)</a> â€“ <a href="#">four registers</a>  |
| 1             | 0011   | UNALLOCATED                                                                   |
| 1             | 0100   | <a href="#">LD3 (multiple structures)</a>                                     |
| 1             | 0101   | UNALLOCATED                                                                   |
| 1             | 0110   | <a href="#">LD1 (multiple structures)</a> â€“ <a href="#">three registers</a> |
| 1             | 0111   | <a href="#">LD1 (multiple structures)</a> â€“ <a href="#">one register</a>    |
| 1             | 1000   | <a href="#">LD2 (multiple structures)</a>                                     |
| 1             | 1001   | UNALLOCATED                                                                   |
| 1             | 1010   | <a href="#">LD1 (multiple structures)</a> â€“ <a href="#">two registers</a>   |
| 1             | 1011   | UNALLOCATED                                                                   |
| 1             | 11xx   | UNALLOCATED                                                                   |

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

These instructions are under [Loads and Stores](#).

|    |    |    |    |    |    |    |    |    |    |    |    |        |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|--------|------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | L  | 0  | Rm | opcode | size | Rn | Rt |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| 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             | !=<br>11111 | 0000   | <a href="#">ST4 (multiple structures)</a> â€“ <a href="#">register offset</a>                  |
| 0             | !=<br>11111 | 0010   | <a href="#">ST1 (multiple structures)</a> â€“ <a href="#">four registers, register offset</a>  |
| 0             | !=<br>11111 | 0100   | <a href="#">ST3 (multiple structures)</a> â€“ <a href="#">register offset</a>                  |
| 0             | !=<br>11111 | 0110   | <a href="#">ST1 (multiple structures)</a> â€“ <a href="#">three registers, register offset</a> |
| 0             | !=<br>11111 | 0111   | <a href="#">ST1 (multiple structures)</a> â€“ <a href="#">one register, register offset</a>    |
| 0             | !=<br>11111 | 1000   | <a href="#">ST2 (multiple structures)</a> â€“ <a href="#">register offset</a>                  |

| Decode fields |              |        | Instruction Details                                                             |
|---------------|--------------|--------|---------------------------------------------------------------------------------|
| L             | Rm           | opcode |                                                                                 |
| 0             | $\neq 11111$ | 1010   | <a href="#">ST1 (multiple structures)</a> â€“ two registers, register offset    |
| 0             | 11111        | 0000   | <a href="#">ST4 (multiple structures)</a> â€“ immediate offset                  |
| 0             | 11111        | 0010   | <a href="#">ST1 (multiple structures)</a> â€“ four registers, immediate offset  |
| 0             | 11111        | 0100   | <a href="#">ST3 (multiple structures)</a> â€“ immediate offset                  |
| 0             | 11111        | 0110   | <a href="#">ST1 (multiple structures)</a> â€“ three registers, immediate offset |
| 0             | 11111        | 0111   | <a href="#">ST1 (multiple structures)</a> â€“ one register, immediate offset    |
| 0             | 11111        | 1000   | <a href="#">ST2 (multiple structures)</a> â€“ immediate offset                  |
| 0             | 11111        | 1010   | <a href="#">ST1 (multiple structures)</a> â€“ two registers, immediate offset   |
| 1             |              | 0001   | UNALLOCATED                                                                     |
| 1             |              | 0011   | UNALLOCATED                                                                     |
| 1             |              | 0101   | UNALLOCATED                                                                     |
| 1             |              | 1001   | UNALLOCATED                                                                     |
| 1             |              | 1011   | UNALLOCATED                                                                     |
| 1             |              | 11xx   | UNALLOCATED                                                                     |
| 1             | $\neq 11111$ | 0000   | <a href="#">LD4 (multiple structures)</a> â€“ register offset                   |
| 1             | $\neq 11111$ | 0010   | <a href="#">LD1 (multiple structures)</a> â€“ four registers, register offset   |
| 1             | $\neq 11111$ | 0100   | <a href="#">LD3 (multiple structures)</a> â€“ register offset                   |
| 1             | $\neq 11111$ | 0110   | <a href="#">LD1 (multiple structures)</a> â€“ three registers, register offset  |
| 1             | $\neq 11111$ | 0111   | <a href="#">LD1 (multiple structures)</a> â€“ one register, register offset     |
| 1             | $\neq 11111$ | 1000   | <a href="#">LD2 (multiple structures)</a> â€“ register offset                   |
| 1             | $\neq 11111$ | 1010   | <a href="#">LD1 (multiple structures)</a> â€“ two registers, register offset    |
| 1             | 11111        | 0000   | <a href="#">LD4 (multiple structures)</a> â€“ immediate offset                  |
| 1             | 11111        | 0010   | <a href="#">LD1 (multiple structures)</a> â€“ four registers, immediate offset  |
| 1             | 11111        | 0100   | <a href="#">LD3 (multiple structures)</a> â€“ immediate offset                  |
| 1             | 11111        | 0110   | <a href="#">LD1 (multiple structures)</a> â€“ three registers, immediate offset |

| Decode fields |       |        | Instruction Details                                                                           |  |
|---------------|-------|--------|-----------------------------------------------------------------------------------------------|--|
| L             | Rm    | opcode |                                                                                               |  |
| 1             | 11111 | 0111   | <a href="#">LD1 (multiple structures)</a> â€“ <a href="#">one register, immediate offset</a>  |  |
| 1             | 11111 | 1000   | <a href="#">LD2 (multiple structures)</a> â€“ <a href="#">immediate offset</a>                |  |
| 1             | 11111 | 1010   | <a href="#">LD1 (multiple structures)</a> â€“ <a href="#">two registers, immediate offset</a> |  |

### Advanced SIMD load/store single structure

These instructions are under [Loads and Stores](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |      |    |    |    |    |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15     | 14 | 13   | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | 0  | 0  | 1  | 1  | 0  | 1  | 0  | L  | R  | 0  | 0  | 0  | 0  | o2 | opcode | S  | size |    | Rn |    | Rt |   |   |   |   |   |   |   |   |   |

| L | R | Decode fields |        |   | Instruction Details |                                                   | Feature |
|---|---|---------------|--------|---|---------------------|---------------------------------------------------|---------|
|   |   | o2            | opcode | S | size                |                                                   |         |
|   | 0 | 1             | x00    | 0 | 00                  | UNALLOCATED                                       | -       |
|   | 0 | 1             | x00    | 0 | 1x                  | UNALLOCATED                                       | -       |
|   | 0 | 1             | x00    | 1 |                     | UNALLOCATED                                       | -       |
|   | 0 | 1             | x01    |   |                     | UNALLOCATED                                       | -       |
|   | 0 | 1             | x1x    |   |                     | UNALLOCATED                                       | -       |
|   | 1 | 1             |        |   |                     | UNALLOCATED                                       | -       |
| 0 |   | 0             | 11x    |   |                     | UNALLOCATED                                       | -       |
| 0 | 0 | 0             | 000    |   |                     | <a href="#">ST1 (single structure)</a> â€“ 8-bit  | -       |
| 0 | 0 | 0             | 001    |   |                     | <a href="#">ST3 (single structure)</a> â€“ 8-bit  | -       |
| 0 | 0 | 0             | 010    |   | x0                  | <a href="#">ST1 (single structure)</a> â€“ 16-bit | -       |
| 0 | 0 | 0             | 010    |   | x1                  | UNALLOCATED                                       | -       |
| 0 | 0 | 0             | 011    |   | x0                  | <a href="#">ST3 (single structure)</a> â€“ 16-bit | -       |
| 0 | 0 | 0             | 011    |   | x1                  | UNALLOCATED                                       | -       |
| 0 | 0 | 0             | 100    |   | 00                  | <a href="#">ST1 (single structure)</a> â€“ 32-bit | -       |
| 0 | 0 | 0             | 100    |   | 1x                  | UNALLOCATED                                       | -       |

| Decode fields |   |    |        |   |      | Instruction Details                               | Feature     |
|---------------|---|----|--------|---|------|---------------------------------------------------|-------------|
| L             | R | o2 | opcode | S | size |                                                   |             |
| 0             | 0 | 0  | 100    | 0 | 01   | <a href="#">ST1 (single structure) â€“ 64-bit</a> | -           |
| 0             | 0 | 0  | 100    | 1 | 01   | UNALLOCATED                                       | -           |
| 0             | 0 | 0  | 101    |   | 00   | <a href="#">ST3 (single structure) â€“ 32-bit</a> | -           |
| 0             | 0 | 0  | 101    |   | 10   | UNALLOCATED                                       | -           |
| 0             | 0 | 0  | 101    | 0 | 01   | <a href="#">ST3 (single structure) â€“ 64-bit</a> | -           |
| 0             | 0 | 0  | 101    | 0 | 11   | UNALLOCATED                                       | -           |
| 0             | 0 | 0  | 101    | 1 | x1   | UNALLOCATED                                       | -           |
| 0             | 0 | 1  | 100    | 0 | 01   | <a href="#">STL1 (SIMD&amp;FP)</a>                | FEAT_LRCPC3 |
| 0             | 1 | 0  | 000    |   |      | <a href="#">ST2 (single structure) â€“ 8-bit</a>  | -           |
| 0             | 1 | 0  | 001    |   |      | <a href="#">ST4 (single structure) â€“ 8-bit</a>  | -           |
| 0             | 1 | 0  | 010    |   | x0   | <a href="#">ST2 (single structure) â€“ 16-bit</a> | -           |
| 0             | 1 | 0  | 010    |   | x1   | UNALLOCATED                                       | -           |
| 0             | 1 | 0  | 011    |   | x0   | <a href="#">ST4 (single structure) â€“ 16-bit</a> | -           |
| 0             | 1 | 0  | 011    |   | x1   | UNALLOCATED                                       | -           |
| 0             | 1 | 0  | 100    |   | 00   | <a href="#">ST2 (single structure) â€“ 32-bit</a> | -           |
| 0             | 1 | 0  | 100    |   | 10   | UNALLOCATED                                       | -           |
| 0             | 1 | 0  | 100    | 0 | 01   | <a href="#">ST2 (single structure) â€“ 64-bit</a> | -           |
| 0             | 1 | 0  | 100    | 0 | 11   | UNALLOCATED                                       | -           |
| 0             | 1 | 0  | 100    | 1 | x1   | UNALLOCATED                                       | -           |
| 0             | 1 | 0  | 101    |   | 00   | <a href="#">ST4 (single structure) â€“ 32-bit</a> | -           |
| 0             | 1 | 0  | 101    |   | 10   | UNALLOCATED                                       | -           |
| 0             | 1 | 0  | 101    | 0 | 01   | <a href="#">ST4 (single structure) â€“ 64-bit</a> | -           |

| Decode fields |   |    |        |   |      | Instruction Details                               | Feature     |
|---------------|---|----|--------|---|------|---------------------------------------------------|-------------|
| L             | R | o2 | opcode | S | size |                                                   |             |
| 0             | 1 | 0  | 101    | 0 | 11   | UNALLOCATED                                       | -           |
| 0             | 1 | 0  | 101    | 1 | x1   | UNALLOCATED                                       | -           |
| 1             | 0 | 0  | 000    |   |      | <a href="#">LD1 (single structure)</a> â€” 8-bit  | -           |
| 1             | 0 | 0  | 001    |   |      | <a href="#">LD3 (single structure)</a> â€” 8-bit  | -           |
| 1             | 0 | 0  | 010    |   | x0   | <a href="#">LD1 (single structure)</a> â€” 16-bit | -           |
| 1             | 0 | 0  | 010    |   | x1   | UNALLOCATED                                       | -           |
| 1             | 0 | 0  | 011    |   | x0   | <a href="#">LD3 (single structure)</a> â€” 16-bit | -           |
| 1             | 0 | 0  | 011    |   | x1   | UNALLOCATED                                       | -           |
| 1             | 0 | 0  | 100    |   | 00   | <a href="#">LD1 (single structure)</a> â€” 32-bit | -           |
| 1             | 0 | 0  | 100    |   | 1x   | UNALLOCATED                                       | -           |
| 1             | 0 | 0  | 100    | 0 | 01   | <a href="#">LD1 (single structure)</a> â€” 64-bit | -           |
| 1             | 0 | 0  | 100    | 1 | 01   | UNALLOCATED                                       | -           |
| 1             | 0 | 0  | 101    |   | 00   | <a href="#">LD3 (single structure)</a> â€” 32-bit | -           |
| 1             | 0 | 0  | 101    |   | 10   | UNALLOCATED                                       | -           |
| 1             | 0 | 0  | 101    | 0 | 01   | <a href="#">LD3 (single structure)</a> â€” 64-bit | -           |
| 1             | 0 | 0  | 101    | 0 | 11   | UNALLOCATED                                       | -           |
| 1             | 0 | 0  | 101    | 1 | x1   | UNALLOCATED                                       | -           |
| 1             | 0 | 0  | 110    | 0 |      | <a href="#">LD1R</a>                              | -           |
| 1             | 0 | 0  | 110    | 1 |      | UNALLOCATED                                       | -           |
| 1             | 0 | 0  | 111    | 0 |      | <a href="#">LD3R</a>                              | -           |
| 1             | 0 | 0  | 111    | 1 |      | UNALLOCATED                                       | -           |
| 1             | 0 | 1  | 100    | 0 | 01   | <a href="#">LDAP1 (SIMD&amp;FP)</a>               | FEAT_LRCPC3 |
| 1             | 1 | 0  | 000    |   |      | <a href="#">LD2 (single structure)</a> â€” 8-bit  | -           |

| Decode fields |   |    |        |   | Instruction Details |                                               | Feature |
|---------------|---|----|--------|---|---------------------|-----------------------------------------------|---------|
| L             | R | o2 | opcode | S | size                |                                               |         |
| 1             | 1 | 0  | 001    |   |                     | <a href="#">LD4 (single structure)</a> 8-bit  | -       |
| 1             | 1 | 0  | 010    |   | x0                  | <a href="#">LD2 (single structure)</a> 16-bit | -       |
| 1             | 1 | 0  | 010    |   | x1                  | UNALLOCATED                                   | -       |
| 1             | 1 | 0  | 011    |   | x0                  | <a href="#">LD4 (single structure)</a> 16-bit | -       |
| 1             | 1 | 0  | 011    |   | x1                  | UNALLOCATED                                   | -       |
| 1             | 1 | 0  | 100    |   | 00                  | <a href="#">LD2 (single structure)</a> 32-bit | -       |
| 1             | 1 | 0  | 100    |   | 10                  | UNALLOCATED                                   | -       |
| 1             | 1 | 0  | 100    | 0 | 01                  | <a href="#">LD2 (single structure)</a> 64-bit | -       |
| 1             | 1 | 0  | 100    | 0 | 11                  | UNALLOCATED                                   | -       |
| 1             | 1 | 0  | 100    | 1 | x1                  | UNALLOCATED                                   | -       |
| 1             | 1 | 0  | 101    |   | 00                  | <a href="#">LD4 (single structure)</a> 32-bit | -       |
| 1             | 1 | 0  | 101    |   | 10                  | UNALLOCATED                                   | -       |
| 1             | 1 | 0  | 101    | 0 | 01                  | <a href="#">LD4 (single structure)</a> 64-bit | -       |
| 1             | 1 | 0  | 101    | 0 | 11                  | UNALLOCATED                                   | -       |
| 1             | 1 | 0  | 101    | 1 | x1                  | UNALLOCATED                                   | -       |
| 1             | 1 | 0  | 110    | 0 |                     | <a href="#">LD2R</a>                          | -       |
| 1             | 1 | 0  | 110    | 1 |                     | UNALLOCATED                                   | -       |
| 1             | 1 | 0  | 111    | 0 |                     | <a href="#">LD4R</a>                          | -       |
| 1             | 1 | 0  | 111    | 1 |                     | UNALLOCATED                                   | -       |

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

These instructions are under [Loads and Stores](#).

| 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    |   |      | <a href="#">ST1 (single structure) â€“ 8-bit, register offset</a>   |
| 0             | 0 | != 11111 | 001    |   |      | <a href="#">ST3 (single structure) â€“ 8-bit, register offset</a>   |
| 0             | 0 | != 11111 | 010    |   | x0   | <a href="#">ST1 (single structure) â€“ 16-bit, register offset</a>  |
| 0             | 0 | != 11111 | 011    |   | x0   | <a href="#">ST3 (single structure) â€“ 16-bit, register offset</a>  |
| 0             | 0 | != 11111 | 100    |   | 00   | <a href="#">ST1 (single structure) â€“ 32-bit, register offset</a>  |
| 0             | 0 | != 11111 | 100    | 0 | 01   | <a href="#">ST1 (single structure) â€“ 64-bit, register offset</a>  |
| 0             | 0 | != 11111 | 101    |   | 00   | <a href="#">ST3 (single structure) â€“ 32-bit, register offset</a>  |
| 0             | 0 | != 11111 | 101    | 0 | 01   | <a href="#">ST3 (single structure) â€“ 64-bit, register offset</a>  |
| 0             | 0 | 11111    | 000    |   |      | <a href="#">ST1 (single structure) â€“ 8-bit, immediate offset</a>  |
| 0             | 0 | 11111    | 001    |   |      | <a href="#">ST3 (single structure) â€“ 8-bit, immediate offset</a>  |
| 0             | 0 | 11111    | 010    |   | x0   | <a href="#">ST1 (single structure) â€“ 16-bit, immediate offset</a> |
| 0             | 0 | 11111    | 011    |   | x0   | <a href="#">ST3 (single structure) â€“ 16-bit, immediate offset</a> |
| 0             | 0 | 11111    | 100    |   | 00   | <a href="#">ST1 (single structure) â€“ 32-bit, immediate offset</a> |
| 0             | 0 | 11111    | 100    | 0 | 01   | <a href="#">ST1 (single structure) â€“ 64-bit, immediate offset</a> |
| 0             | 0 | 11111    | 101    |   | 00   | <a href="#">ST3 (single structure) â€“ 32-bit, immediate offset</a> |
| 0             | 0 | 11111    | 101    | 0 | 01   | <a href="#">ST3 (single structure) â€“ 64-bit, immediate offset</a> |
| 0             | 1 |          | 010    |   | x1   | UNALLOCATED                                                         |
| 0             | 1 |          | 011    |   | x1   | UNALLOCATED                                                         |

| Decode fields |   |          |        |   |      | Instruction Details                                                 |
|---------------|---|----------|--------|---|------|---------------------------------------------------------------------|
| L             | R | Rm       | opcode | S | size |                                                                     |
| 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    |   |      | <a href="#">ST2 (single structure)</a> â€“ 8-bit, register offset   |
| 0             | 1 | != 11111 | 001    |   |      | <a href="#">ST4 (single structure)</a> â€“ 8-bit, register offset   |
| 0             | 1 | != 11111 | 010    |   | x0   | <a href="#">ST2 (single structure)</a> â€“ 16-bit, register offset  |
| 0             | 1 | != 11111 | 011    |   | x0   | <a href="#">ST4 (single structure)</a> â€“ 16-bit, register offset  |
| 0             | 1 | != 11111 | 100    |   | 00   | <a href="#">ST2 (single structure)</a> â€“ 32-bit, register offset  |
| 0             | 1 | != 11111 | 100    | 0 | 01   | <a href="#">ST2 (single structure)</a> â€“ 64-bit, register offset  |
| 0             | 1 | != 11111 | 101    |   | 00   | <a href="#">ST4 (single structure)</a> â€“ 32-bit, register offset  |
| 0             | 1 | != 11111 | 101    | 0 | 01   | <a href="#">ST4 (single structure)</a> â€“ 64-bit, register offset  |
| 0             | 1 | 11111    | 000    |   |      | <a href="#">ST2 (single structure)</a> â€“ 8-bit, immediate offset  |
| 0             | 1 | 11111    | 001    |   |      | <a href="#">ST4 (single structure)</a> â€“ 8-bit, immediate offset  |
| 0             | 1 | 11111    | 010    |   | x0   | <a href="#">ST2 (single structure)</a> â€“ 16-bit, immediate offset |
| 0             | 1 | 11111    | 011    |   | x0   | <a href="#">ST4 (single structure)</a> â€“ 16-bit, immediate offset |
| 0             | 1 | 11111    | 100    |   | 00   | <a href="#">ST2 (single structure)</a> â€“ 32-bit, immediate offset |
| 0             | 1 | 11111    | 100    | 0 | 01   | <a href="#">ST2 (single structure)</a> â€“ 64-bit, immediate offset |
| 0             | 1 | 11111    | 101    |   | 00   | <a href="#">ST4 (single structure)</a> â€“ 32-bit, immediate offset |
| 0             | 1 | 11111    | 101    | 0 | 01   | <a href="#">ST4 (single structure)</a> â€“ 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                                                         |

| Decode fields |   |          |        |   |      | Instruction Details                                                 |
|---------------|---|----------|--------|---|------|---------------------------------------------------------------------|
| L             | R | Rm       | opcode | S | size |                                                                     |
| 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    |   |      | <a href="#">LD1 (single structure)</a> â€“ 8-bit, register offset   |
| 1             | 0 | != 11111 | 001    |   |      | <a href="#">LD3 (single structure)</a> â€“ 8-bit, register offset   |
| 1             | 0 | != 11111 | 010    |   | x0   | <a href="#">LD1 (single structure)</a> â€“ 16-bit, register offset  |
| 1             | 0 | != 11111 | 011    |   | x0   | <a href="#">LD3 (single structure)</a> â€“ 16-bit, register offset  |
| 1             | 0 | != 11111 | 100    |   | 00   | <a href="#">LD1 (single structure)</a> â€“ 32-bit, register offset  |
| 1             | 0 | != 11111 | 100    | 0 | 01   | <a href="#">LD1 (single structure)</a> â€“ 64-bit, register offset  |
| 1             | 0 | != 11111 | 101    |   | 00   | <a href="#">LD3 (single structure)</a> â€“ 32-bit, register offset  |
| 1             | 0 | != 11111 | 101    | 0 | 01   | <a href="#">LD3 (single structure)</a> â€“ 64-bit, register offset  |
| 1             | 0 | != 11111 | 110    | 0 |      | <a href="#">LD1R</a> â€“ register offset                            |
| 1             | 0 | != 11111 | 111    | 0 |      | <a href="#">LD3R</a> â€“ register offset                            |
| 1             | 0 | 11111    | 000    |   |      | <a href="#">LD1 (single structure)</a> â€“ 8-bit, immediate offset  |
| 1             | 0 | 11111    | 001    |   |      | <a href="#">LD3 (single structure)</a> â€“ 8-bit, immediate offset  |
| 1             | 0 | 11111    | 010    |   | x0   | <a href="#">LD1 (single structure)</a> â€“ 16-bit, immediate offset |
| 1             | 0 | 11111    | 011    |   | x0   | <a href="#">LD3 (single structure)</a> â€“ 16-bit, immediate offset |
| 1             | 0 | 11111    | 100    |   | 00   | <a href="#">LD1 (single structure)</a> â€“ 32-bit, immediate offset |
| 1             | 0 | 11111    | 100    | 0 | 01   | <a href="#">LD1 (single structure)</a> â€“ 64-bit, immediate offset |
| 1             | 0 | 11111    | 101    |   | 00   | <a href="#">LD3 (single structure)</a> â€“ 32-bit, immediate offset |
| 1             | 0 | 11111    | 101    | 0 | 01   | <a href="#">LD3 (single structure)</a> â€“ 64-bit, immediate offset |
| 1             | 0 | 11111    | 110    | 0 |      | <a href="#">LD1R</a> â€“ immediate offset                           |
| 1             | 0 | 11111    | 111    | 0 |      | <a href="#">LD3R</a> â€“ immediate offset                           |
| 1             | 1 |          | 010    |   | x1   | UNALLOCATED                                                         |
| 1             | 1 |          | 011    |   | x1   | UNALLOCATED                                                         |

| Decode fields |   |          |        |   |      | Instruction Details                                                 |
|---------------|---|----------|--------|---|------|---------------------------------------------------------------------|
| L             | R | Rm       | opcode | S | size |                                                                     |
| 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    |   |      | <a href="#">LD2 (single structure)</a> â€“ 8-bit, register offset   |
| 1             | 1 | != 11111 | 001    |   |      | <a href="#">LD4 (single structure)</a> â€“ 8-bit, register offset   |
| 1             | 1 | != 11111 | 010    |   | x0   | <a href="#">LD2 (single structure)</a> â€“ 16-bit, register offset  |
| 1             | 1 | != 11111 | 011    |   | x0   | <a href="#">LD4 (single structure)</a> â€“ 16-bit, register offset  |
| 1             | 1 | != 11111 | 100    |   | 00   | <a href="#">LD2 (single structure)</a> â€“ 32-bit, register offset  |
| 1             | 1 | != 11111 | 100    | 0 | 01   | <a href="#">LD2 (single structure)</a> â€“ 64-bit, register offset  |
| 1             | 1 | != 11111 | 101    |   | 00   | <a href="#">LD4 (single structure)</a> â€“ 32-bit, register offset  |
| 1             | 1 | != 11111 | 101    | 0 | 01   | <a href="#">LD4 (single structure)</a> â€“ 64-bit, register offset  |
| 1             | 1 | != 11111 | 110    | 0 |      | <a href="#">LD2R</a> â€“ register offset                            |
| 1             | 1 | != 11111 | 111    | 0 |      | <a href="#">LD4R</a> â€“ register offset                            |
| 1             | 1 | 11111    | 000    |   |      | <a href="#">LD2 (single structure)</a> â€“ 8-bit, immediate offset  |
| 1             | 1 | 11111    | 001    |   |      | <a href="#">LD4 (single structure)</a> â€“ 8-bit, immediate offset  |
| 1             | 1 | 11111    | 010    |   | x0   | <a href="#">LD2 (single structure)</a> â€“ 16-bit, immediate offset |
| 1             | 1 | 11111    | 011    |   | x0   | <a href="#">LD4 (single structure)</a> â€“ 16-bit, immediate offset |
| 1             | 1 | 11111    | 100    |   | 00   | <a href="#">LD2 (single structure)</a> â€“ 32-bit, immediate offset |
| 1             | 1 | 11111    | 100    | 0 | 01   | <a href="#">LD2 (single structure)</a> â€“ 64-bit, immediate offset |
| 1             | 1 | 11111    | 101    |   | 00   | <a href="#">LD4 (single structure)</a> â€“ 32-bit, immediate offset |
| 1             | 1 | 11111    | 101    | 0 | 01   | <a href="#">LD4 (single structure)</a> â€“ 64-bit, immediate offset |

| Decode fields |   |       |        |   |      | Instruction Details  |                    |
|---------------|---|-------|--------|---|------|----------------------|--------------------|
| L             | R | Rm    | opcode | S | size |                      |                    |
| 1             | 1 | 11111 | 110    | 0 |      | <a href="#">LD2R</a> | " immediate offset |
| 1             | 1 | 11111 | 111    | 0 |      | <a href="#">LD4R</a> | " immediate offset |

### RCW compare and swap

These instructions are under [Loads and Stores](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | S  | 0  | 1  | 1  | 0  | 0  | 1  | A  | R  | 1  |    | Rs | 0  | 0  | 0  | 0  | 1  | 0  | Rn |    | Rt |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   | Instruction Details                                                                                                                   |  | Feature  |
|---------------|---|---|---------------------------------------------------------------------------------------------------------------------------------------|--|----------|
| S             | A | R |                                                                                                                                       |  |          |
| 0             | 0 | 0 | <a href="#">RCWCAS</a> , <a href="#">RCWCASA</a> , <a href="#">RCWCASL</a> , <a href="#">RCWCASAL</a> " <a href="#">RCWCAS</a>        |  | FEAT_THE |
| 0             | 0 | 1 | <a href="#">RCWCAS</a> , <a href="#">RCWCASA</a> , <a href="#">RCWCASL</a> , <a href="#">RCWCASAL</a> " <a href="#">RCWCASL</a>       |  | FEAT_THE |
| 0             | 1 | 0 | <a href="#">RCWCAS</a> , <a href="#">RCWCASA</a> , <a href="#">RCWCASL</a> , <a href="#">RCWCASAL</a> " <a href="#">RCWCASA</a>       |  | FEAT_THE |
| 0             | 1 | 1 | <a href="#">RCWCAS</a> , <a href="#">RCWCASA</a> , <a href="#">RCWCASL</a> , <a href="#">RCWCASAL</a> " <a href="#">RCWCASAL</a>      |  | FEAT_THE |
| 1             | 0 | 0 | <a href="#">RCWSCAS</a> , <a href="#">RCWSCASA</a> , <a href="#">RCWSCASL</a> , <a href="#">RCWSCASAL</a> " <a href="#">RCWSCAS</a>   |  | FEAT_THE |
| 1             | 0 | 1 | <a href="#">RCWSCAS</a> , <a href="#">RCWSCASA</a> , <a href="#">RCWSCASL</a> , <a href="#">RCWSCASAL</a> " <a href="#">RCWSCASL</a>  |  | FEAT_THE |
| 1             | 1 | 0 | <a href="#">RCWSCAS</a> , <a href="#">RCWSCASA</a> , <a href="#">RCWSCASL</a> , <a href="#">RCWSCASAL</a> " <a href="#">RCWSCASA</a>  |  | FEAT_THE |
| 1             | 1 | 1 | <a href="#">RCWSCAS</a> , <a href="#">RCWSCASA</a> , <a href="#">RCWSCASL</a> , <a href="#">RCWSCASAL</a> " <a href="#">RCWSCASAL</a> |  | FEAT_THE |

### RCW compare and swap pair

These instructions are under [Loads and Stores](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | S  | 0  | 1  | 1  | 0  | 0  | 1  | A  | R  | 1  |    | Rs | 0  | 0  | 0  | 0  | 1  | 1  | Rn |    | Rt |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   | Instruction Details                                                                                                                 |  | Feature               |
|---------------|---|---|-------------------------------------------------------------------------------------------------------------------------------------|--|-----------------------|
| S             | A | R |                                                                                                                                     |  |                       |
| 0             | 0 | 0 | <a href="#">RCWCASP</a> , <a href="#">RCWCASPA</a> , <a href="#">RCWCASPL</a> , <a href="#">RCWCASPAL</a> " <a href="#">RCWCASP</a> |  | FEAT_D128 && FEAT_THE |

| Decode fields |   |   | Instruction Details                                                                                                                                |  |  | Feature                  |
|---------------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--------------------------|
| S             | A | R |                                                                                                                                                    |  |  |                          |
| 0             | 0 | 1 | <a href="#">RCWCASP</a> , <a href="#">RCWCASPA</a> ,<br><a href="#">RCWCASPL</a> , <a href="#">RCWCASPAL</a> â€”<br><a href="#">RCWCASPL</a>       |  |  | FEAT_D128 &&<br>FEAT_THE |
| 0             | 1 | 0 | <a href="#">RCWCASP</a> , <a href="#">RCWCASPA</a> ,<br><a href="#">RCWCASPL</a> , <a href="#">RCWCASPAL</a> â€”<br><a href="#">RCWCASPA</a>       |  |  | FEAT_D128 &&<br>FEAT_THE |
| 0             | 1 | 1 | <a href="#">RCWCASP</a> , <a href="#">RCWCASPA</a> ,<br><a href="#">RCWCASPL</a> , <a href="#">RCWCASPAL</a> â€”<br><a href="#">RCWCASPAL</a>      |  |  | FEAT_D128 &&<br>FEAT_THE |
| 1             | 0 | 0 | <a href="#">RCWSCASP</a> , <a href="#">RCWSCASPA</a> ,<br><a href="#">RCWSCASPL</a> , <a href="#">RCWSCASPAL</a> â€”<br><a href="#">RCWSCASP</a>   |  |  | FEAT_D128 &&<br>FEAT_THE |
| 1             | 0 | 1 | <a href="#">RCWSCASP</a> , <a href="#">RCWSCASPA</a> ,<br><a href="#">RCWSCASPL</a> , <a href="#">RCWSCASPAL</a> â€”<br><a href="#">RCWSCASPL</a>  |  |  | FEAT_D128 &&<br>FEAT_THE |
| 1             | 1 | 0 | <a href="#">RCWSCASP</a> , <a href="#">RCWSCASPA</a> ,<br><a href="#">RCWSCASPL</a> , <a href="#">RCWSCASPAL</a> â€”<br><a href="#">RCWSCASPA</a>  |  |  | FEAT_D128 &&<br>FEAT_THE |
| 1             | 1 | 1 | <a href="#">RCWSCASP</a> , <a href="#">RCWSCASPA</a> ,<br><a href="#">RCWSCASPL</a> , <a href="#">RCWSCASPAL</a> â€”<br><a href="#">RCWSCASPAL</a> |  |  | FEAT_D128 &&<br>FEAT_THE |

## 128-bit atomic memory operations

These instructions are under [Loads and Stores](#).

|    |    |    |    |    |    |    |    |    |    |    |    |     |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | S  | 0  | 1  | 1  | 0  | 0  | 1  | A  | R  | 1  |    | Rt2 | o3 | opc | 0  | 0  |    | Rn |    | Rt |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |   |    |     | Instruction Details                                                                                                                    |  |  | Feature     |
|---------------|---|---|----|-----|----------------------------------------------------------------------------------------------------------------------------------------|--|--|-------------|
| S             | A | R | o3 | opc |                                                                                                                                        |  |  |             |
| 0             |   |   |    | 1xx | UNALLOCATED                                                                                                                            |  |  | -           |
| 0             |   |   | 0  | 0x0 | UNALLOCATED                                                                                                                            |  |  | -           |
| 0             | 0 | 0 | 0  | 001 | <a href="#">LDCLRP</a> , <a href="#">LDCLRPA</a> ,<br><a href="#">LDCLRPAL</a> , <a href="#">LDCLRPL</a><br>â€” <a href="#">LDCLRP</a> |  |  | FEAT_LSE128 |
| 0             | 0 | 0 | 0  | 011 | <a href="#">LDSETP</a> , <a href="#">LDSETPA</a> ,<br><a href="#">LDSETPAL</a> , <a href="#">LDSETPL</a><br>â€” <a href="#">LDSETP</a> |  |  | FEAT_LSE128 |
| 0             | 0 | 0 | 1  | 000 | <a href="#">SWPP</a> , <a href="#">SWPPA</a> , <a href="#">SWPPAL</a> ,<br><a href="#">SWPPL</a> â€” <a href="#">SWPP</a>              |  |  | FEAT_LSE128 |

| Decode fields |   |   |    |     | Instruction Details                                                                                                                             | Feature                  |
|---------------|---|---|----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| S             | A | R | o3 | opc |                                                                                                                                                 |                          |
| 0             | 0 | 0 | 1  | 001 | <a href="#">RCWCLRP</a> , <a href="#">RCWCLRPA</a> ,<br><a href="#">RCWCLRPL</a> ,<br><a href="#">RCWCLRPAL</a> â€”<br><a href="#">RCWCLRP</a>  | FEAT_D128<br>&& FEAT_THE |
| 0             | 0 | 0 | 1  | 010 | <a href="#">RCWSWPP</a> , <a href="#">RCWSWPRA</a> ,<br><a href="#">RCWSWPPL</a> ,<br><a href="#">RCWSWPAL</a> â€”<br><a href="#">RCWSWPP</a>   | FEAT_D128<br>&& FEAT_THE |
| 0             | 0 | 0 | 1  | 011 | <a href="#">RCWSETP</a> , <a href="#">RCWSETPA</a> ,<br><a href="#">RCWSETPL</a> ,<br><a href="#">RCWSETPAL</a> â€”<br><a href="#">RCWSETP</a>  | FEAT_D128<br>&& FEAT_THE |
| 0             | 0 | 1 | 0  | 001 | <a href="#">LDCLRPA</a> , <a href="#">LDCLRPL</a> ,<br><a href="#">LDCLRPAL</a> , <a href="#">LDCLRPL</a><br>â€” <a href="#">LDCLRPL</a>        | FEAT_LSE128              |
| 0             | 0 | 1 | 0  | 011 | <a href="#">LDSETP</a> , <a href="#">LDSETPA</a> ,<br><a href="#">LDSETPAL</a> , <a href="#">LDSETPPL</a><br>â€” <a href="#">LDSETPL</a>        | FEAT_LSE128              |
| 0             | 0 | 1 | 1  | 000 | <a href="#">SWPP</a> , <a href="#">SWPPA</a> , <a href="#">SWPPAL</a> ,<br><a href="#">SWPPL</a> â€” <a href="#">SWPPL</a>                      | FEAT_LSE128              |
| 0             | 0 | 1 | 1  | 001 | <a href="#">RCWCLRP</a> , <a href="#">RCWCLRPA</a> ,<br><a href="#">RCWCLRPL</a> ,<br><a href="#">RCWCLRPAL</a> â€”<br><a href="#">RCWCLRPL</a> | FEAT_D128<br>&& FEAT_THE |
| 0             | 0 | 1 | 1  | 010 | <a href="#">RCWSWPP</a> , <a href="#">RCWSWPRA</a> ,<br><a href="#">RCWSWPPL</a> ,<br><a href="#">RCWSWPAL</a> â€”<br><a href="#">RCWSWPPL</a>  | FEAT_D128<br>&& FEAT_THE |
| 0             | 0 | 1 | 1  | 011 | <a href="#">RCWSETP</a> , <a href="#">RCWSETPA</a> ,<br><a href="#">RCWSETPL</a> ,<br><a href="#">RCWSETPAL</a> â€”<br><a href="#">RCWSETPL</a> | FEAT_D128<br>&& FEAT_THE |
| 0             | 1 | 0 | 0  | 001 | <a href="#">LDCLRPA</a> , <a href="#">LDCLRPL</a> ,<br><a href="#">LDCLRPAL</a> , <a href="#">LDCLRPL</a><br>â€” <a href="#">LDCLRPA</a>        | FEAT_LSE128              |
| 0             | 1 | 0 | 0  | 011 | <a href="#">LDSETP</a> , <a href="#">LDSETPA</a> ,<br><a href="#">LDSETPAL</a> , <a href="#">LDSETPPL</a><br>â€” <a href="#">LDSETPA</a>        | FEAT_LSE128              |
| 0             | 1 | 0 | 1  | 000 | <a href="#">SWPP</a> , <a href="#">SWPPA</a> , <a href="#">SWPPAL</a> ,<br><a href="#">SWPPL</a> â€” <a href="#">SWPPA</a>                      | FEAT_LSE128              |
| 0             | 1 | 0 | 1  | 001 | <a href="#">RCWCLRP</a> , <a href="#">RCWCLRPA</a> ,<br><a href="#">RCWCLRPL</a> ,<br><a href="#">RCWCLRPAL</a> â€”<br><a href="#">RCWCLRPA</a> | FEAT_D128<br>&& FEAT_THE |

| Decode fields |   |   |    |     | Instruction Details                                                                                                                                    | Feature                  |
|---------------|---|---|----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| S             | A | R | o3 | opc |                                                                                                                                                        |                          |
| 0             | 1 | 0 | 1  | 010 | <a href="#">RCWSWPP</a> , <a href="#">RCWSWPRA</a> ,<br><a href="#">RCWSWPPL</a> ,<br><a href="#">RCWSWPAL</a> â€”<br><a href="#">RCWSWPAL</a>         | FEAT_D128<br>&& FEAT_THE |
| 0             | 1 | 0 | 1  | 011 | <a href="#">RCWSETP</a> , <a href="#">RCWSETPA</a> ,<br><a href="#">RCWSETPL</a> ,<br><a href="#">RCWSETPAL</a> â€”<br><a href="#">RCWSETPA</a>        | FEAT_D128<br>&& FEAT_THE |
| 0             | 1 | 1 | 0  | 001 | <a href="#">LDCLRPA</a> , <a href="#">LDCLRPL</a> ,<br><a href="#">LDCLRPA</a> , <a href="#">LDCLRPL</a><br>â€” <a href="#">LDCLRPA</a>                | FEAT_LSE128              |
| 0             | 1 | 1 | 0  | 011 | <a href="#">LDSETP</a> , <a href="#">LDSETPA</a> ,<br><a href="#">LDSETPAL</a> , <a href="#">LDSETPPL</a><br>â€” <a href="#">LDSETPAL</a>              | FEAT_LSE128              |
| 0             | 1 | 1 | 1  | 000 | <a href="#">SWPP</a> , <a href="#">SWPPA</a> , <a href="#">SWPPAL</a> ,<br><a href="#">SWPPL</a> â€” <a href="#">SWPPAL</a>                            | FEAT_LSE128              |
| 0             | 1 | 1 | 1  | 001 | <a href="#">RCWCLRP</a> , <a href="#">RCWCLRPA</a> ,<br><a href="#">RCWCLRPL</a> ,<br><a href="#">RCWCLRPAL</a> â€”<br><a href="#">RCWCLRPAL</a>       | FEAT_D128<br>&& FEAT_THE |
| 0             | 1 | 1 | 1  | 010 | <a href="#">RCWSWPP</a> , <a href="#">RCWSWPRA</a> ,<br><a href="#">RCWSWPPL</a> ,<br><a href="#">RCWSWPAL</a> â€”<br><a href="#">RCWSWPAL</a>         | FEAT_D128<br>&& FEAT_THE |
| 0             | 1 | 1 | 1  | 011 | <a href="#">RCWSETP</a> , <a href="#">RCWSETPA</a> ,<br><a href="#">RCWSETPL</a> ,<br><a href="#">RCWSETPAL</a> â€”<br><a href="#">RCWSETPAL</a>       | FEAT_D128<br>&& FEAT_THE |
| 1             |   |   | 0  |     | UNALLOCATED                                                                                                                                            | -                        |
| 1             |   |   | 1  | 000 | UNALLOCATED                                                                                                                                            | -                        |
| 1             |   |   | 1  | 1xx | UNALLOCATED                                                                                                                                            | -                        |
| 1             | 0 | 0 | 1  | 001 | <a href="#">RCWSCLRP</a> ,<br><a href="#">RCWSCLRPA</a> ,<br><a href="#">RCWSCLRPL</a> ,<br><a href="#">RCWSCLRPAL</a> â€”<br><a href="#">RCWSCLRP</a> | FEAT_D128<br>&& FEAT_THE |
| 1             | 0 | 0 | 1  | 010 | <a href="#">RCWSSWPP</a> ,<br><a href="#">RCWSSWPRA</a> ,<br><a href="#">RCWSSWPPL</a> ,<br><a href="#">RCWSSWPAL</a> â€”<br><a href="#">RCWSSWPP</a>  | FEAT_D128<br>&& FEAT_THE |
| 1             | 0 | 0 | 1  | 011 | <a href="#">RCWSSETP</a> ,<br><a href="#">RCWSSETPA</a> ,<br><a href="#">RCWSSETPL</a> ,<br><a href="#">RCWSSETPAL</a> â€”<br><a href="#">RCWSSETP</a> | FEAT_D128<br>&& FEAT_THE |

| Decode fields |   |   |    |     | Instruction Details                                                                                                                                     | Feature                  |
|---------------|---|---|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| S             | A | R | o3 | opc |                                                                                                                                                         |                          |
| 1             | 0 | 1 | 1  | 001 | <a href="#">RCWSCLRP</a> ,<br><a href="#">RCWSCLRPA</a> ,<br><a href="#">RCWSCLRPL</a> ,<br><a href="#">RCWSCLRPAL</a> â€”<br><a href="#">RCWSCLRPL</a> | FEAT_D128<br>&& FEAT_THE |
| 1             | 0 | 1 | 1  | 010 | <a href="#">RCWSSWPP</a> ,<br><a href="#">RCWSSWPRA</a> ,<br><a href="#">RCWSSWPPL</a> ,<br><a href="#">RCWSSWPAL</a> â€”<br><a href="#">RCWSSWPPL</a>  | FEAT_D128<br>&& FEAT_THE |
| 1             | 0 | 1 | 1  | 011 | <a href="#">RCWSSETP</a> ,<br><a href="#">RCWSSETPA</a> ,<br><a href="#">RCWSSETPL</a> ,<br><a href="#">RCWSSETPAL</a> â€”<br><a href="#">RCWSSETPL</a> | FEAT_D128<br>&& FEAT_THE |
| 1             | 1 | 0 | 1  | 001 | <a href="#">RCWSCLRP</a> ,<br><a href="#">RCWSCLRPA</a> ,<br><a href="#">RCWSCLRPL</a> ,<br><a href="#">RCWSCLRPAL</a> â€”<br><a href="#">RCWSCLRPA</a> | FEAT_D128<br>&& FEAT_THE |
| 1             | 1 | 0 | 1  | 010 | <a href="#">RCWSSWPP</a> ,<br><a href="#">RCWSSWPRA</a> ,<br><a href="#">RCWSSWPPL</a> ,<br><a href="#">RCWSSWPAL</a> â€”<br><a href="#">RCWSSWPRA</a>  | FEAT_D128<br>&& FEAT_THE |
| 1             | 1 | 0 | 1  | 011 | <a href="#">RCWSSETP</a> ,<br><a href="#">RCWSSETPA</a> ,<br><a href="#">RCWSSETPL</a> ,<br><a href="#">RCWSSETPAL</a> â€”<br><a href="#">RCWSSETPA</a> | FEAT_D128<br>&& FEAT_THE |
| 1             | 1 | 1 | 1  | 001 | <a href="#">RCWSCLRP</a> ,<br><a href="#">RCWSCLRPA</a> ,<br><a href="#">RCWSCLRPL</a> ,<br><a href="#">RCWSCLRPAL</a> â€”<br><a href="#">RCWSCLRPA</a> | FEAT_D128<br>&& FEAT_THE |
| 1             | 1 | 1 | 1  | 010 | <a href="#">RCWSSWPP</a> ,<br><a href="#">RCWSSWPRA</a> ,<br><a href="#">RCWSSWPPL</a> ,<br><a href="#">RCWSSWPAL</a> â€”<br><a href="#">RCWSSWPAL</a>  | FEAT_D128<br>&& FEAT_THE |
| 1             | 1 | 1 | 1  | 011 | <a href="#">RCWSSETP</a> ,<br><a href="#">RCWSSETPA</a> ,<br><a href="#">RCWSSETPL</a> ,<br><a href="#">RCWSSETPAL</a> â€”<br><a href="#">RCWSSETPA</a> | FEAT_D128<br>&& FEAT_THE |

GCS load/store

These instructions are under [Loads and Stores](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | opc | 1  | 1  | Rn |    | Rt |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>opc | Instruction Details     | Feature  |
|----------------------|-------------------------|----------|
| 000                  | <a href="#">GCSSTR</a>  | FEAT_GCS |
| 001                  | <a href="#">GCSSTTR</a> | FEAT_GCS |
| 01x                  | UNALLOCATED             | -        |
| 1xx                  | UNALLOCATED             | -        |

### Load/store memory tags

These instructions are under [Loads and Stores](#).

|    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |      |    |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|------|----|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15 | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 1  | 0  | 0  | 1  | opc | 1  |    |    |    |    |    | imm9 |    | op2 |    | Rn |    | Rt |   |   |   |   |   |   |   |   |   |   |

| Decode fields<br>opc | Instruction Details                   | Feature              |
|----------------------|---------------------------------------|----------------------|
| imm9                 | op2                                   |                      |
| 00                   | <a href="#">STG</a> " post-index      | FEAT_MTE             |
| 00                   | <a href="#">STG</a> " signed offset   | FEAT_MTE             |
| 00                   | <a href="#">STG</a> " pre-index       | FEAT_MTE             |
| 00                   | <a href="#">STZGM</a>                 | FEAT_MTE2            |
| 01                   | <a href="#">LDG</a>                   | FEAT_MTE             |
| 01                   | <a href="#">STZG</a> " post-index     | FEAT_MTE             |
| 01                   | <a href="#">STZG</a> " signed offset  | FEAT_MTE             |
| 01                   | <a href="#">STZG</a> " pre-index      | FEAT_MTE             |
| 10                   | <a href="#">ST2G</a> " post-index     | FEAT_MTE             |
| 10                   | <a href="#">ST2G</a> " signed offset  | FEAT_MTE             |
| 10                   | <a href="#">ST2G</a> " pre-index      | FEAT_MTE             |
| 10                   | != 000000000                          | UNALLOCATED          |
| 10                   | 000000000                             | <a href="#">STGM</a> |
| 11                   | <a href="#">STZ2G</a> " post-index    | FEAT_MTE             |
| 11                   | <a href="#">STZ2G</a> " signed offset | FEAT_MTE             |
| 11                   | <a href="#">STZ2G</a> " pre-index     | FEAT_MTE             |
| 11                   | != 000000000                          | UNALLOCATED          |
| 11                   | 000000000                             | <a href="#">LDGM</a> |

### Load/store exclusive pair

These instructions are under [Loads and Stores](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | sz | 0  | 0  | 1  | 0  | 0  | 0  | 0  | L  | 1  |    | Rs | o0 |    | Rt2 |    |    | Rn |    |    | Rt |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |    | Instruction Details   |     |                        |  |  |  |  |  |
|---------------|---|----|-----------------------|-----|------------------------|--|--|--|--|--|
| sz            | L | o0 |                       |     |                        |  |  |  |  |  |
| 0             | 0 | 0  | <a href="#">STXP</a>  | â€” | <a href="#">32-bit</a> |  |  |  |  |  |
| 0             | 0 | 1  | <a href="#">STLXP</a> | â€” | <a href="#">32-bit</a> |  |  |  |  |  |
| 0             | 1 | 0  | <a href="#">LDXP</a>  | â€” | <a href="#">32-bit</a> |  |  |  |  |  |
| 0             | 1 | 1  | <a href="#">LDAXP</a> | â€” | <a href="#">32-bit</a> |  |  |  |  |  |
| 1             | 0 | 0  | <a href="#">STXP</a>  | â€” | <a href="#">64-bit</a> |  |  |  |  |  |
| 1             | 0 | 1  | <a href="#">STLXP</a> | â€” | <a href="#">64-bit</a> |  |  |  |  |  |
| 1             | 1 | 0  | <a href="#">LDXP</a>  | â€” | <a href="#">64-bit</a> |  |  |  |  |  |
| 1             | 1 | 1  | <a href="#">LDAXP</a> | â€” | <a href="#">64-bit</a> |  |  |  |  |  |

### Load/store exclusive register

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| size | 0  | 0  | 1  | 0  | 0  | 0  | 0  | L  | 0  |    | Rs | o0 |    | Rt2 |    |    | Rn |    |    | Rt |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |    | Instruction Details    |     |                        |  |  |  |  |  |
|---------------|---|----|------------------------|-----|------------------------|--|--|--|--|--|
| size          | L | o0 |                        |     |                        |  |  |  |  |  |
| 00            | 0 | 0  | <a href="#">STXRB</a>  |     |                        |  |  |  |  |  |
| 00            | 0 | 1  | <a href="#">STLXRB</a> |     |                        |  |  |  |  |  |
| 00            | 1 | 0  | <a href="#">LDXRB</a>  |     |                        |  |  |  |  |  |
| 00            | 1 | 1  | <a href="#">LDAXRB</a> |     |                        |  |  |  |  |  |
| 01            | 0 | 0  | <a href="#">STXRH</a>  |     |                        |  |  |  |  |  |
| 01            | 0 | 1  | <a href="#">STLXRH</a> |     |                        |  |  |  |  |  |
| 01            | 1 | 0  | <a href="#">LDXRH</a>  |     |                        |  |  |  |  |  |
| 01            | 1 | 1  | <a href="#">LDAXRH</a> |     |                        |  |  |  |  |  |
| 10            | 0 | 0  | <a href="#">STXR</a>   | â€” | <a href="#">32-bit</a> |  |  |  |  |  |
| 10            | 0 | 1  | <a href="#">STLXR</a>  | â€” | <a href="#">32-bit</a> |  |  |  |  |  |
| 10            | 1 | 0  | <a href="#">LDXR</a>   | â€” | <a href="#">32-bit</a> |  |  |  |  |  |
| 10            | 1 | 1  | <a href="#">LDAXR</a>  | â€” | <a href="#">32-bit</a> |  |  |  |  |  |
| 11            | 0 | 0  | <a href="#">STXR</a>   | â€” | <a href="#">64-bit</a> |  |  |  |  |  |
| 11            | 0 | 1  | <a href="#">STLXR</a>  | â€” | <a href="#">64-bit</a> |  |  |  |  |  |
| 11            | 1 | 0  | <a href="#">LDXR</a>   | â€” | <a href="#">64-bit</a> |  |  |  |  |  |
| 11            | 1 | 1  | <a href="#">LDAXR</a>  | â€” | <a href="#">64-bit</a> |  |  |  |  |  |

## Load/store ordered

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| size | 0  | 0  | 1  | 0  | 0  | 0  | 1  | L  | 0  |    | Rs | o0 |    | Rt2 |    |    | Rn |    | Rt |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |    | Instruction Details            | Feature  |
|---------------|---|----|--------------------------------|----------|
| size          | L | o0 |                                |          |
| 00            | 0 | 0  | <a href="#">STLLRB</a>         | FEAT_LOR |
| 00            | 0 | 1  | <a href="#">STLRB</a>          | -        |
| 00            | 1 | 0  | <a href="#">LDLARB</a>         | FEAT_LOR |
| 00            | 1 | 1  | <a href="#">LDARB</a>          | -        |
| 01            | 0 | 0  | <a href="#">STLLRH</a>         | FEAT_LOR |
| 01            | 0 | 1  | <a href="#">STLRH</a>          | -        |
| 01            | 1 | 0  | <a href="#">LDLARH</a>         | FEAT_LOR |
| 01            | 1 | 1  | <a href="#">LDARH</a>          | -        |
| 10            | 0 | 0  | <a href="#">STLLR</a> " 32-bit | FEAT_LOR |
| 10            | 0 | 1  | <a href="#">STLR</a> " 32-bit  | -        |
| 10            | 1 | 0  | <a href="#">LDLAR</a> " 32-bit | FEAT_LOR |
| 10            | 1 | 1  | <a href="#">LDAR</a> " 32-bit  | -        |
| 11            | 0 | 0  | <a href="#">STLLR</a> " 64-bit | FEAT_LOR |
| 11            | 0 | 1  | <a href="#">STLR</a> " 64-bit  | -        |
| 11            | 1 | 0  | <a href="#">LDLAR</a> " 64-bit | FEAT_LOR |
| 11            | 1 | 1  | <a href="#">LDAR</a> " 64-bit  | -        |

## Compare and swap

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| size | 0  | 0  | 1  | 0  | 0  | 0  | 1  | L  | 1  |    | Rs | o0 |    | Rt2 |    |    | Rn |    | Rt |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |    |             | Instruction Details                                                                                                      | Feature  |
|---------------|---|----|-------------|--------------------------------------------------------------------------------------------------------------------------|----------|
| size          | L | o0 | Rt2         |                                                                                                                          |          |
|               |   |    | !=<br>11111 | UNALLOCATED                                                                                                              | -        |
| 00            | 0 | 0  | 11111       | <a href="#">CASB</a> , <a href="#">CASAB</a> , <a href="#">CASALB</a> ,<br><a href="#">CASLB</a> " <a href="#">CASB</a>  | FEAT_LSE |
| 00            | 0 | 1  | 11111       | <a href="#">CASB</a> , <a href="#">CASAB</a> , <a href="#">CASALB</a> ,<br><a href="#">CASLB</a> " <a href="#">CASLB</a> | FEAT_LSE |
| 00            | 1 | 0  | 11111       | <a href="#">CASB</a> , <a href="#">CASAB</a> , <a href="#">CASALB</a> ,<br><a href="#">CASLB</a> " <a href="#">CASAB</a> | FEAT_LSE |

| Decode fields |   |    |       | Instruction Details                                                     | Feature  |
|---------------|---|----|-------|-------------------------------------------------------------------------|----------|
| size          | L | o0 | Rt2   |                                                                         |          |
| 00            | 1 | 1  | 11111 | <a href="#">CASB, CASAB, CASALB, CASLB</a> â€“ <a href="#">CASALB</a>   | FEAT_LSE |
| 01            | 0 | 0  | 11111 | <a href="#">CASH, CASAH, CASALH, CASLH</a> â€“ <a href="#">CASH</a>     | FEAT_LSE |
| 01            | 0 | 1  | 11111 | <a href="#">CASH, CASAH, CASALH, CASLH</a> â€“ <a href="#">CASLH</a>    | FEAT_LSE |
| 01            | 1 | 0  | 11111 | <a href="#">CASH, CASAH, CASALH, CASLH</a> â€“ <a href="#">CASAH</a>    | FEAT_LSE |
| 01            | 1 | 1  | 11111 | <a href="#">CASH, CASAH, CASALH, CASLH</a> â€“ <a href="#">CASALH</a>   | FEAT_LSE |
| 10            | 0 | 0  | 11111 | <a href="#">CAS, CASA, CASAL, CASL</a> â€“ <a href="#">32-bit CAS</a>   | FEAT_LSE |
| 10            | 0 | 1  | 11111 | <a href="#">CAS, CASA, CASAL, CASL</a> â€“ <a href="#">32-bit CASL</a>  | FEAT_LSE |
| 10            | 1 | 0  | 11111 | <a href="#">CAS, CASA, CASAL, CASL</a> â€“ <a href="#">32-bit CASA</a>  | FEAT_LSE |
| 10            | 1 | 1  | 11111 | <a href="#">CAS, CASA, CASAL, CASL</a> â€“ <a href="#">32-bit CASAL</a> | FEAT_LSE |
| 11            | 0 | 0  | 11111 | <a href="#">CAS, CASA, CASAL, CASL</a> â€“ <a href="#">64-bit CAS</a>   | FEAT_LSE |
| 11            | 0 | 1  | 11111 | <a href="#">CAS, CASA, CASAL, CASL</a> â€“ <a href="#">64-bit CASL</a>  | FEAT_LSE |
| 11            | 1 | 0  | 11111 | <a href="#">CAS, CASA, CASAL, CASL</a> â€“ <a href="#">64-bit CASA</a>  | FEAT_LSE |
| 11            | 1 | 1  | 11111 | <a href="#">CAS, CASA, CASAL, CASL</a> â€“ <a href="#">64-bit CASAL</a> | FEAT_LSE |

## LDIAPP/STILP

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |    |    |    |     |      |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|------|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| size | 0  | 1  | 1  | 0  | 0  | 1  | 0  | L  | 0  | Rt2 | opc2 | 1  | 0  | Rn |    | Rt |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Decode fields |   |      |  | Instruction Details                                          | Feature     |
|---------------|---|------|--|--------------------------------------------------------------|-------------|
| size          | L | opc2 |  |                                                              |             |
| 0x            |   |      |  | UNALLOCATED                                                  | -           |
| 1x            |   | 001x |  | UNALLOCATED                                                  | -           |
| 1x            |   | 01xx |  | UNALLOCATED                                                  | -           |
| 1x            |   | 1xxx |  | UNALLOCATED                                                  | -           |
| 10            | 0 | 0000 |  | <a href="#">STILP</a> â€“ <a href="#">32-bit pre-index</a>   | FEAT_LRCPC3 |
| 10            | 0 | 0001 |  | <a href="#">STILP</a> â€“ <a href="#">32-bit</a>             | FEAT_LRCPC3 |
| 10            | 1 | 0000 |  | <a href="#">LDIAPP</a> â€“ <a href="#">32-bit post-index</a> | FEAT_LRCPC3 |

| Decode fields |   |      | Instruction Details    |                       | Feature     |
|---------------|---|------|------------------------|-----------------------|-------------|
| size          | L | opc2 |                        |                       |             |
| 10            | 1 | 0001 | <a href="#">LDIAPP</a> | â€” 32-bit            | FEAT_LRCPC3 |
| 11            | 0 | 0000 | <a href="#">STILP</a>  | â€” 64-bit pre-index  | FEAT_LRCPC3 |
| 11            | 0 | 0001 | <a href="#">STILP</a>  | â€” 64-bit            | FEAT_LRCPC3 |
| 11            | 1 | 0000 | <a href="#">LDIAPP</a> | â€” 64-bit post-index | FEAT_LRCPC3 |
| 11            | 1 | 0001 | <a href="#">LDIAPP</a> | â€” 64-bit            | FEAT_LRCPC3 |

### LDAPR/STLR (writeback)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |    |   |    |   |   |   |   |   |   |  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|----|---|---|---|---|---|---|--|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |  |
| size | 0  | 1  | 1  | 0  | 0  | 1  | 1  | L  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0 | Rn |   | Rt |   |   |   |   |   |   |  |

| Decode fields |   | Instruction Details   |            | Feature     |
|---------------|---|-----------------------|------------|-------------|
| size          | L |                       |            |             |
| 0x            |   | UNALLOCATED           |            | -           |
| 10            | 0 | <a href="#">STLR</a>  | â€” 32-bit | FEAT_LRCPC3 |
| 10            | 1 | <a href="#">LDAPR</a> | â€” 32-bit | FEAT_LRCPC3 |
| 11            | 0 | <a href="#">STLR</a>  | â€” 64-bit | FEAT_LRCPC3 |
| 11            | 1 | <a href="#">LDAPR</a> | â€” 64-bit | FEAT_LRCPC3 |

### LDAPR/STLR (unscaled immediate)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |   |    |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|---|----|---|---|---|---|---|---|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11 | 10 | 9  | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| size | 0  | 1  | 1  | 0  | 0  | 1  | opc | 0  |    |    |    |    |    |    |    |    |    |    | imm9 | 0  | 0  | Rn |   | Rt |   |   |   |   |   |   |   |

| Decode fields |     | Instruction Details      |            | Feature     |
|---------------|-----|--------------------------|------------|-------------|
| size          | opc |                          |            |             |
| 00            | 00  | <a href="#">STLURB</a>   |            | FEAT_LRCPC2 |
| 00            | 01  | <a href="#">LDAPURB</a>  |            | FEAT_LRCPC2 |
| 00            | 10  | <a href="#">LDAPURSB</a> | â€” 64-bit | FEAT_LRCPC2 |
| 00            | 11  | <a href="#">LDAPURSB</a> | â€” 32-bit | FEAT_LRCPC2 |
| 01            | 00  | <a href="#">STLURH</a>   |            | FEAT_LRCPC2 |
| 01            | 01  | <a href="#">LDAPURH</a>  |            | FEAT_LRCPC2 |
| 01            | 10  | <a href="#">LDAPURSH</a> | â€” 64-bit | FEAT_LRCPC2 |
| 01            | 11  | <a href="#">LDAPURSH</a> | â€” 32-bit | FEAT_LRCPC2 |
| 1x            | 11  | UNALLOCATED              |            | -           |
| 10            | 00  | <a href="#">STLUR</a>    | â€” 32-bit | FEAT_LRCPC2 |

| Decode fields |     | Instruction Details               |  | Feature     |
|---------------|-----|-----------------------------------|--|-------------|
| size          | opc |                                   |  |             |
| 10            | 01  | <a href="#">LDAPUR</a> â€“ 32-bit |  | FEAT_LRCPC2 |
| 10            | 10  | <a href="#">LDAPURSW</a>          |  | FEAT_LRCPC2 |
| 11            | 00  | <a href="#">STLUR</a> â€“ 64-bit  |  | FEAT_LRCPC2 |
| 11            | 01  | <a href="#">LDAPUR</a> â€“ 64-bit |  | FEAT_LRCPC2 |
| 11            | 10  | UNALLOCATED                       |  | -           |

### LDAPR/STLR (SIMD&FP)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |    |
|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|----|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |    |
| size | 0  | 1  | 1  | 1  | 0  | 1  | opc | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Rn |   | Rt |

| Decode fields |     | Instruction Details                              |  | Feature     |
|---------------|-----|--------------------------------------------------|--|-------------|
| size          | opc |                                                  |  |             |
| 00            | 00  | <a href="#">STLUR (SIMD&amp;FP)</a> â€“ 8-bit    |  | FEAT_LRCPC3 |
| 00            | 01  | <a href="#">LDAPUR (SIMD&amp;FP)</a> â€“ 8-bit   |  | FEAT_LRCPC3 |
| 00            | 10  | <a href="#">STLUR (SIMD&amp;FP)</a> â€“ 128-bit  |  | FEAT_LRCPC3 |
| 00            | 11  | <a href="#">LDAPUR (SIMD&amp;FP)</a> â€“ 128-bit |  | FEAT_LRCPC3 |
| 01            | 00  | <a href="#">STLUR (SIMD&amp;FP)</a> â€“ 16-bit   |  | FEAT_LRCPC3 |
| 01            | 01  | <a href="#">LDAPUR (SIMD&amp;FP)</a> â€“ 16-bit  |  | FEAT_LRCPC3 |
| 01            | 1x  | UNALLOCATED                                      |  | -           |
| 1x            | 1x  | UNALLOCATED                                      |  | -           |
| 10            | 00  | <a href="#">STLUR (SIMD&amp;FP)</a> â€“ 32-bit   |  | FEAT_LRCPC3 |
| 10            | 01  | <a href="#">LDAPUR (SIMD&amp;FP)</a> â€“ 32-bit  |  | FEAT_LRCPC3 |
| 11            | 00  | <a href="#">STLUR (SIMD&amp;FP)</a> â€“ 64-bit   |  | FEAT_LRCPC3 |
| 11            | 01  | <a href="#">LDAPUR (SIMD&amp;FP)</a> â€“ 64-bit  |  | FEAT_LRCPC3 |

### Load register (literal)

These instructions are under [Loads and Stores](#).

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |    |   |   |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----|---|---|
| 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1 | 0 |
| opc | 0  | 1  | 1  | VR | 0  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   | Rt |   |   |

| Decode fields |    | Instruction Details                                   |  |
|---------------|----|-------------------------------------------------------|--|
| opc           | VR |                                                       |  |
| 00            | 0  | <a href="#">LDR (literal)</a> â€“ 32-bit              |  |
| 00            | 1  | <a href="#">LDR (literal, SIMD&amp;FP)</a> â€“ 32-bit |  |
| 01            | 0  | <a href="#">LDR (literal)</a> â€“ 64-bit              |  |

| Decode fields |    | Instruction Details                                    |  |  |  |  |  |  |  |  |  |
|---------------|----|--------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| opc           | VR |                                                        |  |  |  |  |  |  |  |  |  |
| 01            | 1  | <a href="#">LDR (literal, SIMD&amp;FP) â€“ 64-bit</a>  |  |  |  |  |  |  |  |  |  |
| 10            | 0  | <a href="#">LDRSW (literal)</a>                        |  |  |  |  |  |  |  |  |  |
| 10            | 1  | <a href="#">LDR (literal, SIMD&amp;FP) â€“ 128-bit</a> |  |  |  |  |  |  |  |  |  |
| 11            | 0  | <a href="#">PRFM (literal)</a>                         |  |  |  |  |  |  |  |  |  |
| 11            | 1  | UNALLOCATED                                            |  |  |  |  |  |  |  |  |  |

## Memory Copy and Memory Set

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |     |    |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|-----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| size | 0  | 1  | 1  | o0 | 0  | 1  | op1 | 0  |    | Rs |    | op2 | 0  | 1  |    | Rn |    | Rd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     |      | Instruction Details                                                           |  |  |  |  |  |  |  |  |  | Feature   |  |
|---------------|-----|------|-------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|-----------|--|
| o0            | op1 | op2  |                                                                               |  |  |  |  |  |  |  |  |  |           |  |
| 0             | 00  | 0000 | <a href="#">CPYFP, CPYFM, CPYFE</a> â€“ <a href="#">CPYFP</a>                 |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 0001 | <a href="#">CPYFPWT, CPYFMWT, CPYFEWT</a> â€“ <a href="#">CPYFPWT</a>         |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 0010 | <a href="#">CPYFPRT, CPYFMRT, CPYFERT</a> â€“ <a href="#">CPYFPRT</a>         |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 0011 | <a href="#">CPYFPT, CPYFMT, CPYFET</a> â€“ <a href="#">CPYFPT</a>             |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 0100 | <a href="#">CPYFPWN, CPYFMWN, CPYFEWN</a> â€“ <a href="#">CPYFPWN</a>         |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 0101 | <a href="#">CPYFPWTWN, CPYFMWTWN, CPYFEWTWN</a> â€“ <a href="#">CPYFPWTWN</a> |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 0110 | <a href="#">CPYFPRTWN, CPYFMRTWN, CPYFERTWN</a> â€“ <a href="#">CPYFPRTWN</a> |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 0111 | <a href="#">CPYFPTWN, CPYFMTWN, CPYFETWN</a> â€“ <a href="#">CPYFPTWN</a>     |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 1000 | <a href="#">CPYFPRN, CPYFMRN, CPYFERN</a> â€“ <a href="#">CPYFPRN</a>         |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 1001 | <a href="#">CPYFPWTRN, CPYFMWTRN, CPYFEWTRN</a> â€“ <a href="#">CPYFPWTRN</a> |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 1010 | <a href="#">CPYFPRTRN, CPYFMRTRN, CPYFERTRN</a> â€“ <a href="#">CPYFPRTRN</a> |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 1011 | <a href="#">CPYFPTRN, CPYFMTRN, CPYFETRN</a> â€“ <a href="#">CPYFPTRN</a>     |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 1100 | <a href="#">CPYFPN, CPYFMN, CPYFEN</a> â€“ <a href="#">CPYFPN</a>             |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 1101 | <a href="#">CPYFPWTN, CPYFMWTN, CPYFEWTN</a> â€“ <a href="#">CPYFPWTN</a>     |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |
| 0             | 00  | 1110 | <a href="#">CPYFPRTN, CPYFMRTN, CPYFERTN</a> â€“ <a href="#">CPYFPRTN</a>     |  |  |  |  |  |  |  |  |  | FEAT_MOPS |  |

| Decode fields |     |      | Instruction Details                                                                                                | Feature   |
|---------------|-----|------|--------------------------------------------------------------------------------------------------------------------|-----------|
| o0            | op1 | op2  |                                                                                                                    |           |
| 0             | 00  | 1111 | <a href="#">CPYFPTN</a> , <a href="#">CPYFMTN</a> , <a href="#">CPYFETN</a><br>â€” <a href="#">CPYFPTN</a>         | FEAT_MOPS |
| 0             | 01  | 0000 | <a href="#">CPYFP</a> , <a href="#">CPYFM</a> , <a href="#">CPYFE</a> â€” <a href="#">CPYFM</a>                    | FEAT_MOPS |
| 0             | 01  | 0001 | <a href="#">CPYFPWT</a> , <a href="#">CPYFMWT</a> , <a href="#">CPYFEWT</a><br>â€” <a href="#">CPYFMWT</a>         | FEAT_MOPS |
| 0             | 01  | 0010 | <a href="#">CPYFPRT</a> , <a href="#">CPYFMRT</a> , <a href="#">CPYFERT</a> â€”<br><a href="#">CPYFMRT</a>         | FEAT_MOPS |
| 0             | 01  | 0011 | <a href="#">CPYFPT</a> , <a href="#">CPYFMT</a> , <a href="#">CPYFET</a> â€”<br><a href="#">CPYFMT</a>             | FEAT_MOPS |
| 0             | 01  | 0100 | <a href="#">CPYFPWN</a> , <a href="#">CPYFMWN</a> , <a href="#">CPYFEWN</a><br>â€” <a href="#">CPYFMWN</a>         | FEAT_MOPS |
| 0             | 01  | 0101 | <a href="#">CPYFPWTWN</a> , <a href="#">CPYFMWTWN</a> ,<br><a href="#">CPYFEWTWN</a> â€” <a href="#">CPYFMWTWN</a> | FEAT_MOPS |
| 0             | 01  | 0110 | <a href="#">CPYFPRTWN</a> , <a href="#">CPYFMRTWN</a> ,<br><a href="#">CPYFERTWN</a> â€” <a href="#">CPYFMRTWN</a> | FEAT_MOPS |
| 0             | 01  | 0111 | <a href="#">CPYFPTWN</a> , <a href="#">CPYFMTWN</a> ,<br><a href="#">CPYFETWN</a> â€” <a href="#">CPYFMTWN</a>     | FEAT_MOPS |
| 0             | 01  | 1000 | <a href="#">CPYFPRN</a> , <a href="#">CPYFMRN</a> , <a href="#">CPYFERN</a><br>â€” <a href="#">CPYFMRN</a>         | FEAT_MOPS |
| 0             | 01  | 1001 | <a href="#">CPYFPWTRN</a> , <a href="#">CPYFMWTRN</a> ,<br><a href="#">CPYFEWTRN</a> â€” <a href="#">CPYFMWTRN</a> | FEAT_MOPS |
| 0             | 01  | 1010 | <a href="#">CPYFPRTRN</a> , <a href="#">CPYFMRTRN</a> ,<br><a href="#">CPYFERTRN</a> â€” <a href="#">CPYFMRTRN</a> | FEAT_MOPS |
| 0             | 01  | 1011 | <a href="#">CPYFPTRN</a> , <a href="#">CPYFMTRN</a> ,<br><a href="#">CPYFETRN</a> â€” <a href="#">CPYFMTRN</a>     | FEAT_MOPS |
| 0             | 01  | 1100 | <a href="#">CPYFPN</a> , <a href="#">CPYFMN</a> , <a href="#">CPYFEN</a> â€”<br><a href="#">CPYFMN</a>             | FEAT_MOPS |
| 0             | 01  | 1101 | <a href="#">CPYFPWTN</a> , <a href="#">CPYFMWTN</a> ,<br><a href="#">CPYFEWTN</a> â€” <a href="#">CPYFMWTN</a>     | FEAT_MOPS |
| 0             | 01  | 1110 | <a href="#">CPYFPRTN</a> , <a href="#">CPYFMRDN</a> ,<br><a href="#">CPYFERTN</a> â€” <a href="#">CPYFMRDN</a>     | FEAT_MOPS |
| 0             | 01  | 1111 | <a href="#">CPYFPTN</a> , <a href="#">CPYFMTN</a> , <a href="#">CPYFETN</a><br>â€” <a href="#">CPYFMTN</a>         | FEAT_MOPS |
| 0             | 10  | 0000 | <a href="#">CPYFP</a> , <a href="#">CPYFM</a> , <a href="#">CPYFE</a> â€” <a href="#">CPYFE</a>                    | FEAT_MOPS |
| 0             | 10  | 0001 | <a href="#">CPYFPWT</a> , <a href="#">CPYFMWT</a> , <a href="#">CPYFEWT</a><br>â€” <a href="#">CPYFEWT</a>         | FEAT_MOPS |
| 0             | 10  | 0010 | <a href="#">CPYFPRT</a> , <a href="#">CPYFMRT</a> , <a href="#">CPYFERT</a> â€”<br><a href="#">CPYFERT</a>         | FEAT_MOPS |
| 0             | 10  | 0011 | <a href="#">CPYFPT</a> , <a href="#">CPYFMT</a> , <a href="#">CPYFET</a> â€”<br><a href="#">CPYFET</a>             | FEAT_MOPS |
| 0             | 10  | 0100 | <a href="#">CPYFPWN</a> , <a href="#">CPYFMWN</a> , <a href="#">CPYFEWN</a><br>â€” <a href="#">CPYFEWN</a>         | FEAT_MOPS |
| 0             | 10  | 0101 | <a href="#">CPYFPWTWN</a> , <a href="#">CPYFMWTWN</a> ,<br><a href="#">CPYFEWTWN</a> â€” <a href="#">CPYFEWTWN</a> | FEAT_MOPS |

| Decode fields |     |      | Instruction Details                                                                                                | Feature   |
|---------------|-----|------|--------------------------------------------------------------------------------------------------------------------|-----------|
| o0            | op1 | op2  |                                                                                                                    |           |
| 0             | 10  | 0110 | <a href="#">CPYFPRTWN</a> , <a href="#">CPYFMRTWN</a> ,<br><a href="#">CPYFERTWN</a> â€“ <a href="#">CPYFERTWN</a> | FEAT_MOPS |
| 0             | 10  | 0111 | <a href="#">CPYFPTWN</a> , <a href="#">CPYFMTWN</a> ,<br><a href="#">CPYFETWN</a> â€“ <a href="#">CPYFETWN</a>     | FEAT_MOPS |
| 0             | 10  | 1000 | <a href="#">CPYFPRN</a> , <a href="#">CPYFMRN</a> , <a href="#">CPYFERN</a><br>â€“ <a href="#">CPYFERN</a>         | FEAT_MOPS |
| 0             | 10  | 1001 | <a href="#">CPYFPWTRN</a> , <a href="#">CPYFMWTRN</a> ,<br><a href="#">CPYFEWTRN</a> â€“ <a href="#">CPYFEWTRN</a> | FEAT_MOPS |
| 0             | 10  | 1010 | <a href="#">CPYFPRTRN</a> , <a href="#">CPYFMRTRN</a> ,<br><a href="#">CPYFERTRN</a> â€“ <a href="#">CPYFERTRN</a> | FEAT_MOPS |
| 0             | 10  | 1011 | <a href="#">CPYFPTRN</a> , <a href="#">CPYFMTRN</a> ,<br><a href="#">CPYFETRN</a> â€“ <a href="#">CPYFETRN</a>     | FEAT_MOPS |
| 0             | 10  | 1100 | <a href="#">CPYFPN</a> , <a href="#">CPYFMN</a> , <a href="#">CPYFEN</a> â€“<br><a href="#">CPYFEN</a>             | FEAT_MOPS |
| 0             | 10  | 1101 | <a href="#">CPYFPWTN</a> , <a href="#">CPYFMWTN</a> ,<br><a href="#">CPYFEWTN</a> â€“ <a href="#">CPYFEWTN</a>     | FEAT_MOPS |
| 0             | 10  | 1110 | <a href="#">CPYFPRTN</a> , <a href="#">CPYFMRTN</a> ,<br><a href="#">CPYFERTN</a> â€“ <a href="#">CPYFERTN</a>     | FEAT_MOPS |
| 0             | 10  | 1111 | <a href="#">CPYFPTN</a> , <a href="#">CPYFMTN</a> , <a href="#">CPYFETN</a><br>â€“ <a href="#">CPYFETN</a>         | FEAT_MOPS |
| 0             | 11  | 0000 | <a href="#">SETP</a> , <a href="#">SETM</a> , <a href="#">SETE</a> â€“ <a href="#">SETP</a>                        | FEAT_MOPS |
| 0             | 11  | 0001 | <a href="#">SETPT</a> , <a href="#">SETMT</a> , <a href="#">SETET</a> â€“ <a href="#">SETPT</a>                    | FEAT_MOPS |
| 0             | 11  | 0010 | <a href="#">SETPN</a> , <a href="#">SETMN</a> , <a href="#">SETEN</a> â€“<br><a href="#">SETPN</a>                 | FEAT_MOPS |
| 0             | 11  | 0011 | <a href="#">SETPTN</a> , <a href="#">SETMTN</a> , <a href="#">SETETN</a> â€“<br><a href="#">SETPTN</a>             | FEAT_MOPS |
| 0             | 11  | 0100 | <a href="#">SETP</a> , <a href="#">SETM</a> , <a href="#">SETE</a> â€“ <a href="#">SETM</a>                        | FEAT_MOPS |
| 0             | 11  | 0101 | <a href="#">SETPT</a> , <a href="#">SETMT</a> , <a href="#">SETET</a> â€“ <a href="#">SETMT</a>                    | FEAT_MOPS |
| 0             | 11  | 0110 | <a href="#">SETPN</a> , <a href="#">SETMN</a> , <a href="#">SETEN</a> â€“<br><a href="#">SETMN</a>                 | FEAT_MOPS |
| 0             | 11  | 0111 | <a href="#">SETPTN</a> , <a href="#">SETMTN</a> , <a href="#">SETETN</a> â€“<br><a href="#">SETMTN</a>             | FEAT_MOPS |
| 0             | 11  | 1000 | <a href="#">SETP</a> , <a href="#">SETM</a> , <a href="#">SETE</a> â€“ <a href="#">SETE</a>                        | FEAT_MOPS |
| 0             | 11  | 1001 | <a href="#">SETPT</a> , <a href="#">SETMT</a> , <a href="#">SETET</a> â€“ <a href="#">SETET</a>                    | FEAT_MOPS |
| 0             | 11  | 1010 | <a href="#">SETPN</a> , <a href="#">SETMN</a> , <a href="#">SETEN</a> â€“<br><a href="#">SETEN</a>                 | FEAT_MOPS |
| 0             | 11  | 1011 | <a href="#">SETPTN</a> , <a href="#">SETMTN</a> , <a href="#">SETETN</a> â€“<br><a href="#">SETETN</a>             | FEAT_MOPS |
| 0             | 11  | 11xx | UNALLOCATED                                                                                                        | -         |
| 1             | 00  | 0000 | <a href="#">CPYP</a> , <a href="#">CPYM</a> , <a href="#">CPYE</a> â€“ <a href="#">CPYP</a>                        | FEAT_MOPS |
| 1             | 00  | 0001 | <a href="#">CPYPWT</a> , <a href="#">CPYMWT</a> , <a href="#">CPYEWT</a> â€“<br><a href="#">CPYPWT</a>             | FEAT_MOPS |
| 1             | 00  | 0010 | <a href="#">CPYPRT</a> , <a href="#">CPYMRT</a> , <a href="#">CPYERT</a> â€“<br><a href="#">CPYPRT</a>             | FEAT_MOPS |

| Decode fields |     |      | Instruction Details                                                                                            | Feature   |
|---------------|-----|------|----------------------------------------------------------------------------------------------------------------|-----------|
| o0            | op1 | op2  |                                                                                                                |           |
| 1             | 00  | 0011 | <a href="#">CPYPT</a> , <a href="#">CPYMT</a> , <a href="#">CPYET</a> â€” <a href="#">CPYPT</a>                | FEAT_MOPS |
| 1             | 00  | 0100 | <a href="#">CPYPWN</a> , <a href="#">CPYMWN</a> , <a href="#">CPYEWN</a> â€” <a href="#">CPYPWN</a>            | FEAT_MOPS |
| 1             | 00  | 0101 | <a href="#">CPYPWTWN</a> , <a href="#">CPYMWTWN</a> ,<br><a href="#">CPYEWTWN</a> â€” <a href="#">CPYPWTWN</a> | FEAT_MOPS |
| 1             | 00  | 0110 | <a href="#">CPYPRTWN</a> , <a href="#">CPYMRTWN</a> ,<br><a href="#">CPYERTWN</a> â€” <a href="#">CPYPRTWN</a> | FEAT_MOPS |
| 1             | 00  | 0111 | <a href="#">CPYPTWN</a> , <a href="#">CPYMTWN</a> , <a href="#">CPYETWN</a><br>â€” <a href="#">CPYPTWN</a>     | FEAT_MOPS |
| 1             | 00  | 1000 | <a href="#">CPYPRN</a> , <a href="#">CPYMRN</a> , <a href="#">CPYERN</a> â€”<br><a href="#">CPYPRN</a>         | FEAT_MOPS |
| 1             | 00  | 1001 | <a href="#">CPYPWTRN</a> , <a href="#">CPYMWTRN</a> ,<br><a href="#">CPYEWTRN</a> â€” <a href="#">CPYPWTRN</a> | FEAT_MOPS |
| 1             | 00  | 1010 | <a href="#">CPYPRTRN</a> , <a href="#">CPYMRTRN</a> ,<br><a href="#">CPYERTRN</a> â€” <a href="#">CPYPRTRN</a> | FEAT_MOPS |
| 1             | 00  | 1011 | <a href="#">CPYPTRN</a> , <a href="#">CPYMTRN</a> , <a href="#">CPYETRN</a><br>â€” <a href="#">CPYPTRN</a>     | FEAT_MOPS |
| 1             | 00  | 1100 | <a href="#">CPYPN</a> , <a href="#">CPYMN</a> , <a href="#">CPYEN</a> â€”<br><a href="#">CPYPN</a>             | FEAT_MOPS |
| 1             | 00  | 1101 | <a href="#">CPYPWTN</a> , <a href="#">CPYMWTN</a> , <a href="#">CPYEWTN</a><br>â€” <a href="#">CPYPWTN</a>     | FEAT_MOPS |
| 1             | 00  | 1110 | <a href="#">CPYPRTN</a> , <a href="#">CPYMRTRN</a> , <a href="#">CPYERTRN</a><br>â€” <a href="#">CPYPRTN</a>   | FEAT_MOPS |
| 1             | 00  | 1111 | <a href="#">CPYPTN</a> , <a href="#">CPYMTN</a> , <a href="#">CPYETN</a> â€”<br><a href="#">CPYPTN</a>         | FEAT_MOPS |
| 1             | 01  | 0000 | <a href="#">CPYP</a> , <a href="#">CPYM</a> , <a href="#">CPYE</a> â€” <a href="#">CPYM</a>                    | FEAT_MOPS |
| 1             | 01  | 0001 | <a href="#">CPYPWT</a> , <a href="#">CPYMWT</a> , <a href="#">CPYEWT</a> â€”<br><a href="#">CPYMWT</a>         | FEAT_MOPS |
| 1             | 01  | 0010 | <a href="#">CPYPRT</a> , <a href="#">CPYMRTRT</a> , <a href="#">CPYERT</a> â€”<br><a href="#">CPYMRTRT</a>     | FEAT_MOPS |
| 1             | 01  | 0011 | <a href="#">CPYPT</a> , <a href="#">CPYMT</a> , <a href="#">CPYET</a> â€” <a href="#">CPYMT</a>                | FEAT_MOPS |
| 1             | 01  | 0100 | <a href="#">CPYPWN</a> , <a href="#">CPYMWN</a> , <a href="#">CPYEWN</a> â€” <a href="#">CPYMWN</a>            | FEAT_MOPS |
| 1             | 01  | 0101 | <a href="#">CPYPWTWN</a> , <a href="#">CPYMWTWN</a> ,<br><a href="#">CPYEWTWN</a> â€” <a href="#">CPYMWTWN</a> | FEAT_MOPS |
| 1             | 01  | 0110 | <a href="#">CPYPRTWN</a> , <a href="#">CPYMRTRN</a> ,<br><a href="#">CPYERTWN</a> â€” <a href="#">CPYMRTRN</a> | FEAT_MOPS |
| 1             | 01  | 0111 | <a href="#">CPYPTWN</a> , <a href="#">CPYMTWN</a> , <a href="#">CPYETWN</a><br>â€” <a href="#">CPYMTWN</a>     | FEAT_MOPS |
| 1             | 01  | 1000 | <a href="#">CPYPRN</a> , <a href="#">CPYMRN</a> , <a href="#">CPYERN</a> â€”<br><a href="#">CPYMRN</a>         | FEAT_MOPS |
| 1             | 01  | 1001 | <a href="#">CPYPWTRN</a> , <a href="#">CPYMWTRN</a> ,<br><a href="#">CPYEWTRN</a> â€” <a href="#">CPYMWTRN</a> | FEAT_MOPS |
| 1             | 01  | 1010 | <a href="#">CPYPRTRN</a> , <a href="#">CPYMRTRN</a> ,<br><a href="#">CPYERTRN</a> â€” <a href="#">CPYMRTRN</a> | FEAT_MOPS |

| Decode fields |     |      | Instruction Details                                                                                            | Feature   |
|---------------|-----|------|----------------------------------------------------------------------------------------------------------------|-----------|
| o0            | op1 | op2  |                                                                                                                |           |
| 1             | 01  | 1011 | <a href="#">CPYPTRN</a> , <a href="#">CPYMTRN</a> , <a href="#">CPYETRN</a><br>â€” <a href="#">CPYMTRN</a>     | FEAT_MOPS |
| 1             | 01  | 1100 | <a href="#">CPYPN</a> , <a href="#">CPYMN</a> , <a href="#">CPYEN</a> â€”<br><a href="#">CPYMN</a>             | FEAT_MOPS |
| 1             | 01  | 1101 | <a href="#">CPYPWTN</a> , <a href="#">CPYMWTN</a> , <a href="#">CPYEWTN</a><br>â€” <a href="#">CPYMWTN</a>     | FEAT_MOPS |
| 1             | 01  | 1110 | <a href="#">CPYPRTN</a> , <a href="#">CPYMRTN</a> , <a href="#">CPYERTN</a><br>â€” <a href="#">CPYMRTN</a>     | FEAT_MOPS |
| 1             | 01  | 1111 | <a href="#">CPYPTN</a> , <a href="#">CPYMTN</a> , <a href="#">CPYETN</a> â€”<br><a href="#">CPYMTN</a>         | FEAT_MOPS |
| 1             | 10  | 0000 | <a href="#">CPYP</a> , <a href="#">CPYM</a> , <a href="#">CPYE</a> â€” <a href="#">CPYE</a>                    | FEAT_MOPS |
| 1             | 10  | 0001 | <a href="#">CPYPWT</a> , <a href="#">CPYMWT</a> , <a href="#">CPYEWT</a> â€”<br><a href="#">CPYEWT</a>         | FEAT_MOPS |
| 1             | 10  | 0010 | <a href="#">CPYPRT</a> , <a href="#">CPYMRT</a> , <a href="#">CPYERT</a> â€”<br><a href="#">CPYERT</a>         | FEAT_MOPS |
| 1             | 10  | 0011 | <a href="#">CPYPT</a> , <a href="#">CPYMT</a> , <a href="#">CPYET</a> â€” <a href="#">CPYET</a>                | FEAT_MOPS |
| 1             | 10  | 0100 | <a href="#">CPYPWN</a> , <a href="#">CPYMWN</a> , <a href="#">CPYEWN</a> â€”<br><a href="#">CPYEWN</a>         | FEAT_MOPS |
| 1             | 10  | 0101 | <a href="#">CPYPWTWN</a> , <a href="#">CPYMWTWN</a> ,<br><a href="#">CPYEWTWN</a> â€” <a href="#">CPYEWTWN</a> | FEAT_MOPS |
| 1             | 10  | 0110 | <a href="#">CPYPRTWN</a> , <a href="#">CPYMRTWN</a> ,<br><a href="#">CPYERTWN</a> â€” <a href="#">CPYERTWN</a> | FEAT_MOPS |
| 1             | 10  | 0111 | <a href="#">CPYPTWN</a> , <a href="#">CPYMTWN</a> , <a href="#">CPYETWN</a><br>â€” <a href="#">CPYETWN</a>     | FEAT_MOPS |
| 1             | 10  | 1000 | <a href="#">CPYPRN</a> , <a href="#">CPYMRN</a> , <a href="#">CPYERN</a> â€”<br><a href="#">CPYERN</a>         | FEAT_MOPS |
| 1             | 10  | 1001 | <a href="#">CPYPWTRN</a> , <a href="#">CPYMWTRN</a> ,<br><a href="#">CPYEWTRN</a> â€” <a href="#">CPYEWTRN</a> | FEAT_MOPS |
| 1             | 10  | 1010 | <a href="#">CPYPRTRN</a> , <a href="#">CPYMRTRN</a> ,<br><a href="#">CPYERTRN</a> â€” <a href="#">CPYERTRN</a> | FEAT_MOPS |
| 1             | 10  | 1011 | <a href="#">CPYPTRN</a> , <a href="#">CPYMTRN</a> , <a href="#">CPYETRN</a><br>â€” <a href="#">CPYETRN</a>     | FEAT_MOPS |
| 1             | 10  | 1100 | <a href="#">CPYPN</a> , <a href="#">CPYMN</a> , <a href="#">CPYEN</a> â€”<br><a href="#">CPYEN</a>             | FEAT_MOPS |
| 1             | 10  | 1101 | <a href="#">CPYPWTN</a> , <a href="#">CPYMWTN</a> , <a href="#">CPYEWTN</a><br>â€” <a href="#">CPYEWTN</a>     | FEAT_MOPS |
| 1             | 10  | 1110 | <a href="#">CPYPRTN</a> , <a href="#">CPYMRTN</a> , <a href="#">CPYERTN</a><br>â€” <a href="#">CPYERTN</a>     | FEAT_MOPS |
| 1             | 10  | 1111 | <a href="#">CPYPTN</a> , <a href="#">CPYMTN</a> , <a href="#">CPYETN</a> â€”<br><a href="#">CPYETN</a>         | FEAT_MOPS |
| 1             | 11  | 0000 | <a href="#">SETGP</a> , <a href="#">SETGM</a> , <a href="#">SETGE</a> â€” <a href="#">SETGP</a>                | FEAT_MOPS |
| 1             | 11  | 0001 | <a href="#">SETGPT</a> , <a href="#">SETGMT</a> , <a href="#">SETGET</a> â€”<br><a href="#">SETGPT</a>         | FEAT_MOPS |
| 1             | 11  | 0010 | <a href="#">SETGPN</a> , <a href="#">SETGMN</a> , <a href="#">SETGEN</a> â€”<br><a href="#">SETGPN</a>         | FEAT_MOPS |

| Decode fields |     |      | Instruction Details                                                   | Feature   |
|---------------|-----|------|-----------------------------------------------------------------------|-----------|
| o0            | op1 | op2  |                                                                       |           |
| 1             | 11  | 0011 | <a href="#">SETGPTN, SETGMTN, SETGETN</a> â€” <a href="#">SETGPTN</a> | FEAT_MOPS |
| 1             | 11  | 0100 | <a href="#">SETGP, SETGM, SETGE</a> â€” <a href="#">SETGM</a>         | FEAT_MOPS |
| 1             | 11  | 0101 | <a href="#">SETGPT, SETGMT, SETGET</a> â€” <a href="#">SETGMT</a>     | FEAT_MOPS |
| 1             | 11  | 0110 | <a href="#">SETGPN, SETGMN, SETGEN</a> â€” <a href="#">SETGMN</a>     | FEAT_MOPS |
| 1             | 11  | 0111 | <a href="#">SETGPTN, SETGMTN, SETGETN</a> â€” <a href="#">SETGMTN</a> | FEAT_MOPS |
| 1             | 11  | 1000 | <a href="#">SETGP, SETGM, SETGE</a> â€” <a href="#">SETGE</a>         | FEAT_MOPS |
| 1             | 11  | 1001 | <a href="#">SETGPT, SETGMT, SETGET</a> â€” <a href="#">SETGET</a>     | FEAT_MOPS |
| 1             | 11  | 1010 | <a href="#">SETGPN, SETGMN, SETGEN</a> â€” <a href="#">SETGEN</a>     | FEAT_MOPS |
| 1             | 11  | 1011 | <a href="#">SETGPTN, SETGMTN, SETGETN</a> â€” <a href="#">SETGETN</a> | FEAT_MOPS |
| 1             | 11  | 11xx | UNALLOCATED                                                           | -         |

#### Load/store no-allocate pair (offset)

These instructions are under [Loads and Stores](#).

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |    |   |    |   |   |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|----|---|----|---|---|
| 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3 | 2  | 1 | 0 |
| opc | 1  | 0  | 1  | VR | 0  | 0  | 0  | L  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Rn |   | Rt |   |   |

| Decode fields |    |   | Instruction Details                                            |
|---------------|----|---|----------------------------------------------------------------|
| opc           | VR | L |                                                                |
| 00            | 0  | 0 | <a href="#">STNP</a> â€” <a href="#">32-bit</a>                |
| 00            | 0  | 1 | <a href="#">LDNP</a> â€” <a href="#">32-bit</a>                |
| 00            | 1  | 0 | <a href="#">STNP (SIMD&amp;FP)</a> â€” <a href="#">32-bit</a>  |
| 00            | 1  | 1 | <a href="#">LDNP (SIMD&amp;FP)</a> â€” <a href="#">32-bit</a>  |
| 01            | 0  |   | UNALLOCATED                                                    |
| 01            | 1  | 0 | <a href="#">STNP (SIMD&amp;FP)</a> â€” <a href="#">64-bit</a>  |
| 01            | 1  | 1 | <a href="#">LDNP (SIMD&amp;FP)</a> â€” <a href="#">64-bit</a>  |
| 10            | 0  | 0 | <a href="#">STNP</a> â€” <a href="#">64-bit</a>                |
| 10            | 0  | 1 | <a href="#">LDNP</a> â€” <a href="#">64-bit</a>                |
| 10            | 1  | 0 | <a href="#">STNP (SIMD&amp;FP)</a> â€” <a href="#">128-bit</a> |
| 10            | 1  | 1 | <a href="#">LDNP (SIMD&amp;FP)</a> â€” <a href="#">128-bit</a> |
| 11            |    |   | UNALLOCATED                                                    |

## Load/store register pair (post-indexed)

These instructions are under [Loads and Stores](#).

|     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7  | 6 | 5  | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|----|---|----|---|---|---|---|---|
| opc | 1  | 0  | 1  | VR | 0  | 0  | 1  | L  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Rt2 |   | Rn |   | Rt |   |   |   |   |   |

| Decode fields |    |   | Instruction Details                                           |  |  | Feature |          |  |
|---------------|----|---|---------------------------------------------------------------|--|--|---------|----------|--|
| opc           | VR | L |                                                               |  |  |         |          |  |
| 00            | 0  | 0 | <a href="#">STP</a> â€“ <a href="#">32-bit</a>                |  |  |         | -        |  |
| 00            | 0  | 1 | <a href="#">LDP</a> â€“ <a href="#">32-bit</a>                |  |  |         | -        |  |
| 00            | 1  | 0 | <a href="#">STP (SIMD&amp;FP)</a> â€“ <a href="#">32-bit</a>  |  |  |         | -        |  |
| 00            | 1  | 1 | <a href="#">LDP (SIMD&amp;FP)</a> â€“ <a href="#">32-bit</a>  |  |  |         | -        |  |
| 01            | 0  | 0 | <a href="#">STGP</a>                                          |  |  |         | FEAT_MTE |  |
| 01            | 0  | 1 | <a href="#">LDPSW</a>                                         |  |  |         | -        |  |
| 01            | 1  | 0 | <a href="#">STP (SIMD&amp;FP)</a> â€“ <a href="#">64-bit</a>  |  |  |         | -        |  |
| 01            | 1  | 1 | <a href="#">LDP (SIMD&amp;FP)</a> â€“ <a href="#">64-bit</a>  |  |  |         | -        |  |
| 10            | 0  | 0 | <a href="#">STP</a> â€“ <a href="#">64-bit</a>                |  |  |         | -        |  |
| 10            | 0  | 1 | <a href="#">LDP</a> â€“ <a href="#">64-bit</a>                |  |  |         | -        |  |
| 10            | 1  | 0 | <a href="#">STP (SIMD&amp;FP)</a> â€“ <a href="#">128-bit</a> |  |  |         | -        |  |
| 10            | 1  | 1 | <a href="#">LDP (SIMD&amp;FP)</a> â€“ <a href="#">128-bit</a> |  |  |         | -        |  |
| 11            |    |   | UNALLOCATED                                                   |  |  |         | -        |  |

## Load/store register pair (offset)

These instructions are under [Loads and Stores](#).

|     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10  | 9 | 8  | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|---|----|---|----|---|---|---|---|---|---|
| opc | 1  | 0  | 1  | VR | 0  | 1  | 0  | L  |    |    |    |    |    |    |    |    |    |    |    |    |    | Rt2 |   | Rn |   | Rt |   |   |   |   |   |   |

| Decode fields |    |   | Instruction Details                                          |  |  | Feature |          |  |
|---------------|----|---|--------------------------------------------------------------|--|--|---------|----------|--|
| opc           | VR | L |                                                              |  |  |         |          |  |
| 00            | 0  | 0 | <a href="#">STP</a> â€“ <a href="#">32-bit</a>               |  |  |         | -        |  |
| 00            | 0  | 1 | <a href="#">LDP</a> â€“ <a href="#">32-bit</a>               |  |  |         | -        |  |
| 00            | 1  | 0 | <a href="#">STP (SIMD&amp;FP)</a> â€“ <a href="#">32-bit</a> |  |  |         | -        |  |
| 00            | 1  | 1 | <a href="#">LDP (SIMD&amp;FP)</a> â€“ <a href="#">32-bit</a> |  |  |         | -        |  |
| 01            | 0  | 0 | <a href="#">STGP</a>                                         |  |  |         | FEAT_MTE |  |
| 01            | 0  | 1 | <a href="#">LDPSW</a>                                        |  |  |         | -        |  |
| 01            | 1  | 0 | <a href="#">STP (SIMD&amp;FP)</a> â€“ <a href="#">64-bit</a> |  |  |         | -        |  |
| 01            | 1  | 1 | <a href="#">LDP (SIMD&amp;FP)</a> â€“ <a href="#">64-bit</a> |  |  |         | -        |  |
| 10            | 0  | 0 | <a href="#">STP</a> â€“ <a href="#">64-bit</a>               |  |  |         | -        |  |
| 10            | 0  | 1 | <a href="#">LDP</a> â€“ <a href="#">64-bit</a>               |  |  |         | -        |  |

| Decode fields |    |   | Instruction Details               |     |                         | Feature |  |
|---------------|----|---|-----------------------------------|-----|-------------------------|---------|--|
| opc           | VR | L |                                   |     |                         |         |  |
| 10            | 1  | 0 | <a href="#">STP (SIMD&amp;FP)</a> | â€” | <a href="#">128-bit</a> | -       |  |
| 10            | 1  | 1 | <a href="#">LDP (SIMD&amp;FP)</a> | â€” | <a href="#">128-bit</a> | -       |  |
| 11            |    |   | UNALLOCATED                       |     |                         | -       |  |

### Load/store register pair (pre-indexed)

These instructions are under [Loads and Stores](#).

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| opc | 1  | 0  | 1  | VR | 0  | 1  | 1  | L  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Rt |   |

| Decode fields |    |   | Instruction Details               |     |                         | Feature  |  |
|---------------|----|---|-----------------------------------|-----|-------------------------|----------|--|
| opc           | VR | L |                                   |     |                         |          |  |
| 00            | 0  | 0 | <a href="#">STP</a>               | â€” | <a href="#">32-bit</a>  | -        |  |
| 00            | 0  | 1 | <a href="#">LDP</a>               | â€” | <a href="#">32-bit</a>  | -        |  |
| 00            | 1  | 0 | <a href="#">STP (SIMD&amp;FP)</a> | â€” | <a href="#">32-bit</a>  | -        |  |
| 00            | 1  | 1 | <a href="#">LDP (SIMD&amp;FP)</a> | â€” | <a href="#">32-bit</a>  | -        |  |
| 01            | 0  | 0 | <a href="#">STGP</a>              |     |                         | FEAT_MTE |  |
| 01            | 0  | 1 | <a href="#">LDPSW</a>             |     |                         | -        |  |
| 01            | 1  | 0 | <a href="#">STP (SIMD&amp;FP)</a> | â€” | <a href="#">64-bit</a>  | -        |  |
| 01            | 1  | 1 | <a href="#">LDP (SIMD&amp;FP)</a> | â€” | <a href="#">64-bit</a>  | -        |  |
| 10            | 0  | 0 | <a href="#">STP</a>               | â€” | <a href="#">64-bit</a>  | -        |  |
| 10            | 0  | 1 | <a href="#">LDP</a>               | â€” | <a href="#">64-bit</a>  | -        |  |
| 10            | 1  | 0 | <a href="#">STP (SIMD&amp;FP)</a> | â€” | <a href="#">128-bit</a> | -        |  |
| 10            | 1  | 1 | <a href="#">LDP (SIMD&amp;FP)</a> | â€” | <a href="#">128-bit</a> | -        |  |
| 11            |    |   | UNALLOCATED                       |     |                         | -        |  |

### Load/store register (unscaled immediate)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |    |   |    |   |   |
|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|----|---|----|---|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3 | 2  | 1 | 0 |
| size | 1  | 1  | 1  | VR | 0  | 0  | opc | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | Rn |   | Rt |   |   |

| Decode fields |    |     | Instruction Details                               |  |  |
|---------------|----|-----|---------------------------------------------------|--|--|
| size          | VR | opc |                                                   |  |  |
| x1            | 1  | 1x  | UNALLOCATED                                       |  |  |
| 00            | 0  | 00  | <a href="#">STURB</a>                             |  |  |
| 00            | 0  | 01  | <a href="#">LDURB</a>                             |  |  |
| 00            | 0  | 10  | <a href="#">LDURSB</a> â€” <a href="#">64-bit</a> |  |  |

| Decode fields |    |     | Instruction Details                            |  |
|---------------|----|-----|------------------------------------------------|--|
| size          | VR | opc |                                                |  |
| 00            | 0  | 11  | <a href="#">LDURSB</a> â€” 32-bit              |  |
| 00            | 1  | 00  | <a href="#">STUR (SIMD&amp;FP)</a> â€” 8-bit   |  |
| 00            | 1  | 01  | <a href="#">LDUR (SIMD&amp;FP)</a> â€” 8-bit   |  |
| 00            | 1  | 10  | <a href="#">STUR (SIMD&amp;FP)</a> â€” 128-bit |  |
| 00            | 1  | 11  | <a href="#">LDUR (SIMD&amp;FP)</a> â€” 128-bit |  |
| 01            | 0  | 00  | <a href="#">STURH</a>                          |  |
| 01            | 0  | 01  | <a href="#">LDURH</a>                          |  |
| 01            | 0  | 10  | <a href="#">LDURSH</a> â€” 64-bit              |  |
| 01            | 0  | 11  | <a href="#">LDURSH</a> â€” 32-bit              |  |
| 01            | 1  | 00  | <a href="#">STUR (SIMD&amp;FP)</a> â€” 16-bit  |  |
| 01            | 1  | 01  | <a href="#">LDUR (SIMD&amp;FP)</a> â€” 16-bit  |  |
| 1x            | 0  | 11  | UNALLOCATED                                    |  |
| 1x            | 1  | 1x  | UNALLOCATED                                    |  |
| 10            | 0  | 00  | <a href="#">STUR</a> â€” 32-bit                |  |
| 10            | 0  | 01  | <a href="#">LDUR</a> â€” 32-bit                |  |
| 10            | 0  | 10  | <a href="#">LDURSW</a>                         |  |
| 10            | 1  | 00  | <a href="#">STUR (SIMD&amp;FP)</a> â€” 32-bit  |  |
| 10            | 1  | 01  | <a href="#">LDUR (SIMD&amp;FP)</a> â€” 32-bit  |  |
| 11            | 0  | 00  | <a href="#">STUR</a> â€” 64-bit                |  |
| 11            | 0  | 01  | <a href="#">LDUR</a> â€” 64-bit                |  |
| 11            | 0  | 10  | <a href="#">PRFUM</a>                          |  |
| 11            | 1  | 00  | <a href="#">STUR (SIMD&amp;FP)</a> â€” 64-bit  |  |
| 11            | 1  | 01  | <a href="#">LDUR (SIMD&amp;FP)</a> â€” 64-bit  |  |

### Load/store register (immediate post-indexed)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |      |   |   |    |   |    |   |   |   |  |
|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------|---|---|----|---|----|---|---|---|--|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5  | 4 | 3  | 2 | 1 | 0 |  |
| size | 1  | 1  | 1  | VR | 0  | 0  | opc | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |   | imm9 | 0 | 1 | Rn |   | Rt |   |   |   |  |

| Decode fields |    |     | Instruction Details                                    |  |
|---------------|----|-----|--------------------------------------------------------|--|
| size          | VR | opc |                                                        |  |
| x1            | 1  | 1x  | UNALLOCATED                                            |  |
| 00            | 0  | 00  | <a href="#">STRB (immediate)</a>                       |  |
| 00            | 0  | 01  | <a href="#">LDRB (immediate)</a>                       |  |
| 00            | 0  | 10  | <a href="#">LDRSB (immediate)</a> â€” 64-bit           |  |
| 00            | 0  | 11  | <a href="#">LDRSB (immediate)</a> â€” 32-bit           |  |
| 00            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP)</a> â€” 8-bit |  |

| Decode fields |    |     | Instruction Details                          |     |                         |  |  |  |  |  |  |  |
|---------------|----|-----|----------------------------------------------|-----|-------------------------|--|--|--|--|--|--|--|
| size          | VR | opc |                                              |     |                         |  |  |  |  |  |  |  |
| 00            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> | â€” | <a href="#">8-bit</a>   |  |  |  |  |  |  |  |
| 00            | 1  | 10  | <a href="#">STR (immediate, SIMD&amp;FP)</a> | â€” | <a href="#">128-bit</a> |  |  |  |  |  |  |  |
| 00            | 1  | 11  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> | â€” | <a href="#">128-bit</a> |  |  |  |  |  |  |  |
| 01            | 0  | 00  | <a href="#">STRH (immediate)</a>             |     |                         |  |  |  |  |  |  |  |
| 01            | 0  | 01  | <a href="#">LDRH (immediate)</a>             |     |                         |  |  |  |  |  |  |  |
| 01            | 0  | 10  | <a href="#">LDRSH (immediate)</a>            | â€” | <a href="#">64-bit</a>  |  |  |  |  |  |  |  |
| 01            | 0  | 11  | <a href="#">LDRSH (immediate)</a>            | â€” | <a href="#">32-bit</a>  |  |  |  |  |  |  |  |
| 01            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP)</a> | â€” | <a href="#">16-bit</a>  |  |  |  |  |  |  |  |
| 01            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> | â€” | <a href="#">16-bit</a>  |  |  |  |  |  |  |  |
| 1x            | 0  | 11  | UNALLOCATED                                  |     |                         |  |  |  |  |  |  |  |
| 1x            | 1  | 1x  | UNALLOCATED                                  |     |                         |  |  |  |  |  |  |  |
| 10            | 0  | 00  | <a href="#">STR (immediate)</a>              | â€” | <a href="#">32-bit</a>  |  |  |  |  |  |  |  |
| 10            | 0  | 01  | <a href="#">LDR (immediate)</a>              | â€” | <a href="#">32-bit</a>  |  |  |  |  |  |  |  |
| 10            | 0  | 10  | <a href="#">LDRSW (immediate)</a>            |     |                         |  |  |  |  |  |  |  |
| 10            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP)</a> | â€” | <a href="#">32-bit</a>  |  |  |  |  |  |  |  |
| 10            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> | â€” | <a href="#">32-bit</a>  |  |  |  |  |  |  |  |
| 11            | 0  | 00  | <a href="#">STR (immediate)</a>              | â€” | <a href="#">64-bit</a>  |  |  |  |  |  |  |  |
| 11            | 0  | 01  | <a href="#">LDR (immediate)</a>              | â€” | <a href="#">64-bit</a>  |  |  |  |  |  |  |  |
| 11            | 0  | 10  | UNALLOCATED                                  |     |                         |  |  |  |  |  |  |  |
| 11            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP)</a> | â€” | <a href="#">64-bit</a>  |  |  |  |  |  |  |  |
| 11            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> | â€” | <a href="#">64-bit</a>  |  |  |  |  |  |  |  |

### Load/store register (unprivileged)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |      |   |   |    |   |    |   |   |   |
|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------|---|---|----|---|----|---|---|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5  | 4 | 3  | 2 | 1 | 0 |
| size | 1  | 1  | 1  | VR | 0  | 0  | opc | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |   | imm9 | 1 | 0 | Rn |   | Rt |   |   |   |

| Decode fields |    |     | Instruction Details    |     |                        |  |  |  |  |  |  |  |
|---------------|----|-----|------------------------|-----|------------------------|--|--|--|--|--|--|--|
| size          | VR | opc |                        |     |                        |  |  |  |  |  |  |  |
|               |    | 1   |                        |     |                        |  |  |  |  |  |  |  |
|               |    |     | UNALLOCATED            |     |                        |  |  |  |  |  |  |  |
| 00            | 0  | 00  | <a href="#">STTRB</a>  |     |                        |  |  |  |  |  |  |  |
| 00            | 0  | 01  | <a href="#">LDTRB</a>  |     |                        |  |  |  |  |  |  |  |
| 00            | 0  | 10  | <a href="#">LDTRSB</a> | â€” | <a href="#">64-bit</a> |  |  |  |  |  |  |  |
| 00            | 0  | 11  | <a href="#">LDTRSB</a> | â€” | <a href="#">32-bit</a> |  |  |  |  |  |  |  |
| 01            | 0  | 00  | <a href="#">STTRH</a>  |     |                        |  |  |  |  |  |  |  |
| 01            | 0  | 01  | <a href="#">LDTRH</a>  |     |                        |  |  |  |  |  |  |  |
| 01            | 0  | 10  | <a href="#">LDTRSH</a> | â€” | <a href="#">64-bit</a> |  |  |  |  |  |  |  |

| Decode fields |    |     | Instruction Details               |
|---------------|----|-----|-----------------------------------|
| size          | VR | opc |                                   |
| 01            | 0  | 11  | <a href="#">LDTRSH</a> â€“ 32-bit |
| 1x            | 0  | 11  | UNALLOCATED                       |
| 10            | 0  | 00  | <a href="#">STTR</a> â€“ 32-bit   |
| 10            | 0  | 01  | <a href="#">LDTR</a> â€“ 32-bit   |
| 10            | 0  | 10  | <a href="#">LDTRSW</a>            |
| 11            | 0  | 00  | <a href="#">STTR</a> â€“ 64-bit   |
| 11            | 0  | 01  | <a href="#">LDTR</a> â€“ 64-bit   |
| 11            | 0  | 10  | UNALLOCATED                       |

### Load/store register (immediate pre-indexed)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |     |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| size | 1  | 1  | 1  | VR | 0  | 0  | opc | 0  |    |    |    |    |    |    | imm9 |    | 1  | 1  |    | Rn |    | Rt |   |   |   |   |   |   |   |   |   |

| Decode fields |    |     | Instruction Details                                      |
|---------------|----|-----|----------------------------------------------------------|
| size          | VR | opc |                                                          |
| x1            | 1  | 1x  | UNALLOCATED                                              |
| 00            | 0  | 00  | <a href="#">STRB (immediate)</a>                         |
| 00            | 0  | 01  | <a href="#">LDRB (immediate)</a>                         |
| 00            | 0  | 10  | <a href="#">LDRSB (immediate)</a> â€“ 64-bit             |
| 00            | 0  | 11  | <a href="#">LDRSB (immediate)</a> â€“ 32-bit             |
| 00            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP)</a> â€“ 8-bit   |
| 00            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> â€“ 8-bit   |
| 00            | 1  | 10  | <a href="#">STR (immediate, SIMD&amp;FP)</a> â€“ 128-bit |
| 00            | 1  | 11  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> â€“ 128-bit |
| 01            | 0  | 00  | <a href="#">STRH (immediate)</a>                         |
| 01            | 0  | 01  | <a href="#">LDRH (immediate)</a>                         |
| 01            | 0  | 10  | <a href="#">LDRSH (immediate)</a> â€“ 64-bit             |
| 01            | 0  | 11  | <a href="#">LDRSH (immediate)</a> â€“ 32-bit             |
| 01            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP)</a> â€“ 16-bit  |
| 01            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> â€“ 16-bit  |
| 1x            | 0  | 11  | UNALLOCATED                                              |
| 1x            | 1  | 1x  | UNALLOCATED                                              |
| 10            | 0  | 00  | <a href="#">STR (immediate)</a> â€“ 32-bit               |
| 10            | 0  | 01  | <a href="#">LDR (immediate)</a> â€“ 32-bit               |
| 10            | 0  | 10  | <a href="#">LDRSW (immediate)</a>                        |
| 10            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP)</a> â€“ 32-bit  |

| Decode fields |    |     | Instruction Details                                                     |
|---------------|----|-----|-------------------------------------------------------------------------|
| size          | VR | opc |                                                                         |
| 10            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> â€“ <a href="#">32-bit</a> |
| 11            | 0  | 00  | <a href="#">STR (immediate)</a> â€“ <a href="#">64-bit</a>              |
| 11            | 0  | 01  | <a href="#">LDR (immediate)</a> â€“ <a href="#">64-bit</a>              |
| 11            | 0  | 10  | UNALLOCATED                                                             |
| 11            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP)</a> â€“ <a href="#">64-bit</a> |
| 11            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP)</a> â€“ <a href="#">64-bit</a> |

## Atomic memory operations

These instructions are under [Loads and Stores](#).

|      |   |   |   |    |   |   |   |   |   |    |    |     |   |   |    |  |    |
|------|---|---|---|----|---|---|---|---|---|----|----|-----|---|---|----|--|----|
| size | 1 | 1 | 1 | VR | 0 | 0 | A | R | 1 | Rs | o3 | opc | 0 | 0 | Rn |  | Rt |
|------|---|---|---|----|---|---|---|---|---|----|----|-----|---|---|----|--|----|

| size | VR | Decode fields |   |    | o3 | opc | Instruction Details                                                                                                                          |          | Feature |
|------|----|---------------|---|----|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|
|      |    | A             | R | Rs |    |     |                                                                                                                                              |          |         |
|      | 0  |               |   |    | 1  | 11x | UNALLOCATED                                                                                                                                  | -        |         |
|      | 0  | 0             |   |    | 1  | 100 | UNALLOCATED                                                                                                                                  | -        |         |
|      | 0  | 0             | 1 |    | 1  | 101 | UNALLOCATED                                                                                                                                  | -        |         |
|      | 0  | 1             | 0 |    | 1  | 101 | UNALLOCATED                                                                                                                                  | -        |         |
|      | 0  | 1             | 1 |    | 1  | 100 | UNALLOCATED                                                                                                                                  | -        |         |
|      | 0  | 1             | 1 |    | 1  | 101 | UNALLOCATED                                                                                                                                  | -        |         |
|      | 1  |               |   |    |    |     | UNALLOCATED                                                                                                                                  | -        |         |
| 00   | 0  | 0             | 0 |    | 0  | 000 | <a href="#">LDADDB</a> ,<br><a href="#">LDADDAB</a> ,<br><a href="#">LDADDALB</a> ,<br><a href="#">LDADDLB</a> â€”<br><a href="#">LDADDB</a> | FEAT_LSE |         |
| 00   | 0  | 0             | 0 |    | 0  | 001 | <a href="#">LDCLRB</a> ,<br><a href="#">LDCLRAB</a> ,<br><a href="#">LDCLRALB</a> ,<br><a href="#">LDCLRLB</a> â€”<br><a href="#">LDCLRB</a> | FEAT_LSE |         |
| 00   | 0  | 0             | 0 |    | 0  | 010 | <a href="#">LDEORB</a> ,<br><a href="#">LDEORAB</a> ,<br><a href="#">LDEORALB</a> ,<br><a href="#">LDEORLB</a> â€”<br><a href="#">LDEORB</a> | FEAT_LSE |         |
| 00   | 0  | 0             | 0 |    | 0  | 011 | <a href="#">LDSETB</a> ,<br><a href="#">LDSETAB</a> ,<br><a href="#">LDSETALB</a> ,<br><a href="#">LDSETLB</a> â€”<br><a href="#">LDSETB</a> | FEAT_LSE |         |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                               | Feature  |
|------|----|---------------|---|----|--|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                   |          |
| 00   | 0  | 0             | 0 |    |  | 0  | 100 | <a href="#">LDSMAXB</a> ,<br><a href="#">LDSMAXAB</a> ,<br><a href="#">LDSMAXALB</a> ,<br><a href="#">LDSMAXLB</a> â€”<br><a href="#">LDSMAXB</a> | FEAT_LSE |
| 00   | 0  | 0             | 0 |    |  | 0  | 101 | <a href="#">LDSMINB</a> ,<br><a href="#">LDSMINAB</a> ,<br><a href="#">LDSMINALB</a> ,<br><a href="#">LDSMINLB</a> â€”<br><a href="#">LDSMINB</a> | FEAT_LSE |
| 00   | 0  | 0             | 0 |    |  | 0  | 110 | <a href="#">LDUMAXB</a> ,<br><a href="#">LDUMAXAB</a> ,<br><a href="#">LDUMAXALB</a> ,<br><a href="#">LDUMAXLB</a> â€”<br><a href="#">LDUMAXB</a> | FEAT_LSE |
| 00   | 0  | 0             | 0 |    |  | 0  | 111 | <a href="#">LDUMINB</a> ,<br><a href="#">LDUMINAB</a> ,<br><a href="#">LDUMINALB</a> ,<br><a href="#">LDUMINLB</a> â€”<br><a href="#">LDUMINB</a> | FEAT_LSE |
| 00   | 0  | 0             | 0 |    |  | 1  | 000 | <a href="#">SWPB</a> , <a href="#">SWPAB</a> ,<br><a href="#">SWPALB</a> ,<br><a href="#">SWPLB</a> â€”<br><a href="#">SWPB</a>                   | FEAT_LSE |
| 00   | 0  | 0             | 0 |    |  | 1  | 001 | <a href="#">RCWCLR</a> ,<br><a href="#">RCWCLRA</a> ,<br><a href="#">RCWCLRL</a> ,<br><a href="#">RCWCLRAL</a> â€”<br><a href="#">RCWCLR</a>      | FEAT_THE |
| 00   | 0  | 0             | 0 |    |  | 1  | 010 | <a href="#">RCWSWP</a> ,<br><a href="#">RCWSWPA</a> ,<br><a href="#">RCWSWPL</a> ,<br><a href="#">RCWSWPAL</a> â€”<br><a href="#">RCWSWP</a>      | FEAT_THE |
| 00   | 0  | 0             | 0 |    |  | 1  | 011 | <a href="#">RCWSET</a> ,<br><a href="#">RCWSETA</a> ,<br><a href="#">RCWSETL</a> ,<br><a href="#">RCWSETAL</a> â€”<br><a href="#">RCWSET</a>      | FEAT_THE |
| 00   | 0  | 0             | 0 |    |  | 1  | 101 | UNALLOCATED                                                                                                                                       | -        |
| 00   | 0  | 0             | 1 |    |  | 0  | 000 | <a href="#">LDADDB</a> ,<br><a href="#">LDADDAB</a> ,<br><a href="#">LDADDALB</a> ,<br><a href="#">LDADDLB</a> â€”<br><a href="#">LDADDLB</a>     | FEAT_LSE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                | Feature  |
|------|----|---------------|---|----|--|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                    |          |
| 00   | 0  | 0             | 1 |    |  | 0  | 001 | <a href="#">LDCLRB</a> ,<br><a href="#">LDCLRAB</a> ,<br><a href="#">LDCLRALB</a> ,<br><a href="#">LDCLRLB</a> â€”<br><a href="#">LDCLRLB</a>      | FEAT_LSE |
| 00   | 0  | 0             | 1 |    |  | 0  | 010 | <a href="#">LDEORB</a> ,<br><a href="#">LDEORAB</a> ,<br><a href="#">LDEORALB</a> ,<br><a href="#">LDEORLB</a> â€”<br><a href="#">LDEORLB</a>      | FEAT_LSE |
| 00   | 0  | 0             | 1 |    |  | 0  | 011 | <a href="#">LDSETB</a> ,<br><a href="#">LDSETAB</a> ,<br><a href="#">LDSETALB</a> ,<br><a href="#">LDSETLB</a> â€”<br><a href="#">LDSETLB</a>      | FEAT_LSE |
| 00   | 0  | 0             | 1 |    |  | 0  | 100 | <a href="#">LDSMAXB</a> ,<br><a href="#">LDSMAXAB</a> ,<br><a href="#">LDSMAXALB</a> ,<br><a href="#">LDSMAXLB</a> â€”<br><a href="#">LDSMAXLB</a> | FEAT_LSE |
| 00   | 0  | 0             | 1 |    |  | 0  | 101 | <a href="#">LDSMINB</a> ,<br><a href="#">LDSMINAB</a> ,<br><a href="#">LDSMINALB</a> ,<br><a href="#">LDSMINLB</a> â€”<br><a href="#">LDSMINLB</a> | FEAT_LSE |
| 00   | 0  | 0             | 1 |    |  | 0  | 110 | <a href="#">LDUMAXB</a> ,<br><a href="#">LDUMAXAB</a> ,<br><a href="#">LDUMAXALB</a> ,<br><a href="#">LDUMAXLB</a> â€”<br><a href="#">LDUMAXLB</a> | FEAT_LSE |
| 00   | 0  | 0             | 1 |    |  | 0  | 111 | <a href="#">LDUMINB</a> ,<br><a href="#">LDUMINAB</a> ,<br><a href="#">LDUMINALB</a> ,<br><a href="#">LDUMINLB</a> â€”<br><a href="#">LDUMINLB</a> | FEAT_LSE |
| 00   | 0  | 0             | 1 |    |  | 1  | 000 | <a href="#">SWPB</a> , <a href="#">SWPAB</a> ,<br><a href="#">SWPALB</a> ,<br><a href="#">SWPLB</a> â€”<br><a href="#">SWPLB</a>                   | FEAT_LSE |
| 00   | 0  | 0             | 1 |    |  | 1  | 001 | <a href="#">RCWCLR</a> ,<br><a href="#">RCWCLRA</a> ,<br><a href="#">RCWCLRL</a> ,<br><a href="#">RCWCLRAL</a> â€”<br><a href="#">RCWCLRL</a>      | FEAT_THE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                | Feature  |
|------|----|---------------|---|----|--|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                    |          |
| 00   | 0  | 0             | 1 |    |  | 1  | 010 | <a href="#">RCWSWP</a> ,<br><a href="#">RCWSWPA</a> ,<br><a href="#">RCWSWPL</a> ,<br><a href="#">RCWSWPAL</a> â€”<br><a href="#">RCWSWPL</a>      | FEAT_THE |
| 00   | 0  | 0             | 1 |    |  | 1  | 011 | <a href="#">RCWSET</a> ,<br><a href="#">RCWSETA</a> ,<br><a href="#">RCWSETL</a> ,<br><a href="#">RCWSETAL</a> â€”<br><a href="#">RCWSETL</a>      | FEAT_THE |
| 00   | 0  | 1             | 0 |    |  | 0  | 000 | <a href="#">LDADDB</a> ,<br><a href="#">LDADDAB</a> ,<br><a href="#">LDADDALB</a> ,<br><a href="#">LDADDLB</a> â€”<br><a href="#">LDADDAB</a>      | FEAT_LSE |
| 00   | 0  | 1             | 0 |    |  | 0  | 001 | <a href="#">LDCLRB</a> ,<br><a href="#">LDCLRAB</a> ,<br><a href="#">LDCLRALB</a> ,<br><a href="#">LDCLRLB</a> â€”<br><a href="#">LDCLRAB</a>      | FEAT_LSE |
| 00   | 0  | 1             | 0 |    |  | 0  | 010 | <a href="#">LDEORB</a> ,<br><a href="#">LDEORAB</a> ,<br><a href="#">LDEORALB</a> ,<br><a href="#">LDEORLB</a> â€”<br><a href="#">LDEORAB</a>      | FEAT_LSE |
| 00   | 0  | 1             | 0 |    |  | 0  | 011 | <a href="#">LDSETB</a> ,<br><a href="#">LDSETAB</a> ,<br><a href="#">LDSETALB</a> ,<br><a href="#">LDSETLB</a> â€”<br><a href="#">LDSETAB</a>      | FEAT_LSE |
| 00   | 0  | 1             | 0 |    |  | 0  | 100 | <a href="#">LDSMAXB</a> ,<br><a href="#">LDSMAXAB</a> ,<br><a href="#">LDSMAXALB</a> ,<br><a href="#">LDSMAXLB</a> â€”<br><a href="#">LDSMAXAB</a> | FEAT_LSE |
| 00   | 0  | 1             | 0 |    |  | 0  | 101 | <a href="#">LDSMINB</a> ,<br><a href="#">LDSMINAB</a> ,<br><a href="#">LDSMINALB</a> ,<br><a href="#">LDSMINLB</a> â€”<br><a href="#">LDSMINAB</a> | FEAT_LSE |
| 00   | 0  | 1             | 0 |    |  | 0  | 110 | <a href="#">LDUMAXB</a> ,<br><a href="#">LDUMAXAB</a> ,<br><a href="#">LDUMAXALB</a> ,<br><a href="#">LDUMAXLB</a> â€”<br><a href="#">LDUMAXAB</a> | FEAT_LSE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                | Feature     |
|------|----|---------------|---|----|--|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                    |             |
| 00   | 0  | 1             | 0 |    |  | 0  | 111 | <a href="#">LDUMINB</a> ,<br><a href="#">LDUMINAB</a> ,<br><a href="#">LDUMINALB</a> ,<br><a href="#">LDUMINLB</a> â€”<br><a href="#">LDUMINAB</a> | FEAT_LSE    |
| 00   | 0  | 1             | 0 |    |  | 1  | 000 | <a href="#">SWPB</a> , <a href="#">SWPAB</a> ,<br><a href="#">SWPALB</a> ,<br><a href="#">SWPLB</a> â€”<br><a href="#">SWPAB</a>                   | FEAT_LSE    |
| 00   | 0  | 1             | 0 |    |  | 1  | 001 | <a href="#">RCWCLR</a> ,<br><a href="#">RCWCLRA</a> ,<br><a href="#">RCWCLRL</a> ,<br><a href="#">RCWCLRAL</a> â€”<br><a href="#">RCWCLRA</a>      | FEAT_THE    |
| 00   | 0  | 1             | 0 |    |  | 1  | 010 | <a href="#">RCWSWP</a> ,<br><a href="#">RCWSWPA</a> ,<br><a href="#">RCWSWPL</a> ,<br><a href="#">RCWSWPAL</a> â€”<br><a href="#">RCWSWPA</a>      | FEAT_THE    |
| 00   | 0  | 1             | 0 |    |  | 1  | 011 | <a href="#">RCWSET</a> ,<br><a href="#">RCWSETA</a> ,<br><a href="#">RCWSETL</a> ,<br><a href="#">RCWSETAL</a> â€”<br><a href="#">RCWSETA</a>      | FEAT_THE    |
| 00   | 0  | 1             | 0 |    |  | 1  | 100 | <a href="#">LDAPRB</a>                                                                                                                             | FEAT_LRPCPC |
| 00   | 0  | 1             | 1 |    |  | 0  | 000 | <a href="#">LDADDB</a> ,<br><a href="#">LDADDAB</a> ,<br><a href="#">LDADDALB</a> ,<br><a href="#">LDADDLB</a> â€”<br><a href="#">LDADDALB</a>     | FEAT_LSE    |
| 00   | 0  | 1             | 1 |    |  | 0  | 001 | <a href="#">LDCLRB</a> ,<br><a href="#">LDCLRAB</a> ,<br><a href="#">LDCLRALB</a> ,<br><a href="#">LDCLRLB</a> â€”<br><a href="#">LDCLRALB</a>     | FEAT_LSE    |
| 00   | 0  | 1             | 1 |    |  | 0  | 010 | <a href="#">LDEORB</a> ,<br><a href="#">LDEORAB</a> ,<br><a href="#">LDEORALB</a> ,<br><a href="#">LDEORLB</a> â€”<br><a href="#">LDEORALB</a>     | FEAT_LSE    |
| 00   | 0  | 1             | 1 |    |  | 0  | 011 | <a href="#">LDSETB</a> ,<br><a href="#">LDSETAB</a> ,<br><a href="#">LDSETALB</a> ,<br><a href="#">LDSETLB</a> â€”<br><a href="#">LDSETALB</a>     | FEAT_LSE    |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                 | Feature  |
|------|----|---------------|---|----|--|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                     |          |
| 00   | 0  | 1             | 1 |    |  | 0  | 100 | <a href="#">LDSMAXB</a> ,<br><a href="#">LDSMAXAB</a> ,<br><a href="#">LDSMAXALB</a> ,<br><a href="#">LDSMAXLB</a> â€”<br><a href="#">LDSMAXALB</a> | FEAT_LSE |
| 00   | 0  | 1             | 1 |    |  | 0  | 101 | <a href="#">LDSMINB</a> ,<br><a href="#">LDSMINAB</a> ,<br><a href="#">LDSMINALB</a> ,<br><a href="#">LDSMINLB</a> â€”<br><a href="#">LDSMINALB</a> | FEAT_LSE |
| 00   | 0  | 1             | 1 |    |  | 0  | 110 | <a href="#">LDUMAXB</a> ,<br><a href="#">LDUMAXAB</a> ,<br><a href="#">LDUMAXALB</a> ,<br><a href="#">LDUMAXLB</a> â€”<br><a href="#">LDUMAXALB</a> | FEAT_LSE |
| 00   | 0  | 1             | 1 |    |  | 0  | 111 | <a href="#">LDUMINB</a> ,<br><a href="#">LDUMINAB</a> ,<br><a href="#">LDUMINALB</a> ,<br><a href="#">LDUMINLB</a> â€”<br><a href="#">LDUMINALB</a> | FEAT_LSE |
| 00   | 0  | 1             | 1 |    |  | 1  | 000 | <a href="#">SWPB</a> , <a href="#">SWPAB</a> ,<br><a href="#">SWPALB</a> ,<br><a href="#">SWPLB</a> â€”<br><a href="#">SWPALB</a>                   | FEAT_LSE |
| 00   | 0  | 1             | 1 |    |  | 1  | 001 | <a href="#">RCWCLR</a> ,<br><a href="#">RCWCLRA</a> ,<br><a href="#">RCWCLRL</a> ,<br><a href="#">RCWCLRAL</a> â€”<br><a href="#">RCWCLRAL</a>      | FEAT_THE |
| 00   | 0  | 1             | 1 |    |  | 1  | 010 | <a href="#">RCWSWP</a> ,<br><a href="#">RCWSWPA</a> ,<br><a href="#">RCWSWPL</a> ,<br><a href="#">RCWSWPAL</a> â€”<br><a href="#">RCWSWPAL</a>      | FEAT_THE |
| 00   | 0  | 1             | 1 |    |  | 1  | 011 | <a href="#">RCWSET</a> ,<br><a href="#">RCWSETA</a> ,<br><a href="#">RCWSETL</a> ,<br><a href="#">RCWSETAL</a> â€”<br><a href="#">RCWSETAL</a>      | FEAT_THE |
| 01   | 0  | 0             | 0 |    |  | 0  | 000 | <a href="#">LDADDH</a> ,<br><a href="#">LDADDAH</a> ,<br><a href="#">LDADDALH</a> ,<br><a href="#">LDADDLH</a> â€”<br><a href="#">LDADDH</a>        | FEAT_LSE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                               | Feature  |
|------|----|---------------|---|----|--|----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                   |          |
| 01   | 0  | 0             | 0 |    |  | 0  | 001 | <a href="#">LDCLRH</a> ,<br><a href="#">LDCLRAH</a> ,<br><a href="#">LDCLRALH</a> ,<br><a href="#">LDCLRLH</a> â€”<br><a href="#">LDCLRH</a>      | FEAT_LSE |
| 01   | 0  | 0             | 0 |    |  | 0  | 010 | <a href="#">LDEORH</a> ,<br><a href="#">LDEORAH</a> ,<br><a href="#">LDEORALH</a> ,<br><a href="#">LDEORLH</a> â€”<br><a href="#">LDEORH</a>      | FEAT_LSE |
| 01   | 0  | 0             | 0 |    |  | 0  | 011 | <a href="#">LDSETH</a> ,<br><a href="#">LDSETAH</a> ,<br><a href="#">LDSETALH</a> ,<br><a href="#">LDSETLH</a> â€”<br><a href="#">LDSETH</a>      | FEAT_LSE |
| 01   | 0  | 0             | 0 |    |  | 0  | 100 | <a href="#">LDSMAXH</a> ,<br><a href="#">LDSMAXAH</a> ,<br><a href="#">LDSMAXALH</a> ,<br><a href="#">LDSMAXLH</a> â€”<br><a href="#">LDSMAXH</a> | FEAT_LSE |
| 01   | 0  | 0             | 0 |    |  | 0  | 101 | <a href="#">LDSMINH</a> ,<br><a href="#">LDSMINAH</a> ,<br><a href="#">LDSMINALH</a> ,<br><a href="#">LDSMINLH</a> â€”<br><a href="#">LDSMINH</a> | FEAT_LSE |
| 01   | 0  | 0             | 0 |    |  | 0  | 110 | <a href="#">LDUMAXH</a> ,<br><a href="#">LDUMAXAH</a> ,<br><a href="#">LDUMAXALH</a> ,<br><a href="#">LDUMAXLH</a> â€”<br><a href="#">LDUMAXH</a> | FEAT_LSE |
| 01   | 0  | 0             | 0 |    |  | 0  | 111 | <a href="#">LDUMINH</a> ,<br><a href="#">LDUMINAH</a> ,<br><a href="#">LDUMINALH</a> ,<br><a href="#">LDUMINLH</a> â€”<br><a href="#">LDUMINH</a> | FEAT_LSE |
| 01   | 0  | 0             | 0 |    |  | 1  | 000 | <a href="#">SWPH</a> , <a href="#">SWPAH</a> ,<br><a href="#">SWPALH</a> ,<br><a href="#">SWPLH</a> â€”<br><a href="#">SWPH</a>                   | FEAT_LSE |
| 01   | 0  | 0             | 0 |    |  | 1  | 001 | <a href="#">RCWSCLR</a> ,<br><a href="#">RCWSCLRA</a> ,<br><a href="#">RCWSCLRL</a> ,<br><a href="#">RCWSCLRAL</a><br>â€” <a href="#">RCWSCLR</a> | FEAT_THE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                | Feature  |
|------|----|---------------|---|----|--|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                    |          |
| 01   | 0  | 0             | 0 |    |  | 1  | 010 | <a href="#">RCWSSWP</a> ,<br><a href="#">RCWSSWPA</a> ,<br><a href="#">RCWSSWPL</a> ,<br><a href="#">RCWSSWPAL</a><br>â€” <a href="#">RCWSSWP</a>  | FEAT_THE |
| 01   | 0  | 0             | 0 |    |  | 1  | 011 | <a href="#">RCWSSET</a> ,<br><a href="#">RCWSSETA</a> ,<br><a href="#">RCWSSETL</a> ,<br><a href="#">RCWSSETAL</a> â€”<br><a href="#">RCWSSET</a>  | FEAT_THE |
| 01   | 0  | 0             | 0 |    |  | 1  | 101 | UNALLOCATED                                                                                                                                        | -        |
| 01   | 0  | 0             | 1 |    |  | 0  | 000 | <a href="#">LDADDH</a> ,<br><a href="#">LDADDAH</a> ,<br><a href="#">LDADDALH</a> ,<br><a href="#">LDADDLH</a> â€”<br><a href="#">LDADDLH</a>      | FEAT_LSE |
| 01   | 0  | 0             | 1 |    |  | 0  | 001 | <a href="#">LDCLRH</a> ,<br><a href="#">LDCLRAH</a> ,<br><a href="#">LDCLRALH</a> ,<br><a href="#">LDCLRLH</a> â€”<br><a href="#">LDCLRLH</a>      | FEAT_LSE |
| 01   | 0  | 0             | 1 |    |  | 0  | 010 | <a href="#">LDEORH</a> ,<br><a href="#">LDEORAH</a> ,<br><a href="#">LDEORALH</a> ,<br><a href="#">LDEORLH</a> â€”<br><a href="#">LDEORLH</a>      | FEAT_LSE |
| 01   | 0  | 0             | 1 |    |  | 0  | 011 | <a href="#">LDSETH</a> ,<br><a href="#">LDSETAH</a> ,<br><a href="#">LDSETALH</a> ,<br><a href="#">LDSETLH</a> â€”<br><a href="#">LDSETLH</a>      | FEAT_LSE |
| 01   | 0  | 0             | 1 |    |  | 0  | 100 | <a href="#">LDSMAXH</a> ,<br><a href="#">LDSMAXAH</a> ,<br><a href="#">LDSMAXALH</a> ,<br><a href="#">LDSMAXLH</a> â€”<br><a href="#">LDSMAXLH</a> | FEAT_LSE |
| 01   | 0  | 0             | 1 |    |  | 0  | 101 | <a href="#">LDSMINH</a> ,<br><a href="#">LDSMINAH</a> ,<br><a href="#">LDSMINALH</a> ,<br><a href="#">LDSMINLH</a> â€”<br><a href="#">LDSMINLH</a> | FEAT_LSE |
| 01   | 0  | 0             | 1 |    |  | 0  | 110 | <a href="#">LDUMAXH</a> ,<br><a href="#">LDUMAXAH</a> ,<br><a href="#">LDUMAXALH</a> ,<br><a href="#">LDUMAXLH</a> â€”<br><a href="#">LDUMAXLH</a> | FEAT_LSE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                | Feature  |
|------|----|---------------|---|----|--|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                    |          |
| 01   | 0  | 0             | 1 |    |  | 0  | 111 | <a href="#">LDUMINH</a> ,<br><a href="#">LDUMINAH</a> ,<br><a href="#">LDUMINALH</a> ,<br><a href="#">LDUMINLH</a> â€”<br><a href="#">LDUMINLH</a> | FEAT_LSE |
| 01   | 0  | 0             | 1 |    |  | 1  | 000 | <a href="#">SWPH</a> , <a href="#">SWPAH</a> ,<br><a href="#">SWPALH</a> ,<br><a href="#">SWPLH</a> â€”<br><a href="#">SWPLH</a>                   | FEAT_LSE |
| 01   | 0  | 0             | 1 |    |  | 1  | 001 | <a href="#">RCWSCLR</a> ,<br><a href="#">RCWSCLRA</a> ,<br><a href="#">RCWSCLRL</a> ,<br><a href="#">RCWSCLRAL</a><br>â€” <a href="#">RCWSCLRL</a> | FEAT_THE |
| 01   | 0  | 0             | 1 |    |  | 1  | 010 | <a href="#">RCWSSWP</a> ,<br><a href="#">RCWSSWPA</a> ,<br><a href="#">RCWSSWPL</a> ,<br><a href="#">RCWSSWPAL</a><br>â€” <a href="#">RCWSSWPL</a> | FEAT_THE |
| 01   | 0  | 0             | 1 |    |  | 1  | 011 | <a href="#">RCWSSET</a> ,<br><a href="#">RCWSSETA</a> ,<br><a href="#">RCWSSETL</a> ,<br><a href="#">RCWSSETAL</a> â€”<br><a href="#">RCWSSETL</a> | FEAT_THE |
| 01   | 0  | 1             | 0 |    |  | 0  | 000 | <a href="#">LDADDH</a> ,<br><a href="#">LDADDAH</a> ,<br><a href="#">LDADDALH</a> ,<br><a href="#">LDADDLH</a> â€”<br><a href="#">LDADDAH</a>      | FEAT_LSE |
| 01   | 0  | 1             | 0 |    |  | 0  | 001 | <a href="#">LDCLRH</a> ,<br><a href="#">LDCLRAH</a> ,<br><a href="#">LDCLRALH</a> ,<br><a href="#">LDCLRLH</a> â€”<br><a href="#">LDCLRAH</a>      | FEAT_LSE |
| 01   | 0  | 1             | 0 |    |  | 0  | 010 | <a href="#">LDEORH</a> ,<br><a href="#">LDEORAH</a> ,<br><a href="#">LDEORALH</a> ,<br><a href="#">LDEORLH</a> â€”<br><a href="#">LDEORAH</a>      | FEAT_LSE |
| 01   | 0  | 1             | 0 |    |  | 0  | 011 | <a href="#">LDSETH</a> ,<br><a href="#">LDSETAH</a> ,<br><a href="#">LDSETALH</a> ,<br><a href="#">LDSETLH</a> â€”<br><a href="#">LDSETAH</a>      | FEAT_LSE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                | Feature    |
|------|----|---------------|---|----|--|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|------------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                    |            |
| 01   | 0  | 1             | 0 |    |  | 0  | 100 | <a href="#">LDSMAXH</a> ,<br><a href="#">LDSMAXAH</a> ,<br><a href="#">LDSMAXALH</a> ,<br><a href="#">LDSMAXLH</a> â€”<br><a href="#">LDSMAXAH</a> | FEAT_LSE   |
| 01   | 0  | 1             | 0 |    |  | 0  | 101 | <a href="#">LDSMINH</a> ,<br><a href="#">LDSMINAH</a> ,<br><a href="#">LDSMINALH</a> ,<br><a href="#">LDSMINLH</a> â€”<br><a href="#">LDSMINAH</a> | FEAT_LSE   |
| 01   | 0  | 1             | 0 |    |  | 0  | 110 | <a href="#">LDUMAXH</a> ,<br><a href="#">LDUMAXAH</a> ,<br><a href="#">LDUMAXALH</a> ,<br><a href="#">LDUMAXLH</a> â€”<br><a href="#">LDUMAXAH</a> | FEAT_LSE   |
| 01   | 0  | 1             | 0 |    |  | 0  | 111 | <a href="#">LDUMINH</a> ,<br><a href="#">LDUMINAH</a> ,<br><a href="#">LDUMINALH</a> ,<br><a href="#">LDUMINLH</a> â€”<br><a href="#">LDUMINAH</a> | FEAT_LSE   |
| 01   | 0  | 1             | 0 |    |  | 1  | 000 | <a href="#">SWPH</a> , <a href="#">SWPAH</a> ,<br><a href="#">SWPALH</a> ,<br><a href="#">SWPLH</a> â€”<br><a href="#">SWPAH</a>                   | FEAT_LSE   |
| 01   | 0  | 1             | 0 |    |  | 1  | 001 | <a href="#">RCWSCLR</a> ,<br><a href="#">RCWSCLRA</a> ,<br><a href="#">RCWSCLRL</a> ,<br><a href="#">RCWSCLRAL</a><br>â€” <a href="#">RCWSCLRA</a> | FEAT_THE   |
| 01   | 0  | 1             | 0 |    |  | 1  | 010 | <a href="#">RCWSSWP</a> ,<br><a href="#">RCWSSWPA</a> ,<br><a href="#">RCWSSWPL</a> ,<br><a href="#">RCWSSWPAL</a><br>â€” <a href="#">RCWSSWPA</a> | FEAT_THE   |
| 01   | 0  | 1             | 0 |    |  | 1  | 011 | <a href="#">RCWSSET</a> ,<br><a href="#">RCWSSETA</a> ,<br><a href="#">RCWSSETL</a> ,<br><a href="#">RCWSSETAL</a> â€”<br><a href="#">RCWSSETA</a> | FEAT_THE   |
| 01   | 0  | 1             | 0 |    |  | 1  | 100 | <a href="#">LDAPRH</a>                                                                                                                             | FEAT_LRPCP |
| 01   | 0  | 1             | 1 |    |  | 0  | 000 | <a href="#">LDADDH</a> ,<br><a href="#">LDADDAH</a> ,<br><a href="#">LDADDALH</a> ,<br><a href="#">LDADDLH</a> â€”<br><a href="#">LDADDALH</a>     | FEAT_LSE   |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                    | Feature  |
|------|----|---------------|---|----|--|----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                        |          |
| 01   | 0  | 1             | 1 |    |  | 0  | 001 | <a href="#">LDCLRH</a> ,<br><a href="#">LDCLRAH</a> ,<br><a href="#">LDCLRALH</a> ,<br><a href="#">LDCLRLH</a> â€”<br><a href="#">LDCLRALH</a>         | FEAT_LSE |
| 01   | 0  | 1             | 1 |    |  | 0  | 010 | <a href="#">LDEORH</a> ,<br><a href="#">LDEORAH</a> ,<br><a href="#">LDEORALH</a> ,<br><a href="#">LDEORLH</a> â€”<br><a href="#">LDEORALH</a>         | FEAT_LSE |
| 01   | 0  | 1             | 1 |    |  | 0  | 011 | <a href="#">LDSETH</a> ,<br><a href="#">LDSETAH</a> ,<br><a href="#">LDSETALH</a> ,<br><a href="#">LDSETLH</a> â€”<br><a href="#">LDSETALH</a>         | FEAT_LSE |
| 01   | 0  | 1             | 1 |    |  | 0  | 100 | <a href="#">LDSMAXH</a> ,<br><a href="#">LDSMAXAH</a> ,<br><a href="#">LDSMAXALH</a> ,<br><a href="#">LDSMAXLH</a> â€”<br><a href="#">LDSMAXALH</a>    | FEAT_LSE |
| 01   | 0  | 1             | 1 |    |  | 0  | 101 | <a href="#">LDSMINH</a> ,<br><a href="#">LDSMINAH</a> ,<br><a href="#">LDSMINALH</a> ,<br><a href="#">LDSMINLH</a> â€”<br><a href="#">LDSMINALH</a>    | FEAT_LSE |
| 01   | 0  | 1             | 1 |    |  | 0  | 110 | <a href="#">LDUMAXH</a> ,<br><a href="#">LDUMAXAH</a> ,<br><a href="#">LDUMAXALH</a> ,<br><a href="#">LDUMAXLH</a> â€”<br><a href="#">LDUMAXALH</a>    | FEAT_LSE |
| 01   | 0  | 1             | 1 |    |  | 0  | 111 | <a href="#">LDUMINH</a> ,<br><a href="#">LDUMINAH</a> ,<br><a href="#">LDUMINALH</a> ,<br><a href="#">LDUMINLH</a> â€”<br><a href="#">LDUMINALH</a>    | FEAT_LSE |
| 01   | 0  | 1             | 1 |    |  | 1  | 000 | <a href="#">SWPH</a> , <a href="#">SWPAH</a> ,<br><a href="#">SWPALH</a> ,<br><a href="#">SWPLH</a> â€”<br><a href="#">SWPALH</a>                      | FEAT_LSE |
| 01   | 0  | 1             | 1 |    |  | 1  | 001 | <a href="#">RCWSCLR</a> ,<br><a href="#">RCWSCLRA</a> ,<br><a href="#">RCWSCLRL</a> ,<br><a href="#">RCWSCLRAL</a><br>â€”<br><a href="#">RCWSCLRAL</a> | FEAT_THE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                    | Feature  |
|------|----|---------------|---|----|--|----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                        |          |
| 01   | 0  | 1             | 1 |    |  | 1  | 010 | <a href="#">RCWSSWP</a> ,<br><a href="#">RCWSSWPA</a> ,<br><a href="#">RCWSSWPL</a> ,<br><a href="#">RCWSSWPAL</a><br>â€”<br><a href="#">RCWSSWPAL</a> | FEAT_THE |
| 01   | 0  | 1             | 1 |    |  | 1  | 011 | <a href="#">RCWSSET</a> ,<br><a href="#">RCWSSETA</a> ,<br><a href="#">RCWSSETL</a> ,<br><a href="#">RCWSSETAL</a> â€”<br><a href="#">RCWSSETAL</a>    | FEAT_THE |
| 1x   | 0  | 0             | 1 |    |  | 1  | 001 | UNALLOCATED                                                                                                                                            | -        |
| 1x   | 0  | 0             | 1 |    |  | 1  | 010 | UNALLOCATED                                                                                                                                            | -        |
| 1x   | 0  | 0             | 1 |    |  | 1  | 011 | UNALLOCATED                                                                                                                                            | -        |
| 1x   | 0  | 1             | 0 |    |  | 1  | 001 | UNALLOCATED                                                                                                                                            | -        |
| 1x   | 0  | 1             | 0 |    |  | 1  | 010 | UNALLOCATED                                                                                                                                            | -        |
| 1x   | 0  | 1             | 0 |    |  | 1  | 011 | UNALLOCATED                                                                                                                                            | -        |
| 1x   | 0  | 1             | 1 |    |  | 1  | 001 | UNALLOCATED                                                                                                                                            | -        |
| 1x   | 0  | 1             | 1 |    |  | 1  | 010 | UNALLOCATED                                                                                                                                            | -        |
| 1x   | 0  | 1             | 1 |    |  | 1  | 011 | UNALLOCATED                                                                                                                                            | -        |
| 10   | 0  | 0             | 0 |    |  | 0  | 000 | <a href="#">LDADD</a> ,<br><a href="#">LDADDA</a> ,<br><a href="#">LDADDAL</a> ,<br><a href="#">LDADDL</a> â€” <a href="#">32-bit LDADD</a>            | FEAT_LSE |
| 10   | 0  | 0             | 0 |    |  | 0  | 001 | <a href="#">LDCLR</a> ,<br><a href="#">LDCLRA</a> ,<br><a href="#">LDCLRAL</a> ,<br><a href="#">LDCLRL</a> â€” <a href="#">32-bit LDCLR</a>            | FEAT_LSE |
| 10   | 0  | 0             | 0 |    |  | 0  | 010 | <a href="#">LDEOR</a> ,<br><a href="#">LDEORA</a> ,<br><a href="#">LDEORAL</a> ,<br><a href="#">LDEORL</a> â€” <a href="#">32-bit LDEOR</a>            | FEAT_LSE |
| 10   | 0  | 0             | 0 |    |  | 0  | 011 | <a href="#">LDSET</a> , <a href="#">LDSETA</a> ,<br><a href="#">LDSETAL</a> ,<br><a href="#">LDSETL</a> â€” <a href="#">32-bit LDSET</a>               | FEAT_LSE |
| 10   | 0  | 0             | 0 |    |  | 0  | 100 | <a href="#">LDSMAX</a> ,<br><a href="#">LDSMAXA</a> ,<br><a href="#">LDSMAXAL</a> ,<br><a href="#">LDSMAXL</a> â€”<br><a href="#">32-bit LDSMAX</a>    | FEAT_LSE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                               | Feature  |
|------|----|---------------|---|----|--|----|-----|-----------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                   |          |
| 10   | 0  | 0             | 0 |    |  | 0  | 101 | <a href="#">LDSMIN</a> ,<br><a href="#">LDSMINA</a> ,<br><a href="#">LDSMINAL</a> ,<br><a href="#">LDSMINL</a> â€” 32-bit LDSMIN  | FEAT_LSE |
| 10   | 0  | 0             | 0 |    |  | 0  | 110 | <a href="#">LDUMAX</a> ,<br><a href="#">LDUMAXA</a> ,<br><a href="#">LDUMAXAL</a> ,<br><a href="#">LDUMAXL</a> â€” 32-bit LDUMAX  | FEAT_LSE |
| 10   | 0  | 0             | 0 |    |  | 0  | 111 | <a href="#">LDUMIN</a> ,<br><a href="#">LDUMINA</a> ,<br><a href="#">LDUMINAL</a> ,<br><a href="#">LDUMINL</a> â€” 32-bit LDUMIN  | FEAT_LSE |
| 10   | 0  | 0             | 0 |    |  | 1  | 000 | <a href="#">SWP</a> , <a href="#">SWPA</a> ,<br><a href="#">SWPAL</a> , <a href="#">SWPL</a> â€” 32-bit SWP                       | FEAT_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 | <a href="#">LDADD</a> ,<br><a href="#">LDADDA</a> ,<br><a href="#">LDADDAL</a> ,<br><a href="#">LDADDL</a> â€” 32-bit LDADDL      | FEAT_LSE |
| 10   | 0  | 0             | 1 |    |  | 0  | 001 | <a href="#">LDCLR</a> ,<br><a href="#">LDCLRA</a> ,<br><a href="#">LDCLRAL</a> ,<br><a href="#">LDCLRL</a> â€” 32-bit LDCLRL      | FEAT_LSE |
| 10   | 0  | 0             | 1 |    |  | 0  | 010 | <a href="#">LDEOR</a> ,<br><a href="#">LDEORA</a> ,<br><a href="#">LDEORAL</a> ,<br><a href="#">LDEORL</a> â€” 32-bit LDEORL      | FEAT_LSE |
| 10   | 0  | 0             | 1 |    |  | 0  | 011 | <a href="#">LDSET</a> , <a href="#">LDSETA</a> ,<br><a href="#">LDSETAL</a> ,<br><a href="#">LDSETL</a> â€” 32-bit LDSETL         | FEAT_LSE |
| 10   | 0  | 0             | 1 |    |  | 0  | 100 | <a href="#">LDSMAX</a> ,<br><a href="#">LDSMAXA</a> ,<br><a href="#">LDSMAXAL</a> ,<br><a href="#">LDSMAXL</a> â€” 32-bit LDSMAXL | FEAT_LSE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                  | Feature  |
|------|----|---------------|---|----|--|----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                      |          |
| 10   | 0  | 0             | 1 |    |  | 0  | 101 | <a href="#">LDSMIN</a> ,<br><a href="#">LDSMINA</a> ,<br><a href="#">LDSMINAL</a> ,<br><a href="#">LDSMINL</a> â€“<br>32-bit <a href="#">LDSMINL</a> | FEAT_LSE |
| 10   | 0  | 0             | 1 |    |  | 0  | 110 | <a href="#">LDUMAX</a> ,<br><a href="#">LDUMAXA</a> ,<br><a href="#">LDUMAXAL</a> ,<br><a href="#">LDUMAXL</a> â€“<br>32-bit <a href="#">LDUMAXL</a> | FEAT_LSE |
| 10   | 0  | 0             | 1 |    |  | 0  | 111 | <a href="#">LDUMIN</a> ,<br><a href="#">LDUMINA</a> ,<br><a href="#">LDUMINAL</a> ,<br><a href="#">LDUMINL</a> â€“<br>32-bit <a href="#">LDUMINI</a> | FEAT_LSE |
| 10   | 0  | 0             | 1 |    |  | 1  | 000 | <a href="#">SWP</a> , <a href="#">SWPA</a> ,<br><a href="#">SWPAL</a> , <a href="#">SWPL</a><br>â€“ 32-bit <a href="#">SWPL</a>                      | FEAT_LSE |
| 10   | 0  | 1             | 0 |    |  | 0  | 000 | <a href="#">LDADD</a> ,<br><a href="#">LDADDA</a> ,<br><a href="#">LDADDAL</a> ,<br><a href="#">LDADDL</a> â€“ 32-bit <a href="#">LDADDA</a>         | FEAT_LSE |
| 10   | 0  | 1             | 0 |    |  | 0  | 001 | <a href="#">LDCLR</a> ,<br><a href="#">LDCLRA</a> ,<br><a href="#">LDCLRAL</a> ,<br><a href="#">LDCLRL</a> â€“ 32-bit <a href="#">LDCLRA</a>         | FEAT_LSE |
| 10   | 0  | 1             | 0 |    |  | 0  | 010 | <a href="#">LDEOR</a> ,<br><a href="#">LDEORA</a> ,<br><a href="#">LDEORAL</a> ,<br><a href="#">LDEORL</a> â€“ 32-bit <a href="#">LDEORA</a>         | FEAT_LSE |
| 10   | 0  | 1             | 0 |    |  | 0  | 011 | <a href="#">LDSET</a> , <a href="#">LDSETA</a> ,<br><a href="#">LDSETAL</a> ,<br><a href="#">LDSETL</a> â€“ 32-bit <a href="#">LDSETA</a>            | FEAT_LSE |
| 10   | 0  | 1             | 0 |    |  | 0  | 100 | <a href="#">LDSMAX</a> ,<br><a href="#">LDSMAXA</a> ,<br><a href="#">LDSMAXAL</a> ,<br><a href="#">LDSMAXL</a> â€“ 32-bit <a href="#">LDSMAXA</a>    | FEAT_LSE |
| 10   | 0  | 1             | 0 |    |  | 0  | 101 | <a href="#">LDSMIN</a> ,<br><a href="#">LDSMINA</a> ,<br><a href="#">LDSMINAL</a> ,<br><a href="#">LDSMINL</a> â€“ 32-bit <a href="#">LDSMINA</a>    | FEAT_LSE |

| size | VR | Decode fields |   |    |    | Instruction Details |                                                                                                                                                          | Feature    |
|------|----|---------------|---|----|----|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
|      |    | A             | R | Rs | o3 | opc                 |                                                                                                                                                          |            |
| 10   | 0  | 1             | 0 |    | 0  | 110                 | <a href="#">LDUMAX</a> ,<br><a href="#">LDUMAXA</a> ,<br><a href="#">LDUMAXAL</a> ,<br><a href="#">LDUMAXL</a> â€”<br>32-bit<br><a href="#">LDUMAXA</a>  | FEAT_LSE   |
| 10   | 0  | 1             | 0 |    | 0  | 111                 | <a href="#">LDUMIN</a> ,<br><a href="#">LDUMINA</a> ,<br><a href="#">LDUMINAL</a> ,<br><a href="#">LDUMINL</a> â€”<br>32-bit <a href="#">LDUMINA</a>     | FEAT_LSE   |
| 10   | 0  | 1             | 0 |    | 1  | 000                 | <a href="#">SWP</a> , <a href="#">SWPA</a> ,<br><a href="#">SWPAL</a> , <a href="#">SWPL</a><br>â€” 32-bit <a href="#">SWPA</a>                          | FEAT_LSE   |
| 10   | 0  | 1             | 0 |    | 1  | 100                 | <a href="#">LDAPR</a> â€” 32-bit                                                                                                                         | FEAT_LRCPC |
| 10   | 0  | 1             | 1 |    | 0  | 000                 | <a href="#">LDADD</a> ,<br><a href="#">LDADDA</a> ,<br><a href="#">LDADDAL</a> ,<br><a href="#">LDADDL</a> â€” 32-bit <a href="#">LDADDAL</a>            | FEAT_LSE   |
| 10   | 0  | 1             | 1 |    | 0  | 001                 | <a href="#">LDCLR</a> ,<br><a href="#">LDCLRA</a> ,<br><a href="#">LDCLRAL</a> ,<br><a href="#">LDCLRL</a> â€” 32-bit <a href="#">LDCLRAL</a>            | FEAT_LSE   |
| 10   | 0  | 1             | 1 |    | 0  | 010                 | <a href="#">LDEOR</a> ,<br><a href="#">LDEORA</a> ,<br><a href="#">LDEORAL</a> ,<br><a href="#">LDEORL</a> â€” 32-bit <a href="#">LDEORAL</a>            | FEAT_LSE   |
| 10   | 0  | 1             | 1 |    | 0  | 011                 | <a href="#">LDSET</a> , <a href="#">LDSETA</a> ,<br><a href="#">LDSETAL</a> ,<br><a href="#">LDSETL</a> â€” 32-bit <a href="#">LDSETAL</a>               | FEAT_LSE   |
| 10   | 0  | 1             | 1 |    | 0  | 100                 | <a href="#">LDSMAX</a> ,<br><a href="#">LDSMAXA</a> ,<br><a href="#">LDSMAXAL</a> ,<br><a href="#">LDSMAXL</a> â€”<br>32-bit<br><a href="#">LDSMAXAL</a> | FEAT_LSE   |
| 10   | 0  | 1             | 1 |    | 0  | 101                 | <a href="#">LDSMIN</a> ,<br><a href="#">LDSMINA</a> ,<br><a href="#">LDSMINAL</a> ,<br><a href="#">LDSMINL</a> â€”<br>32-bit<br><a href="#">LDSMINAL</a> | FEAT_LSE   |

| size | VR | Decode fields |   |    |   | o3  | opc | Instruction Details                                                                                                                                      | Feature  |
|------|----|---------------|---|----|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |   |     |     |                                                                                                                                                          |          |
| 10   | 0  | 1             | 1 |    | 0 | 110 |     | <a href="#">LDUMAX</a> ,<br><a href="#">LDUMAXA</a> ,<br><a href="#">LDUMAXAL</a> ,<br><a href="#">LDUMAXL</a> â€“<br>32-bit<br><a href="#">LDUMAXAL</a> | FEAT_LSE |
| 10   | 0  | 1             | 1 |    | 0 | 111 |     | <a href="#">LDUMIN</a> ,<br><a href="#">LDUMINA</a> ,<br><a href="#">LDUMINAL</a> ,<br><a href="#">LDUMINL</a> â€“<br>32-bit<br><a href="#">LDUMINAL</a> | FEAT_LSE |
| 10   | 0  | 1             | 1 |    | 1 | 000 |     | <a href="#">SWP</a> , <a href="#">SWPA</a> ,<br><a href="#">SWPAL</a> , <a href="#">SWPL</a><br>â€“ 32-bit<br><a href="#">SWPAL</a>                      | FEAT_LSE |
| 11   | 0  | 0             | 0 |    | 0 | 000 |     | <a href="#">LDADD</a> ,<br><a href="#">LDADDA</a> ,<br><a href="#">LDADDAL</a> ,<br><a href="#">LDADDL</a> â€“ 64-bit<br><a href="#">LDADD</a>           | FEAT_LSE |
| 11   | 0  | 0             | 0 |    | 0 | 001 |     | <a href="#">LDCLR</a> ,<br><a href="#">LDCLRA</a> ,<br><a href="#">LDCLRAL</a> ,<br><a href="#">LDCLRL</a> â€“ 64-bit<br><a href="#">LDCLR</a>           | FEAT_LSE |
| 11   | 0  | 0             | 0 |    | 0 | 010 |     | <a href="#">LDEOR</a> ,<br><a href="#">LDEORA</a> ,<br><a href="#">LDEORAL</a> ,<br><a href="#">LDEORL</a> â€“ 64-bit<br><a href="#">LDEOR</a>           | FEAT_LSE |
| 11   | 0  | 0             | 0 |    | 0 | 011 |     | <a href="#">LDSET</a> , <a href="#">LDSETA</a> ,<br><a href="#">LDSETAL</a> ,<br><a href="#">LDSETL</a> â€“ 64-bit<br><a href="#">LDSET</a>              | FEAT_LSE |
| 11   | 0  | 0             | 0 |    | 0 | 100 |     | <a href="#">LDSMAX</a> ,<br><a href="#">LDSMAXA</a> ,<br><a href="#">LDSMAXAL</a> ,<br><a href="#">LDSMAXL</a> â€“<br>64-bit <a href="#">LDSMAX</a>      | FEAT_LSE |
| 11   | 0  | 0             | 0 |    | 0 | 101 |     | <a href="#">LDSMIN</a> ,<br><a href="#">LDSMINA</a> ,<br><a href="#">LDSMINAL</a> ,<br><a href="#">LDSMINL</a> â€“<br>64-bit <a href="#">LDSMIN</a>      | FEAT_LSE |

| size | VR | Decode fields |   |       |  | o3 | opc | Instruction Details                                                                                                               | Feature         |
|------|----|---------------|---|-------|--|----|-----|-----------------------------------------------------------------------------------------------------------------------------------|-----------------|
|      |    | A             | R | Rs    |  |    |     |                                                                                                                                   |                 |
| 11   | 0  | 0             | 0 |       |  | 0  | 110 | <a href="#">LDUMAX</a> ,<br><a href="#">LDUMAXA</a> ,<br><a href="#">LDUMAXAL</a> ,<br><a href="#">LDUMAXL</a> â€“ 64-bit LDUMAX  | FEAT_LSE        |
| 11   | 0  | 0             | 0 |       |  | 0  | 111 | <a href="#">LDUMIN</a> ,<br><a href="#">LDUMINA</a> ,<br><a href="#">LDUMINAL</a> ,<br><a href="#">LDUMINL</a> â€“ 64-bit LDUMIN  | FEAT_LSE        |
| 11   | 0  | 0             | 0 |       |  | 1  | 000 | <a href="#">SWP</a> , <a href="#">SWPA</a> ,<br><a href="#">SWPAL</a> , <a href="#">SWPL</a> â€“ 64-bit SWP                       | FEAT_LSE        |
| 11   | 0  | 0             | 0 |       |  | 1  | 010 | <a href="#">ST64BV0</a>                                                                                                           | FEAT_LS64_ACCDA |
| 11   | 0  | 0             | 0 |       |  | 1  | 011 | <a href="#">ST64BV</a>                                                                                                            | FEAT_LS64_V     |
| 11   | 0  | 0             | 0 | 11111 |  | 1  | 001 | <a href="#">ST64B</a>                                                                                                             | FEAT_LS64       |
| 11   | 0  | 0             | 0 | 11111 |  | 1  | 101 | <a href="#">LD64B</a>                                                                                                             | FEAT_LS64       |
| 11   | 0  | 0             | 1 |       |  | 0  | 000 | <a href="#">LDADD</a> ,<br><a href="#">LDADDA</a> ,<br><a href="#">LDADDAL</a> ,<br><a href="#">LDADDL</a> â€“ 64-bit LDADDL      | FEAT_LSE        |
| 11   | 0  | 0             | 1 |       |  | 0  | 001 | <a href="#">LDCLR</a> ,<br><a href="#">LDCLRA</a> ,<br><a href="#">LDCLRAL</a> ,<br><a href="#">LDCLRL</a> â€“ 64-bit LDCLRL      | FEAT_LSE        |
| 11   | 0  | 0             | 1 |       |  | 0  | 010 | <a href="#">LDEOR</a> ,<br><a href="#">LDEORA</a> ,<br><a href="#">LDEORAL</a> ,<br><a href="#">LDEORL</a> â€“ 64-bit LDEORL      | FEAT_LSE        |
| 11   | 0  | 0             | 1 |       |  | 0  | 011 | <a href="#">LDSET</a> , <a href="#">LDSETA</a> ,<br><a href="#">LDSETAL</a> ,<br><a href="#">LDSETL</a> â€“ 64-bit LDSETL         | FEAT_LSE        |
| 11   | 0  | 0             | 1 |       |  | 0  | 100 | <a href="#">LDSMAX</a> ,<br><a href="#">LDSMAXA</a> ,<br><a href="#">LDSMAXAL</a> ,<br><a href="#">LDSMAXL</a> â€“ 64-bit LDSMAXL | FEAT_LSE        |
| 11   | 0  | 0             | 1 |       |  | 0  | 101 | <a href="#">LDSMIN</a> ,<br><a href="#">LDSMINA</a> ,<br><a href="#">LDSMINAL</a> ,<br><a href="#">LDSMINL</a> â€“ 64-bit LDSMINL | FEAT_LSE        |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                               | Feature  |
|------|----|---------------|---|----|--|----|-----|-----------------------------------------------------------------------------------------------------------------------------------|----------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                   |          |
| 11   | 0  | 0             | 1 |    |  | 0  | 110 | <a href="#">LDUMAX</a> ,<br><a href="#">LDUMAXA</a> ,<br><a href="#">LDUMAXAL</a> ,<br><a href="#">LDUMAXL</a> â€“ 64-bit LDUMAXL | FEAT_LSE |
| 11   | 0  | 0             | 1 |    |  | 0  | 111 | <a href="#">LDUMIN</a> ,<br><a href="#">LDUMINA</a> ,<br><a href="#">LDUMINAL</a> ,<br><a href="#">LDUMINL</a> â€“ 64-bit LDUMINL | FEAT_LSE |
| 11   | 0  | 0             | 1 |    |  | 1  | 000 | <a href="#">SWP</a> , <a href="#">SWPA</a> ,<br><a href="#">SWPAL</a> , <a href="#">SWPL</a> â€“ 64-bit SWPL                      | FEAT_LSE |
| 11   | 0  | 1             | 0 |    |  | 0  | 000 | <a href="#">LDADD</a> ,<br><a href="#">LDADDA</a> ,<br><a href="#">LDADDAL</a> ,<br><a href="#">LDADDL</a> â€“ 64-bit LDADDA      | FEAT_LSE |
| 11   | 0  | 1             | 0 |    |  | 0  | 001 | <a href="#">LDCLR</a> ,<br><a href="#">LDCLRA</a> ,<br><a href="#">LDCLRAL</a> ,<br><a href="#">LDCLRL</a> â€“ 64-bit LDCLRA      | FEAT_LSE |
| 11   | 0  | 1             | 0 |    |  | 0  | 010 | <a href="#">LDEOR</a> ,<br><a href="#">LDEORA</a> ,<br><a href="#">LDEORAL</a> ,<br><a href="#">LDEORL</a> â€“ 64-bit LDEORA      | FEAT_LSE |
| 11   | 0  | 1             | 0 |    |  | 0  | 011 | <a href="#">LDSET</a> , <a href="#">LDSETA</a> ,<br><a href="#">LDSETAL</a> ,<br><a href="#">LDSETL</a> â€“ 64-bit LDSETA         | FEAT_LSE |
| 11   | 0  | 1             | 0 |    |  | 0  | 100 | <a href="#">LDSMAX</a> ,<br><a href="#">LDSMAXA</a> ,<br><a href="#">LDSMAXAL</a> ,<br><a href="#">LDSMAXL</a> â€“ 64-bit LDSMAXA | FEAT_LSE |
| 11   | 0  | 1             | 0 |    |  | 0  | 101 | <a href="#">LDSMIN</a> ,<br><a href="#">LDSMINA</a> ,<br><a href="#">LDSMINAL</a> ,<br><a href="#">LDSMINL</a> â€“ 64-bit LDSMINA | FEAT_LSE |
| 11   | 0  | 1             | 0 |    |  | 0  | 110 | <a href="#">LDUMAX</a> ,<br><a href="#">LDUMAXA</a> ,<br><a href="#">LDUMAXAL</a> ,<br><a href="#">LDUMAXL</a> â€“ 64-bit LDUMAXA | FEAT_LSE |

| size | VR | Decode fields |   |    |  | o3 | opc | Instruction Details                                                                                                                                | Feature    |
|------|----|---------------|---|----|--|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|------------|
|      |    | A             | R | Rs |  |    |     |                                                                                                                                                    |            |
| 11   | 0  | 1             | 0 |    |  | 0  | 111 | <a href="#">LDUMIN</a> ,<br><a href="#">LDUMINA</a> ,<br><a href="#">LDUMINAL</a> ,<br><a href="#">LDUMINL</a> â€” 64-bit <a href="#">LDUMINA</a>  | FEAT_LSE   |
| 11   | 0  | 1             | 0 |    |  | 1  | 000 | <a href="#">SWP</a> , <a href="#">SWPA</a> ,<br><a href="#">SWPAL</a> , <a href="#">SWPL</a> â€” 64-bit <a href="#">SWPA</a>                       | FEAT_LSE   |
| 11   | 0  | 1             | 0 |    |  | 1  | 100 | <a href="#">LDAPR</a> â€” 64-bit <a href="#">LDAPR</a>                                                                                             | FEAT_LRCPC |
| 11   | 0  | 1             | 1 |    |  | 0  | 000 | <a href="#">LDADD</a> ,<br><a href="#">LDADDA</a> ,<br><a href="#">LDADDAL</a> ,<br><a href="#">LDADDL</a> â€” 64-bit <a href="#">LDADDAL</a>      | FEAT_LSE   |
| 11   | 0  | 1             | 1 |    |  | 0  | 001 | <a href="#">LDCLR</a> ,<br><a href="#">LDCLRA</a> ,<br><a href="#">LDCLRAL</a> ,<br><a href="#">LDCLRL</a> â€” 64-bit <a href="#">LDCLRAL</a>      | FEAT_LSE   |
| 11   | 0  | 1             | 1 |    |  | 0  | 010 | <a href="#">LDEOR</a> ,<br><a href="#">LDEORA</a> ,<br><a href="#">LDEORAL</a> ,<br><a href="#">LDEORL</a> â€” 64-bit <a href="#">LDEORAL</a>      | FEAT_LSE   |
| 11   | 0  | 1             | 1 |    |  | 0  | 011 | <a href="#">LDSET</a> , <a href="#">LDSETA</a> ,<br><a href="#">LDSETAL</a> ,<br><a href="#">LDSETL</a> â€” 64-bit <a href="#">LDSETAL</a>         | FEAT_LSE   |
| 11   | 0  | 1             | 1 |    |  | 0  | 100 | <a href="#">LDSMAX</a> ,<br><a href="#">LDSMAXA</a> ,<br><a href="#">LDSMAXAL</a> ,<br><a href="#">LDSMAXL</a> â€” 64-bit <a href="#">LDSMAXAL</a> | FEAT_LSE   |
| 11   | 0  | 1             | 1 |    |  | 0  | 101 | <a href="#">LDSMIN</a> ,<br><a href="#">LDSMINA</a> ,<br><a href="#">LDSMINAL</a> ,<br><a href="#">LDSMINL</a> â€” 64-bit <a href="#">LDSMINAL</a> | FEAT_LSE   |
| 11   | 0  | 1             | 1 |    |  | 0  | 110 | <a href="#">LDUMAX</a> ,<br><a href="#">LDUMAXA</a> ,<br><a href="#">LDUMAXAL</a> ,<br><a href="#">LDUMAXL</a> â€” 64-bit <a href="#">LDUMAXAL</a> | FEAT_LSE   |

| size | VR | Decode fields |   |    |    |     | Instruction Details                                                                                                                                      |          | Feature |
|------|----|---------------|---|----|----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|
|      |    | A             | R | Rs | o3 | opc |                                                                                                                                                          |          |         |
| 11   | 0  | 1             | 1 |    | 0  | 111 | <a href="#">LDUMIN</a> ,<br><a href="#">LDUMINA</a> ,<br><a href="#">LDUMINAL</a> ,<br><a href="#">LDUMINL</a> â€”<br>64-bit<br><a href="#">LDUMINAL</a> | FEAT_LSE |         |
| 11   | 0  | 1             | 1 |    | 1  | 000 | <a href="#">SWP</a> , <a href="#">SWPA</a> ,<br><a href="#">SWPAL</a> , <a href="#">SWPL</a><br>â€” 64-bit<br><a href="#">SWPAL</a>                      | FEAT_LSE |         |

### Load/store register (register offset)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |     |    |    |    |        |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|-----|----|----|----|--------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20     | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| size | 1  | 1  | 1  | VR | 0  | 0  | opc | 1  | Rm |    | option | S  | 1  | 0  |    | Rn |    | Rt |    |    |    |   |   |   |   |   |   |   |   |   |   |

| size | VR | Decode fields |        |    | Instruction Details                                                                          |   | Feature |
|------|----|---------------|--------|----|----------------------------------------------------------------------------------------------|---|---------|
|      |    | opc           | option | Rt |                                                                                              |   |         |
| x1   | 1  | 1x            |        |    | UNALLOCATED                                                                                  | - |         |
| 00   | 0  | 00            | != 011 |    | <a href="#">STRB (register)</a><br>â€” <a href="#">extended register</a>                     | - |         |
| 00   | 0  | 00            | 011    |    | <a href="#">STRB (register)</a><br>â€” <a href="#">shifted register</a>                      | - |         |
| 00   | 0  | 01            | != 011 |    | <a href="#">LDRB (register)</a><br>â€” <a href="#">extended register</a>                     | - |         |
| 00   | 0  | 01            | 011    |    | <a href="#">LDRB (register)</a><br>â€” <a href="#">shifted register</a>                      | - |         |
| 00   | 0  | 10            | != 011 |    | <a href="#">LDRSB (register)</a><br>â€” <a href="#">64-bit with extended register offset</a> | - |         |
| 00   | 0  | 10            | 011    |    | <a href="#">LDRSB (register)</a><br>â€” <a href="#">64-bit with shifted register offset</a>  | - |         |
| 00   | 0  | 11            | != 011 |    | <a href="#">LDRSB (register)</a><br>â€” <a href="#">32-bit with extended register offset</a> | - |         |

| size | VR | Decode fields |        |          | Rt | Instruction Details                                                         | Feature    |
|------|----|---------------|--------|----------|----|-----------------------------------------------------------------------------|------------|
|      |    | opc           | option |          |    |                                                                             |            |
| 00   | 0  | 11            | 011    |          |    | <a href="#">LDRSB (register)</a><br>â€” 32-bit with shifted register offset | -          |
| 00   | 1  | 00            | != 011 |          |    | <a href="#">STR (register, SIMD&amp;FP)</a>                                 | -          |
| 00   | 1  | 00            | 011    |          |    | <a href="#">STR (register, SIMD&amp;FP)</a>                                 | -          |
| 00   | 1  | 01            | != 011 |          |    | <a href="#">LDR (register, SIMD&amp;FP)</a>                                 | -          |
| 00   | 1  | 01            | 011    |          |    | <a href="#">LDR (register, SIMD&amp;FP)</a>                                 | -          |
| 00   | 1  | 10            |        |          |    | <a href="#">STR (register, SIMD&amp;FP)</a>                                 | -          |
| 00   | 1  | 11            |        |          |    | <a href="#">LDR (register, SIMD&amp;FP)</a>                                 | -          |
| 01   | 0  | 00            |        |          |    | <a href="#">STRH (register)</a>                                             | -          |
| 01   | 0  | 01            |        |          |    | <a href="#">LDRH (register)</a>                                             | -          |
| 01   | 0  | 10            |        |          |    | <a href="#">LDRSH (register)</a><br>â€” 64-bit                              | -          |
| 01   | 0  | 11            |        |          |    | <a href="#">LDRSH (register)</a><br>â€” 32-bit                              | -          |
| 01   | 1  | 00            |        |          |    | <a href="#">STR (register, SIMD&amp;FP)</a>                                 | -          |
| 01   | 1  | 01            |        |          |    | <a href="#">LDR (register, SIMD&amp;FP)</a>                                 | -          |
| 1x   | 0  | 11            |        |          |    | UNALLOCATED                                                                 | -          |
| 1x   | 1  | 1x            |        |          |    | UNALLOCATED                                                                 | -          |
| 10   | 0  | 00            |        |          |    | <a href="#">STR (register)</a><br>â€” 32-bit                                | -          |
| 10   | 0  | 01            |        |          |    | <a href="#">LDR (register)</a><br>â€” 32-bit                                | -          |
| 10   | 0  | 10            |        |          |    | <a href="#">LDRSW (register)</a>                                            | -          |
| 10   | 1  | 00            |        |          |    | <a href="#">STR (register, SIMD&amp;FP)</a>                                 | -          |
| 10   | 1  | 01            |        |          |    | <a href="#">LDR (register, SIMD&amp;FP)</a>                                 | -          |
| 11   | 0  | 00            |        |          |    | <a href="#">STR (register)</a><br>â€” 64-bit                                | -          |
| 11   | 0  | 01            |        |          |    | <a href="#">LDR (register)</a><br>â€” 64-bit                                | -          |
| 11   | 0  | 10            | x0x    |          |    | UNALLOCATED                                                                 | -          |
| 11   | 0  | 10            | x1x    | != 11xxx |    | <a href="#">PRFM (register)</a>                                             | -          |
| 11   | 0  | 10            | x1x    | 11xxx    |    | <a href="#">RPRFM</a>                                                       | FEAT_RPRFM |

| size | VR | opc | Decode fields |  | Rt | Instruction Details                         | Feature |
|------|----|-----|---------------|--|----|---------------------------------------------|---------|
|      |    |     | option        |  |    |                                             |         |
| 11   | 1  | 00  |               |  |    | <a href="#">STR (register, SIMD&amp;FP)</a> | -       |
| 11   | 1  | 01  |               |  |    | <a href="#">LDR (register, SIMD&amp;FP)</a> | -       |

### Load/store register (pac)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |    |   |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |
| size | 1  | 1  | 1  | VR | 0  | 0  | M  | S  | 1  |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   | Rt |   |

| size  | VR | Decode fields |   | W | Instruction Details                              | Feature    |
|-------|----|---------------|---|---|--------------------------------------------------|------------|
|       |    | M             |   |   |                                                  |            |
| != 11 |    |               |   |   | UNALLOCATED                                      | -          |
| 11    | 0  | 0             | 0 |   | <a href="#">LDRAA, LDRAB</a> "key A, offset      | FEAT_PAuth |
| 11    | 0  | 0             | 1 |   | <a href="#">LDRAA, LDRAB</a> "key A, pre-indexed | FEAT_PAuth |
| 11    | 0  | 1             | 0 |   | <a href="#">LDRAA, LDRAB</a> "key B, offset      | FEAT_PAuth |
| 11    | 0  | 1             | 1 |   | <a href="#">LDRAA, LDRAB</a> "key B, pre-indexed | FEAT_PAuth |
| 11    | 1  |               |   |   | UNALLOCATED                                      | -          |

### Load/store register (unsigned immediate)

These instructions are under [Loads and Stores](#).

|      |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |    |   |    |   |
|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|----|---|----|---|
| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1  | 0 |
| size | 1  | 1  | 1  | VR | 0  | 1  | opc |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   | Rn |   | Rt |   |

| size | VR | Decode fields |  | Instruction Details                                  |
|------|----|---------------|--|------------------------------------------------------|
|      |    | opc           |  |                                                      |
| x1   | 1  | 1x            |  | UNALLOCATED                                          |
| 00   | 0  | 00            |  | <a href="#">STRB (immediate)</a>                     |
| 00   | 0  | 01            |  | <a href="#">LDRB (immediate)</a>                     |
| 00   | 0  | 10            |  | <a href="#">LDRSB (immediate) 64-bit</a>             |
| 00   | 0  | 11            |  | <a href="#">LDRSB (immediate) 32-bit</a>             |
| 00   | 1  | 00            |  | <a href="#">STR (immediate, SIMD&amp;FP) 8-bit</a>   |
| 00   | 1  | 01            |  | <a href="#">LDR (immediate, SIMD&amp;FP) 8-bit</a>   |
| 00   | 1  | 10            |  | <a href="#">STR (immediate, SIMD&amp;FP) 128-bit</a> |

| Decode fields |    |     | Instruction Details                                      |
|---------------|----|-----|----------------------------------------------------------|
| size          | VR | opc |                                                          |
| 00            | 1  | 11  | <a href="#">LDR (immediate, SIMD&amp;FP) â€“ 128-bit</a> |
| 01            | 0  | 00  | <a href="#">STRH (immediate)</a>                         |
| 01            | 0  | 01  | <a href="#">LDRH (immediate)</a>                         |
| 01            | 0  | 10  | <a href="#">LDRSH (immediate) â€“ 64-bit</a>             |
| 01            | 0  | 11  | <a href="#">LDRSH (immediate) â€“ 32-bit</a>             |
| 01            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP) â€“ 16-bit</a>  |
| 01            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP) â€“ 16-bit</a>  |
| 1x            | 0  | 11  | UNALLOCATED                                              |
| 1x            | 1  | 1x  | UNALLOCATED                                              |
| 10            | 0  | 00  | <a href="#">STR (immediate) â€“ 32-bit</a>               |
| 10            | 0  | 01  | <a href="#">LDR (immediate) â€“ 32-bit</a>               |
| 10            | 0  | 10  | <a href="#">LDRSW (immediate)</a>                        |
| 10            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP) â€“ 32-bit</a>  |
| 10            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP) â€“ 32-bit</a>  |
| 11            | 0  | 00  | <a href="#">STR (immediate) â€“ 64-bit</a>               |
| 11            | 0  | 01  | <a href="#">LDR (immediate) â€“ 64-bit</a>               |
| 11            | 0  | 10  | <a href="#">PRFM (immediate)</a>                         |
| 11            | 1  | 00  | <a href="#">STR (immediate, SIMD&amp;FP) â€“ 64-bit</a>  |
| 11            | 1  | 01  | <a href="#">LDR (immediate, SIMD&amp;FP) â€“ 64-bit</a>  |

## Data Processing -- Register

These instructions are under the [top-level](#).

|     |     |     |    |     |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|-----|-----|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31  | 30  | 29  | 28 | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| op0 | op1 | 101 |    | op2 |    |    |    |    |    |    |    |    |    |    |    | op3 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Decode fields |     |      |        | Instruction details                              |
|---------------|-----|------|--------|--------------------------------------------------|
| op0           | op1 | op2  | op3    |                                                  |
| 0             | 1   | 0110 |        | <a href="#">Data-processing (2 source)</a>       |
| 1             | 1   | 0110 |        | <a href="#">Data-processing (1 source)</a>       |
|               | 0   | 0xxx |        | <a href="#">Logical (shifted register)</a>       |
|               | 0   | 1xx0 |        | <a href="#">Add/subtract (shifted register)</a>  |
|               | 0   | 1xx1 |        | <a href="#">Add/subtract (extended register)</a> |
|               | 1   | 0000 | 000000 | <a href="#">Add/subtract (with carry)</a>        |
|               | 1   | 0000 | x00001 | <a href="#">Rotate right into flags</a>          |
|               | 1   | 0000 | xx0010 | <a href="#">Evaluate into flags</a>              |
|               | 1   | 0010 | xxxx0x | <a href="#">Conditional compare (register)</a>   |
|               | 1   | 0010 | xxxx1x | <a href="#">Conditional compare (immediate)</a>  |
|               | 1   | 0100 |        | <a href="#">Conditional select</a>               |

|  |   |      |  |                                            |
|--|---|------|--|--------------------------------------------|
|  | 1 | 1xxx |  | <a href="#">Data-processing (3 source)</a> |
|--|---|------|--|--------------------------------------------|

## Data-processing (2 source)

These instructions are under [Data Processing -- Register](#).

|    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| sf | 0  | S  | 1  | 1  | 0  | 1  | 0  | 1  | 1  | 0  | Rm | opcode | Rn | Rd |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |        | Instruction Details                                                                                                                  | Feature    |
|---------------|---|--------|--------------------------------------------------------------------------------------------------------------------------------------|------------|
| sf            | S | opcode |                                                                                                                                      |            |
|               |   | 000001 | UNALLOCATED                                                                                                                          | -          |
|               |   | 1xxxxx | UNALLOCATED                                                                                                                          | -          |
|               | 0 | 00011x | UNALLOCATED                                                                                                                          | -          |
|               | 0 | 001101 | UNALLOCATED                                                                                                                          | -          |
|               | 0 | 00111x | UNALLOCATED                                                                                                                          | -          |
|               | 0 | 0111xx | UNALLOCATED                                                                                                                          | -          |
|               | 1 | 00001x | UNALLOCATED                                                                                                                          | -          |
|               | 1 | 0001xx | UNALLOCATED                                                                                                                          | -          |
|               | 1 | 001xxx | UNALLOCATED                                                                                                                          | -          |
|               | 1 | 01xxxx | UNALLOCATED                                                                                                                          | -          |
| 0             |   | 000000 | UNALLOCATED                                                                                                                          | -          |
| 0             | 0 | 000010 | <a href="#">UDIV</a> â€“ <a href="#">32-bit</a>                                                                                      | -          |
| 0             | 0 | 000011 | <a href="#">SDIV</a> â€“ <a href="#">32-bit</a>                                                                                      | -          |
| 0             | 0 | 00010x | UNALLOCATED                                                                                                                          | -          |
| 0             | 0 | 001000 | <a href="#">LSLV</a> â€“ <a href="#">32-bit</a>                                                                                      | -          |
| 0             | 0 | 001001 | <a href="#">LSRV</a> â€“ <a href="#">32-bit</a>                                                                                      | -          |
| 0             | 0 | 001010 | <a href="#">ASRV</a> â€“ <a href="#">32-bit</a>                                                                                      | -          |
| 0             | 0 | 001011 | <a href="#">RORV</a> â€“ <a href="#">32-bit</a>                                                                                      | -          |
| 0             | 0 | 001100 | UNALLOCATED                                                                                                                          | -          |
| 0             | 0 | 010x11 | UNALLOCATED                                                                                                                          | -          |
| 0             | 0 | 010000 | <a href="#">CRC32B</a> , <a href="#">CRC32H</a> , <a href="#">CRC32W</a> ,<br><a href="#">CRC32X</a> â€“ <a href="#">CRC32B</a>      | FEAT_CRC32 |
| 0             | 0 | 010001 | <a href="#">CRC32B</a> , <a href="#">CRC32H</a> , <a href="#">CRC32W</a> ,<br><a href="#">CRC32X</a> â€“ <a href="#">CRC32H</a>      | FEAT_CRC32 |
| 0             | 0 | 010010 | <a href="#">CRC32B</a> , <a href="#">CRC32H</a> , <a href="#">CRC32W</a> ,<br><a href="#">CRC32X</a> â€“ <a href="#">CRC32W</a>      | FEAT_CRC32 |
| 0             | 0 | 010100 | <a href="#">CRC32CB</a> , <a href="#">CRC32CH</a> , <a href="#">CRC32CW</a> ,<br><a href="#">CRC32CX</a> â€“ <a href="#">CRC32CB</a> | FEAT_CRC32 |
| 0             | 0 | 010101 | <a href="#">CRC32CB</a> , <a href="#">CRC32CH</a> , <a href="#">CRC32CW</a> ,<br><a href="#">CRC32CX</a> â€“ <a href="#">CRC32CH</a> | FEAT_CRC32 |
| 0             | 0 | 010110 | <a href="#">CRC32CB</a> , <a href="#">CRC32CH</a> , <a href="#">CRC32CW</a> ,<br><a href="#">CRC32CX</a> â€“ <a href="#">CRC32CW</a> | FEAT_CRC32 |

| Decode fields |   |        | Instruction Details                                                            | Feature    |
|---------------|---|--------|--------------------------------------------------------------------------------|------------|
| sf            | S | opcode |                                                                                |            |
| 0             | 0 | 011000 | <a href="#">SMAX (register)</a> â€“ 32-bit                                     | FEAT_CSSC  |
| 0             | 0 | 011001 | <a href="#">UMAX (register)</a> â€“ 32-bit                                     | FEAT_CSSC  |
| 0             | 0 | 011010 | <a href="#">SMIN (register)</a> â€“ 32-bit                                     | FEAT_CSSC  |
| 0             | 0 | 011011 | <a href="#">UMIN (register)</a> â€“ 32-bit                                     | FEAT_CSSC  |
| 1             | 0 | 000000 | <a href="#">SUBP</a>                                                           | FEAT_MTE   |
| 1             | 0 | 000010 | <a href="#">UDIV</a> â€“ 64-bit                                                | -          |
| 1             | 0 | 000011 | <a href="#">SDIV</a> â€“ 64-bit                                                | -          |
| 1             | 0 | 000100 | <a href="#">IRG</a>                                                            | FEAT_MTE   |
| 1             | 0 | 000101 | <a href="#">GMI</a>                                                            | FEAT_MTE   |
| 1             | 0 | 001000 | <a href="#">LSLV</a> â€“ 64-bit                                                | -          |
| 1             | 0 | 001001 | <a href="#">LSRV</a> â€“ 64-bit                                                | -          |
| 1             | 0 | 001010 | <a href="#">ASRV</a> â€“ 64-bit                                                | -          |
| 1             | 0 | 001011 | <a href="#">RORV</a> â€“ 64-bit                                                | -          |
| 1             | 0 | 001100 | <a href="#">PACGA</a>                                                          | FEAT_PAuth |
| 1             | 0 | 010xx0 | UNALLOCATED                                                                    | -          |
| 1             | 0 | 010x0x | UNALLOCATED                                                                    | -          |
| 1             | 0 | 010011 | <a href="#">CRC32B, CRC32H, CRC32W, CRC32X</a> â€“ <a href="#">CRC32X</a>      | FEAT_CRC32 |
| 1             | 0 | 010111 | <a href="#">CRC32CB, CRC32CH, CRC32CW, CRC32CX</a> â€“ <a href="#">CRC32CX</a> | FEAT_CRC32 |
| 1             | 0 | 011000 | <a href="#">SMAX (register)</a> â€“ 64-bit                                     | FEAT_CSSC  |
| 1             | 0 | 011001 | <a href="#">UMAX (register)</a> â€“ 64-bit                                     | FEAT_CSSC  |
| 1             | 0 | 011010 | <a href="#">SMIN (register)</a> â€“ 64-bit                                     | FEAT_CSSC  |
| 1             | 0 | 011011 | <a href="#">UMIN (register)</a> â€“ 64-bit                                     | FEAT_CSSC  |
| 1             | 1 | 000000 | <a href="#">SUBPS</a>                                                          | FEAT_MTE   |

### Data-processing (1 source)

These instructions are under [Data Processing -- Register](#).

|    |    |    |    |    |    |    |    |    |    |    |         |    |        |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|---------|----|--------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20      | 19 | 18     | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| sf | 1  | S  | 1  | 1  | 0  | 1  | 0  | 1  | 1  | 0  | opcode2 |    | opcode |    | Rn |    | Rd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |         | Instruction Details | Feature |             |   |
|---------------|---|---------|---------------------|---------|-------------|---|
| sf            | S | opcode2 | opcode              | Rn      |             |   |
|               |   |         | 1xxxxx              |         | UNALLOCATED | - |
|               |   | xxx1x   |                     |         | UNALLOCATED | - |
|               |   | xx1xx   |                     |         | UNALLOCATED | - |
|               |   | x1xxx   |                     |         | UNALLOCATED | - |
|               |   | 1xxxx   |                     |         | UNALLOCATED | - |

| sf | S | Decode fields |        |  | Rn | Instruction Details                                                                                                                                                 | Feature    |
|----|---|---------------|--------|--|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
|    |   | opcode2       | opcode |  |    |                                                                                                                                                                     |            |
|    | 0 | 00000         | 001001 |  |    | UNALLOCATED                                                                                                                                                         | -          |
|    | 0 | 00000         | 00101x |  |    | UNALLOCATED                                                                                                                                                         | -          |
|    | 0 | 00000         | 0011xx |  |    | UNALLOCATED                                                                                                                                                         | -          |
|    | 0 | 00000         | 01xxxx |  |    | UNALLOCATED                                                                                                                                                         | -          |
|    | 1 |               |        |  |    | UNALLOCATED                                                                                                                                                         | -          |
|    | 0 |               | 00001  |  |    | UNALLOCATED                                                                                                                                                         | -          |
| 0  | 0 | 00000         | 000000 |  |    | <a href="#">RBIT</a> â€” <a href="#">32-bit</a>                                                                                                                     | -          |
| 0  | 0 | 00000         | 000001 |  |    | <a href="#">REV16</a> â€” <a href="#">32-bit</a>                                                                                                                    | -          |
| 0  | 0 | 00000         | 000010 |  |    | <a href="#">REV</a> â€” <a href="#">32-bit</a>                                                                                                                      | -          |
| 0  | 0 | 00000         | 000011 |  |    | UNALLOCATED                                                                                                                                                         | -          |
| 0  | 0 | 00000         | 000100 |  |    | <a href="#">CLZ</a> â€” <a href="#">32-bit</a>                                                                                                                      | -          |
| 0  | 0 | 00000         | 000101 |  |    | <a href="#">CLS</a> â€” <a href="#">32-bit</a>                                                                                                                      | -          |
| 0  | 0 | 00000         | 000110 |  |    | <a href="#">CTZ</a> â€” <a href="#">32-bit</a>                                                                                                                      | FEAT_CSSC  |
| 0  | 0 | 00000         | 000111 |  |    | <a href="#">CNT</a> â€” <a href="#">32-bit</a>                                                                                                                      | FEAT_CSSC  |
| 0  | 0 | 00000         | 001000 |  |    | <a href="#">ABS</a> â€” <a href="#">32-bit</a>                                                                                                                      | FEAT_CSSC  |
| 1  | 0 | 00000         | 000000 |  |    | <a href="#">RBIT</a> â€” <a href="#">64-bit</a>                                                                                                                     | -          |
| 1  | 0 | 00000         | 000001 |  |    | <a href="#">REV16</a> â€” <a href="#">64-bit</a>                                                                                                                    | -          |
| 1  | 0 | 00000         | 000010 |  |    | <a href="#">REV32</a>                                                                                                                                               | -          |
| 1  | 0 | 00000         | 000011 |  |    | <a href="#">REV</a> â€” <a href="#">64-bit</a>                                                                                                                      | -          |
| 1  | 0 | 00000         | 000100 |  |    | <a href="#">CLZ</a> â€” <a href="#">64-bit</a>                                                                                                                      | -          |
| 1  | 0 | 00000         | 000101 |  |    | <a href="#">CLS</a> â€” <a href="#">64-bit</a>                                                                                                                      | -          |
| 1  | 0 | 00000         | 000110 |  |    | <a href="#">CTZ</a> â€” <a href="#">64-bit</a>                                                                                                                      | FEAT_CSSC  |
| 1  | 0 | 00000         | 000111 |  |    | <a href="#">CNT</a> â€” <a href="#">64-bit</a>                                                                                                                      | FEAT_CSSC  |
| 1  | 0 | 00000         | 001000 |  |    | <a href="#">ABS</a> â€” <a href="#">64-bit</a>                                                                                                                      | FEAT_CSSC  |
| 1  | 0 | 00001         | 000000 |  |    | <a href="#">PACIA</a> ,<br><a href="#">PACIA1716</a> ,<br><a href="#">PACIASP</a> , <a href="#">PACIAZ</a> ,<br><a href="#">PACIZA</a> â€”<br><a href="#">PACIA</a> | FEAT_PAuth |
| 1  | 0 | 00001         | 000001 |  |    | <a href="#">PACIB</a> ,<br><a href="#">PACIB1716</a> ,<br><a href="#">PACIBSP</a> , <a href="#">PACIBZ</a> ,<br><a href="#">PACIZB</a> â€”<br><a href="#">PACIB</a> | FEAT_PAuth |
| 1  | 0 | 00001         | 000010 |  |    | <a href="#">PACDA</a> , <a href="#">PACDZA</a> â€” <a href="#">PACDA</a>                                                                                            | FEAT_PAuth |
| 1  | 0 | 00001         | 000011 |  |    | <a href="#">PACDB</a> , <a href="#">PACDZB</a> â€” <a href="#">PACDB</a>                                                                                            | FEAT_PAuth |

| sf | S | Decode fields |        |       | Rn | Instruction Details                                                                                                                                                  | Feature    |
|----|---|---------------|--------|-------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
|    |   | opcode2       | opcode |       |    |                                                                                                                                                                      |            |
| 1  | 0 | 00001         | 000100 |       |    | <a href="#">AUTIA</a> ,<br><a href="#">AUTIA1716</a> ,<br><a href="#">AUTIASP</a> ,<br><a href="#">AUTIAZ</a> , <a href="#">AUTIZA</a><br>â€” <a href="#">AUTIA</a>  | FEAT_PAuth |
| 1  | 0 | 00001         | 000101 |       |    | <a href="#">AUTIB</a> ,<br><a href="#">AUTIB1716</a> ,<br><a href="#">AUTIBSP</a> ,<br><a href="#">AUTIBZ</a> , <a href="#">AUTIZB</a><br>â€” <a href="#">AUTIB</a>  | FEAT_PAuth |
| 1  | 0 | 00001         | 000110 |       |    | <a href="#">AUTDA</a> , <a href="#">AUTDZA</a><br>â€” <a href="#">AUTDA</a>                                                                                          | FEAT_PAuth |
| 1  | 0 | 00001         | 000111 |       |    | <a href="#">AUTDB</a> , <a href="#">AUTDZB</a><br>â€” <a href="#">AUTDB</a>                                                                                          | FEAT_PAuth |
| 1  | 0 | 00001         | 001000 | 11111 |    | <a href="#">PACIA</a> ,<br><a href="#">PACIA1716</a> ,<br><a href="#">PACIASP</a> , <a href="#">PACIAZ</a> ,<br><a href="#">PACIZA</a> â€”<br><a href="#">PACIZA</a> | FEAT_PAuth |
| 1  | 0 | 00001         | 001001 | 11111 |    | <a href="#">PACIB</a> ,<br><a href="#">PACIB1716</a> ,<br><a href="#">PACIBSP</a> , <a href="#">PACIBZ</a> ,<br><a href="#">PACIZB</a> â€”<br><a href="#">PACIZB</a> | FEAT_PAuth |
| 1  | 0 | 00001         | 001010 | 11111 |    | <a href="#">PACDA</a> , <a href="#">PACDZA</a><br>â€” <a href="#">PACDZA</a>                                                                                         | FEAT_PAuth |
| 1  | 0 | 00001         | 001011 | 11111 |    | <a href="#">PACDB</a> , <a href="#">PACDZB</a><br>â€” <a href="#">PACDZB</a>                                                                                         | FEAT_PAuth |
| 1  | 0 | 00001         | 001100 | 11111 |    | <a href="#">AUTIA</a> ,<br><a href="#">AUTIA1716</a> ,<br><a href="#">AUTIASP</a> ,<br><a href="#">AUTIAZ</a> , <a href="#">AUTIZA</a><br>â€” <a href="#">AUTIZA</a> | FEAT_PAuth |
| 1  | 0 | 00001         | 001101 | 11111 |    | <a href="#">AUTIB</a> ,<br><a href="#">AUTIB1716</a> ,<br><a href="#">AUTIBSP</a> ,<br><a href="#">AUTIBZ</a> , <a href="#">AUTIZB</a><br>â€” <a href="#">AUTIZB</a> | FEAT_PAuth |
| 1  | 0 | 00001         | 001110 | 11111 |    | <a href="#">AUTDA</a> , <a href="#">AUTDZA</a><br>â€” <a href="#">AUTDZA</a>                                                                                         | FEAT_PAuth |
| 1  | 0 | 00001         | 001111 | 11111 |    | <a href="#">AUTDB</a> , <a href="#">AUTDZB</a><br>â€” <a href="#">AUTDZB</a>                                                                                         | FEAT_PAuth |
| 1  | 0 | 00001         | 010000 | 11111 |    | <a href="#">XPACD</a> , <a href="#">XPACL</a> ,<br><a href="#">XPACLRI</a> â€”<br><a href="#">XPACI</a>                                                              | FEAT_PAuth |

| Decode fields |   |         |        |       | Instruction Details                                                                                     | Feature    |
|---------------|---|---------|--------|-------|---------------------------------------------------------------------------------------------------------|------------|
| sf            | S | opcode2 | opcode | Rn    |                                                                                                         |            |
| 1             | 0 | 00001   | 010001 | 11111 | <a href="#">XPACD</a> , <a href="#">XPACI</a> ,<br><a href="#">XPACLRI</a> â€”<br><a href="#">XPACD</a> | FEAT_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](#).

| Decode fields |     |   |        | Instruction Details                                |
|---------------|-----|---|--------|----------------------------------------------------|
| sf            | opc | N | imm6   |                                                    |
| 0             |     |   | 1xxxxx | UNALLOCATED                                        |
| 0             | 00  | 0 |        | <a href="#">AND (shifted register)</a> â€” 32-bit  |
| 0             | 00  | 1 |        | <a href="#">BIC (shifted register)</a> â€” 32-bit  |
| 0             | 01  | 0 |        | <a href="#">ORR (shifted register)</a> â€” 32-bit  |
| 0             | 01  | 1 |        | <a href="#">ORN (shifted register)</a> â€” 32-bit  |
| 0             | 10  | 0 |        | <a href="#">EOR (shifted register)</a> â€” 32-bit  |
| 0             | 10  | 1 |        | <a href="#">EON (shifted register)</a> â€” 32-bit  |
| 0             | 11  | 0 |        | <a href="#">ANDS (shifted register)</a> â€” 32-bit |
| 0             | 11  | 1 |        | <a href="#">BICS (shifted register)</a> â€” 32-bit |
| 1             | 00  | 0 |        | <a href="#">AND (shifted register)</a> â€” 64-bit  |
| 1             | 00  | 1 |        | <a href="#">BIC (shifted register)</a> â€” 64-bit  |
| 1             | 01  | 0 |        | <a href="#">ORR (shifted register)</a> â€” 64-bit  |
| 1             | 01  | 1 |        | <a href="#">ORN (shifted register)</a> â€” 64-bit  |
| 1             | 10  | 0 |        | <a href="#">EOR (shifted register)</a> â€” 64-bit  |
| 1             | 10  | 1 |        | <a href="#">EON (shifted register)</a> â€” 64-bit  |
| 1             | 11  | 0 |        | <a href="#">ANDS (shifted register)</a> â€” 64-bit |
| 1             | 11  | 1 |        | <a href="#">BICS (shifted register)</a> â€” 64-bit |

## Add/subtract (shifted register)

These instructions are under [Data Processing -- Register](#).

| Decode fields |    |   |       |        | Instruction Details                                |
|---------------|----|---|-------|--------|----------------------------------------------------|
| sf            | op | S | shift | imm6   |                                                    |
|               |    |   | 11    |        | UNALLOCATED                                        |
| 0             |    |   |       | 1xxxxx | UNALLOCATED                                        |
| 0             | 0  | 0 |       |        | <a href="#">ADD (shifted register)</a> â€“ 32-bit  |
| 0             | 0  | 1 |       |        | <a href="#">ADDS (shifted register)</a> â€“ 32-bit |
| 0             | 1  | 0 |       |        | <a href="#">SUB (shifted register)</a> â€“ 32-bit  |
| 0             | 1  | 1 |       |        | <a href="#">SUBS (shifted register)</a> â€“ 32-bit |
| 1             | 0  | 0 |       |        | <a href="#">ADD (shifted register)</a> â€“ 64-bit  |
| 1             | 0  | 1 |       |        | <a href="#">ADDS (shifted register)</a> â€“ 64-bit |
| 1             | 1  | 0 |       |        | <a href="#">SUB (shifted register)</a> â€“ 64-bit  |
| 1             | 1  | 1 |       |        | <a href="#">SUBS (shifted register)</a> â€“ 64-bit |

## Add/subtract (extended register)

These instructions are under [Data Processing -- Register](#).

| Decode fields |    |   |     |      | Instruction Details                                                 |
|---------------|----|---|-----|------|---------------------------------------------------------------------|
| sf            | op | S | opt | imm3 |                                                                     |
|               |    |   |     | 1x1  | UNALLOCATED                                                         |
|               |    |   |     | 11x  | UNALLOCATED                                                         |
|               |    |   | x1  |      | UNALLOCATED                                                         |
|               |    |   | 1x  |      | UNALLOCATED                                                         |
| 0             | 0  | 0 | 00  |      | <a href="#">ADD (extended register)</a> â€“ <a href="#">32-bit</a>  |
| 0             | 0  | 1 | 00  |      | <a href="#">ADDS (extended register)</a> â€“ <a href="#">32-bit</a> |
| 0             | 1  | 0 | 00  |      | <a href="#">SUB (extended register)</a> â€“ <a href="#">32-bit</a>  |
| 0             | 1  | 1 | 00  |      | <a href="#">SUBS (extended register)</a> â€“ <a href="#">32-bit</a> |
| 1             | 0  | 0 | 00  |      | <a href="#">ADD (extended register)</a> â€“ <a href="#">64-bit</a>  |
| 1             | 0  | 1 | 00  |      | <a href="#">ADDS (extended register)</a> â€“ <a href="#">64-bit</a> |
| 1             | 1  | 0 | 00  |      | <a href="#">SUB (extended register)</a> â€“ <a href="#">64-bit</a>  |
| 1             | 1  | 1 | 00  |      | <a href="#">SUBS (extended register)</a> â€“ <a href="#">64-bit</a> |

## Add/subtract (with carry)

These instructions are under [Data Processing -- Register](#).

| Decode fields |    |   | Instruction Details             |
|---------------|----|---|---------------------------------|
| sf            | op | S |                                 |
| 0             | 0  | 0 | <a href="#">ADC</a> â€“ 32-bit  |
| 0             | 0  | 1 | <a href="#">ADCS</a> â€“ 32-bit |
| 0             | 1  | 0 | <a href="#">SBC</a> â€“ 32-bit  |
| 0             | 1  | 1 | <a href="#">SBCS</a> â€“ 32-bit |
| 1             | 0  | 0 | <a href="#">ADC</a> â€“ 64-bit  |
| 1             | 0  | 1 | <a href="#">ADCS</a> â€“ 64-bit |
| 1             | 1  | 0 | <a href="#">SBC</a> â€“ 64-bit  |
| 1             | 1  | 1 | <a href="#">SBCS</a> â€“ 64-bit |

### Rotate right into flags

These instructions are under [Data Processing -- Register](#).

|    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |      |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|------|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| sf | op | S  | 1  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | imm6 | 0  | 0  | 0  | 0  | 1  | Rn | o2 | mask |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |    |   |    | Instruction Details  | Feature    |
|---------------|----|---|----|----------------------|------------|
| sf            | op | S | o2 |                      |            |
| 0             |    |   |    | UNALLOCATED          | -          |
| 1             | 0  | 0 |    | UNALLOCATED          | -          |
| 1             | 0  | 1 | 0  | <a href="#">RMIF</a> | FEAT_FlagM |
| 1             | 0  | 1 | 1  | UNALLOCATED          | -          |
| 1             | 1  |   |    | UNALLOCATED          | -          |

### Evaluate into flags

These instructions are under [Data Processing -- Register](#).

|    |    |    |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    |    |      |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|------|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20      | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| sf | op | S  | 1  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | opcode2 | sz | 0  | 0  | 1  | 0  | Rn | o3 | mask |    |    |   |   |   |   |   |   |   |   |   |   |

| 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    | <a href="#">SETF8, SETF16</a><br>â€“ <a href="#">SETF8</a> | FEAT_FlagM |

| sf | op | S | Decode fields |    |    |      | Instruction Details                                         |            | Feature |
|----|----|---|---------------|----|----|------|-------------------------------------------------------------|------------|---------|
|    |    |   | opcode2       | sz | o3 | mask |                                                             |            |         |
| 0  | 0  | 1 | 000000        | 1  | 0  | 1101 | <a href="#">SETF8, SETF16</a><br>etc <a href="#">SETF16</a> | FEAT_FlagM |         |
| 0  | 1  |   |               |    |    |      | UNALLOCATED                                                 | -          |         |
| 1  |    |   |               |    |    |      | UNALLOCATED                                                 | -          |         |

### Conditional compare (register)

These instructions are under [Data Processing -- Register](#).

|    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |    |    |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|----|----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| sf | op | S  | 1  | 1  | 0  | 1  | 0  | 0  | 1  | 0  | Rm | cond | 0  | o2 | Rn | o3 | nzcv |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| sf | op | S | Decode fields |    | Instruction Details                        |  |
|----|----|---|---------------|----|--------------------------------------------|--|
|    |    |   | o2            | o3 |                                            |  |
|    |    |   |               | 1  | UNALLOCATED                                |  |
|    |    |   |               | 1  | UNALLOCATED                                |  |
|    |    |   | 0             |    | UNALLOCATED                                |  |
| 0  | 0  | 1 | 0             | 0  | <a href="#">CCMN (register) etc 32-bit</a> |  |
| 0  | 1  | 1 | 0             | 0  | <a href="#">CCMP (register) etc 32-bit</a> |  |
| 1  | 0  | 1 | 0             | 0  | <a href="#">CCMN (register) etc 64-bit</a> |  |
| 1  | 1  | 1 | 0             | 0  | <a href="#">CCMP (register) etc 64-bit</a> |  |

### Conditional compare (immediate)

These instructions are under [Data Processing -- Register](#).

|    |    |    |    |    |    |    |    |    |    |    |      |      |    |    |    |    |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|----|----|----|----|------|------|----|----|----|----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19   | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| sf | op | S  | 1  | 1  | 0  | 1  | 0  | 0  | 1  | 0  | imm5 | cond | 1  | o2 | Rn | o3 | nzcv |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| sf | op | S | Decode fields |    | Instruction Details                         |  |
|----|----|---|---------------|----|---------------------------------------------|--|
|    |    |   | o2            | o3 |                                             |  |
|    |    |   |               | 1  | UNALLOCATED                                 |  |
|    |    |   |               | 1  | UNALLOCATED                                 |  |
|    |    |   | 0             |    | UNALLOCATED                                 |  |
| 0  | 0  | 1 | 0             | 0  | <a href="#">CCMN (immediate) etc 32-bit</a> |  |
| 0  | 1  | 1 | 0             | 0  | <a href="#">CCMP (immediate) etc 32-bit</a> |  |
| 1  | 0  | 1 | 0             | 0  | <a href="#">CCMN (immediate) etc 64-bit</a> |  |
| 1  | 1  | 1 | 0             | 0  | <a href="#">CCMP (immediate) etc 64-bit</a> |  |

### Conditional select

These instructions are under [Data Processing -- Register](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17  | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| sf | op | S  | 1  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | Rm |    | cond | op2 |    | Rn |    | Rd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |    |   |     | Instruction Details                              |
|---------------|----|---|-----|--------------------------------------------------|
| sf            | op | S | op2 |                                                  |
|               |    |   | 1x  | UNALLOCATED                                      |
|               |    | 1 |     | UNALLOCATED                                      |
| 0             | 0  | 0 | 00  | <a href="#">CSEL</a> â€“ <a href="#">32-bit</a>  |
| 0             | 0  | 0 | 01  | <a href="#">CSINC</a> â€“ <a href="#">32-bit</a> |
| 0             | 1  | 0 | 00  | <a href="#">CSINV</a> â€“ <a href="#">32-bit</a> |
| 0             | 1  | 0 | 01  | <a href="#">CSNEG</a> â€“ <a href="#">32-bit</a> |
| 1             | 0  | 0 | 00  | <a href="#">CSEL</a> â€“ <a href="#">64-bit</a>  |
| 1             | 0  | 0 | 01  | <a href="#">CSINC</a> â€“ <a href="#">64-bit</a> |
| 1             | 1  | 0 | 00  | <a href="#">CSINV</a> â€“ <a href="#">64-bit</a> |
| 1             | 1  | 0 | 01  | <a href="#">CSNEG</a> â€“ <a href="#">64-bit</a> |

### Data-processing (3 source)

These instructions are under [Data Processing -- Register](#).

|    |      |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|------|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30   | 29 | 28 | 27 | 26 | 25 | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| sf | op54 | 1  | 1  | 0  | 1  | 1  | op31 |    | Rm | 00 | Ra |    | Rn |    | Rd |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| 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  | <a href="#">MADD</a> â€“ <a href="#">32-bit</a> |
| 0             | 00   | 000  | 1  | <a href="#">MSUB</a> â€“ <a href="#">32-bit</a> |
| 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                                     |

| sf | Decode fields |      |    | Instruction Details           |
|----|---------------|------|----|-------------------------------|
|    | op54          | op31 | o0 |                               |
| 1  | 00            | 000  | 0  | <a href="#">MADD</a> " 64-bit |
| 1  | 00            | 000  | 1  | <a href="#">MSUB</a> " 64-bit |
| 1  | 00            | 001  | 0  | <a href="#">SMADDL</a>        |
| 1  | 00            | 001  | 1  | <a href="#">SMSUBL</a>        |
| 1  | 00            | 010  | 0  | <a href="#">SMULH</a>         |
| 1  | 00            | 101  | 0  | <a href="#">UMADDL</a>        |
| 1  | 00            | 101  | 1  | <a href="#">UMSUBL</a>        |
| 1  | 00            | 110  | 0  | <a href="#">UMULH</a>         |

## Data Processing -- Scalar Floating-Point and Advanced SIMD

These instructions are under the [top-level](#).

|     |     |     |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31  | 30  | 29  | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| op0 | 111 | op1 | op2 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| op0  | Decode fields |      |           | Instruction details                                                  | Feature |
|------|---------------|------|-----------|----------------------------------------------------------------------|---------|
|      | op1           | op2  | op3       |                                                                      |         |
| 0000 | 0x            | x101 | 00xxxxx10 | UNALLOCATED                                                          | -       |
| 0010 | 0x            | x101 | 00xxxxx10 | UNALLOCATED                                                          | -       |
| 0100 | 0x            | x101 | 00xxxxx10 | <a href="#">Cryptographic AES</a>                                    | -       |
| 0101 | 0x            | x0xx | xxx0xxx00 | <a href="#">Cryptographic three-register SHA</a>                     | -       |
| 0101 | 0x            | x0xx | xxx0xxx10 | UNALLOCATED                                                          | -       |
| 0101 | 0x            | x101 | 00xxxxx10 | <a href="#">Cryptographic two-register SHA</a>                       | -       |
| 0110 | 0x            | x101 | 00xxxxx10 | UNALLOCATED                                                          | -       |
| 0111 | 0x            | x0xx | xxx0xxxx0 | UNALLOCATED                                                          | -       |
| 0111 | 0x            | x101 | 00xxxxx10 | UNALLOCATED                                                          | -       |
| 01x1 | 00            | 00xx | xxx0xxxx1 | <a href="#">Advanced SIMD scalar copy</a>                            | -       |
| 01x1 | 01            | 00xx | xxx0xxxx1 | UNALLOCATED                                                          | -       |
| 01x1 | 0x            | 0111 | 00xxxxx10 | UNALLOCATED                                                          | -       |
| 01x1 | 0x            | 10xx | xxx00xxx1 | <a href="#">Advanced SIMD scalar three same FP16</a>                 | -       |
| 01x1 | 0x            | 10xx | xxx01xxx1 | UNALLOCATED                                                          | -       |
| 01x1 | 0x            | 1111 | 00xxxxx10 | <a href="#">Advanced SIMD scalar two-register miscellaneous FP16</a> | -       |
| 01x1 | 0x            | x0xx | xxx1xxxx0 | UNALLOCATED                                                          | -       |
| 01x1 | 0x            | x0xx | xxx1xxxx1 | <a href="#">Advanced SIMD scalar three same extra</a>                | -       |

|      |    |      |            |                                                                 |   |
|------|----|------|------------|-----------------------------------------------------------------|---|
| 01x1 | 0x | x100 | 00xxxxx10  | <a href="#">Advanced SIMD scalar two-register miscellaneous</a> | - |
| 01x1 | 0x | x110 | 00xxxxx10  | <a href="#">Advanced SIMD scalar pairwise</a>                   | - |
| 01x1 | 0x | x1xx | 1xxxxxx10  | UNALLOCATED                                                     | - |
| 01x1 | 0x | x1xx | x1xxxxx10  | UNALLOCATED                                                     | - |
| 01x1 | 0x | x1xx | xxxxxxx00  | <a href="#">Advanced SIMD scalar three different</a>            | - |
| 01x1 | 0x | x1xx | xxxxxxxx1  | <a href="#">Advanced SIMD scalar three same</a>                 | - |
| 01x1 | 10 |      | xxxxxxxx1  | <a href="#">Advanced SIMD scalar shift by immediate</a>         | - |
| 01x1 | 11 |      | xxxxxxxx1  | UNALLOCATED                                                     | - |
| 01x1 | 1x |      | xxxxxxxx0  | <a href="#">Advanced SIMD scalar x indexed element</a>          | - |
| 0x00 | 0x | x0xx | xxx0xxx00  | <a href="#">Advanced SIMD table lookup</a>                      | - |
| 0x00 | 0x | x0xx | xxx0xxx10  | <a href="#">Advanced SIMD permute</a>                           | - |
| 0x10 | 0x | x0xx | xxx0xxxx0  | <a href="#">Advanced SIMD extract</a>                           | - |
| 0xx0 | 00 | 00xx | xxx0xxxx1  | <a href="#">Advanced SIMD copy</a>                              | - |
| 0xx0 | 01 | 00xx | xxx0xxxx1  | UNALLOCATED                                                     | - |
| 0xx0 | 0x | 0111 | 00xxxxx10  | UNALLOCATED                                                     | - |
| 0xx0 | 0x | 10xx | xxx00xxx1  | <a href="#">Advanced SIMD three same (FP16)</a>                 | - |
| 0xx0 | 0x | 10xx | xxx01xxx1  | UNALLOCATED                                                     | - |
| 0xx0 | 0x | 1111 | 00xxxxx10  | <a href="#">Advanced SIMD two-register miscellaneous (FP16)</a> | - |
| 0xx0 | 0x | x0xx | xxx1xxxx0  | UNALLOCATED                                                     | - |
| 0xx0 | 0x | x0xx | xxx1xxxx1  | <a href="#">Advanced SIMD three-register extension</a>          | - |
| 0xx0 | 0x | x100 | 00xxxxx10  | <a href="#">Advanced SIMD two-register miscellaneous</a>        | - |
| 0xx0 | 0x | x110 | 00xxxxx10  | <a href="#">Advanced SIMD across lanes</a>                      | - |
| 0xx0 | 0x | x1xx | 1xxxxxx10  | UNALLOCATED                                                     | - |
| 0xx0 | 0x | x1xx | x1xxxxx10  | UNALLOCATED                                                     | - |
| 0xx0 | 0x | x1xx | xxxxxxxx00 | <a href="#">Advanced SIMD three different</a>                   | - |
| 0xx0 | 0x | x1xx | xxxxxxxx1  | <a href="#">Advanced SIMD three same</a>                        | - |
| 0xx0 | 10 | 0000 | xxxxxxxx1  | <a href="#">Advanced SIMD modified immediate</a>                | - |

|      |    |                |            |                                                                   |           |
|------|----|----------------|------------|-------------------------------------------------------------------|-----------|
| 0xx0 | 10 | $\neq$<br>0000 | xxxxxxxx1  | <a href="#">Advanced SIMD shift by immediate</a>                  | -         |
| 0xx0 | 11 |                | xxxxxxxx1  | UNALLOCATED                                                       | -         |
| 0xx0 | 1x |                | xxxxxxxx0  | <a href="#">Advanced SIMD vector x indexed element</a>            | -         |
| 1100 | 00 | 10xx           | xxx10xxxx  | <a href="#">Cryptographic three-register, imm2</a>                | -         |
| 1100 | 00 | 11xx           | xxx1x00xx  | <a href="#">Cryptographic three-register SHA 512</a>              | -         |
| 1100 | 00 |                | xxx0xxxx   | <a href="#">Cryptographic four-register</a>                       | -         |
| 1100 | 01 | 00xx           |            | <a href="#">XAR</a>                                               | FEAT_SHA3 |
| 1100 | 01 | 1000           | 0001000xx  | <a href="#">Cryptographic two-register SHA 512</a>                | -         |
| 1xx0 | 1x |                |            | UNALLOCATED                                                       | -         |
| x0x1 | 0x | x0xx           |            | <a href="#">Conversion between floating-point and fixed-point</a> | -         |
| x0x1 | 0x | x1xx           | xxx000000  | <a href="#">Conversion between floating-point and integer</a>     | -         |
| x0x1 | 0x | x1xx           | xxxx10000  | <a href="#">Floating-point data-processing (1 source)</a>         | -         |
| x0x1 | 0x | x1xx           | xxxxx1000  | <a href="#">Floating-point compare</a>                            | -         |
| x0x1 | 0x | x1xx           | xxxxxx100  | <a href="#">Floating-point immediate</a>                          | -         |
| x0x1 | 0x | x1xx           | xxxxxxxx01 | <a href="#">Floating-point conditional compare</a>                | -         |
| x0x1 | 0x | x1xx           | xxxxxxxx10 | <a href="#">Floating-point data-processing (2 source)</a>         | -         |
| x0x1 | 0x | x1xx           | xxxxxxxx11 | <a href="#">Floating-point conditional select</a>                 | -         |
| x0x1 | 1x |                |            | <a href="#">Floating-point data-processing (3 source)</a>         | -         |

## Cryptographic AES

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|--------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17     | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | 0  | 0  | 1  | 1  | 1  | 0  | size | 1  | 0  | 1  | 0  | 0  | opcode | 1  | 0  | Rn |    | Rd |    |    |   |   |   |   |   |   |   |   |   |   |

**Decode fields**  
**size**      **opcode**

**Instruction Details**

**Feature**

|  |       |             |   |
|--|-------|-------------|---|
|  | x1xxx | UNALLOCATED | - |
|--|-------|-------------|---|

| <b>Decode fields</b> | <b>Instruction Details</b> | <b>Feature</b>         |          |
|----------------------|----------------------------|------------------------|----------|
| <b>size</b>          | <b>opcode</b>              |                        |          |
|                      | 000xx                      | UNALLOCATED            | -        |
|                      | 1xxxx                      | UNALLOCATED            | -        |
| x1                   |                            | UNALLOCATED            | -        |
| 00                   | 00100                      | <a href="#">AESE</a>   | FEAT_AES |
| 00                   | 00101                      | <a href="#">AESD</a>   | FEAT_AES |
| 00                   | 00110                      | <a href="#">AESMC</a>  | FEAT_AES |
| 00                   | 00111                      | <a href="#">AESIMC</a> | FEAT_AES |
| 1x                   |                            | UNALLOCATED            | -        |

# Cryptographic three-register SHA

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

| Decode fields |        | Instruction Details       | Feature     |
|---------------|--------|---------------------------|-------------|
| size          | opcode |                           |             |
|               | 111    | UNALLOCATED               | -           |
| x1            |        | UNALLOCATED               | -           |
| 00            | 000    | <a href="#">SHA1C</a>     | FEAT_SHA1   |
| 00            | 001    | <a href="#">SHA1P</a>     | FEAT_SHA1   |
| 00            | 010    | <a href="#">SHA1M</a>     | FEAT_SHA1   |
| 00            | 011    | <a href="#">SHA1SU0</a>   | FEAT_SHA1   |
| 00            | 100    | <a href="#">SHA256H</a>   | FEAT_SHA256 |
| 00            | 101    | <a href="#">SHA256H2</a>  | FEAT_SHA256 |
| 00            | 110    | <a href="#">SHA256SU1</a> | FEAT_SHA256 |
| 1x            |        | UNALLOCATED               | -           |

## Cryptographic two-register SHA

These instructions are under [Data Processing -- Scalar Floating-Point](#) and [Advanced SIMD](#).

| Decode fields |        | Instruction Details       | Feature     |
|---------------|--------|---------------------------|-------------|
| size          | opcode |                           |             |
|               | xx1xx  | UNALLOCATED               | -           |
|               | x1xxx  | UNALLOCATED               | -           |
|               | 1xxxx  | UNALLOCATED               | -           |
| x1            |        | UNALLOCATED               | -           |
| 00            | 00000  | <a href="#">SHA1H</a>     | FEAT_SHA1   |
| 00            | 00001  | <a href="#">SHA1SU1</a>   | FEAT_SHA1   |
| 00            | 00010  | <a href="#">SHA256SU0</a> | FEAT_SHA256 |
| 00            | 00011  | UNALLOCATED               | -           |
| 1x            |        | UNALLOCATED               | -           |

### Advanced SIMD scalar copy

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |    |    |      |    |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|----|----|----|----|------|----|------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19 | 18   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 0  | 1  | op | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  | imm5 | 0  | imm4 | 1  | Rn |    | Rd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Decode fields |      | Instruction Details           |
|---------------|------|-------------------------------|
| op            | imm4 |                               |
| 0             | xxx1 | UNALLOCATED                   |
| 0             | xx1x | UNALLOCATED                   |
| 0             | x1xx | UNALLOCATED                   |
| 0             | 0000 | <a href="#">DUP (element)</a> |
| 0             | 1xxx | UNALLOCATED                   |
| 1             |      | UNALLOCATED                   |

### Advanced SIMD scalar three same FP16

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 0  | 1  | U  | 1  | 1  | 1  | 1  | 0  | a  | 1  | 0  | Rm | 0  | 0  | opcode | 1  | Rn |    | Rd |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

| Decode fields |   |        | Instruction Details | Feature |
|---------------|---|--------|---------------------|---------|
| U             | a | opcode |                     |         |
|               |   | 110    | UNALLOCATED         | -       |
|               | 1 | 011    | UNALLOCATED         | -       |

| Decode fields |   |        | Instruction Details              | Feature   |
|---------------|---|--------|----------------------------------|-----------|
| U             | a | opcode |                                  |           |
| 0             | 0 | 011    | <a href="#">FMULX</a>            | FEAT_FP16 |
| 0             | 0 | 100    | <a href="#">FCMEQ (register)</a> | FEAT_FP16 |
| 0             | 0 | 101    | UNALLOCATED                      | -         |
| 0             | 0 | 111    | <a href="#">FRECPS</a>           | FEAT_FP16 |
| 0             | 1 | 100    | UNALLOCATED                      | -         |
| 0             | 1 | 101    | UNALLOCATED                      | -         |
| 0             | 1 | 111    | <a href="#">FRSQRTS</a>          | FEAT_FP16 |
| 1             | 0 | 011    | UNALLOCATED                      | -         |
| 1             | 0 | 100    | <a href="#">FCMGE (register)</a> | FEAT_FP16 |
| 1             | 0 | 101    | <a href="#">FACGE</a>            | FEAT_FP16 |
| 1             | 0 | 111    | UNALLOCATED                      | -         |
| 1             | 1 | 010    | <a href="#">FABD</a>             | FEAT_FP16 |
| 1             | 1 | 100    | <a href="#">FCMGT (register)</a> | FEAT_FP16 |
| 1             | 1 | 101    | <a href="#">FACGT</a>            | FEAT_FP16 |
| 1             | 1 | 111    | UNALLOCATED                      | -         |

### Advanced SIMD scalar two-register miscellaneous FP16

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | U  | 1  | 1  | 1  | 1  | 0  | a  | 1  | 1  | 1  | 1  | 0  | 0  | opcode | 1  | 0  | Rn |    | Rd |    |   |   |   |   |   |   |   |   |   |   |

| 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  | <a href="#">FCVTNS (vector)</a>         | FEAT_FP16 |
| 0             | 0 | 11011  | <a href="#">FCVTMS (vector)</a>         | FEAT_FP16 |
| 0             | 0 | 11100  | <a href="#">FCVTAS (vector)</a>         | FEAT_FP16 |
| 0             | 0 | 11101  | <a href="#">SCVTF (vector, integer)</a> | FEAT_FP16 |

| Decode fields |   |        | Instruction Details                      | Feature   |
|---------------|---|--------|------------------------------------------|-----------|
| U             | a | opcode |                                          |           |
| 0             | 1 | 01100  | <a href="#">FCMGT (zero)</a>             | FEAT_FP16 |
| 0             | 1 | 01101  | <a href="#">FCMEQ (zero)</a>             | FEAT_FP16 |
| 0             | 1 | 01110  | <a href="#">FCMLT (zero)</a>             | FEAT_FP16 |
| 0             | 1 | 11010  | <a href="#">FCVTPS (vector)</a>          | FEAT_FP16 |
| 0             | 1 | 11011  | <a href="#">FCVTZS (vector, integer)</a> | FEAT_FP16 |
| 0             | 1 | 11101  | <a href="#">FRECPE</a>                   | FEAT_FP16 |
| 0             | 1 | 11111  | <a href="#">FRECPX</a>                   | FEAT_FP16 |
| 1             | 0 | 11010  | <a href="#">FCVTNU (vector)</a>          | FEAT_FP16 |
| 1             | 0 | 11011  | <a href="#">FCVTMU (vector)</a>          | FEAT_FP16 |
| 1             | 0 | 11100  | <a href="#">FCVTAU (vector)</a>          | FEAT_FP16 |
| 1             | 0 | 11101  | <a href="#">UCVTF (vector, integer)</a>  | FEAT_FP16 |
| 1             | 1 | 01100  | <a href="#">FCMGE (zero)</a>             | FEAT_FP16 |
| 1             | 1 | 01101  | <a href="#">FCMLE (zero)</a>             | FEAT_FP16 |
| 1             | 1 | 01110  | UNALLOCATED                              | -         |
| 1             | 1 | 11010  | <a href="#">FCVTPU (vector)</a>          | FEAT_FP16 |
| 1             | 1 | 11011  | <a href="#">FCVTZU (vector, integer)</a> | FEAT_FP16 |
| 1             | 1 | 11101  | <a href="#">FRSQRTE</a>                  | FEAT_FP16 |
| 1             | 1 | 11111  | UNALLOCATED                              | -         |

### Advanced SIMD scalar three same extra

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|------|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0  | 1  | U  | 1  | 1  | 1  | 1  | 0  | size | 0  | Rm | 1  | opcode | 1  | Rn |    | Rd |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Decode fields |   |        | Instruction Details               | Feature  |
|---------------|---|--------|-----------------------------------|----------|
| U             | a | opcode |                                   |          |
|               |   | 001x   | UNALLOCATED                       | -        |
|               |   | 01xx   | UNALLOCATED                       | -        |
|               |   | 1xxx   | UNALLOCATED                       | -        |
| 0             |   | 0000   | UNALLOCATED                       | -        |
| 0             |   | 0001   | UNALLOCATED                       | -        |
| 1             |   | 0000   | <a href="#">SQRDMLAH (vector)</a> | FEAT_RDM |
| 1             |   | 0001   | <a href="#">SQRDMLSH (vector)</a> | FEAT_RDM |

### Advanced SIMD scalar two-register miscellaneous

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|--------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17     | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | U  | 1  | 1  | 1  | 1  | 0  | size | 1  | 0  | 0  | 0  | 0  | opcode | 1  | 0  | Rn |    | Rd |    |    |   |   |   |   |   |   |   |   |   |   |

| 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  | <a href="#">SUQADD</a>                   |
| 0             |      | 00111  | <a href="#">SQABS</a>                    |
| 0             |      | 01000  | <a href="#">CMGT (zero)</a>              |
| 0             |      | 01001  | <a href="#">CMEQ (zero)</a>              |
| 0             |      | 01010  | <a href="#">CMLT (zero)</a>              |
| 0             |      | 01011  | <a href="#">ABS</a>                      |
| 0             |      | 10010  | UNALLOCATED                              |
| 0             |      | 10100  | <a href="#">SQXTN, SQXTN2</a>            |
| 0             | 0x   | 10110  | UNALLOCATED                              |
| 0             | 0x   | 11010  | <a href="#">FCVTNS (vector)</a>          |
| 0             | 0x   | 11011  | <a href="#">FCVTMS (vector)</a>          |
| 0             | 0x   | 11100  | <a href="#">FCVTAS (vector)</a>          |
| 0             | 0x   | 11101  | <a href="#">SCVTF (vector, integer)</a>  |
| 0             | 1x   | 01100  | <a href="#">FCMGT (zero)</a>             |
| 0             | 1x   | 01101  | <a href="#">FCMEO (zero)</a>             |
| 0             | 1x   | 01110  | <a href="#">FCMLT (zero)</a>             |
| 0             | 1x   | 11010  | <a href="#">FCVTPS (vector)</a>          |
| 0             | 1x   | 11011  | <a href="#">FCVTZS (vector, integer)</a> |

| Decode fields |      |        | Instruction Details                      |
|---------------|------|--------|------------------------------------------|
| U             | size | opcode |                                          |
| 0             | 1x   | 11101  | <a href="#">FRECPE</a>                   |
| 0             | 1x   | 11111  | <a href="#">FRECPX</a>                   |
| 1             |      | 00011  | <a href="#">USQADD</a>                   |
| 1             |      | 00111  | <a href="#">SQNEG</a>                    |
| 1             |      | 01000  | <a href="#">CMGE (zero)</a>              |
| 1             |      | 01001  | <a href="#">CMLE (zero)</a>              |
| 1             |      | 01010  | UNALLOCATED                              |
| 1             |      | 01011  | <a href="#">NEG (vector)</a>             |
| 1             |      | 10010  | <a href="#">SQXTUN, SQXTUN2</a>          |
| 1             |      | 10100  | <a href="#">UQXTN, UQXTN2</a>            |
| 1             | 0x   | 10110  | <a href="#">FCVTXN, FCVTXN2</a>          |
| 1             | 0x   | 11010  | <a href="#">FCVTNU (vector)</a>          |
| 1             | 0x   | 11011  | <a href="#">FCVTMU (vector)</a>          |
| 1             | 0x   | 11100  | <a href="#">FCVTAU (vector)</a>          |
| 1             | 0x   | 11101  | <a href="#">UCVTF (vector, integer)</a>  |
| 1             | 1x   | 01100  | <a href="#">FCMGE (zero)</a>             |
| 1             | 1x   | 01101  | <a href="#">FCMLE (zero)</a>             |
| 1             | 1x   | 01110  | UNALLOCATED                              |
| 1             | 1x   | 11010  | <a href="#">FCVTPU (vector)</a>          |
| 1             | 1x   | 11011  | <a href="#">FCVTZU (vector, integer)</a> |
| 1             | 1x   | 11101  | <a href="#">FRSQRTE</a>                  |
| 1             | 1x   | 11111  | UNALLOCATED                              |

### Advanced SIMD scalar pairwise

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |    |    |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|----|----|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1  | 0 |
| 0  | 1  | U  | 1  | 1  | 1  | 1  | 0  | size | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Rn | Rd |   |

| Decode fields |      |        | Instruction Details | Feature |
|---------------|------|--------|---------------------|---------|
| U             | size | opcode |                     |         |
|               |      | 00xxx  | UNALLOCATED         | -       |
|               |      | 010xx  | UNALLOCATED         | -       |
|               |      | 01110  | UNALLOCATED         | -       |
|               |      | 10xxx  | UNALLOCATED         | -       |
|               |      | 1100x  | UNALLOCATED         | -       |
|               |      | 11010  | UNALLOCATED         | -       |

| Decode fields |      |        | Instruction Details                                                                        | Feature   |
|---------------|------|--------|--------------------------------------------------------------------------------------------|-----------|
| U             | size | opcode |                                                                                            |           |
|               |      | 111xx  | UNALLOCATED                                                                                | -         |
|               | 1x   | 01101  | UNALLOCATED                                                                                | -         |
| 0             |      | 11011  | <a href="#">ADDP (scalar)</a>                                                              | -         |
| 0             | 0x   | 01100  | <a href="#">FMAXNMP (scalar)</a> â€“ <a href="#">half-precision</a>                        | FEAT_FP16 |
| 0             | 0x   | 01101  | <a href="#">FADDP (scalar)</a> â€“ <a href="#">half-precision</a>                          | FEAT_FP16 |
| 0             | 0x   | 01111  | <a href="#">FMAXP (scalar)</a> â€“ <a href="#">half-precision</a>                          | FEAT_FP16 |
| 0             | 1x   | 01100  | <a href="#">FMINNMP (scalar)</a> â€“ <a href="#">half-precision</a>                        | FEAT_FP16 |
| 0             | 1x   | 01111  | <a href="#">FMINP (scalar)</a> â€“ <a href="#">half-precision</a>                          | FEAT_FP16 |
| 1             |      | 11011  | UNALLOCATED                                                                                | -         |
| 1             | 0x   | 01100  | <a href="#">FMAXNMP (scalar)</a> â€“ <a href="#">single-precision and double-precision</a> | -         |
| 1             | 0x   | 01101  | <a href="#">FADDP (scalar)</a> â€“ <a href="#">single-precision and double-precision</a>   | -         |
| 1             | 0x   | 01111  | <a href="#">FMAXP (scalar)</a> â€“ <a href="#">single-precision and double-precision</a>   | -         |
| 1             | 1x   | 01100  | <a href="#">FMINNMP (scalar)</a> â€“ <a href="#">single-precision and double-precision</a> | -         |
| 1             | 1x   | 01111  | <a href="#">FMINP (scalar)</a> â€“ <a href="#">single-precision and double-precision</a>   | -         |

### Advanced SIMD scalar three different

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | U  | 1  | 1  | 1  | 1  | 0  | size | 1  | Rm |    | opcode | 0  | 0  | Rn |    | Rd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |        |                                            | Instruction Details |
|---------------|--------|--------------------------------------------|---------------------|
| U             | opcode |                                            |                     |
|               | 00xx   | UNALLOCATED                                |                     |
|               | 01xx   | UNALLOCATED                                |                     |
|               | 1000   | UNALLOCATED                                |                     |
|               | 1010   | UNALLOCATED                                |                     |
|               | 1100   | UNALLOCATED                                |                     |
|               | 111x   | UNALLOCATED                                |                     |
| 0             | 1001   | <a href="#">SQDMLAL, SQDMLAL2 (vector)</a> |                     |
| 0             | 1011   | <a href="#">SQDMLSL, SQDMLSL2 (vector)</a> |                     |
| 0             | 1101   | <a href="#">SQDMULL, SQDMULL2 (vector)</a> |                     |
| 1             | 1001   | UNALLOCATED                                |                     |

| Decode fields |        | Instruction Details |
|---------------|--------|---------------------|
| U             | opcode |                     |
| 1             | 1011   | UNALLOCATED         |
| 1             | 1101   | UNALLOCATED         |

### Advanced SIMD scalar three same

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | U  | 1  | 1  | 1  | 1  | 0  | size | 1  | Rm |    | opcode | 1  | Rn |    | Rd |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |      | Instruction Details |                                  |
|---------------|------|---------------------|----------------------------------|
| U             | size | opcode              |                                  |
|               |      | 00000               | UNALLOCATED                      |
|               |      | 0001x               | UNALLOCATED                      |
|               |      | 00100               | UNALLOCATED                      |
|               |      | 011xx               | UNALLOCATED                      |
|               |      | 1001x               | UNALLOCATED                      |
|               | 1x   | 11011               | UNALLOCATED                      |
| 0             |      | 00001               | <a href="#">SQADD</a>            |
| 0             |      | 00101               | <a href="#">SQSUB</a>            |
| 0             |      | 00110               | <a href="#">CMGT (register)</a>  |
| 0             |      | 00111               | <a href="#">CMGE (register)</a>  |
| 0             |      | 01000               | <a href="#">SSH</a>              |
| 0             |      | 01001               | <a href="#">SOSHL (register)</a> |
| 0             |      | 01010               | <a href="#">SRSHL</a>            |
| 0             |      | 01011               | <a href="#">SQRSHL</a>           |
| 0             |      | 10000               | <a href="#">ADD (vector)</a>     |
| 0             |      | 10001               | <a href="#">CMTST</a>            |
| 0             |      | 10100               | UNALLOCATED                      |
| 0             |      | 10101               | UNALLOCATED                      |
| 0             |      | 10110               | <a href="#">SQDMULH (vector)</a> |
| 0             |      | 10111               | UNALLOCATED                      |
| 0             | 0x   | 11000               | UNALLOCATED                      |
| 0             | 0x   | 11001               | UNALLOCATED                      |
| 0             | 0x   | 11010               | UNALLOCATED                      |
| 0             | 0x   | 11011               | <a href="#">FMULX</a>            |
| 0             | 0x   | 11100               | <a href="#">FCMEQ (register)</a> |
| 0             | 0x   | 11101               | UNALLOCATED                      |

| Decode fields |      |        | Instruction Details               |
|---------------|------|--------|-----------------------------------|
| U             | size | opcode |                                   |
| 0             | 0x   | 11110  | UNALLOCATED                       |
| 0             | 0x   | 11111  | <a href="#">FRECPS</a>            |
| 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  | <a href="#">FRSQRTS</a>           |
| 1             |      | 00001  | <a href="#">UQADD</a>             |
| 1             |      | 00101  | <a href="#">UQSUB</a>             |
| 1             |      | 00110  | <a href="#">CMHI (register)</a>   |
| 1             |      | 00111  | <a href="#">CMHS (register)</a>   |
| 1             |      | 01000  | <a href="#">USHL</a>              |
| 1             |      | 01001  | <a href="#">UQSHL (register)</a>  |
| 1             |      | 01010  | <a href="#">URSHL</a>             |
| 1             |      | 01011  | <a href="#">UQRSHL</a>            |
| 1             |      | 10000  | <a href="#">SUB (vector)</a>      |
| 1             |      | 10001  | <a href="#">CMEQ (register)</a>   |
| 1             |      | 10100  | UNALLOCATED                       |
| 1             |      | 10101  | UNALLOCATED                       |
| 1             |      | 10110  | <a href="#">SQRDMULH (vector)</a> |
| 1             |      | 10111  | UNALLOCATED                       |
| 1             | 0x   | 11000  | UNALLOCATED                       |
| 1             | 0x   | 11001  | UNALLOCATED                       |
| 1             | 0x   | 11010  | UNALLOCATED                       |
| 1             | 0x   | 11011  | UNALLOCATED                       |
| 1             | 0x   | 11100  | <a href="#">FCMGE (register)</a>  |
| 1             | 0x   | 11101  | <a href="#">FACGE</a>             |
| 1             | 0x   | 11110  | UNALLOCATED                       |
| 1             | 0x   | 11111  | UNALLOCATED                       |
| 1             | 1x   | 11000  | UNALLOCATED                       |
| 1             | 1x   | 11001  | UNALLOCATED                       |
| 1             | 1x   | 11010  | <a href="#">FABD</a>              |
| 1             | 1x   | 11100  | <a href="#">FCMGT (register)</a>  |
| 1             | 1x   | 11101  | <a href="#">FACGT</a>             |
| 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](#).

|    |    |    |    |    |    |    |    |    |      |    |      |    |        |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|------|----|------|----|--------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21 | 20   | 19 | 18     | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | U  | 1  | 1  | 1  | 1  | 0  |    | immh |    | immb |    | opcode |    | 1  |    | Rn |    | Rd |    |    |   |   |   |   |   |   |   |   |   |   |

| 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  | <a href="#">SSHR</a>                         |
| 0             | != 0000 | 00010  | <a href="#">SSRA</a>                         |
| 0             | != 0000 | 00100  | <a href="#">SRSHR</a>                        |
| 0             | != 0000 | 00110  | <a href="#">SRSRA</a>                        |
| 0             | != 0000 | 01000  | UNALLOCATED                                  |
| 0             | != 0000 | 01010  | <a href="#">SHL</a>                          |
| 0             | != 0000 | 01100  | UNALLOCATED                                  |
| 0             | != 0000 | 01110  | <a href="#">SQSHL (immediate)</a>            |
| 0             | != 0000 | 10000  | UNALLOCATED                                  |
| 0             | != 0000 | 10001  | UNALLOCATED                                  |
| 0             | != 0000 | 10010  | <a href="#">SQSHRN, SQSHRN2</a>              |
| 0             | != 0000 | 10011  | <a href="#">SQRSHRN, SQRSHRN2</a>            |
| 0             | != 0000 | 11100  | <a href="#">SCVTF (vector, fixed-point)</a>  |
| 0             | != 0000 | 11111  | <a href="#">FCVTZS (vector, fixed-point)</a> |
| 1             | != 0000 | 00000  | <a href="#">USHR</a>                         |
| 1             | != 0000 | 00010  | <a href="#">USRA</a>                         |
| 1             | != 0000 | 00100  | <a href="#">URSHR</a>                        |
| 1             | != 0000 | 00110  | <a href="#">URSRA</a>                        |

| Decode fields |         |        | Instruction Details                          |
|---------------|---------|--------|----------------------------------------------|
| U             | immh    | opcode |                                              |
| 1             | != 0000 | 01000  | <a href="#">SRI</a>                          |
| 1             | != 0000 | 01010  | <a href="#">SLI</a>                          |
| 1             | != 0000 | 01100  | <a href="#">SQSHLU</a>                       |
| 1             | != 0000 | 01110  | <a href="#">UQSHL (immediate)</a>            |
| 1             | != 0000 | 10000  | <a href="#">SQSHRUN, SQSHRUN2</a>            |
| 1             | != 0000 | 10001  | <a href="#">SQRSHRUN, SQRSHRUN2</a>          |
| 1             | != 0000 | 10010  | <a href="#">UQSHRN, UQSHRN2</a>              |
| 1             | != 0000 | 10011  | <a href="#">UQRSHRN, UQRSHRN2</a>            |
| 1             | != 0000 | 11100  | <a href="#">UCVTF (vector, fixed-point)</a>  |
| 1             | != 0000 | 11111  | <a href="#">FCVTZU (vector, fixed-point)</a> |

### Advanced SIMD scalar x indexed element

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | 1  | U  | 1  | 1  | 1  | 1  | 1  | size | L  | M  | Rm | opcode | H  | 0  | Rn |    | Rd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| 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   | <a href="#">SQDMLAL, SQDMLAL2 (by element)</a> | -       |
| 0             |      | 0111   | <a href="#">SQDMLSL, SQDMLSL2 (by element)</a> | -       |
| 0             |      | 1011   | <a href="#">SQDMULL, SQDMULL2 (by element)</a> | -       |
| 0             |      | 1100   | <a href="#">SQDMULH (by element)</a>           | -       |
| 0             |      | 1101   | <a href="#">SQRDMULH (by element)</a>          | -       |
| 0             |      | 1111   | UNALLOCATED                                    | -       |

| Decode fields |      |        | Instruction Details                                                                          | Feature   |
|---------------|------|--------|----------------------------------------------------------------------------------------------|-----------|
| U             | size | opcode |                                                                                              |           |
| 0             | 00   | 0001   | <a href="#">FMLA (by element)</a> â€“ <a href="#">half-precision</a>                         | FEAT_FP16 |
| 0             | 00   | 0101   | <a href="#">FMLS (by element)</a> â€“ <a href="#">half-precision</a>                         | FEAT_FP16 |
| 0             | 00   | 1001   | <a href="#">FMUL (by element)</a> â€“ <a href="#">half-precision</a>                         | FEAT_FP16 |
| 0             | 1x   | 0001   | <a href="#">FMLA (by element)</a> â€“ <a href="#">single-precision and double-precision</a>  | -         |
| 0             | 1x   | 0101   | <a href="#">FMLS (by element)</a> â€“ <a href="#">single-precision and double-precision</a>  | -         |
| 0             | 1x   | 1001   | <a href="#">FMUL (by element)</a> â€“ <a href="#">single-precision and double-precision</a>  | -         |
| 1             |      | 0011   | UNALLOCATED                                                                                  | -         |
| 1             |      | 0111   | UNALLOCATED                                                                                  | -         |
| 1             |      | 1011   | UNALLOCATED                                                                                  | -         |
| 1             |      | 1100   | UNALLOCATED                                                                                  | -         |
| 1             |      | 1101   | <a href="#">SQRDMLAH (by element)</a>                                                        | FEAT_RDM  |
| 1             |      | 1111   | <a href="#">SQRDMLSH (by element)</a>                                                        | FEAT_RDM  |
| 1             | 00   | 0001   | UNALLOCATED                                                                                  | -         |
| 1             | 00   | 0101   | UNALLOCATED                                                                                  | -         |
| 1             | 00   | 1001   | <a href="#">FMULX (by element)</a> â€“ <a href="#">half-precision</a>                        | FEAT_FP16 |
| 1             | 1x   | 0001   | UNALLOCATED                                                                                  | -         |
| 1             | 1x   | 0101   | UNALLOCATED                                                                                  | -         |
| 1             | 1x   | 1001   | <a href="#">FMULX (by element)</a> â€“ <a href="#">single-precision and double-precision</a> | -         |

### Advanced SIMD table lookup

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |     |    |    |    |     |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|-----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | 0  | 0  | 1  | 1  | 1  | 0  | op2 | 0  | Rm | 0  | len | op | 0  | 0  | Rn | Rd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |     |    | Instruction Details                                           |
|---------------|-----|----|---------------------------------------------------------------|
| op2           | len | op |                                                               |
| x1            |     |    | UNALLOCATED                                                   |
| 00            | 00  | 0  | <a href="#">TBL</a> â€“ <a href="#">single register table</a> |
| 00            | 00  | 1  | <a href="#">TBX</a> â€“ <a href="#">single register table</a> |
| 00            | 01  | 0  | <a href="#">TBL</a> â€“ <a href="#">two register table</a>    |
| 00            | 01  | 1  | <a href="#">TBX</a> â€“ <a href="#">two register table</a>    |

| Decode fields |     |    | Instruction Details |                      |  |  |  |  |  |  |  |  |
|---------------|-----|----|---------------------|----------------------|--|--|--|--|--|--|--|--|
| op2           | len | op |                     |                      |  |  |  |  |  |  |  |  |
| 00            | 10  | 0  | TBL                 | three register table |  |  |  |  |  |  |  |  |
| 00            | 10  | 1  | TBX                 | three register table |  |  |  |  |  |  |  |  |
| 00            | 11  | 0  | TBL                 | four register table  |  |  |  |  |  |  |  |  |
| 00            | 11  | 1  | TBX                 | four register table  |  |  |  |  |  |  |  |  |
| 1x            |     |    | UNALLOCATED         |                      |  |  |  |  |  |  |  |  |

### Advanced SIMD permute

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | 0  | 0  | 1  | 1  | 1  | 0  | size | 0  | Rm | 0  | opcode | 1  | 0  |    | Rn |    | Rd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details  |  |  |  |  |  |  |  |  |  |
|---------------|--|----------------------|--|--|--|--|--|--|--|--|--|
| opcode        |  |                      |  |  |  |  |  |  |  |  |  |
| 000           |  | UNALLOCATED          |  |  |  |  |  |  |  |  |  |
| 001           |  | <a href="#">UZP1</a> |  |  |  |  |  |  |  |  |  |
| 010           |  | <a href="#">TRN1</a> |  |  |  |  |  |  |  |  |  |
| 011           |  | <a href="#">ZIP1</a> |  |  |  |  |  |  |  |  |  |
| 100           |  | UNALLOCATED          |  |  |  |  |  |  |  |  |  |
| 101           |  | <a href="#">UZP2</a> |  |  |  |  |  |  |  |  |  |
| 110           |  | <a href="#">TRN2</a> |  |  |  |  |  |  |  |  |  |
| 111           |  | <a href="#">ZIP2</a> |  |  |  |  |  |  |  |  |  |

### Advanced SIMD extract

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |     |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-----|----|----|----|------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | 1  | 0  | 1  | 1  | 1  | 0  | op2 | 0  | Rm | 0  | imm4 | 0  | Rn |    | Rd |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |  | Instruction Details |  |  |  |  |  |  |  |  |  |
|---------------|--|---------------------|--|--|--|--|--|--|--|--|--|
| op2           |  |                     |  |  |  |  |  |  |  |  |  |
| x1            |  | UNALLOCATED         |  |  |  |  |  |  |  |  |  |
| 00            |  | <a href="#">EXT</a> |  |  |  |  |  |  |  |  |  |
| 1x            |  | UNALLOCATED         |  |  |  |  |  |  |  |  |  |

### Advanced SIMD copy

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |    |    |      |    |      |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|----|----|----|------|----|------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19 | 18   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0  | Q  | op | 0  | 1  | 1  | 1  | 0  | 0  | 0  | 0  | imm5 | 0  | imm4 | 1  | Rn |    | Rd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Q | Decode fields |       |      | Instruction Details           |
|---|---------------|-------|------|-------------------------------|
|   | op            | imm5  | imm4 |                               |
|   |               | x0000 |      | UNALLOCATED                   |
|   | 0             |       | 0000 | <a href="#">DUP (element)</a> |
|   | 0             |       | 0001 | <a href="#">DUP (general)</a> |
|   | 0             |       | 0010 | UNALLOCATED                   |
|   | 0             |       | 0100 | UNALLOCATED                   |
|   | 0             |       | 0110 | UNALLOCATED                   |
|   | 0             |       | 1xxx | UNALLOCATED                   |
| 0 | 0             |       | 0011 | UNALLOCATED                   |
| 0 | 0             |       | 0101 | <a href="#">SMOV</a>          |
| 0 | 0             |       | 0111 | <a href="#">UMOV</a>          |
| 0 | 1             |       |      | UNALLOCATED                   |
| 1 | 0             |       | 0011 | <a href="#">INS (general)</a> |
| 1 | 0             |       | 0101 | <a href="#">SMOV</a>          |
| 1 | 0             | x1000 | 0111 | <a href="#">UMOV</a>          |
| 1 | 1             |       |      | <a href="#">INS (element)</a> |

### Advanced SIMD three same (FP16)

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | U  | 0  | 1  | 1  | 1  | 0  | a  | 1  | 0  | Rm | 0  | 0  | opcode | 1  | Rn |    | Rd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| U | a | Decode fields |  | Instruction Details              | Feature   |
|---|---|---------------|--|----------------------------------|-----------|
|   |   | opcode        |  |                                  |           |
| 0 | 0 | 000           |  | <a href="#">FMAXNM (vector)</a>  | FEAT_FP16 |
| 0 | 0 | 001           |  | <a href="#">FMLA (vector)</a>    | FEAT_FP16 |
| 0 | 0 | 010           |  | <a href="#">FADD (vector)</a>    | FEAT_FP16 |
| 0 | 0 | 011           |  | <a href="#">FMULX</a>            | FEAT_FP16 |
| 0 | 0 | 100           |  | <a href="#">FCMEQ (register)</a> | FEAT_FP16 |
| 0 | 0 | 101           |  | UNALLOCATED                      | -         |
| 0 | 0 | 110           |  | <a href="#">FMAX (vector)</a>    | FEAT_FP16 |
| 0 | 0 | 111           |  | <a href="#">FRECPS</a>           | FEAT_FP16 |

| Decode fields |   |        | Instruction Details              | Feature   |
|---------------|---|--------|----------------------------------|-----------|
| U             | a | opcode |                                  |           |
| 0             | 1 | 000    | <a href="#">FMINNM (vector)</a>  | FEAT_FP16 |
| 0             | 1 | 001    | <a href="#">FMLS (vector)</a>    | FEAT_FP16 |
| 0             | 1 | 010    | <a href="#">FSUB (vector)</a>    | FEAT_FP16 |
| 0             | 1 | 011    | UNALLOCATED                      | -         |
| 0             | 1 | 100    | UNALLOCATED                      | -         |
| 0             | 1 | 101    | UNALLOCATED                      | -         |
| 0             | 1 | 110    | <a href="#">FMIN (vector)</a>    | FEAT_FP16 |
| 0             | 1 | 111    | <a href="#">FRSQRTS</a>          | FEAT_FP16 |
| 1             | 0 | 000    | <a href="#">FMAXNMP (vector)</a> | FEAT_FP16 |
| 1             | 0 | 001    | UNALLOCATED                      | -         |
| 1             | 0 | 010    | <a href="#">FADDP (vector)</a>   | FEAT_FP16 |
| 1             | 0 | 011    | <a href="#">FMUL (vector)</a>    | FEAT_FP16 |
| 1             | 0 | 100    | <a href="#">FCMGE (register)</a> | FEAT_FP16 |
| 1             | 0 | 101    | <a href="#">FACGE</a>            | FEAT_FP16 |
| 1             | 0 | 110    | <a href="#">FMAXP (vector)</a>   | FEAT_FP16 |
| 1             | 0 | 111    | <a href="#">FDIV (vector)</a>    | FEAT_FP16 |
| 1             | 1 | 000    | <a href="#">FMINNMP (vector)</a> | FEAT_FP16 |
| 1             | 1 | 001    | UNALLOCATED                      | -         |
| 1             | 1 | 010    | <a href="#">FABD</a>             | FEAT_FP16 |
| 1             | 1 | 011    | UNALLOCATED                      | -         |
| 1             | 1 | 100    | <a href="#">FCMGT (register)</a> | FEAT_FP16 |
| 1             | 1 | 101    | <a href="#">FACGT</a>            | FEAT_FP16 |
| 1             | 1 | 110    | <a href="#">FMINP (vector)</a>   | FEAT_FP16 |
| 1             | 1 | 111    | UNALLOCATED                      | -         |

### Advanced SIMD two-register miscellaneous (FP16)

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | U  | 0  | 1  | 1  | 1  | 0  | a  | 1  | 1  | 1  | 1  | 0  | 0  | opcode | 1  | 0  | Rn |    | Rd |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |        | Instruction Details | Feature |
|---------------|---|--------|---------------------|---------|
| U             | a | opcode |                     |         |
|               |   | 00xxx  | UNALLOCATED         | -       |
|               |   | 010xx  | UNALLOCATED         | -       |
|               |   | 10xxx  | UNALLOCATED         | -       |
|               |   | 11110  | UNALLOCATED         | -       |

| Decode fields |   |        | Instruction Details                      | Feature   |
|---------------|---|--------|------------------------------------------|-----------|
| U             | a | opcode |                                          |           |
|               | 0 | 011xx  | UNALLOCATED                              | -         |
|               | 0 | 11111  | UNALLOCATED                              | -         |
|               | 1 | 11100  | UNALLOCATED                              | -         |
| 0             | 0 | 11000  | <a href="#">FRINTN (vector)</a>          | FEAT_FP16 |
| 0             | 0 | 11001  | <a href="#">FRINTM (vector)</a>          | FEAT_FP16 |
| 0             | 0 | 11010  | <a href="#">FCVTNS (vector)</a>          | FEAT_FP16 |
| 0             | 0 | 11011  | <a href="#">FCVTMS (vector)</a>          | FEAT_FP16 |
| 0             | 0 | 11100  | <a href="#">FCVTAS (vector)</a>          | FEAT_FP16 |
| 0             | 0 | 11101  | <a href="#">SCVTF (vector, integer)</a>  | FEAT_FP16 |
| 0             | 1 | 01100  | <a href="#">FCMGT (zero)</a>             | FEAT_FP16 |
| 0             | 1 | 01101  | <a href="#">FCMEQ (zero)</a>             | FEAT_FP16 |
| 0             | 1 | 01110  | <a href="#">FCMLT (zero)</a>             | FEAT_FP16 |
| 0             | 1 | 01111  | <a href="#">FABS (vector)</a>            | FEAT_FP16 |
| 0             | 1 | 11000  | <a href="#">FRINTP (vector)</a>          | FEAT_FP16 |
| 0             | 1 | 11001  | <a href="#">FRINTZ (vector)</a>          | FEAT_FP16 |
| 0             | 1 | 11010  | <a href="#">FCVTPS (vector)</a>          | FEAT_FP16 |
| 0             | 1 | 11011  | <a href="#">FCVTZS (vector, integer)</a> | FEAT_FP16 |
| 0             | 1 | 11101  | <a href="#">FRECPE</a>                   | FEAT_FP16 |
| 0             | 1 | 11111  | UNALLOCATED                              | -         |
| 1             | 0 | 11000  | <a href="#">FRINTA (vector)</a>          | FEAT_FP16 |
| 1             | 0 | 11001  | <a href="#">FRINTX (vector)</a>          | FEAT_FP16 |
| 1             | 0 | 11010  | <a href="#">FCVTNU (vector)</a>          | FEAT_FP16 |
| 1             | 0 | 11011  | <a href="#">FCVTMU (vector)</a>          | FEAT_FP16 |
| 1             | 0 | 11100  | <a href="#">FCVTAU (vector)</a>          | FEAT_FP16 |
| 1             | 0 | 11101  | <a href="#">UCVTF (vector, integer)</a>  | FEAT_FP16 |
| 1             | 1 | 01100  | <a href="#">FCMGE (zero)</a>             | FEAT_FP16 |
| 1             | 1 | 01101  | <a href="#">FCMLE (zero)</a>             | FEAT_FP16 |
| 1             | 1 | 01110  | UNALLOCATED                              | -         |
| 1             | 1 | 01111  | <a href="#">FNNEG (vector)</a>           | FEAT_FP16 |
| 1             | 1 | 11000  | UNALLOCATED                              | -         |
| 1             | 1 | 11001  | <a href="#">FRINTI (vector)</a>          | FEAT_FP16 |
| 1             | 1 | 11010  | <a href="#">FCVTPU (vector)</a>          | FEAT_FP16 |
| 1             | 1 | 11011  | <a href="#">FCVTZU (vector, integer)</a> | FEAT_FP16 |
| 1             | 1 | 11101  | <a href="#">FRSQRTE</a>                  | FEAT_FP16 |
| 1             | 1 | 11111  | <a href="#">FSQRT (vector)</a>           | FEAT_FP16 |

## Advanced SIMD three-register extension

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | U  | 0  | 1  | 1  | 1  | 0  | size | 0  | Rm | 1  | opcode | 1  | Rn | Rd |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |      |        | Instruction Details                       | Feature      |
|---------------|---|------|--------|-------------------------------------------|--------------|
| Q             | U | size | opcode |                                           |              |
|               |   | 0x   | 0011   | UNALLOCATED                               | -            |
|               |   | 11   | 0011   | UNALLOCATED                               | -            |
|               | 0 |      | 0000   | UNALLOCATED                               | -            |
|               | 0 |      | 0001   | UNALLOCATED                               | -            |
|               | 0 |      | 0010   | <a href="#">SDOT (vector)</a>             | FEAT_DotProd |
|               | 0 |      | 1xxx   | UNALLOCATED                               | -            |
|               | 0 | 10   | 0011   | <a href="#">USDOT (vector)</a>            | FEAT_I8MM    |
|               | 1 |      | 0000   | <a href="#">SQRDMLAH (vector)</a>         | FEAT_RDM     |
|               | 1 |      | 0001   | <a href="#">SQRDMLSH (vector)</a>         | FEAT_RDM     |
|               | 1 |      | 0010   | <a href="#">UDOT (vector)</a>             | FEAT_DotProd |
|               | 1 |      | 10xx   | <a href="#">FCMLA</a>                     | FEAT_FCMA    |
|               | 1 |      | 11x0   | <a href="#">FCADD</a>                     | FEAT_FCMA    |
|               | 1 | 00   | 1101   | UNALLOCATED                               | -            |
|               | 1 | 00   | 1111   | UNALLOCATED                               | -            |
|               | 1 | 01   | 1111   | <a href="#">BFDOT (vector)</a>            | FEAT_BF16    |
|               | 1 | 1x   | 1101   | UNALLOCATED                               | -            |
|               | 1 | 10   | 0011   | UNALLOCATED                               | -            |
|               | 1 | 10   | 1111   | UNALLOCATED                               | -            |
|               | 1 | 11   | 1111   | <a href="#">BFMLALB, BFMLALT (vector)</a> | FEAT_BF16    |
| 0             |   |      | 01xx   | UNALLOCATED                               | -            |
| 0             | 1 | 01   | 1101   | UNALLOCATED                               | -            |
| 1             |   | 0x   | 01xx   | UNALLOCATED                               | -            |
| 1             |   | 1x   | 011x   | UNALLOCATED                               | -            |
| 1             | 0 | 10   | 0100   | <a href="#">SMMLA (vector)</a>            | FEAT_I8MM    |
| 1             | 0 | 10   | 0101   | <a href="#">USMMLA (vector)</a>           | FEAT_I8MM    |
| 1             | 1 | 01   | 1101   | <a href="#">BFMMLA</a>                    | FEAT_BF16    |
| 1             | 1 | 10   | 0100   | <a href="#">UMMLA (vector)</a>            | FEAT_I8MM    |
| 1             | 1 | 10   | 0101   | UNALLOCATED                               | -            |

### Advanced SIMD two-register miscellaneous

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |        |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|--------|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17     | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | U  | 0  | 1  | 1  | 1  | 0  | size | 1  | 0  | 0  | 0  | 0  | opcode | 1  | 0  | Rn |    | Rd |    |    |   |   |   |   |   |   |   |   |   |   |

| 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  | <a href="#">REV64</a>                   |              | -       |
| 0             |      | 00001  | <a href="#">REV16 (vector)</a>          |              | -       |
| 0             |      | 00010  | <a href="#">SADDLP</a>                  |              | -       |
| 0             |      | 00011  | <a href="#">SUQADD</a>                  |              | -       |
| 0             |      | 00100  | <a href="#">CLS (vector)</a>            |              | -       |
| 0             |      | 00101  | <a href="#">CNT</a>                     |              | -       |
| 0             |      | 00110  | <a href="#">SADALP</a>                  |              | -       |
| 0             |      | 00111  | <a href="#">SQABS</a>                   |              | -       |
| 0             |      | 01000  | <a href="#">CMGT (zero)</a>             |              | -       |
| 0             |      | 01001  | <a href="#">CMEQ (zero)</a>             |              | -       |
| 0             |      | 01010  | <a href="#">CMLT (zero)</a>             |              | -       |
| 0             |      | 01011  | <a href="#">ABS</a>                     |              | -       |
| 0             |      | 10010  | <a href="#">XTN, XTN2</a>               |              | -       |
| 0             |      | 10011  | UNALLOCATED                             |              | -       |
| 0             |      | 10100  | <a href="#">SQXTN, SQXTN2</a>           |              | -       |
| 0             | 0x   | 10110  | <a href="#">FCVTN, FCVTN2</a>           |              | -       |
| 0             | 0x   | 10111  | <a href="#">FCVTL, FCVTL2</a>           |              | -       |
| 0             | 0x   | 11000  | <a href="#">FRINTN (vector)</a>         |              | -       |
| 0             | 0x   | 11001  | <a href="#">FRINTM (vector)</a>         |              | -       |
| 0             | 0x   | 11010  | <a href="#">FCVTNS (vector)</a>         |              | -       |
| 0             | 0x   | 11011  | <a href="#">FCVTMS (vector)</a>         |              | -       |
| 0             | 0x   | 11100  | <a href="#">FCVTAS (vector)</a>         |              | -       |
| 0             | 0x   | 11101  | <a href="#">SCVTF (vector, integer)</a> |              | -       |
| 0             | 0x   | 11110  | <a href="#">FRINT32Z (vector)</a>       | FEAT_FRINTTS |         |
| 0             | 0x   | 11111  | <a href="#">FRINT64Z (vector)</a>       | FEAT_FRINTTS |         |
| 0             | 1x   | 01100  | <a href="#">FCMGT (zero)</a>            | -            |         |
| 0             | 1x   | 01101  | <a href="#">FCMEQ (zero)</a>            | -            |         |
| 0             | 1x   | 01110  | <a href="#">FCMLT (zero)</a>            | -            |         |
| 0             | 1x   | 01111  | <a href="#">FABS (vector)</a>           | -            |         |

| Decode fields |      |        | Instruction Details                      | Feature      |
|---------------|------|--------|------------------------------------------|--------------|
| U             | size | opcode |                                          |              |
| 0             | 1x   | 11000  | <a href="#">FRINTP (vector)</a>          | -            |
| 0             | 1x   | 11001  | <a href="#">FRINTZ (vector)</a>          | -            |
| 0             | 1x   | 11010  | <a href="#">FCVTPS (vector)</a>          | -            |
| 0             | 1x   | 11011  | <a href="#">FCVTZS (vector, integer)</a> | -            |
| 0             | 1x   | 11100  | <a href="#">URECPE</a>                   | -            |
| 0             | 1x   | 11101  | <a href="#">FRECPE</a>                   | -            |
| 0             | 1x   | 11111  | UNALLOCATED                              | -            |
| 0             | 10   | 10110  | <a href="#">BFCVTN, BFCVTN2</a>          | FEAT_BF16    |
| 1             |      | 00000  | <a href="#">REV32 (vector)</a>           | -            |
| 1             |      | 00001  | UNALLOCATED                              | -            |
| 1             |      | 00010  | <a href="#">UADDLP</a>                   | -            |
| 1             |      | 00011  | <a href="#">USQADD</a>                   | -            |
| 1             |      | 00100  | <a href="#">CLZ (vector)</a>             | -            |
| 1             |      | 00110  | <a href="#">UADALP</a>                   | -            |
| 1             |      | 00111  | <a href="#">SQNEG</a>                    | -            |
| 1             |      | 01000  | <a href="#">CMGE (zero)</a>              | -            |
| 1             |      | 01001  | <a href="#">CMLE (zero)</a>              | -            |
| 1             |      | 01010  | UNALLOCATED                              | -            |
| 1             |      | 01011  | <a href="#">NEG (vector)</a>             | -            |
| 1             |      | 10010  | <a href="#">SQXTUN, SQXTUN2</a>          | -            |
| 1             |      | 10011  | <a href="#">SHLL, SHLL2</a>              | -            |
| 1             |      | 10100  | <a href="#">UQXTN, UQXTN2</a>            | -            |
| 1             | 0x   | 10110  | <a href="#">FCVTXN, FCVTXN2</a>          | -            |
| 1             | 0x   | 10111  | UNALLOCATED                              | -            |
| 1             | 0x   | 11000  | <a href="#">FRINTA (vector)</a>          | -            |
| 1             | 0x   | 11001  | <a href="#">FRINTX (vector)</a>          | -            |
| 1             | 0x   | 11010  | <a href="#">FCVTNU (vector)</a>          | -            |
| 1             | 0x   | 11011  | <a href="#">FCVTMU (vector)</a>          | -            |
| 1             | 0x   | 11100  | <a href="#">FCVTAU (vector)</a>          | -            |
| 1             | 0x   | 11101  | <a href="#">UCVTF (vector, integer)</a>  | -            |
| 1             | 0x   | 11110  | <a href="#">FRINT32X (vector)</a>        | FEAT_FRINTTS |
| 1             | 0x   | 11111  | <a href="#">FRINT64X (vector)</a>        | FEAT_FRINTTS |
| 1             | 00   | 00101  | <a href="#">NOT</a>                      | -            |
| 1             | 01   | 00101  | <a href="#">RBIT (vector)</a>            | -            |
| 1             | 1x   | 00101  | UNALLOCATED                              | -            |
| 1             | 1x   | 01100  | <a href="#">FCMGE (zero)</a>             | -            |
| 1             | 1x   | 01101  | <a href="#">FCMLE (zero)</a>             | -            |
| 1             | 1x   | 01110  | UNALLOCATED                              | -            |

| Decode fields |      |        | Instruction Details                      | Feature |
|---------------|------|--------|------------------------------------------|---------|
| U             | size | opcode |                                          |         |
| 1             | 1x   | 01111  | <a href="#">FNEG (vector)</a>            | -       |
| 1             | 1x   | 11000  | UNALLOCATED                              | -       |
| 1             | 1x   | 11001  | <a href="#">FRINTI (vector)</a>          | -       |
| 1             | 1x   | 11010  | <a href="#">FCVTPU (vector)</a>          | -       |
| 1             | 1x   | 11011  | <a href="#">FCVTZU (vector, integer)</a> | -       |
| 1             | 1x   | 11100  | <a href="#">URSQRTE</a>                  | -       |
| 1             | 1x   | 11101  | <a href="#">FRSQRTE</a>                  | -       |
| 1             | 1x   | 11111  | <a href="#">FSQRT (vector)</a>           | -       |
| 1             | 10   | 10110  | UNALLOCATED                              | -       |

### Advanced SIMD across lanes

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |    |    |    |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|----|----|----|----|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | U  | 0  | 1  | 1  | 1  | 0  | size | 1  | 1  | 0  | 0  | 0  | 0  | opcode | 1  | 0  | Rn |    | Rd |    |   |   |   |   |   |   |   |   |   |   |

| 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  | <a href="#">SADDLV</a>                     | -         |
| 0             |      | 01010  | <a href="#">SMAXV</a>                      | -         |
| 0             |      | 11010  | <a href="#">SMINV</a>                      | -         |
| 0             |      | 11011  | <a href="#">ADDV</a>                       | -         |
| 0             | 00   | 01100  | <a href="#">FMAXNMV</a> â€“ half-precision | FEAT_FP16 |
| 0             | 00   | 01111  | <a href="#">FMAXV</a> â€“ half-precision   | FEAT_FP16 |
| 0             | 01   | 01100  | UNALLOCATED                                | -         |
| 0             | 01   | 01111  | UNALLOCATED                                | -         |
| 0             | 10   | 01100  | <a href="#">FMINNMV</a> â€“ half-precision | FEAT_FP16 |

| Decode fields |      |        | Instruction Details                                                                               | Feature   |
|---------------|------|--------|---------------------------------------------------------------------------------------------------|-----------|
| U             | size | opcode |                                                                                                   |           |
| 0             | 10   | 01111  | <a href="#">FMINV</a> â€“ <a href="#">half-precision</a>                                          | FEAT_FP16 |
| 0             | 11   | 01100  | UNALLOCATED                                                                                       | -         |
| 0             | 11   | 01111  | UNALLOCATED                                                                                       | -         |
| 1             |      | 00011  | <a href="#">UADDLV</a>                                                                            | -         |
| 1             |      | 01010  | <a href="#">UMAXV</a>                                                                             | -         |
| 1             |      | 11010  | <a href="#">UMINV</a>                                                                             | -         |
| 1             |      | 11011  | UNALLOCATED                                                                                       | -         |
| 1             | 0x   | 01100  | <a href="#">FMAXNMV</a> â€“ <a href="#">single-precision</a> and <a href="#">double-precision</a> | -         |
| 1             | 0x   | 01111  | <a href="#">FMAXV</a> â€“ <a href="#">single-precision</a> and <a href="#">double-precision</a>   | -         |
| 1             | 1x   | 01100  | <a href="#">FMINNMV</a> â€“ <a href="#">single-precision</a> and <a href="#">double-precision</a> | -         |
| 1             | 1x   | 01111  | <a href="#">FMINV</a> â€“ <a href="#">single-precision</a> and <a href="#">double-precision</a>   | -         |

### Advanced SIMD three different

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |        |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|------|----|----|--------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20     | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 0  | Q  | U  | 0  | 1  | 1  | 1  | 0  | size | 1  | Rm | opcode | 0  | 0  | Rn | Rd |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |

| Decode fields |        | Instruction Details                        |
|---------------|--------|--------------------------------------------|
| U             | opcode |                                            |
|               | 1111   | UNALLOCATED                                |
| 0             | 0000   | <a href="#">SADDL, SADDL2</a>              |
| 0             | 0001   | <a href="#">SADDW, SADDW2</a>              |
| 0             | 0010   | <a href="#">SSUBL, SSUBL2</a>              |
| 0             | 0011   | <a href="#">SSUBW, SSUBW2</a>              |
| 0             | 0100   | <a href="#">ADDHN, ADDHN2</a>              |
| 0             | 0101   | <a href="#">SABAL, SABAL2</a>              |
| 0             | 0110   | <a href="#">SUBHN, SUBHN2</a>              |
| 0             | 0111   | <a href="#">SABDL, SABDL2</a>              |
| 0             | 1000   | <a href="#">SMLAL, SMLAL2 (vector)</a>     |
| 0             | 1001   | <a href="#">SQDMLAL, SQDMLAL2 (vector)</a> |
| 0             | 1010   | <a href="#">SMLS1, SMLS12 (vector)</a>     |
| 0             | 1011   | <a href="#">SQDMLSL, SQDMLSL2 (vector)</a> |
| 0             | 1100   | <a href="#">SMULL, SMULL2 (vector)</a>     |
| 0             | 1101   | <a href="#">SQDMULL, SQDMULL2 (vector)</a> |

| Decode fields |        | Instruction Details                    |
|---------------|--------|----------------------------------------|
| U             | opcode |                                        |
| 0             | 1110   | <a href="#">PMULL, PMULL2</a>          |
| 1             | 0000   | <a href="#">UADDL, UADDL2</a>          |
| 1             | 0001   | <a href="#">UADDW, UADDW2</a>          |
| 1             | 0010   | <a href="#">USUBL, USUBL2</a>          |
| 1             | 0011   | <a href="#">USUBW, USUBW2</a>          |
| 1             | 0100   | <a href="#">RADDHN, RADDHN2</a>        |
| 1             | 0101   | <a href="#">UABAL, UABAL2</a>          |
| 1             | 0110   | <a href="#">RSUBHN, RSUBHN2</a>        |
| 1             | 0111   | <a href="#">UABDL, UABDL2</a>          |
| 1             | 1000   | <a href="#">UMLAL, UMLAL2 (vector)</a> |
| 1             | 1001   | UNALLOCATED                            |
| 1             | 1010   | <a href="#">UMLSL, UMLSL2 (vector)</a> |
| 1             | 1011   | UNALLOCATED                            |
| 1             | 1100   | <a href="#">UMULL, UMULL2 (vector)</a> |
| 1             | 1101   | UNALLOCATED                            |
| 1             | 1110   | UNALLOCATED                            |

### Advanced SIMD three same

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |        |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|------|----|----|--------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20     | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0  | Q  | U  | 0  | 1  | 1  | 1  | 0  | size | 1  | Rm | opcode | 1  | Rn | Rd |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |      |        | Instruction Details              | Feature |
|---------------|------|--------|----------------------------------|---------|
| U             | size | opcode |                                  |         |
| 0             |      | 00000  | <a href="#">SHADD</a>            | -       |
| 0             |      | 00001  | <a href="#">SQADD</a>            | -       |
| 0             |      | 00010  | <a href="#">SRHADD</a>           | -       |
| 0             |      | 00100  | <a href="#">SHSUB</a>            | -       |
| 0             |      | 00101  | <a href="#">SQSUB</a>            | -       |
| 0             |      | 00110  | <a href="#">CMGT (register)</a>  | -       |
| 0             |      | 00111  | <a href="#">CMGE (register)</a>  | -       |
| 0             |      | 01000  | <a href="#">SSH</a>              | -       |
| 0             |      | 01001  | <a href="#">SQSHL (register)</a> | -       |
| 0             |      | 01010  | <a href="#">SRSHL</a>            | -       |
| 0             |      | 01011  | <a href="#">SQRSHL</a>           | -       |
| 0             |      | 01100  | <a href="#">SMAX</a>             | -       |

| Decode fields |      |        | Instruction Details                                              | Feature  |
|---------------|------|--------|------------------------------------------------------------------|----------|
| U             | size | opcode |                                                                  |          |
| 0             |      | 01101  | <a href="#">SMIN</a>                                             | -        |
| 0             |      | 01110  | <a href="#">SABD</a>                                             | -        |
| 0             |      | 01111  | <a href="#">SABA</a>                                             | -        |
| 0             |      | 10000  | <a href="#">ADD (vector)</a>                                     | -        |
| 0             |      | 10001  | <a href="#">CMTST</a>                                            | -        |
| 0             |      | 10010  | <a href="#">MLA (vector)</a>                                     | -        |
| 0             |      | 10011  | <a href="#">MUL (vector)</a>                                     | -        |
| 0             |      | 10100  | <a href="#">SMAXP</a>                                            | -        |
| 0             |      | 10101  | <a href="#">SMINP</a>                                            | -        |
| 0             |      | 10110  | <a href="#">SQDMULH (vector)</a>                                 | -        |
| 0             |      | 10111  | <a href="#">ADDP (vector)</a>                                    | -        |
| 0             | 0x   | 11000  | <a href="#">FMAXNM (vector)</a>                                  | -        |
| 0             | 0x   | 11001  | <a href="#">FMLA (vector)</a>                                    | -        |
| 0             | 0x   | 11010  | <a href="#">FADD (vector)</a>                                    | -        |
| 0             | 0x   | 11011  | <a href="#">FMULX</a>                                            | -        |
| 0             | 0x   | 11100  | <a href="#">FCMEO (register)</a>                                 | -        |
| 0             | 0x   | 11110  | <a href="#">FMAX (vector)</a>                                    | -        |
| 0             | 0x   | 11111  | <a href="#">FRECPS</a>                                           | -        |
| 0             | 00   | 00011  | <a href="#">AND (vector)</a>                                     | -        |
| 0             | 00   | 11101  | <a href="#">FMLAL, FMLAL2 (vector)</a> â€“ <a href="#">FMLAL</a> | FEAT_FHM |
| 0             | 01   | 00011  | <a href="#">BIC (vector, register)</a>                           | -        |
| 0             | 01   | 11101  | UNALLOCATED                                                      | -        |
| 0             | 1x   | 11000  | <a href="#">FMINNM (vector)</a>                                  | -        |
| 0             | 1x   | 11001  | <a href="#">FMLS (vector)</a>                                    | -        |
| 0             | 1x   | 11010  | <a href="#">FSUB (vector)</a>                                    | -        |
| 0             | 1x   | 11011  | UNALLOCATED                                                      | -        |
| 0             | 1x   | 11100  | UNALLOCATED                                                      | -        |
| 0             | 1x   | 11110  | <a href="#">FMIN (vector)</a>                                    | -        |
| 0             | 1x   | 11111  | <a href="#">FRSQRTS</a>                                          | -        |
| 0             | 10   | 00011  | <a href="#">ORR (vector, register)</a>                           | -        |
| 0             | 10   | 11101  | <a href="#">FMLS, FMLS2 (vector)</a> â€“ <a href="#">FMLS</a>    | FEAT_FHM |
| 0             | 11   | 00011  | <a href="#">ORN (vector)</a>                                     | -        |
| 0             | 11   | 11101  | UNALLOCATED                                                      | -        |
| 1             |      | 00000  | <a href="#">UHADD</a>                                            | -        |
| 1             |      | 00001  | <a href="#">UQADD</a>                                            | -        |
| 1             |      | 00010  | <a href="#">URHADD</a>                                           | -        |
| 1             |      | 00100  | <a href="#">UHSUB</a>                                            | -        |

| Decode fields |      |        | Instruction Details                                                  | Feature  |
|---------------|------|--------|----------------------------------------------------------------------|----------|
| U             | size | opcode |                                                                      |          |
| 1             |      | 00101  | <a href="#">UQSUB</a>                                                | -        |
| 1             |      | 00110  | <a href="#">CMHI (register)</a>                                      | -        |
| 1             |      | 00111  | <a href="#">CMHS (register)</a>                                      | -        |
| 1             |      | 01000  | <a href="#">USHL</a>                                                 | -        |
| 1             |      | 01001  | <a href="#">UQSHL (register)</a>                                     | -        |
| 1             |      | 01010  | <a href="#">URSHL</a>                                                | -        |
| 1             |      | 01011  | <a href="#">UQRSHL</a>                                               | -        |
| 1             |      | 01100  | <a href="#">UMAX</a>                                                 | -        |
| 1             |      | 01101  | <a href="#">UMIN</a>                                                 | -        |
| 1             |      | 01110  | <a href="#">UABD</a>                                                 | -        |
| 1             |      | 01111  | <a href="#">UABA</a>                                                 | -        |
| 1             |      | 10000  | <a href="#">SUB (vector)</a>                                         | -        |
| 1             |      | 10001  | <a href="#">CMEQ (register)</a>                                      | -        |
| 1             |      | 10010  | <a href="#">MLS (vector)</a>                                         | -        |
| 1             |      | 10011  | <a href="#">PMUL</a>                                                 | -        |
| 1             |      | 10100  | <a href="#">UMAXP</a>                                                | -        |
| 1             |      | 10101  | <a href="#">UMINP</a>                                                | -        |
| 1             |      | 10110  | <a href="#">SQRDMDLH (vector)</a>                                    | -        |
| 1             |      | 10111  | UNALLOCATED                                                          | -        |
| 1             | 0x   | 11000  | <a href="#">FMAXNMP (vector)</a>                                     | -        |
| 1             | 0x   | 11010  | <a href="#">FADDP (vector)</a>                                       | -        |
| 1             | 0x   | 11011  | <a href="#">FMUL (vector)</a>                                        | -        |
| 1             | 0x   | 11100  | <a href="#">FCMGE (register)</a>                                     | -        |
| 1             | 0x   | 11101  | <a href="#">FACGE</a>                                                | -        |
| 1             | 0x   | 11110  | <a href="#">FMAXP (vector)</a>                                       | -        |
| 1             | 0x   | 11111  | <a href="#">FDIV (vector)</a>                                        | -        |
| 1             | 00   | 00011  | <a href="#">EOR (vector)</a>                                         | -        |
| 1             | 00   | 11001  | <a href="#">FMLAL, FMLAL2 (vector)</a> â€”<br><a href="#">FMLAL2</a> | FEAT_FHM |
| 1             | 01   | 00011  | <a href="#">BSL</a>                                                  | -        |
| 1             | 01   | 11001  | UNALLOCATED                                                          | -        |
| 1             | 1x   | 11000  | <a href="#">FMINNMP (vector)</a>                                     | -        |
| 1             | 1x   | 11010  | <a href="#">FABD</a>                                                 | -        |
| 1             | 1x   | 11011  | UNALLOCATED                                                          | -        |
| 1             | 1x   | 11100  | <a href="#">FCMGT (register)</a>                                     | -        |
| 1             | 1x   | 11101  | <a href="#">FACGT</a>                                                | -        |
| 1             | 1x   | 11110  | <a href="#">FMINP (vector)</a>                                       | -        |
| 1             | 1x   | 11111  | UNALLOCATED                                                          | -        |

| Decode fields |      |        | Instruction Details                                                             | Feature  |
|---------------|------|--------|---------------------------------------------------------------------------------|----------|
| U             | size | opcode |                                                                                 |          |
| 1             | 10   | 00011  | <a href="#">BIT</a>                                                             | -        |
| 1             | 10   | 11001  | <a href="#">FMLS</a> , <a href="#">FMLS2 (vector)</a> â€“ <a href="#">FMLS2</a> | FEAT_FHM |
| 1             | 11   | 00011  | <a href="#">BIF</a>                                                             | -        |
| 1             | 11   | 11001  | UNALLOCATED                                                                     | -        |

### Advanced SIMD modified immediate

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16    | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 0  | Q  | op | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  | a  | b  | c  | cmode | o2 | 1  | d  | e  | f  | g  | h | Rd |   |   |   |   |   |   |   |   |  |  |

| Decode fields |    |       | Instruction Details | Feature                                                                       |           |
|---------------|----|-------|---------------------|-------------------------------------------------------------------------------|-----------|
| Q             | op | cmode | o2                  |                                                                               |           |
|               | 0  | 0xxx  | 1                   | UNALLOCATED                                                                   | -         |
|               | 0  | 0xx0  | 0                   | <a href="#">MOVI</a> â€“ <a href="#">32-bit shifted immediate</a>             | -         |
|               | 0  | 0xx1  | 0                   | <a href="#">ORR (vector, immediate)</a> â€“ <a href="#">32-bit</a>            | -         |
|               | 0  | 10xx  | 1                   | UNALLOCATED                                                                   | -         |
|               | 0  | 10x0  | 0                   | <a href="#">MOVI</a> â€“ <a href="#">16-bit shifted immediate</a>             | -         |
|               | 0  | 10x1  | 0                   | <a href="#">ORR (vector, immediate)</a> â€“ <a href="#">16-bit</a>            | -         |
|               | 0  | 110x  | 0                   | <a href="#">MOVI</a> â€“ <a href="#">32-bit shifting ones</a>                 | -         |
|               | 0  | 110x  | 1                   | UNALLOCATED                                                                   | -         |
|               | 0  | 1110  | 0                   | <a href="#">MOVI</a> â€“ <a href="#">8-bit</a>                                | -         |
|               | 0  | 1110  | 1                   | UNALLOCATED                                                                   | -         |
|               | 0  | 1111  | 0                   | <a href="#">FMOV (vector, immediate)</a> â€“ <a href="#">single-precision</a> | -         |
|               | 0  | 1111  | 1                   | <a href="#">FMOV (vector, immediate)</a> â€“ <a href="#">half-precision</a>   | FEAT_FP16 |
|               | 1  |       | 1                   | UNALLOCATED                                                                   | -         |
|               | 1  | 0xx0  | 0                   | <a href="#">MVNI</a> â€“ <a href="#">32-bit shifted immediate</a>             | -         |
|               | 1  | 0xx1  | 0                   | <a href="#">BIC (vector, immediate)</a> â€“ <a href="#">32-bit</a>            | -         |
|               | 1  | 10x0  | 0                   | <a href="#">MVNI</a> â€“ <a href="#">16-bit shifted immediate</a>             | -         |
|               | 1  | 10x1  | 0                   | <a href="#">BIC (vector, immediate)</a> â€“ <a href="#">16-bit</a>            | -         |

| Decode fields |    |       |    | Instruction Details                                              | Feature |
|---------------|----|-------|----|------------------------------------------------------------------|---------|
| Q             | op | cmode | o2 |                                                                  |         |
|               | 1  | 110x  | 0  | <a href="#">MVNI</a> â€“ 32-bit shifting ones                    | -       |
| 0             | 1  | 1110  | 0  | <a href="#">MOVI</a> â€“ 64-bit scalar                           | -       |
| 0             | 1  | 1111  | 0  | UNALLOCATED                                                      | -       |
| 1             | 1  | 1110  | 0  | <a href="#">MOVI</a> â€“ 64-bit vector                           | -       |
| 1             | 1  | 1111  | 0  | <a href="#">FMOV</a> (vector, immediate)<br>â€“ double-precision | -       |

### Advanced SIMD shift by immediate

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |         |      |      |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |
|----|----|----|----|----|----|----|----|----|---------|------|------|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22      | 21   | 20   | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| 0  | Q  | U  | 0  | 1  | 1  | 1  | 1  | 0  | != 0000 | immh | immb | opcode | 1  | Rn |    | Rd |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |

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  | <a href="#">SSHR</a>  |
| 0             | 00010  | <a href="#">SSRA</a>  |
| 0             | 00100  | <a href="#">SRSHR</a> |
| 0             | 00110  | <a href="#">SRSRA</a> |
| 0             | 01000  | UNALLOCATED           |
| 0             | 01010  | <a href="#">SHL</a>   |

| Decode fields |        | Instruction Details                          |
|---------------|--------|----------------------------------------------|
| U             | opcode |                                              |
| 0             | 01100  | UNALLOCATED                                  |
| 0             | 01110  | <a href="#">SQSHL (immediate)</a>            |
| 0             | 10000  | <a href="#">SHRN, SHRN2</a>                  |
| 0             | 10001  | <a href="#">RSHRN, RSHRN2</a>                |
| 0             | 10010  | <a href="#">SQSHRN, SQSHRN2</a>              |
| 0             | 10011  | <a href="#">SQRSHRN, SQRSHRN2</a>            |
| 0             | 10100  | <a href="#">SSHLL, SSHLL2</a>                |
| 0             | 11100  | <a href="#">SCVTF (vector, fixed-point)</a>  |
| 0             | 11111  | <a href="#">FCVTZS (vector, fixed-point)</a> |
| 1             | 00000  | <a href="#">USHR</a>                         |
| 1             | 00010  | <a href="#">USRA</a>                         |
| 1             | 00100  | <a href="#">URSHR</a>                        |
| 1             | 00110  | <a href="#">URSRA</a>                        |
| 1             | 01000  | <a href="#">SRI</a>                          |
| 1             | 01010  | <a href="#">SLI</a>                          |
| 1             | 01100  | <a href="#">SQSHLU</a>                       |
| 1             | 01110  | <a href="#">UQSHL (immediate)</a>            |
| 1             | 10000  | <a href="#">SQSHRUN, SQSHRUN2</a>            |
| 1             | 10001  | <a href="#">SQRSHRUN, SQRSHRUN2</a>          |
| 1             | 10010  | <a href="#">UQSHRN, UQSHRN2</a>              |
| 1             | 10011  | <a href="#">UQRSHRN, UQRSHRN2</a>            |
| 1             | 10100  | <a href="#">USHLL, USHLL2</a>                |
| 1             | 11100  | <a href="#">UCVTF (vector, fixed-point)</a>  |
| 1             | 11111  | <a href="#">FCVTZU (vector, fixed-point)</a> |

### Advanced SIMD vector x indexed element

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |      |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|----|----|----|----|----|----|----|----|------|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| 0  | Q  | U  | 0  | 1  | 1  | 1  | 1  | size | L  | M  | Rm | opcode | H  | 0  | Rn | Rd |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| Decode fields |      |        | Instruction Details                            | Feature |
|---------------|------|--------|------------------------------------------------|---------|
| U             | size | opcode |                                                |         |
|               | 01   | 1001   | UNALLOCATED                                    | -       |
| 0             |      | 0010   | <a href="#">SMLAL, SMLAL2 (by element)</a>     | -       |
| 0             |      | 0011   | <a href="#">SQDMLAL, SQDMLAL2 (by element)</a> | -       |
| 0             |      | 0110   | <a href="#">SMLSL, SMLSL2 (by element)</a>     | -       |

| Decode fields |      |        | Instruction Details                                                         | Feature      |
|---------------|------|--------|-----------------------------------------------------------------------------|--------------|
| U             | size | opcode |                                                                             |              |
| 0             |      | 0111   | <a href="#">SQDMLSL, SQDMLSL2 (by element)</a>                              | -            |
| 0             |      | 1000   | <a href="#">MUL (by element)</a>                                            | -            |
| 0             |      | 1010   | <a href="#">SMULL, SMULL2 (by element)</a>                                  | -            |
| 0             |      | 1011   | <a href="#">SQDMULL, SQDMULL2 (by element)</a>                              | -            |
| 0             |      | 1100   | <a href="#">SQDMULH (by element)</a>                                        | -            |
| 0             |      | 1101   | <a href="#">SORDMULH (by element)</a>                                       | -            |
| 0             |      | 1110   | <a href="#">SDOT (by element)</a>                                           | FEAT_DotProd |
| 0             | 0x   | 0000   | UNALLOCATED                                                                 | -            |
| 0             | 0x   | 0100   | UNALLOCATED                                                                 | -            |
| 0             | 00   | 0001   | <a href="#">FMLA (by element) â€“ half-precision</a>                        | FEAT_FP16    |
| 0             | 00   | 0101   | <a href="#">FMLS (by element) â€“ half-precision</a>                        | FEAT_FP16    |
| 0             | 00   | 1001   | <a href="#">FMUL (by element) â€“ half-precision</a>                        | FEAT_FP16    |
| 0             | 00   | 1111   | <a href="#">SUDOT (by element)</a>                                          | FEAT_I8MM    |
| 0             | 01   | 0001   | UNALLOCATED                                                                 | -            |
| 0             | 01   | 0101   | UNALLOCATED                                                                 | -            |
| 0             | 01   | 1111   | <a href="#">BFDOT (by element)</a>                                          | FEAT_BF16    |
| 0             | 1x   | 0001   | <a href="#">FMLA (by element) â€“ single-precision and double-precision</a> | -            |
| 0             | 1x   | 0101   | <a href="#">FMLS (by element) â€“ single-precision and double-precision</a> | -            |
| 0             | 1x   | 1001   | <a href="#">FMUL (by element) â€“ single-precision and double-precision</a> | -            |
| 0             | 10   | 0000   | <a href="#">FMLAL, FMLAL2 (by element)<br/>â€“ <a href="#">FMLAL</a></a>    | FEAT_FHM     |
| 0             | 10   | 0100   | <a href="#">FMLSL, FMLSL2 (by element)<br/>â€“ <a href="#">FMLSL</a></a>    | FEAT_FHM     |
| 0             | 10   | 1111   | <a href="#">USDOT (by element)</a>                                          | FEAT_I8MM    |
| 0             | 11   | 0000   | UNALLOCATED                                                                 | -            |
| 0             | 11   | 0100   | UNALLOCATED                                                                 | -            |
| 0             | 11   | 1111   | <a href="#">BFMLALB, BFMLALT (by element)</a>                               | FEAT_BF16    |
| 1             |      | 0000   | <a href="#">MLA (by element)</a>                                            | -            |
| 1             |      | 0010   | <a href="#">UMLAL, UMLAL2 (by element)</a>                                  | -            |
| 1             |      | 0100   | <a href="#">MLS (by element)</a>                                            | -            |
| 1             |      | 0110   | <a href="#">UMLSL, UMLSL2 (by element)</a>                                  | -            |
| 1             |      | 1010   | <a href="#">UMULL, UMULL2 (by element)</a>                                  | -            |

| Decode fields |      |        | Instruction Details                                                                          | Feature      |
|---------------|------|--------|----------------------------------------------------------------------------------------------|--------------|
| U             | size | opcode |                                                                                              |              |
| 1             |      | 1011   | UNALLOCATED                                                                                  | -            |
| 1             |      | 1101   | <a href="#">SQRDMLAH (by element)</a>                                                        | FEAT_RDM     |
| 1             |      | 1110   | <a href="#">UDOT (by element)</a>                                                            | FEAT_DotProd |
| 1             |      | 1111   | <a href="#">SQRDMLSH (by element)</a>                                                        | 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   | <a href="#">FMULX (by element)</a> â€“ <a href="#">half-precision</a>                        | FEAT_FP16    |
| 1             | 01   | 0xx1   | <a href="#">FCMLA (by element)</a>                                                           | FEAT_FCMA    |
| 1             | 1x   | 1001   | <a href="#">FMULX (by element)</a> â€“ <a href="#">single-precision and double-precision</a> | -            |
| 1             | 10   | 0xx1   | <a href="#">FCMLA (by element)</a>                                                           | FEAT_FCMA    |
| 1             | 10   | 1000   | <a href="#">FMLAL, FMLAL2 (by element)</a> â€“ <a href="#">FMLAL2</a>                        | FEAT_FHM     |
| 1             | 10   | 1100   | <a href="#">FMLS, FMLS2 (by element)</a> â€“ <a href="#">FMLS2</a>                           | FEAT_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](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 1  | 0  | Rm | 1  | 0  | imm2 | opcode | Rn |    | Rd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |        | Instruction Details     | Feature  |
|---------------|--------|-------------------------|----------|
|               | opcode |                         |          |
|               | 00     | <a href="#">SM3TT1A</a> | FEAT_SM3 |
|               | 01     | <a href="#">SM3TT1B</a> | FEAT_SM3 |
|               | 10     | <a href="#">SM3TT2A</a> | FEAT_SM3 |

| <b>Decode fields<br/>opcode</b> | <b>Instruction Details</b> | <b>Feature</b> |
|---------------------------------|----------------------------|----------------|
| 11                              | <a href="#">SM3TT2B</a>    | FEAT_SM3       |

---

### Cryptographic three-register SHA 512

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |   |   |   |   |   |   |    |   |   |   |  |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|---|---|---|---|---|---|----|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1 | 0 |  |
| 1  | 1  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 1  | 1  | Rm | 1  | 0  | 0  | 0  | opcode | Rn |    |    |    |    |   |   |   |   |   |   | Rd |   |   |   |  |

| <b>Decode fields<br/>O<br/>opcode</b> | <b>Instruction Details</b> | <b>Feature</b> |
|---------------------------------------|----------------------------|----------------|
| 0                                     | <a href="#">SHA512H</a>    | FEAT_SHA512    |
| 0                                     | <a href="#">SHA512H2</a>   | FEAT_SHA512    |
| 0                                     | <a href="#">SHA512SU1</a>  | FEAT_SHA512    |
| 0                                     | <a href="#">RAX1</a>       | FEAT_SHA3      |
| 1                                     | <a href="#">SM3PARTW1</a>  | FEAT_SM3       |
| 1                                     | <a href="#">SM3PARTW2</a>  | FEAT_SM3       |
| 1                                     | <a href="#">SM4EKEY</a>    | FEAT_SM4       |
| 1                                     | UNALLOCATED                | -              |

---

### Cryptographic four-register

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | Op0 |    | Rm | 0  |    | Ra |    | Rn |    | Rd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| <b>Decode fields<br/>Op0</b> | <b>Instruction Details</b> | <b>Feature</b> |
|------------------------------|----------------------------|----------------|
| 00                           | <a href="#">FOR3</a>       | FEAT_SHA3      |
| 01                           | <a href="#">BCAX</a>       | FEAT_SHA3      |
| 10                           | <a href="#">SM3SS1</a>     | FEAT_SM3       |
| 11                           | UNALLOCATED                | -              |

---

### Cryptographic two-register SHA 512

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |   |    |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|---|----|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10     | 9  | 8 | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | opcode | Rn |   | Rd |   |   |   |   |   |   |   |

### Decode fields opcode

### Instruction Details

### Feature

|    |                           |             |
|----|---------------------------|-------------|
| 00 | <a href="#">SHA512SU0</a> | FEAT_SHA512 |
| 01 | <a href="#">SM4E</a>      | FEAT_SM4    |
| 1x | UNALLOCATED               | -           |

### Conversion between floating-point and fixed-point

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |       |    |       |        |    |       |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-------|----|-------|--------|----|-------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21    | 20     | 19 | 18    | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| sf | 0  | S  | 1  | 1  | 1  | 1  | 0  | ftype | 0  | rmode | opcode |    | scale |    |    | Rn |    | Rd |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |       |       |        |        | Instruction Details                                                         | Feature |
|---------------|---|-------|-------|--------|--------|-----------------------------------------------------------------------------|---------|
| sf            | S | ftype | 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    |        | <a href="#">SCVTF (scalar, fixed-point) â€“ 32-bit to single-precision</a>  | -       |
| 0             | 0 | 00    | 00    | 011    |        | <a href="#">UCVTF (scalar, fixed-point) â€“ 32-bit to single-precision</a>  | -       |
| 0             | 0 | 00    | 11    | 000    |        | <a href="#">FCVTZS (scalar, fixed-point) â€“ single-precision to 32-bit</a> | -       |
| 0             | 0 | 00    | 11    | 001    |        | <a href="#">FCVTZU (scalar, fixed-point) â€“ single-precision to 32-bit</a> | -       |

| Decode fields |   |        |       |        |       | Instruction Details                                                         | Feature   |
|---------------|---|--------|-------|--------|-------|-----------------------------------------------------------------------------|-----------|
| sf            | S | fptype | rmode | opcode | scale |                                                                             |           |
| 0             | 0 | 01     | 00    | 010    |       | <a href="#">SCVTF (scalar, fixed-point)</a> â€“ 32-bit to double-precision  | -         |
| 0             | 0 | 01     | 00    | 011    |       | <a href="#">UCVTF (scalar, fixed-point)</a> â€“ 32-bit to double-precision  | -         |
| 0             | 0 | 01     | 11    | 000    |       | <a href="#">FCVTZS (scalar, fixed-point)</a> â€“ double-precision to 32-bit | -         |
| 0             | 0 | 01     | 11    | 001    |       | <a href="#">FCVTZU (scalar, fixed-point)</a> â€“ double-precision to 32-bit | -         |
| 0             | 0 | 11     | 00    | 010    |       | <a href="#">SCVTF (scalar, fixed-point)</a> â€“ 32-bit to half-precision    | FEAT_FP16 |
| 0             | 0 | 11     | 00    | 011    |       | <a href="#">UCVTF (scalar, fixed-point)</a> â€“ 32-bit to half-precision    | FEAT_FP16 |
| 0             | 0 | 11     | 11    | 000    |       | <a href="#">FCVTZS (scalar, fixed-point)</a> â€“ half-precision to 32-bit   | FEAT_FP16 |
| 0             | 0 | 11     | 11    | 001    |       | <a href="#">FCVTZU (scalar, fixed-point)</a> â€“ half-precision to 32-bit   | FEAT_FP16 |
| 1             | 0 | 00     | 00    | 010    |       | <a href="#">SCVTF (scalar, fixed-point)</a> â€“ 64-bit to single-precision  | -         |
| 1             | 0 | 00     | 00    | 011    |       | <a href="#">UCVTF (scalar, fixed-point)</a> â€“ 64-bit to single-precision  | -         |

| Decode fields |   |       |       |        |       | Instruction Details                                                         | Feature   |
|---------------|---|-------|-------|--------|-------|-----------------------------------------------------------------------------|-----------|
| sf            | S | ftype | rmode | opcode | scale |                                                                             |           |
| 1             | 0 | 00    | 11    | 000    |       | <a href="#">FCVTZS (scalar, fixed-point)</a> â€“ single-precision to 64-bit | -         |
| 1             | 0 | 00    | 11    | 001    |       | <a href="#">FCVTZU (scalar, fixed-point)</a> â€“ single-precision to 64-bit | -         |
| 1             | 0 | 01    | 00    | 010    |       | <a href="#">SCVTF (scalar, fixed-point)</a> â€“ 64-bit to double-precision  | -         |
| 1             | 0 | 01    | 00    | 011    |       | <a href="#">UCVTF (scalar, fixed-point)</a> â€“ 64-bit to double-precision  | -         |
| 1             | 0 | 01    | 11    | 000    |       | <a href="#">FCVTZS (scalar, fixed-point)</a> â€“ double-precision to 64-bit | -         |
| 1             | 0 | 01    | 11    | 001    |       | <a href="#">FCVTZU (scalar, fixed-point)</a> â€“ double-precision to 64-bit | -         |
| 1             | 0 | 11    | 00    | 010    |       | <a href="#">SCVTF (scalar, fixed-point)</a> â€“ 64-bit to half-precision    | FEAT_FP16 |
| 1             | 0 | 11    | 00    | 011    |       | <a href="#">UCVTF (scalar, fixed-point)</a> â€“ 64-bit to half-precision    | FEAT_FP16 |
| 1             | 0 | 11    | 11    | 000    |       | <a href="#">FCVTZS (scalar, fixed-point)</a> â€“ half-precision to 64-bit   | FEAT_FP16 |
| 1             | 0 | 11    | 11    | 001    |       | <a href="#">FCVTZU (scalar, fixed-point)</a> â€“ half-precision to 64-bit   | FEAT_FP16 |

## Conversion between floating-point and integer

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |       |    |       |        |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-------|----|-------|--------|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21    | 20     | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| sf | 0  | S  | 1  | 1  | 1  | 1  | 0  | ftype | 1  | rmode | opcode | 0  | 0  | 0  | 0  | 0  | 0  | Rn |    | Rd |    |   |   |   |   |   |   |   |   |   |   |

| sf | S  | Decode fields |       |    | opcode | Instruction Details                                                                    |             | Feature |
|----|----|---------------|-------|----|--------|----------------------------------------------------------------------------------------|-------------|---------|
|    |    | ftype         | rmode | 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    | <a href="#">FCVTNS (scalar)</a><br>â€” <a href="#">single-precision to 32-bit</a>      | -           |         |
| 0  | 0  | 00            | 00    |    | 001    | <a href="#">FCVTNU (scalar)</a><br>â€” <a href="#">single-precision to 32-bit</a>      | -           |         |
| 0  | 0  | 00            | 00    |    | 010    | <a href="#">SCVTF (scalar, integer)</a> â€” <a href="#">32-bit to single-precision</a> | -           |         |
| 0  | 0  | 00            | 00    |    | 011    | <a href="#">UCVTF (scalar, integer)</a> â€” <a href="#">32-bit to single-precision</a> | -           |         |
| 0  | 0  | 00            | 00    |    | 100    | <a href="#">FCVTAS (scalar)</a><br>â€” <a href="#">single-precision to 32-bit</a>      | -           |         |
| 0  | 0  | 00            | 00    |    | 101    | <a href="#">FCVTAU (scalar)</a><br>â€” <a href="#">single-precision to 32-bit</a>      | -           |         |
| 0  | 0  | 00            | 00    |    | 110    | <a href="#">FMOV (general)</a><br>â€” <a href="#">single-precision to 32-bit</a>       | -           |         |

| sf | S | Decode fields |       | opcode | Instruction Details                                                                     | Feature |
|----|---|---------------|-------|--------|-----------------------------------------------------------------------------------------|---------|
|    |   | ftype         | rmode |        |                                                                                         |         |
| 0  | 0 | 00            | 00    | 111    | <a href="#">FMOV (general)</a><br>â€” <a href="#">32-bit to single-precision</a>        | -       |
| 0  | 0 | 00            | 01    | 000    | <a href="#">FCVTPS (scalar)</a><br>â€” <a href="#">single-precision to 32-bit</a>       | -       |
| 0  | 0 | 00            | 01    | 001    | <a href="#">FCVTPU (scalar)</a><br>â€” <a href="#">single-precision to 32-bit</a>       | -       |
| 0  | 0 | 00            | 1x    | 11x    | UNALLOCATED                                                                             | -       |
| 0  | 0 | 00            | 10    | 000    | <a href="#">FCVTMS (scalar)</a><br>â€” <a href="#">single-precision to 32-bit</a>       | -       |
| 0  | 0 | 00            | 10    | 001    | <a href="#">FCVTMU (scalar)</a> â€” <a href="#">single-precision to 32-bit</a>          | -       |
| 0  | 0 | 00            | 11    | 000    | <a href="#">FCVTZS (scalar, integer)</a> â€” <a href="#">single-precision to 32-bit</a> | -       |
| 0  | 0 | 00            | 11    | 001    | <a href="#">FCVTZU (scalar, integer)</a> â€” <a href="#">single-precision to 32-bit</a> | -       |
| 0  | 0 | 01            | 0x    | 11x    | UNALLOCATED                                                                             | -       |
| 0  | 0 | 01            | 00    | 000    | <a href="#">FCVTNS (scalar)</a><br>â€” <a href="#">double-precision to 32-bit</a>       | -       |
| 0  | 0 | 01            | 00    | 001    | <a href="#">FCVTNU (scalar)</a><br>â€” <a href="#">double-precision to 32-bit</a>       | -       |
| 0  | 0 | 01            | 00    | 010    | <a href="#">SCVTF (scalar, integer)</a> â€” <a href="#">32-bit to double-precision</a>  | -       |
| 0  | 0 | 01            | 00    | 011    | <a href="#">UCVTF (scalar, integer)</a> â€” <a href="#">32-bit to double-precision</a>  | -       |

| sf | S | Decode fields |       | opcode | Instruction Details                                                                        | Feature    |
|----|---|---------------|-------|--------|--------------------------------------------------------------------------------------------|------------|
|    |   | ftype         | rmode |        |                                                                                            |            |
| 0  | 0 | 01            | 00    | 100    | <a href="#">FCVTAS (scalar)</a><br>â€” <a href="#">double-precision to 32-bit</a>          | -          |
| 0  | 0 | 01            | 00    | 101    | <a href="#">FCVTAU (scalar)</a><br>â€” <a href="#">double-precision to 32-bit</a>          | -          |
| 0  | 0 | 01            | 01    | 000    | <a href="#">FCVTPS (scalar)</a><br>â€” <a href="#">double-precision to 32-bit</a>          | -          |
| 0  | 0 | 01            | 01    | 001    | <a href="#">FCVTPU (scalar)</a><br>â€” <a href="#">double-precision to 32-bit</a>          | -          |
| 0  | 0 | 01            | 10    | 000    | <a href="#">FCVTMS (scalar)</a><br>â€” <a href="#">double-precision to 32-bit</a>          | -          |
| 0  | 0 | 01            | 10    | 001    | <a href="#">FCVTMU (scalar)</a><br>â€” <a href="#">double-precision to 32-bit</a>          | -          |
| 0  | 0 | 01            | 10    | 11x    | UNALLOCATED                                                                                | -          |
| 0  | 0 | 01            | 11    | 000    | <a href="#">FCVTZS (scalar, integer)</a><br>â€” <a href="#">double-precision to 32-bit</a> | -          |
| 0  | 0 | 01            | 11    | 001    | <a href="#">FCVTZU (scalar, integer)</a><br>â€” <a href="#">double-precision to 32-bit</a> | -          |
| 0  | 0 | 01            | 11    | 110    | <a href="#">FJCVTZS</a>                                                                    | FEAT_JSCVT |
| 0  | 0 | 01            | 11    | 111    | UNALLOCATED                                                                                | -          |
| 0  | 0 | 10            |       | 11x    | UNALLOCATED                                                                                | -          |
| 0  | 0 | 11            | 00    | 000    | <a href="#">FCVTNS (scalar)</a><br>â€” <a href="#">half-precision to 32-bit</a>            | FEAT_FP16  |
| 0  | 0 | 11            | 00    | 001    | <a href="#">FCVTNU (scalar)</a><br>â€” <a href="#">half-precision to 32-bit</a>            | FEAT_FP16  |

| sf | S | Decode fields |       | opcode | Instruction Details                                                                  | Feature   |
|----|---|---------------|-------|--------|--------------------------------------------------------------------------------------|-----------|
|    |   | fptype        | rmode |        |                                                                                      |           |
| 0  | 0 | 11            | 00    | 010    | <a href="#">SCVTF (scalar integer)</a> â€“ <a href="#">32-bit to half-precision</a>  | FEAT_FP16 |
| 0  | 0 | 11            | 00    | 011    | <a href="#">UCVTF (scalar integer)</a> â€“ <a href="#">32-bit to half-precision</a>  | FEAT_FP16 |
| 0  | 0 | 11            | 00    | 100    | <a href="#">FCVTAS (scalar)</a> â€“ <a href="#">half-precision to 32-bit</a>         | FEAT_FP16 |
| 0  | 0 | 11            | 00    | 101    | <a href="#">FCVTAU (scalar)</a> â€“ <a href="#">half-precision to 32-bit</a>         | FEAT_FP16 |
| 0  | 0 | 11            | 00    | 110    | <a href="#">FMOV (general)</a> â€“ <a href="#">half-precision to 32-bit</a>          | FEAT_FP16 |
| 0  | 0 | 11            | 00    | 111    | <a href="#">FMOV (general)</a> â€“ <a href="#">32-bit to half-precision</a>          | FEAT_FP16 |
| 0  | 0 | 11            | 01    | 000    | <a href="#">FCVTPS (scalar)</a> â€“ <a href="#">half-precision to 32-bit</a>         | FEAT_FP16 |
| 0  | 0 | 11            | 01    | 001    | <a href="#">FCVTPU (scalar)</a> â€“ <a href="#">half-precision to 32-bit</a>         | FEAT_FP16 |
| 0  | 0 | 11            | 10    | 000    | <a href="#">FCVTMS (scalar)</a> â€“ <a href="#">half-precision to 32-bit</a>         | FEAT_FP16 |
| 0  | 0 | 11            | 10    | 001    | <a href="#">FCVTMU (scalar)</a> â€“ <a href="#">half-precision to 32-bit</a>         | FEAT_FP16 |
| 0  | 0 | 11            | 11    | 000    | <a href="#">FCVTZS (scalar integer)</a> â€“ <a href="#">half-precision to 32-bit</a> | FEAT_FP16 |
| 0  | 0 | 11            | 11    | 001    | <a href="#">FCVTZU (scalar integer)</a> â€“ <a href="#">half-precision to 32-bit</a> | FEAT_FP16 |

| sf | S | Decode fields |       | opcode | Instruction Details                                                                     | Feature |
|----|---|---------------|-------|--------|-----------------------------------------------------------------------------------------|---------|
|    |   | fptype        | rmode |        |                                                                                         |         |
| 1  | 0 | 00            |       | 11x    | UNALLOCATED                                                                             | -       |
| 1  | 0 | 00            | 00    | 000    | <a href="#">FCVTNS (scalar)</a><br>â€” <a href="#">single-precision to 64-bit</a>       | -       |
| 1  | 0 | 00            | 00    | 001    | <a href="#">FCVTNU (scalar)</a><br>â€” <a href="#">single-precision to 64-bit</a>       | -       |
| 1  | 0 | 00            | 00    | 010    | <a href="#">SCVTF (scalar, integer)</a> â€” <a href="#">64-bit to single-precision</a>  | -       |
| 1  | 0 | 00            | 00    | 011    | <a href="#">UCVTF (scalar, integer)</a> â€” <a href="#">64-bit to single-precision</a>  | -       |
| 1  | 0 | 00            | 00    | 100    | <a href="#">FCVTAS (scalar)</a><br>â€” <a href="#">single-precision to 64-bit</a>       | -       |
| 1  | 0 | 00            | 00    | 101    | <a href="#">FCVTAU (scalar)</a><br>â€” <a href="#">single-precision to 64-bit</a>       | -       |
| 1  | 0 | 00            | 01    | 000    | <a href="#">FCVTPS (scalar)</a><br>â€” <a href="#">single-precision to 64-bit</a>       | -       |
| 1  | 0 | 00            | 01    | 001    | <a href="#">FCVTPU (scalar)</a><br>â€” <a href="#">single-precision to 64-bit</a>       | -       |
| 1  | 0 | 00            | 10    | 000    | <a href="#">FCVTMS (scalar)</a><br>â€” <a href="#">single-precision to 64-bit</a>       | -       |
| 1  | 0 | 00            | 10    | 001    | <a href="#">FCVTMU (scalar)</a> â€” <a href="#">single-precision to 64-bit</a>          | -       |
| 1  | 0 | 00            | 11    | 000    | <a href="#">FCVTZS (scalar, integer)</a> â€” <a href="#">single-precision to 64-bit</a> | -       |

| sf | S | Decode fields |       | opcode | Instruction Details                                                     | Feature |
|----|---|---------------|-------|--------|-------------------------------------------------------------------------|---------|
|    |   | ftype         | rmode |        |                                                                         |         |
| 1  | 0 | 00            | 11    | 001    | <a href="#">FCVTZU (scalar, integer)</a> â€“ single-precision to 64-bit | -       |
| 1  | 0 | 01            | x1    | 11x    | UNALLOCATED                                                             | -       |
| 1  | 0 | 01            | 00    | 000    | <a href="#">FCVTNS (scalar)</a> â€“ double-precision to 64-bit          | -       |
| 1  | 0 | 01            | 00    | 001    | <a href="#">FCVTNU (scalar)</a> â€“ double-precision to 64-bit          | -       |
| 1  | 0 | 01            | 00    | 010    | <a href="#">SCVTF (scalar, integer)</a> â€“ 64-bit to double-precision  | -       |
| 1  | 0 | 01            | 00    | 011    | <a href="#">UCVTF (scalar, integer)</a> â€“ 64-bit to double-precision  | -       |
| 1  | 0 | 01            | 00    | 100    | <a href="#">FCVTAS (scalar)</a> â€“ double-precision to 64-bit          | -       |
| 1  | 0 | 01            | 00    | 101    | <a href="#">FCVTAU (scalar)</a> â€“ double-precision to 64-bit          | -       |
| 1  | 0 | 01            | 00    | 110    | <a href="#">FMOV (general)</a> â€“ double-precision to 64-bit           | -       |
| 1  | 0 | 01            | 00    | 111    | <a href="#">FMOV (general)</a> â€“ 64-bit to double-precision           | -       |
| 1  | 0 | 01            | 01    | 000    | <a href="#">FCVTPS (scalar)</a> â€“ double-precision to 64-bit          | -       |
| 1  | 0 | 01            | 01    | 001    | <a href="#">FCVTPU (scalar)</a> â€“ double-precision to 64-bit          | -       |
| 1  | 0 | 01            | 1x    | 11x    | UNALLOCATED                                                             | -       |

| sf | S | Decode fields |       | opcode | Instruction Details                                                                        | Feature   |
|----|---|---------------|-------|--------|--------------------------------------------------------------------------------------------|-----------|
|    |   | fptype        | rmode |        |                                                                                            |           |
| 1  | 0 | 01            | 10    | 000    | <a href="#">FCVTMS (scalar)</a><br>â€” <a href="#">double-precision to 64-bit</a>          | -         |
| 1  | 0 | 01            | 10    | 001    | <a href="#">FCVTMU (scalar)</a><br>â€” <a href="#">double-precision to 64-bit</a>          | -         |
| 1  | 0 | 01            | 11    | 000    | <a href="#">FCVTZS (scalar, integer)</a><br>â€” <a href="#">double-precision to 64-bit</a> | -         |
| 1  | 0 | 01            | 11    | 001    | <a href="#">FCVTZU (scalar, integer)</a><br>â€” <a href="#">double-precision to 64-bit</a> | -         |
| 1  | 0 | 10            | x0    | 11x    | UNALLOCATED                                                                                | -         |
| 1  | 0 | 10            | 01    | 110    | <a href="#">FMOV (general)</a><br>â€” <a href="#">top half of 128-bit to 64-bit</a>        | -         |
| 1  | 0 | 10            | 01    | 111    | <a href="#">FMOV (general)</a><br>â€” <a href="#">64-bit to top half of 128-bit</a>        | -         |
| 1  | 0 | 10            | 1x    | 11x    | UNALLOCATED                                                                                | -         |
| 1  | 0 | 11            | 00    | 000    | <a href="#">FCVTNS (scalar)</a><br>â€” <a href="#">half-precision to 64-bit</a>            | FEAT_FP16 |
| 1  | 0 | 11            | 00    | 001    | <a href="#">FCVTNU (scalar)</a><br>â€” <a href="#">half-precision to 64-bit</a>            | FEAT_FP16 |
| 1  | 0 | 11            | 00    | 010    | <a href="#">SCVTF (scalar, integer)</a><br>â€” <a href="#">64-bit to half-precision</a>    | FEAT_FP16 |
| 1  | 0 | 11            | 00    | 011    | <a href="#">UCVTF (scalar, integer)</a><br>â€” <a href="#">64-bit to half-precision</a>    | FEAT_FP16 |
| 1  | 0 | 11            | 00    | 100    | <a href="#">FCVTAS (scalar)</a><br>â€” <a href="#">half-precision to 64-bit</a>            | FEAT_FP16 |

| sf | S | Decode fields |       |  | opcode | Instruction Details                                                                   | Feature   |
|----|---|---------------|-------|--|--------|---------------------------------------------------------------------------------------|-----------|
|    |   | ftype         | rmode |  |        |                                                                                       |           |
| 1  | 0 | 11            | 00    |  | 101    | <a href="#">FCVTAU (scalar)</a><br>â€” <a href="#">half-precision to 64-bit</a>       | FEAT_FP16 |
| 1  | 0 | 11            | 00    |  | 110    | <a href="#">FMOV (general)</a><br>â€” <a href="#">half-precision to 64-bit</a>        | FEAT_FP16 |
| 1  | 0 | 11            | 00    |  | 111    | <a href="#">FMOV (general)</a><br>â€” <a href="#">64-bit to half-precision</a>        | FEAT_FP16 |
| 1  | 0 | 11            | 01    |  | 000    | <a href="#">FCVTPS (scalar)</a><br>â€” <a href="#">half-precision to 64-bit</a>       | FEAT_FP16 |
| 1  | 0 | 11            | 01    |  | 001    | <a href="#">FCVTPU (scalar)</a><br>â€” <a href="#">half-precision to 64-bit</a>       | FEAT_FP16 |
| 1  | 0 | 11            | 10    |  | 000    | <a href="#">FCVTMS (scalar)</a><br>â€” <a href="#">half-precision to 64-bit</a>       | FEAT_FP16 |
| 1  | 0 | 11            | 10    |  | 001    | <a href="#">FCVTMU (scalar)</a> â€” <a href="#">half-precision to 64-bit</a>          | FEAT_FP16 |
| 1  | 0 | 11            | 11    |  | 000    | <a href="#">FCVTZS (scalar, integer)</a> â€” <a href="#">half-precision to 64-bit</a> | FEAT_FP16 |
| 1  | 0 | 11            | 11    |  | 001    | <a href="#">FCVTZU (scalar, integer)</a> â€” <a href="#">half-precision to 64-bit</a> | FEAT_FP16 |

## Floating-point data-processing (1 source)

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |       |    |    |        |    |    |    |    |    |    |    |    |    |    |   |   |   |    |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-------|----|----|--------|----|----|----|----|----|----|----|----|----|----|---|---|---|----|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20     | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
| M  | 0  | S  | 1  | 1  | 1  | 1  | 0  | ftype | 1  |    | opcode |    |    |    |    | 1  | 0  | 0  | 0  | 0  | Rn |   |   |   | Rd |   |   |   |   |   |   |

| Decode fields |   |       |         | Instruction Details                                           | Feature      |
|---------------|---|-------|---------|---------------------------------------------------------------|--------------|
| M             | S | ftype | opcode  |                                                               |              |
|               |   |       | 1xxxxxx | UNALLOCATED                                                   | -            |
|               | 1 |       |         | UNALLOCATED                                                   | -            |
| 0             | 0 | 00    | 000000  | <a href="#">FMOV (register) â€“ single-precision</a>          | -            |
| 0             | 0 | 00    | 000001  | <a href="#">FABS (scalar) â€“ single-precision</a>            | -            |
| 0             | 0 | 00    | 000010  | <a href="#">FNNEG (scalar) â€“ single-precision</a>           | -            |
| 0             | 0 | 00    | 000011  | <a href="#">FSQRT (scalar) â€“ single-precision</a>           | -            |
| 0             | 0 | 00    | 000100  | UNALLOCATED                                                   | -            |
| 0             | 0 | 00    | 000101  | <a href="#">FCVT â€“ single-precision to double-precision</a> | -            |
| 0             | 0 | 00    | 000110  | UNALLOCATED                                                   | -            |
| 0             | 0 | 00    | 000111  | <a href="#">FCVT â€“ single-precision to half-precision</a>   | -            |
| 0             | 0 | 00    | 001000  | <a href="#">FRINTN (scalar) â€“ single-precision</a>          | -            |
| 0             | 0 | 00    | 001001  | <a href="#">FRINTP (scalar) â€“ single-precision</a>          | -            |
| 0             | 0 | 00    | 001010  | <a href="#">FRINTM (scalar) â€“ single-precision</a>          | -            |
| 0             | 0 | 00    | 001011  | <a href="#">FRINTZ (scalar) â€“ single-precision</a>          | -            |
| 0             | 0 | 00    | 001100  | <a href="#">FRINTA (scalar) â€“ single-precision</a>          | -            |
| 0             | 0 | 00    | 001101  | UNALLOCATED                                                   | -            |
| 0             | 0 | 00    | 001110  | <a href="#">FRINTX (scalar) â€“ single-precision</a>          | -            |
| 0             | 0 | 00    | 001111  | <a href="#">FRINTI (scalar) â€“ single-precision</a>          | -            |
| 0             | 0 | 00    | 010000  | <a href="#">FRINT32Z (scalar) â€“ single-precision</a>        | FEAT_FRINTTS |
| 0             | 0 | 00    | 010001  | <a href="#">FRINT32X (scalar) â€“ single-precision</a>        | FEAT_FRINTTS |
| 0             | 0 | 00    | 010010  | <a href="#">FRINT64Z (scalar) â€“ single-precision</a>        | FEAT_FRINTTS |
| 0             | 0 | 00    | 010011  | <a href="#">FRINT64X (scalar) â€“ single-precision</a>        | FEAT_FRINTTS |
| 0             | 0 | 00    | 0101xx  | UNALLOCATED                                                   | -            |
| 0             | 0 | 00    | 011xxx  | UNALLOCATED                                                   | -            |

| M | S | Decode fields<br>ftype | opcode | Instruction Details                                           | Feature      |
|---|---|------------------------|--------|---------------------------------------------------------------|--------------|
| 0 | 0 | 01                     | 000000 | <a href="#">FMOV (register) â€“ double-precision</a>          | -            |
| 0 | 0 | 01                     | 000001 | <a href="#">FABS (scalar) â€“ double-precision</a>            | -            |
| 0 | 0 | 01                     | 000010 | <a href="#">FNNEG (scalar) â€“ double-precision</a>           | -            |
| 0 | 0 | 01                     | 000011 | <a href="#">FSQRT (scalar) â€“ double-precision</a>           | -            |
| 0 | 0 | 01                     | 000100 | <a href="#">FCVT â€“ double-precision to single-precision</a> | -            |
| 0 | 0 | 01                     | 000101 | UNALLOCATED                                                   | -            |
| 0 | 0 | 01                     | 000110 | <a href="#">BFCVT</a>                                         | FEAT_BF16    |
| 0 | 0 | 01                     | 000111 | <a href="#">FCVT â€“ double-precision to half-precision</a>   | -            |
| 0 | 0 | 01                     | 001000 | <a href="#">FRINTN (scalar) â€“ double-precision</a>          | -            |
| 0 | 0 | 01                     | 001001 | <a href="#">FRINTP (scalar) â€“ double-precision</a>          | -            |
| 0 | 0 | 01                     | 001010 | <a href="#">FRINTM (scalar) â€“ double-precision</a>          | -            |
| 0 | 0 | 01                     | 001011 | <a href="#">FRINTZ (scalar) â€“ double-precision</a>          | -            |
| 0 | 0 | 01                     | 001100 | <a href="#">FRINTA (scalar) â€“ double-precision</a>          | -            |
| 0 | 0 | 01                     | 001101 | UNALLOCATED                                                   | -            |
| 0 | 0 | 01                     | 001110 | <a href="#">FRINTX (scalar) â€“ double-precision</a>          | -            |
| 0 | 0 | 01                     | 001111 | <a href="#">FRINTI (scalar) â€“ double-precision</a>          | -            |
| 0 | 0 | 01                     | 010000 | <a href="#">FRINT32Z (scalar) â€“ double-precision</a>        | FEAT_FRINTTS |
| 0 | 0 | 01                     | 010001 | <a href="#">FRINT32X (scalar) â€“ double-precision</a>        | FEAT_FRINTTS |
| 0 | 0 | 01                     | 010010 | <a href="#">FRINT64Z (scalar) â€“ double-precision</a>        | FEAT_FRINTTS |
| 0 | 0 | 01                     | 010011 | <a href="#">FRINT64X (scalar) â€“ double-precision</a>        | FEAT_FRINTTS |
| 0 | 0 | 01                     | 0101xx | UNALLOCATED                                                   | -            |
| 0 | 0 | 01                     | 011xxx | UNALLOCATED                                                   | -            |
| 0 | 0 | 10                     | 0xxxxx | UNALLOCATED                                                   | -            |
| 0 | 0 | 11                     | 000000 | <a href="#">FMOV (register) â€“ half-precision</a>            | FEAT_FP16    |

| M | S | Decode fields<br>ftype | opcode | Instruction Details                                                         | Feature   |
|---|---|------------------------|--------|-----------------------------------------------------------------------------|-----------|
| 0 | 0 | 11                     | 000001 | <a href="#">FABS (scalar)</a> â€“ <a href="#">half-precision</a>            | FEAT_FP16 |
| 0 | 0 | 11                     | 000010 | <a href="#">FNNEG (scalar)</a> â€“ <a href="#">half-precision</a>           | FEAT_FP16 |
| 0 | 0 | 11                     | 000011 | <a href="#">FSQRT (scalar)</a> â€“ <a href="#">half-precision</a>           | FEAT_FP16 |
| 0 | 0 | 11                     | 000100 | <a href="#">FCVT</a> â€“ <a href="#">half-precision to single-precision</a> | -         |
| 0 | 0 | 11                     | 000101 | <a href="#">FCVT</a> â€“ <a href="#">half-precision to double-precision</a> | -         |
| 0 | 0 | 11                     | 00011x | UNALLOCATED                                                                 | -         |
| 0 | 0 | 11                     | 001000 | <a href="#">FRINTN (scalar)</a> â€“ <a href="#">half-precision</a>          | FEAT_FP16 |
| 0 | 0 | 11                     | 001001 | <a href="#">FRINTP (scalar)</a> â€“ <a href="#">half-precision</a>          | FEAT_FP16 |
| 0 | 0 | 11                     | 001010 | <a href="#">FRINTM (scalar)</a> â€“ <a href="#">half-precision</a>          | FEAT_FP16 |
| 0 | 0 | 11                     | 001011 | <a href="#">FRINTZ (scalar)</a> â€“ <a href="#">half-precision</a>          | FEAT_FP16 |
| 0 | 0 | 11                     | 001100 | <a href="#">FRINTA (scalar)</a> â€“ <a href="#">half-precision</a>          | FEAT_FP16 |
| 0 | 0 | 11                     | 001101 | UNALLOCATED                                                                 | -         |
| 0 | 0 | 11                     | 001110 | <a href="#">FRINTX (scalar)</a> â€“ <a href="#">half-precision</a>          | FEAT_FP16 |
| 0 | 0 | 11                     | 001111 | <a href="#">FRINTI (scalar)</a> â€“ <a href="#">half-precision</a>          | FEAT_FP16 |
| 0 | 0 | 11                     | 01xxxx | UNALLOCATED                                                                 | -         |
| 1 |   |                        |        | UNALLOCATED                                                                 | -         |

### Floating-point compare

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |
|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|----|---------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14      | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
| M  | 0  | S  | 1  | 1  | 1  | 1  | 0  | ftype | 1  | Rm | op | 1  | 0  | 0  | 0  | Rn | opcode2 |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |

| M | S | Decode fields<br>ftype | op | opcode2 | Instruction Details | Feature |
|---|---|------------------------|----|---------|---------------------|---------|
|   |   |                        |    | xxxx1   | UNALLOCATED         | -       |
|   |   |                        |    | xxx1x   | UNALLOCATED         | -       |
|   |   |                        |    | xx1xx   | UNALLOCATED         | -       |
|   |   |                        | x1 |         | UNALLOCATED         | -       |

| Decode fields |   |       |    |         | Instruction Details   | Feature   |
|---------------|---|-------|----|---------|-----------------------|-----------|
| M             | S | ftype | op | opcode2 |                       |           |
|               |   |       | 1x |         | UNALLOCATED           | -         |
|               |   | 10    |    |         | UNALLOCATED           | -         |
|               |   | 1     |    |         | UNALLOCATED           | -         |
| 0             | 0 | 00    | 00 | 00000   | <a href="#">FCMP</a>  | -         |
| 0             | 0 | 00    | 00 | 01000   | <a href="#">FCMP</a>  | -         |
| 0             | 0 | 00    | 00 | 10000   | <a href="#">FCMPE</a> | -         |
| 0             | 0 | 00    | 00 | 11000   | <a href="#">FCMPE</a> | -         |
| 0             | 0 | 01    | 00 | 00000   | <a href="#">FCMP</a>  | -         |
| 0             | 0 | 01    | 00 | 01000   | <a href="#">FCMP</a>  | -         |
| 0             | 0 | 01    | 00 | 10000   | <a href="#">FCMPE</a> | -         |
| 0             | 0 | 01    | 00 | 11000   | <a href="#">FCMPE</a> | -         |
| 0             | 0 | 11    | 00 | 00000   | <a href="#">FCMP</a>  | FEAT_FP16 |
| 0             | 0 | 11    | 00 | 01000   | <a href="#">FCMP</a>  | FEAT_FP16 |
| 0             | 0 | 11    | 00 | 10000   | <a href="#">FCMPE</a> | FEAT_FP16 |
| 0             | 0 | 11    | 00 | 11000   | <a href="#">FCMPE</a> | FEAT_FP16 |
| 1             |   |       |    |         | UNALLOCATED           | -         |

### Floating-point immediate

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |      |    |    |    |    |    |   |      |   |   |    |   |   |   |   |   |  |
|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|------|----|----|----|----|----|---|------|---|---|----|---|---|---|---|---|--|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5  | 4 | 3 | 2 | 1 | 0 |  |
| M  | 0  | S  | 1  | 1  | 1  | 1  | 0  | ftype | 1  |    |    |    |    |    |    | imm8 |    |    | 1  | 0  | 0  |   | imm5 |   |   | Rd |   |   |   |   |   |  |

| Decode fields |   |       |       | Instruction Details                                               | Feature   |
|---------------|---|-------|-------|-------------------------------------------------------------------|-----------|
| M             | S | ftype | imm5  |                                                                   |           |
|               |   |       | xxxx1 | UNALLOCATED                                                       | -         |
|               |   |       | xxx1x | UNALLOCATED                                                       | -         |
|               |   |       | xx1xx | UNALLOCATED                                                       | -         |
|               |   |       | x1xxx | UNALLOCATED                                                       | -         |
|               |   |       | 1xxxx | UNALLOCATED                                                       | -         |
|               |   | 10    |       | UNALLOCATED                                                       | -         |
|               |   | 1     |       | UNALLOCATED                                                       | -         |
| 0             | 0 | 00    | 00000 | <a href="#">FMOV (scalar, immediate)<br/>â€” single-precision</a> | -         |
| 0             | 0 | 01    | 00000 | <a href="#">FMOV (scalar, immediate)<br/>â€” double-precision</a> | -         |
| 0             | 0 | 11    | 00000 | <a href="#">FMOV (scalar, immediate)<br/>â€” half-precision</a>   | FEAT_FP16 |

| Decode fields |   |       |      | Instruction Details |  |  |  | Feature |  |
|---------------|---|-------|------|---------------------|--|--|--|---------|--|
| M             | S | ftype | imm5 |                     |  |  |  |         |  |
| 1             |   |       |      | UNALLOCATED         |  |  |  | -       |  |

### Floating-point conditional compare

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |       |    |    |    |      |    |    |    |    |      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-------|----|----|----|------|----|----|----|----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| M  | 0  | S  | 1  | 1  | 1  | 1  | 0  | ftype | 1  | Rm |    | cond | 0  | 1  | Rn | op | nzcv |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |       |    | Instruction Details                                         |  |  |  | Feature   |  |
|---------------|---|-------|----|-------------------------------------------------------------|--|--|--|-----------|--|
| M             | S | ftype | op |                                                             |  |  |  |           |  |
|               |   | 10    |    | UNALLOCATED                                                 |  |  |  | -         |  |
|               |   | 1     |    | UNALLOCATED                                                 |  |  |  | -         |  |
| 0             | 0 | 00    | 0  | <a href="#">FCCMP</a> â€“ <a href="#">single-precision</a>  |  |  |  | -         |  |
| 0             | 0 | 00    | 1  | <a href="#">FCCMPE</a> â€“ <a href="#">single-precision</a> |  |  |  | -         |  |
| 0             | 0 | 01    | 0  | <a href="#">FCCMP</a> â€“ <a href="#">double-precision</a>  |  |  |  | -         |  |
| 0             | 0 | 01    | 1  | <a href="#">FCCMPE</a> â€“ <a href="#">double-precision</a> |  |  |  | -         |  |
| 0             | 0 | 11    | 0  | <a href="#">FCCMP</a> â€“ <a href="#">half-precision</a>    |  |  |  | FEAT_FP16 |  |
| 0             | 0 | 11    | 1  | <a href="#">FCCMPE</a> â€“ <a href="#">half-precision</a>   |  |  |  | FEAT_FP16 |  |
| 1             |   |       |    | UNALLOCATED                                                 |  |  |  | -         |  |

### Floating-point data-processing (2 source)

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |       |    |    |    |        |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-------|----|----|----|--------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19     | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| M  | 0  | S  | 1  | 1  | 1  | 1  | 0  | ftype | 1  | Rm |    | opcode | 1  | 0  | Rn |    | Rd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Decode fields |   |       |        | Instruction Details                                                |  |  |  | Feature |  |
|---------------|---|-------|--------|--------------------------------------------------------------------|--|--|--|---------|--|
| M             | S | ftype | opcode |                                                                    |  |  |  |         |  |
|               |   |       | 1xx1   | UNALLOCATED                                                        |  |  |  | -       |  |
|               |   |       | 1x1x   | UNALLOCATED                                                        |  |  |  | -       |  |
|               |   |       | 11xx   | UNALLOCATED                                                        |  |  |  | -       |  |
|               |   | 10    |        | UNALLOCATED                                                        |  |  |  | -       |  |
|               | 1 |       |        | UNALLOCATED                                                        |  |  |  | -       |  |
| 0             | 0 | 00    | 0000   | <a href="#">FMUL (scalar)</a> â€“ <a href="#">single-precision</a> |  |  |  | -       |  |
| 0             | 0 | 00    | 0001   | <a href="#">FDIV (scalar)</a> â€“ <a href="#">single-precision</a> |  |  |  | -       |  |

| <b>M</b> | <b>Decode fields</b> | <b>Instruction Details</b> | <b>Feature</b>                                                       |           |
|----------|----------------------|----------------------------|----------------------------------------------------------------------|-----------|
| <b>S</b> | <b>ftype</b>         | <b>opcode</b>              |                                                                      |           |
| 0        | 0                    | 00                         | <a href="#">FADD (scalar)</a> â€“ <a href="#">single-precision</a>   | -         |
| 0        | 0                    | 00                         | <a href="#">FSUB (scalar)</a> â€“ <a href="#">single-precision</a>   | -         |
| 0        | 0                    | 00                         | <a href="#">FMAX (scalar)</a> â€“ <a href="#">single-precision</a>   | -         |
| 0        | 0                    | 00                         | <a href="#">FMIN (scalar)</a> â€“ <a href="#">single-precision</a>   | -         |
| 0        | 0                    | 00                         | <a href="#">FMAXNM (scalar)</a> â€“ <a href="#">single-precision</a> | -         |
| 0        | 0                    | 00                         | <a href="#">FMINNM (scalar)</a> â€“ <a href="#">single-precision</a> | -         |
| 0        | 0                    | 00                         | <a href="#">FNMUL (scalar)</a> â€“ <a href="#">single-precision</a>  | -         |
| 0        | 0                    | 01                         | <a href="#">FMUL (scalar)</a> â€“ <a href="#">double-precision</a>   | -         |
| 0        | 0                    | 01                         | <a href="#">FDIV (scalar)</a> â€“ <a href="#">double-precision</a>   | -         |
| 0        | 0                    | 01                         | <a href="#">FADD (scalar)</a> â€“ <a href="#">double-precision</a>   | -         |
| 0        | 0                    | 01                         | <a href="#">FSUB (scalar)</a> â€“ <a href="#">double-precision</a>   | -         |
| 0        | 0                    | 01                         | <a href="#">FMAX (scalar)</a> â€“ <a href="#">double-precision</a>   | -         |
| 0        | 0                    | 01                         | <a href="#">FMIN (scalar)</a> â€“ <a href="#">double-precision</a>   | -         |
| 0        | 0                    | 01                         | <a href="#">FMAXNM (scalar)</a> â€“ <a href="#">double-precision</a> | -         |
| 0        | 0                    | 01                         | <a href="#">FMINNM (scalar)</a> â€“ <a href="#">double-precision</a> | -         |
| 0        | 0                    | 01                         | <a href="#">FNMUL (scalar)</a> â€“ <a href="#">double-precision</a>  | -         |
| 0        | 0                    | 11                         | <a href="#">FMUL (scalar)</a> â€“ <a href="#">half-precision</a>     | FEAT_FP16 |
| 0        | 0                    | 11                         | <a href="#">FDIV (scalar)</a> â€“ <a href="#">half-precision</a>     | FEAT_FP16 |
| 0        | 0                    | 11                         | <a href="#">FADD (scalar)</a> â€“ <a href="#">half-precision</a>     | FEAT_FP16 |
| 0        | 0                    | 11                         | <a href="#">FSUB (scalar)</a> â€“ <a href="#">half-precision</a>     | FEAT_FP16 |
| 0        | 0                    | 11                         | <a href="#">FMAX (scalar)</a> â€“ <a href="#">half-precision</a>     | FEAT_FP16 |
| 0        | 0                    | 11                         | <a href="#">FMIN (scalar)</a> â€“ <a href="#">half-precision</a>     | FEAT_FP16 |
| 0        | 0                    | 11                         | <a href="#">FMAXNM (scalar)</a> â€“ <a href="#">half-precision</a>   | FEAT_FP16 |

| M | S | Decode fields |        | Instruction Details                                                | Feature   |
|---|---|---------------|--------|--------------------------------------------------------------------|-----------|
|   |   | ftype         | opcode |                                                                    |           |
| 0 | 0 | 11            | 0111   | <a href="#">FMINNM (scalar)</a> â€“ <a href="#">half-precision</a> | FEAT_FP16 |
| 0 | 0 | 11            | 1000   | <a href="#">FNMUL (scalar)</a> â€“ <a href="#">half-precision</a>  | FEAT_FP16 |
| 1 |   |               |        | UNALLOCATED                                                        | -         |

### Floating-point conditional select

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |       |    |    |    |      |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-------|----|----|----|------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| M  | 0  | S  | 1  | 1  | 1  | 1  | 0  | ftype | 1  | Rm |    | cond | 1  | 1  | Rn |    | Rd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| M | S | Decode fields |  | Instruction Details                                        | Feature   |
|---|---|---------------|--|------------------------------------------------------------|-----------|
|   |   | ftype         |  |                                                            |           |
|   |   | 10            |  | UNALLOCATED                                                | -         |
|   | 1 |               |  | UNALLOCATED                                                | -         |
| 0 | 0 | 00            |  | <a href="#">FCSEL</a> â€“ <a href="#">single-precision</a> | -         |
| 0 | 0 | 01            |  | <a href="#">FCSEL</a> â€“ <a href="#">double-precision</a> | -         |
| 0 | 0 | 11            |  | <a href="#">FCSEL</a> â€“ <a href="#">half-precision</a>   | FEAT_FP16 |
| 1 |   |               |  | UNALLOCATED                                                | -         |

### Floating-point data-processing (3 source)

These instructions are under [Data Processing -- Scalar Floating-Point and Advanced SIMD](#).

|    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| M  | 0  | S  | 1  | 1  | 1  | 1  | 1  | ftype | 01 | Rm | 00 | Ra |    | Rn |    | Rd |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| M | S | Decode fields |    | Instruction Details                                         | Feature |
|---|---|---------------|----|-------------------------------------------------------------|---------|
|   |   | ftype         | o1 |                                                             |         |
|   |   | 10            |    | UNALLOCATED                                                 | -       |
|   | 1 |               |    | UNALLOCATED                                                 | -       |
| 0 | 0 | 00            | 0  | <a href="#">FMADD</a> â€“ <a href="#">single-precision</a>  | -       |
| 0 | 0 | 00            | 0  | <a href="#">FMSUB</a> â€“ <a href="#">single-precision</a>  | -       |
| 0 | 0 | 00            | 1  | <a href="#">FNMADD</a> â€“ <a href="#">single-precision</a> | -       |

| Decode fields |   |        |    |    | Instruction Details                                         | Feature   |
|---------------|---|--------|----|----|-------------------------------------------------------------|-----------|
| M             | S | fptype | o1 | o0 |                                                             |           |
| 0             | 0 | 00     | 1  | 1  | <a href="#">FNMSUB</a> â€“ <a href="#">single-precision</a> | -         |
| 0             | 0 | 01     | 0  | 0  | <a href="#">FMADD</a> â€“ <a href="#">double-precision</a>  | -         |
| 0             | 0 | 01     | 0  | 1  | <a href="#">FMSUB</a> â€“ <a href="#">double-precision</a>  | -         |
| 0             | 0 | 01     | 1  | 0  | <a href="#">FNMADD</a> â€“ <a href="#">double-precision</a> | -         |
| 0             | 0 | 01     | 1  | 1  | <a href="#">FNMSUB</a> â€“ <a href="#">double-precision</a> | -         |
| 0             | 0 | 11     | 0  | 0  | <a href="#">FMADD</a> â€“ <a href="#">half-precision</a>    | FEAT_FP16 |
| 0             | 0 | 11     | 0  | 1  | <a href="#">FMSUB</a> â€“ <a href="#">half-precision</a>    | FEAT_FP16 |
| 0             | 0 | 11     | 1  | 0  | <a href="#">FNMADD</a> â€“ <a href="#">half-precision</a>   | FEAT_FP16 |
| 0             | 0 | 11     | 1  | 1  | <a href="#">FNMSUB</a> â€“ <a href="#">half-precision</a>   | FEAT_FP16 |
| 1             |   |        |    |    | UNALLOCATED                                                 | -         |

[Base Instructions](#)

[SIMD&FP Instructions](#)

[SVE Instructions](#)

[SME Instructions](#)

[Index by Encoding](#)

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

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

Sh  
Pseu