

## Arm<sup>®</sup> Cortex<sup>®</sup>-A710 Core Cryptographic Extension

Revision: r2p1

### **Technical Reference Manual**

Non-Confidential

Issue 06

Copyright  $\mbox{\sc 0}$  2020–2021 Arm Limited (or its affiliates). 101802\_0201\_06\_en All rights reserved.



### Arm<sup>®</sup> Cortex<sup>®</sup>-A710 Core Cryptographic Extension **Technical Reference Manual**

Copyright © 2020–2021 Arm Limited (or its affiliates). All rights reserved.

### **Release Information**

### Document history

| Issue   | Date             | Date Confidentiality Change |                                       |  |  |  |
|---------|------------------|-----------------------------|---------------------------------------|--|--|--|
| 0000-01 | 24 January 2020  | Confidential                | First beta release for r0p0           |  |  |  |
| 0000-02 | 30 March 2020    | Confidential                | First limited access release for rOpO |  |  |  |
| 0100-03 | 12 June 2020     | Confidential                | First limited access release for r1p0 |  |  |  |
| 0200-04 | 21 August 2020   | Confidential                | First early access release for r2p0   |  |  |  |
| 0200-05 | 25 May 2020      | Non-Confidential            | Second early access release for r2p0  |  |  |  |
| 0201-06 | 10 December 2021 | Non-Confidential            | First release for r2p1                |  |  |  |

### **Proprietary Notice**

This document is protected by copyright and other related rights and the practice or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of Arm. No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether implementations infringe any third party patents.

THIS DOCUMENT IS PROVIDED "AS IS". ARM PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, Arm makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of, third party patents, copyrights, trade secrets, or other rights.

This document may include technical inaccuracies or typographical errors.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL,

### INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

This document consists solely of commercial items. You shall be responsible for ensuring that any use, duplication or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to Arm's customers is not intended to create or refer to any partnership relationship with any other company. Arm may make changes to this document at any time and without notice.

If any of the provisions contained in these terms conflict with any of the provisions of any click through or signed written agreement covering this document with Arm, then the click through or signed written agreement prevails over and supersedes the conflicting provisions of these terms. This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version of the Agreement shall prevail.

The Arm corporate logo and words marked with ® or <sup>™</sup> are registered trademarks or trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners. Please follow Arm's trademark usage guidelines at https://www.arm.com/company/policies/trademarks.

Copyright © 2020–2021 Arm Limited (or its affiliates). All rights reserved.

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

(LES-PRE-20349)

### **Confidentiality Status**

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by Arm and the party that Arm delivered this document to.

Unrestricted Access is an Arm internal classification.

### **Product Status**

The information in this document is Final, that is for a developed product.

### Inclusive language commitment

Arm values inclusive communities. Arm recognizes that we and our industry have used terms that can be offensive. Arm strives to lead the industry and create change.

This document includes terms that can be offensive. We will replace these terms in a future issue of this document.

If you find offensive terms in this document, please contact terms@arm.com.

# Contents

| 1 Introduction                                                     | 6  |
|--------------------------------------------------------------------|----|
| 1.1 Product revision status                                        | 6  |
| 1.2 Intended audience                                              | 6  |
| 1.3 Conventions                                                    | 6  |
| 1.4 Additional reading                                             | 8  |
| 1.5 Feedback                                                       |    |
| 2 Cryptographic extension support in the Cortex®-A710 core         |    |
| 2.1 Product Revisions                                              |    |
| 2.2 Disabling the Cryptographic Extension                          |    |
| 2.3 Cryptographic Extensions register summary                      |    |
| 2.4 ID_AA64ISAR0_EL1, AArch64 Instruction Set Attribute Register 0 |    |
| 2.5 ID_ISAR5_EL1, AArch32 Instruction Set Attribute Register 5     |    |
| A Document revisions                                               | 17 |
| A.1 Revisions                                                      | 17 |

