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

Sh Pseu

## **SYSL**

System instruction with result. For more information, see *Op0 equals 0b01*, cache maintenance, TLB maintenance, and address translation instructions for the encodings of System instructions.

This instruction is used by the aliases GCSPOPM, and GCSSS2.

| 31 30 29 28 27 | 26 25 24 | 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 1    | 0 1   | op1      | CRn         | CRm       | op2   | Rt        |
|                |          |          |       |          |             |           |       | •         |

```
SYSL <Xt>, #<op1>, <Cn>, <Cm>, #<op2>
```

```
AArch64.CheckSystemAccess('01', op1, CRn, CRm, op2, Rt, L);
integer t = <u>UInt</u>(Rt);
integer sys_op1 = UInt(op1);
integer sys_op2 = <u>UInt</u>(op2);
integer sys_crn = UInt(CRn);
integer sys_crm = UInt(CRm);
```

## **Assembler Symbols**

| <xt></xt>   | Is the 64-bit name of the general-purpose destination register, encoded in the "Rt" field. |
|-------------|--------------------------------------------------------------------------------------------|
| <op1></op1> | Is a 3-bit unsigned immediate, in the range 0 to 7, encoded in the "op1" field.            |
| <cn></cn>   | Is a name 'Cn', with 'n' in the range 0 to 15, encoded in the "CRn" field.                 |
| <cm></cm>   | Is a name 'Cm', with 'm' in the range 0 to 15, encoded in the "CRm" field.                 |
| <op2></op2> | Is a 3-bit unsigned immediate, in the range 0 to 7, encoded in the "op2" field.            |

## **Alias Conditions**

```
Alias
         Is preferred when
GCSPOPM op1 == '011' && CRn == '0111' && CRm == '0111' && op2 == '001
GCSSS2
```

op1 == '011' && CRn == '0111' && CRm == '0111' && op2 == '011

## **Operation**

```
// No architecturally defined instructions here.
AArch64.SysInstrWithResult(1, sys_op1, sys_crn, sys_crm, sys_op2, t);
```

BaseSIMD&FPSVESMEIndex byInstructionsInstructionsInstructionsInstructions

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

Sh Pseu

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