# 1 Introduction

### **1.1 Product revision status**

The  $r_{xp_y}$  identifier indicates the revision status of the product described in this manual, for example,  $r_{1p_2}$ , where:

**r***x* Identifies the major revision of the product, for example, r1.

**p**<sub>*Y*</sub> Identifies the minor revision or modification status of the product, for example, p2.

### **1.2 Intended audience**

This manual is for system designers, system integrators, and programmers who are designing or programming a *System-on-Chip* (SoC) that uses the Cortex<sup>®</sup>-A710 core with the optional Cryptographic Extension.

### **1.3 Conventions**

The following subsections describe conventions used in Arm documents.

### Glossary

The Arm<sup>®</sup> Glossary is a list of terms used in Arm documentation, together with definitions for those terms. The Arm Glossary does not contain terms that are industry standard unless the Arm meaning differs from the generally accepted meaning.

See the Arm Glossary for more information: developer.arm.com/glossary.

### Typographic conventions

| Convention                 | Use                                                                                                                                     |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| italic                     | Introduces citations.                                                                                                                   |
| bold                       | Highlights interface elements, such as menu names. Denotes signal names. Also used for terms in descriptive lists, where appropriate.   |
| monospace                  | Denotes text that you can enter at the keyboard, such as commands, file and program names, and source code.                             |
| monospace bold             | Denotes language keywords when used outside example code.                                                                               |
| monospace <u>underline</u> | Denotes a permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name. |

| Convention     | Use                                                                                                                                                                                                                                                  |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <and></and>    | Encloses replaceable terms for assembler syntax where they appear in code or code fragments. For example:                                                                                                                                            |
|                | MRC p15, 0, <rd>, <crn>, <crm>, <opcode_2></opcode_2></crm></crn></rd>                                                                                                                                                                               |
| SMALL CAPITALS | Used in body text for a few terms that have specific technical meanings, that are defined in the<br><i>Arm® Glossary</i> . For example, <b>IMPLEMENTATION DEFINED</b> , <b>IMPLEMENTATION SPECIFIC</b> , <b>UNKNOWN</b> , and <b>UNPREDICTABLE</b> . |
|                | This represents a recommendation which, if not followed, might lead to system failure or damage.                                                                                                                                                     |
| Warning        | This represents a requirement for the system that, if not followed, might result in system failure or damage.                                                                                                                                        |
| Danger         | This represents a requirement for the system that, if not followed, will result in system failure or damage.                                                                                                                                         |
| Note           | This represents an important piece of information that needs your attention.                                                                                                                                                                         |
| - Č            | This represents a useful tip that might make it easier, better or faster to perform a task.                                                                                                                                                          |
| Remember       | This is a reminder of something important that relates to the information you are reading.                                                                                                                                                           |

### Timing diagrams

The following figure explains the components used in timing diagrams. Variations, when they occur, have clear labels. You must not assume any timing information that is not explicit in the diagrams.

Shaded bus and signal areas are undefined, so the bus or signal can assume any value within the shaded area at that time. The actual level is unimportant and does not affect normal operation.

### Figure 1-1: Key to timing diagram conventions



### Signals

The signal conventions are:

### Signal level

The level of an asserted signal depends on whether the signal is active-HIGH or active-LOW. Asserted means:

- HIGH for active-HIGH signals.
- LOW for active-LOW signals.

#### Lowercase n

At the start or end of a signal name, n denotes an active-LOW signal.

### 1.4 Additional reading

This document contains information that is specific to this product. See the following documents for other relevant information:

#### Table 1-2: Arm publications

| Document Name                                                                        | Document ID | Licensee only |
|--------------------------------------------------------------------------------------|-------------|---------------|
| Arm <sup>®</sup> Cortex <sup>®</sup> -A710 Core Technical Reference<br>Manual        | 101800      | No            |
| Arm <sup>®</sup> Cortex <sup>®</sup> -A710 Core Configuration and Integration Manual | 101801      | Yes           |
| Arm <sup>®</sup> Architecture Reference Manual Armv8,<br>for A-profile architecture  | DDI 0487    | No            |

| Document Name                                                                                           | Document ID | Licensee only |
|---------------------------------------------------------------------------------------------------------|-------------|---------------|
| Arm <sup>®</sup> Architecture Reference Manual<br>Supplement Armv9, for Armv9-A architecture<br>profile | DDI 0608    | No            |

#### Table 1-3: Other publications

| Document Name                                          | Document ID |
|--------------------------------------------------------|-------------|
| Advanced Encryption Standard (FIPS 197, November 2001) | -           |
| Secure Hash Standard (SHS) (FIPS 180-4, August 2015)   | -           |
| Secure Hash Standard (SHS) (FIPS 202, August 2015)     | -           |

### 1.5 Feedback

Arm welcomes feedback on this product and its documentation.

### Feedback on this product

If you have any comments or suggestions about this product, contact your supplier and give:

- The product name.
- The product revision or version.
- An explanation with as much information as you can provide. Include symptoms and diagnostic procedures if appropriate.

### Feedback on content

Information about how to give feedback on the content.

If you have comments on content then send an e-mail to errata@arm.com. Give:

- The title Arm<sup>®</sup> Cortex<sup>®</sup>-A710 Core Cryptographic Extension Technical Reference Manual.
- The number 101802\_0201\_06\_en.
- If applicable, the page number(s) to which your comments refer.
- A concise explanation of your comments.

Arm also welcomes general suggestions for additions and improvements.



Arm tests the PDF only in Adobe Acrobat and Acrobat Reader, and cannot guarantee the quality of the represented document when used with any other PDF reader.

# 2 Cryptographic extension support in the Cortex<sup>®</sup>-A710 core

The Cortex®-A710 core supports the optional Arm®v8.0-A and Arm®v8.2-A Cryptographic Extension.

The Arm<sup>®</sup>v8.0-A Cryptographic Extension adds A64 instructions to Advanced SIMD that accelerate *Advanced Encryption Standard* (AES) encryption and decryption. It also adds instructions to implement the *Secure Hash Algorithm* (SHA) functions SHA-1, SHA-224, and SHA-256.

The Arm  $^{\otimes}$  v8.2-A extensions, Armv8.2-A-SHA and Armv8.2-SM, add A64 instructions to accelerate SHA2-512, SHA3, SM3, and SM4.

The SVE2-AES, SVE2-SHA3, and SVE2-SM extensions add A64 instructions to accelerate SHA3, SM3, SM4, and AES encryption and decryption.

### 2.1 Product Revisions

The following table indicates the main differences in functionality between product revisions.

| Revision | Notes                                           |  |  |  |  |
|----------|-------------------------------------------------|--|--|--|--|
| r0p0     | irst release. There are no technical changes.   |  |  |  |  |
| r1p0     | Second release. There are no technical changes. |  |  |  |  |
| r2p0     | Third release. There are no technical changes.  |  |  |  |  |
| r2p1     | Fourth release. There are no technical changes. |  |  |  |  |

Changes in functionality that have an impact on the documentation also appear in A.1 Revisions on page 17.

### 2.2 Disabling the Cryptographic Extension

Disabling of the Cryptographic Extension applies to all Cortex<sup>®</sup>-A710 cores in a cluster.

To disable the Cryptographic Extension, assert **CRYPTODISABLE**.

### When **CRYPTODISABLE** is asserted:

- Executing a cryptographic instruction results in an **UNDEFINED** exception.
- ID\_AA64ISAR0\_EL1 and ID\_ISAR5\_EL1 indicates that the Cryptographic Extension is not implemented.

### **Related information**

2.4 ID\_AA64ISAR0\_EL1, AArch64 Instruction Set Attribute Register 0 on page 11 2.5 ID\_ISAR5\_EL1, AArch32 Instruction Set Attribute Register 5 on page 14

### 2.3 Cryptographic Extensions register summary

Software can identify the cryptographic instructions that are implemented in the Cortex®-A710 core by reading identification registers.

The following table shows the instruction identification registers for the Cortex<sup>®</sup>-A710 core Cryptographic Extension.

#### Table 2-2: Cryptographic Extension register summary

| Name Execution state |         | Description                                                                       |
|----------------------|---------|-----------------------------------------------------------------------------------|
| ID_AA64ISAR0_EL1     | AArch64 | See 2.4 ID_AA64ISAR0_EL1, AArch64 Instruction Set Attribute Register 0 on page 11 |
| ID_ISAR5_EL1         | AArch32 | See 2.5 ID_ISAR5_EL1, AArch32 Instruction Set Attribute Register 5 on page 14     |

### 2.4 ID\_AA64ISAR0\_EL1, AArch64 Instruction Set Attribute Register 0

Provides information about the instructions implemented in AArch64 state.

For general information about the interpretation of the ID registers, see 'Principles of the ID scheme for fields in ID registers'.

### Configurations

• This register is available in all configurations.

### Attributes

### Width

64

### Functional group

Identification

### **Reset value**

See individual bit resets.

### **Bit descriptions**

### Figure 2-1: AArch64\_ID\_AA64ISAR0\_EL1 bit assignments

| L | 63   | 60 | 59 |      | 56 | 55     | 52 | 51 48 | 47 |      | 44 | 43  | 40 | 39 |     | 36 I | 35 |      | 32 |
|---|------|----|----|------|----|--------|----|-------|----|------|----|-----|----|----|-----|------|----|------|----|
|   | RES0 |    |    | TLB  |    | TS     |    | FHM   |    | DP   |    | SM  | 1  |    | SM3 |      | S  | SHA3 |    |
| - | 31   | 28 | 27 |      | 24 | 23     | 20 | 19 16 | 15 |      | 12 | 11  | 8  | 7  |     | 4    | 3  |      | 0  |
|   | RDM  |    |    | res0 |    | Atomic |    | CRC32 |    | SHA2 |    | SHA | 1  |    | AES |      | F  | res0 |    |

### Table 2-3: ID\_AA64ISAR0\_EL1 bit descriptions

| Bits    | Name | Description                                                                                                                                                           | Reset      |
|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| [63:60] | RESO | Reserved                                                                                                                                                              | 0b0        |
| [59:56] | TLB  | Indicates support for Outer shareable and TLB range maintenance instructions. Defined values are:                                                                     |            |
|         |      | 0b0010                                                                                                                                                                |            |
|         |      | Outer shareable and TLB range maintenance instructions are implemented.                                                                                               |            |
| [55:52] | TS   | Indicates support for flag manipulation instructions. Defined values are:                                                                                             |            |
|         |      | 0Ь0010                                                                                                                                                                |            |
|         |      | CFINV, RMIF, SETF16, SETF8, AXFLAG, and XAFLAG instructions are implemented.                                                                                          |            |
| [51:48] | FHM  | Indicates support for FMLAL and FMLSL instructions. Defined values are:                                                                                               |            |
|         |      | 060001                                                                                                                                                                |            |
|         |      | FMLAL and FMLSL instructions are implemented.                                                                                                                         |            |
| [47:44] | DP   | Indicates support for Dot Product instructions in AArch64 state. Defined values are:                                                                                  |            |
|         |      | 0Ъ0001                                                                                                                                                                |            |
|         |      | UDOT and SDOT instructions implemented.                                                                                                                               |            |
| [43:40] | SM4  | Indicates support for SM4 instructions in AArch64 state. Defined values are:                                                                                          |            |
|         |      | 0ъ0000                                                                                                                                                                |            |
|         |      | When Cryptographic extensions are not implemented or disabled then SM3 instructions are not implemented.                                                              |            |
|         |      | 0b0001                                                                                                                                                                |            |
|         |      | When Cryptographic extensions are implemented and enabled then SM3 instructions SM4E and SM4EKEY are implemented.                                                     |            |
| [39:36] | SM3  | Indicates support for SM3 instructions in AArch64 state. Defined values are:                                                                                          |            |
|         |      | 0Ъ0000                                                                                                                                                                |            |
|         |      | When Cryptographic extensions are not implemented or disabled then SM4 instructions are not implemented.                                                              |            |
|         |      | 0Ь0001                                                                                                                                                                |            |
|         |      | When Cryptographic extensions are implemented and enabled then SM4 instructions SM3SS1, SM3TT1A, SM3TT1B, SM3TT2A, SM3TT2B, SM3PARTW1, and SM3PARTW2 are implemented. |            |
| [35:32] | SHA3 | Indicates support for SHA3 instructions in AArch64 state. Defined values are:                                                                                         |            |
|         |      | 0ь0000                                                                                                                                                                |            |
|         |      | When Cryptographic extensions are not implemented or disabled then SHA3 instructions are not implemented.                                                             |            |
|         |      | 0b0001                                                                                                                                                                |            |
|         |      | When Cryptographic extensions are implemented and enabled then SHA3 instructions EOR3, RAX1, XAI and BCAX are implemented.                                            | <b>ર</b> , |

| Bits    | Name   | Description                                                                                                                                                                                       | Reset |
|---------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| [31:28] | RDM    | Indicates support for SQRDMLAH and SQRDMLSH instructions in AArch64 state. Defined values are:                                                                                                    |       |
|         |        | 0b0001                                                                                                                                                                                            |       |
|         |        | SQRDMLAH and SQRDMLSH instructions implemented.                                                                                                                                                   |       |
| [27:24] | RESO   | Reserved                                                                                                                                                                                          | 0b0   |
| [23:20] | Atomic | Indicates support for Atomic instructions in AArch64 state. Defined values are:                                                                                                                   |       |
|         |        | 0b0010                                                                                                                                                                                            |       |
|         |        | LDADD, LDCLR, LDEOR, LDSET, LDSMAX, LDSMIN, LDUMAX, LDUMIN, CAS, CASP, and SWP instructions implemented.                                                                                          |       |
| [19:16] | CRC32  | CRC32 instructions implemented in AArch64 state. Defined values are:                                                                                                                              |       |
|         |        | 0b0001                                                                                                                                                                                            |       |
|         |        | CRC32B, CRC32H, CRC32W, CRC32X, CRC32CB, CRC32CH, CRC32CW, and CRC32CX instructions implemented.                                                                                                  |       |
| [15:12] | SHA2   | SHA2 instructions implemented in AArch64 state. Defined values are:                                                                                                                               |       |
|         |        | 0Ъ0000                                                                                                                                                                                            |       |
|         |        | When Cryptographic extensions are not implemented or disabled then SHA2 instructions are not implemented.                                                                                         |       |
|         |        | 0b0010                                                                                                                                                                                            |       |
|         |        | When Cryptographic extensions are implemented and enabled then SHA256H, SHA256H2, SHA256SU0, SHA256SU1, SHA512H, SHA512H2, SHA512SU0, and SHA512SU1 instructions are implemented.                 |       |
| [11:8]  | SHA1   | SHA1 instructions implemented in AArch64 state. Defined values are:                                                                                                                               |       |
|         |        | 0Ъ0000                                                                                                                                                                                            |       |
|         |        | When Cryptographic extensions are not implemented or disabled then SHA1 instructions are not implemented.                                                                                         |       |
|         |        | 0b0001                                                                                                                                                                                            |       |
|         |        | When Cryptographic extensions are implemented and enabled then SHA1C, SHA1P, SHA1M, SHA1H, SHA1SU0, and SHA1SU1 instructions are implemented.                                                     |       |
| [7:4]   | AES    | AES instructions implemented in AArch64 state. Defined values are:                                                                                                                                |       |
|         |        | 0Ъ0000                                                                                                                                                                                            |       |
|         |        | When Cryptographic extensions are not implemented or disabled then AES instructions are not implemented.                                                                                          |       |
|         |        | 0b0010                                                                                                                                                                                            |       |
|         |        | When Cryptographic extensions are implemented and enabled then AESE, AESD, AESMC, and AESIMC instructions are implemented and also PMULL/PMULL2 instructions operating on 64-bit data quantities. |       |
| [3:0]   | RESO   | Reserved                                                                                                                                                                                          | 0b0   |

### Access

MRS <Xt>, ID\_AA64ISAR0\_EL1

| <systemreg></systemreg> | орО  | op1   | CRn   | CRm    | ор2   |
|-------------------------|------|-------|-------|--------|-------|
| ID_AA64ISAR0_EL1        | 0b11 | 0b000 | 00000 | 0b0110 | 0b000 |

### Accessibility

MRS <Xt>, ID\_AA64ISAR0\_EL1

```
if PSTATE.EL == EL0 then
    if EL2Enabled() && HCR_EL2.TGE == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        AArch64.SystemAccessTrap(EL1, 0x18);
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.TID3 == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        return ID_AA64ISAR0_EL1;
elsif PSTATE.EL == EL2 then
        return ID_AA64ISAR0_EL1;
elsif PSTATE.EL == EL3 then
        return ID_AA64ISAR0_EL1;
```

### 2.5 ID\_ISAR5\_EL1, AArch32 Instruction Set Attribute Register 5

Provides information about the instruction sets implemented by the PE in AArch32 state.

Must be interpreted with AArch64-ID\_ISAR0\_EL1, AArch64-ID\_ISAR1\_EL1, AArch64-ID\_ISAR2\_EL1, AArch64-ID\_ISAR3\_EL1, and AArch64-ID\_ISAR4\_EL1.

For general information about the interpretation of the ID registers see 'Principles of the ID scheme for fields in ID registers'.

### Configurations

• This register is available in all configurations.

### Attributes

### Width

64

Functional group

Identification

### **Reset value**

See individual bit resets.

### **Bit descriptions**

### Figure 2-2: AArch64\_ID\_ISAR5\_EL1 bit assignments



### Table 2-5: ID\_ISAR5\_EL1 bit descriptions

| Bits    | Name  | Description                                                                                                                                   | Reset |
|---------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------|
| [63:32] | RESO  | Reserved                                                                                                                                      | 0b0   |
| [31:28] | VCMA  | Indicates AArch32 support for complex number addition and multiplication where numbers are stored in vectors. Defined values are:             |       |
|         |       | 0b0001                                                                                                                                        |       |
|         |       | The VCMLA and VCADD instructions are implemented in AArch32.                                                                                  |       |
| [27:24] | RDM   | Indicates whether the VQRDMLAH and VQRDMLSH instructions are implemented in AArch32 state. Defined values are:                                |       |
|         |       | 0Ь0001                                                                                                                                        |       |
|         |       | VQRDMLAH and VQRDMLSH instructions implemented.                                                                                               |       |
| [23:20] | RESO  | Reserved                                                                                                                                      | 0b0   |
| [19:16] | CRC32 | Indicates whether the CRC32 instructions are implemented in AArch32 state.                                                                    |       |
|         |       | 060001                                                                                                                                        |       |
|         |       | CRC32B, CRC32H, CRC32W, CRC32CB, CRC32CH, and CRC32CW instructions implemented.                                                               |       |
| [15:12] | SHA2  | Indicates whether the SHA2 instructions are implemented in AArch32 state.                                                                     |       |
|         |       | 0ь0000                                                                                                                                        |       |
|         |       | When Cryptographic extensions are not implemented or disabled then SHA2 instructions are not implemented.                                     |       |
|         |       | 0b0001                                                                                                                                        |       |
|         |       | When Cryptographic extensions are implemented and enabled then SHA256H, SHA256H2, SHA256SU0, and SHA256SU1 instructions are implemented.      |       |
| [11:8]  | SHA1  | Indicates whether the SHA1 instructions are implemented in AArch32 state.                                                                     |       |
|         |       | 0Ъ0000                                                                                                                                        |       |
|         |       | When Cryptographic extensions are not implemented or disabled then SHA1 instructions are not implemented.                                     |       |
|         |       | 0b0001                                                                                                                                        |       |
|         |       | When Cryptographic extensions are implemented and enabled then SHA1C, SHA1P, SHA1M, SHA1H, SHA1SU0, and SHA1SU1 instructions are implemented. |       |
| [7:4]   | AES   | Indicates whether the AES instructions are implemented in AArch32 state.                                                                      |       |
|         |       | 0Ъ0000                                                                                                                                        |       |
|         |       | When Cryptographic extensions are not implemented or disabled then AES instructions are not implemented.                                      |       |
|         |       | 050010                                                                                                                                        |       |
|         |       | When Cryptographic extensions are implemented and enabled then AESE, AESD, AESMC, AESIMC and VMULL.64 instructions are implemented.           |       |

| Bits  | Name | Description                                                             | Reset |
|-------|------|-------------------------------------------------------------------------|-------|
| [3:0] | SEVL | Indicates whether the SEVL instruction is implemented in AArch32 state. |       |
|       |      | 0b0001                                                                  |       |
|       |      | SEVL is implemented as Send Event Local.                                |       |

### Access

MRS <Xt>, ID\_ISAR5\_EL1

| <systemreg></systemreg> | орО  | op1   | CRn   | CRm    | op2   |
|-------------------------|------|-------|-------|--------|-------|
| ID_ISAR5_EL1            | 0b11 | 00000 | 00000 | 0b0010 | 0b101 |

#### Accessibility

MRS <Xt>, ID\_ISAR5\_EL1

```
if PSTATE.EL == EL0 then
    if EL2Enabled() && HCR_EL2.TGE == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        AArch64.SystemAccessTrap(EL1, 0x18);
elsif PSTATE.EL == EL1 then
    if EL2Enabled() && HCR_EL2.TID3 == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    else
        return ID_ISAR5_EL1;
elsif PSTATE.EL == EL2 then
    return ID_ISAR5_EL1;
elsif PSTATE.EL == EL3 then
    return ID_ISAR5_EL1;
```

# Appendix A Document revisions

This appendix records the changes between released issues of this document.

### A.1 Revisions

Changes between released issues of this book are summarized in tables.

The first table is for the first release. Then, each table compares the new issue of the book with the last released issue of the book. Release numbers match the revision history in Release Information on page 2.

#### Table A-1: Issue 0000-01

| Change                      | Location |
|-----------------------------|----------|
| First beta release for rOpO | -        |

#### Table A-2: Differences between Issue 0000-01 and Issue 0000-02

| Change                                | Location |
|---------------------------------------|----------|
| First limited access release for rOpO | -        |

#### Table A-3: Differences between Issue 0000-02 and Issue 0100-03

| Change                                | Location |
|---------------------------------------|----------|
| First limited access release for r1p0 | -        |

#### Table A-4: Differences between Issue 0100-03 and Issue 0200-04

| Change                              | Location |
|-------------------------------------|----------|
| First early access release for r2p0 | -        |

#### Table A-5: Differences between Issue 0200-04 and Issue 0200-05

| Change                                 | Location |
|----------------------------------------|----------|
| Second early access release for r2p0 - | -        |

#### Table A-6: Differences between Issue 0200-05 and Issue 0201-06

| Change                 | Location |
|------------------------|----------|
| First release for r2p1 | -        |