# arm

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

Revision r0p4

## **Technical Reference Manual**

#### Non-Confidential

Issue 07

Copyright © 2021–2024 Arm Limited (or its affiliates).  $102519_{0004_{07_{en}}}$  All rights reserved.



# Arm® Cortex®-A520 Core Cryptographic Extension Technical Reference Manual

This document is Non-Confidential.

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

This document is protected by copyright and other intellectual property rights. Arm only permits use of this document if you have reviewed and accepted Arm's Proprietary Notice found at the end of this document.

This document (102519\_0004\_07\_en) was issued on 2024-11-08. There might be a later issue at https://developer.arm.com/documentation/102519

The product revision is r0p4.

See also: Proprietary Notice | Product and document information | Useful resources

#### Start Reading

If you prefer, you can skip to the start of the content.

#### 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>-A520 core with the optional Cryptographic Extension.

#### Inclusive language commitment

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

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

To report offensive language in this document, email terms@arm.com.

#### Feedback

Arm welcomes feedback on this product and its documentation. To provide feedback on the product, create a ticket on https://support.developer.arm.com.

To provide feedback on the document, fill the following survey: https://developer.arm.com/ documentation-feedback-survey.

# Contents

| 1. Cryptographic Extension support in the Cortex <sup>®</sup> -A520 core | 4  |
|--------------------------------------------------------------------------|----|
| 1.1 Disabling the Cryptographic Extension                                |    |
| 1.2 Product revisions                                                    |    |
| 2. AArch64 instruction identification system registers                   | 6  |
| 2.1 Cryptographic Extensions register summary                            | 6  |
| 2.2 ID_AA64ISAR0_EL1, AArch64 Instruction Set Attribute Register 0       | 6  |
| 2.3 ID_AA64ZFR0_EL1, SVE Feature ID register 0                           | 9  |
| Proprietary Notice                                                       |    |
| Product and document information                                         |    |
| Product status                                                           |    |
| Revision history                                                         |    |
| Conventions                                                              | 16 |
| Useful resources                                                         |    |

# 1. Cryptographic Extension support in the Cortex<sup>®</sup>-A520 core

The Cortex<sup>®</sup>-A520 core supports the optional Arm<sup>®</sup> Cryptographic Extension.

The Arm® Cryptographic Extension adds A64 instructions to Advanced SIMD to:

- Accelerate Advanced Encryption Standard (AES) encryption and decryption
- Implement the Secure Hash Algorithm (SHA) functions
- Perform Polynomial Multiply Long (PMULL) instructions

#### Supported features

The Arm<sup>®</sup> Cryptographic Extension supports the following features:

Table 1-1: Features supported by the Arm® Cryptographic Extension

| Feature           | Description                                          | Architecture version |
|-------------------|------------------------------------------------------|----------------------|
| FEAT_AES          | Advanced SIMD AES instructions                       | Arm®v8.0             |
| FEAT_PMULL        | Advanced SIMD PMULL instructions                     |                      |
| FEAT_SHA1         | Advanced SIMD SHA1 instructions                      |                      |
| FEAT_SHA256       | Advanced SIMD SHA256 instructions                    |                      |
| FEAT_SHA512       | Advanced SIMD SHA512 instructions                    | Arm®v8.2             |
| FEAT_SHA3         | Advanced SIMD EOR3, RAX1, XAR, and BCAX instructions |                      |
| FEAT_SM3          | Advanced SIMD SM3 instructions                       |                      |
| FEAT_SM4          | Advanced SIMD SM4 instructions                       |                      |
| FEAT_SVE_AES      | SVE AES instructions                                 | Arm®v9.0             |
| FEAT_SVE_PMULL128 | SVE PMULL instructions                               |                      |
| FEAT_SVE_SHA3     | SVE SHA3 instructions                                |                      |
| FEAT_SVE_SM4      | SVE SM4 instructions                                 |                      |

## 1.1 Disabling the Cryptographic Extension

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

To disable the Cryptographic Extension, assert the CRYPTODISABLE signal.

When the CRYPTODISABLE signal is asserted:

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

#### **Related information**

2.2 ID\_AA64ISAR0\_EL1, AArch64 Instruction Set Attribute Register 0 on page 6 2.3 ID\_AA64ZFR0\_EL1, SVE Feature ID register 0 on page 9

### **1.2 Product revisions**

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

#### Table 1-2: Product revisions

| Revision | Notes                                                                                                                |
|----------|----------------------------------------------------------------------------------------------------------------------|
| r0p0     | First limited access release                                                                                         |
| r0p1     | Added support for FEAT_ECBHB. Exploitative Control using Branch History Buffer information between exception levels. |
| r0p2     | Bug fixes                                                                                                            |
| r0p3     | Bug fixes                                                                                                            |
| r0p4     | Bug fix                                                                                                              |

Changes in functionality that have an impact on the documentation also appear in Revision history on page 14.

# 2. AArch64 instruction identification system registers

This chapter describes the ID\_AA64ISARO\_EL1 and ID\_AA64ZFRO\_EL1 registers. These identification registers provide information about the instructions implemented in the Cortex<sup>®</sup>-A520 core, including the instructions provided by the Cryptographic Extension.

## 2.1 Cryptographic Extensions register summary

The Cortex<sup>®</sup>-A520 core has a single instruction identification register, ID\_AA64ISAR0\_EL1. Software can identify the cryptographic instructions that are implemented by reading this register.

The following table shows the instruction identification register for the Cortex®-A520 core Cryptographic Extension.

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

| Name             | Description                                                                      |
|------------------|----------------------------------------------------------------------------------|
| ID_AA64ISAR0_EL1 | See 2.2 ID_AA64ISAR0_EL1, AArch64 Instruction Set Attribute Register 0 on page 6 |
| ID_AA64ZFR0_EL1  | See 2.3 ID_AA64ZFR0_EL1, SVE Feature ID register 0 on page 9                     |

## 2.2 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 in the Arm<sup>®</sup> Architecture Reference Manual for A-profile architecture.

#### 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 I | 59 |     | 56 | 55 52  | 51 | 48    | 47 |      | 44 | 43 |      | 40 | 39 |     | 36 | 35 |      | 32 |
|--------|------|------|----|-----|----|--------|----|-------|----|------|----|----|------|----|----|-----|----|----|------|----|
|        | RNDR |      |    | TLB |    | TS     |    | FHM   |    | DP   |    |    | SM4  |    |    | SM3 |    |    | SHA3 |    |
| -<br>L | 31   | 28   | 27 |     | 24 | 23 20  | 19 | 16    | 15 |      | 12 | 11 |      | 8  | 7  |     | 4  | 3  |      | 0  |
|        | RDM  |      |    | TME |    | Atomic |    | CRC32 |    | SHA2 |    |    | SHA1 |    |    | AES |    |    | res0 |    |

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

| Bits    | Name | Description                                                                                                                                                                        | Reset |
|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| [63:60] | RNDR | Indicates support for Random Number instructions in AArch64 state. Defined values are:                                                                                             |       |
|         |      | 0000                                                                                                                                                                               |       |
|         |      | No Random Number instructions are implemented.                                                                                                                                     |       |
| [59:56] | TLB  | Indicates support for Outer Shareable and TLB range maintenance instructions. Defined values are:                                                                                  |       |
|         |      | 0010                                                                                                                                                                               |       |
|         |      | Outer Shareable and TLB range maintenance instructions are implemented.                                                                                                            |       |
| [55:52] | TS   | Indicates support for flag manipulation instructions. Defined values are:                                                                                                          |       |
|         |      | 0010                                                                                                                                                                               |       |
|         |      | CFINV, RMIF, SETF16, SETF8, AXFLAG, and XAFLAG instructions are implemented.                                                                                                       |       |
| [51:48] | FHM  | Indicates support for FMLAL and FMLSL instructions. Defined values are:                                                                                                            |       |
|         |      | 0001                                                                                                                                                                               |       |
|         |      | FMLAL and FMLSL instructions are implemented.                                                                                                                                      |       |
| [47:44] | DP   | Indicates support for Dot Product instructions in AArch64 state. Defined values are:                                                                                               |       |
|         |      | 0001                                                                                                                                                                               |       |
|         |      | UDOT and SDOT instructions are implemented.                                                                                                                                        |       |
| [43:40] | SM4  | Indicates support for SM4 instructions in AArch64 state. Defined values are:                                                                                                       |       |
|         |      | 0000                                                                                                                                                                               |       |
|         |      | No SM4 instructions are implemented. This value is reported when Cryptographic Extension is not implemented or is disabled.                                                        |       |
|         |      | 0001                                                                                                                                                                               |       |
|         |      | SM4E and SM4EKEY instructions are implemented. This value is reported when Cryptographic Extension is implemented and enabled.                                                     |       |
| [39:36] | SM3  | Indicates support for SM3 instructions in AArch64 state. Defined values are:                                                                                                       |       |
|         |      | 0000                                                                                                                                                                               |       |
|         |      | No SM3 instructions are implemented. This value is reported when Cryptographic Extension is not implemented or is disabled.                                                        |       |
|         |      | 0001                                                                                                                                                                               |       |
|         |      | SM3SS1, SM3TT1A, SM3TT1B, SM3TT2A, SM3TT2B, SM3PARTW1, and SM3PARTW2 instructions are implemented. This value is reported when Cryptographic Extension is implemented and enabled. |       |

| Bits    | Name   | Description                                                                                                                                                                                        | Reset |
|---------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| [35:32] | SHA3   | Indicates support for SHA3 instructions in AArch64 state. Defined values are:                                                                                                                      |       |
|         |        | 0000                                                                                                                                                                                               |       |
|         |        | No SHA3 instructions are implemented. This value is reported when Cryptographic Extension is not implemented or is disabled.                                                                       |       |
|         |        | 0001                                                                                                                                                                                               |       |
|         |        | EOR3, RAX1, XAR, and BCAX instructions are implemented. This value is reported when Cryptographic<br>Extension is implemented and enabled.                                                         |       |
| [31:28] | RDM    | Indicates support for SQRDMLAH and SQRDMLSH instructions in AArch64 state. Defined values are:                                                                                                     |       |
|         |        | 0001                                                                                                                                                                                               |       |
|         |        | SQRDMLAH and SQRDMLSH instructions are implemented.                                                                                                                                                |       |
| [27:24] | TME    | Indicates support for TME instructions. Defined values are:                                                                                                                                        |       |
|         |        | 0000                                                                                                                                                                                               |       |
|         |        | TME instructions are not implemented.                                                                                                                                                              |       |
| [23:20] | Atomic | Indicates support for Atomic instructions in AArch64 state. Defined values are:                                                                                                                    |       |
|         |        | 0010                                                                                                                                                                                               |       |
|         |        | LDADD, LDCLR, LDEOR, LDSET, LDSMAX, LDSMIN, LDUMAX, LDUMIN, CAS, CASP, and SWP instructions are implemented.                                                                                       |       |
| [19:16] | CRC32  | CRC32 instructions are implemented in AArch64 state. Defined values are:                                                                                                                           |       |
|         |        | 0001                                                                                                                                                                                               |       |
|         |        | CRC32B, CRC32H, CRC32W, CRC32X, CRC32CB, CRC32CH, CRC32CW, and CRC32CX instructions are implemented.                                                                                               |       |
| [15:12] | SHA2   | SHA2 instructions are implemented in AArch64 state. Defined values are:                                                                                                                            |       |
|         |        | 0000                                                                                                                                                                                               |       |
|         |        | No SHA2 instructions are implemented. This value is reported when Cryptographic Extension is not implemented or is disabled.                                                                       |       |
|         |        | 0010                                                                                                                                                                                               |       |
|         |        | SHA256H, SHA256H2, SHA256SU0, SHA256SU1, SHA512H, SHA512H2, SHA512SU0, and SHA512SU1 instructions are implemented. This value is reported when Cryptographic Extension is implemented and enabled. |       |
|         |        | When the CRYPTO configuration parameter is true and the CRYPTODISABLE input is low at reset Cryptographic Extension is implemented.                                                                |       |
| [11:8]  | SHA1   | SHA1 instructions are implemented in AArch64 state. Defined values are:                                                                                                                            |       |
|         |        | 0000                                                                                                                                                                                               |       |
|         |        | No SHA1 instructions are implemented. This value is reported when Cryptographic Extension is not implemented or is disabled.                                                                       |       |
|         |        | 0001                                                                                                                                                                                               |       |
|         |        | SHA1C, SHA1P, SHA1M, SHA1H, SHA1SUO, and SHA1SU1 instructions are implemented. This value is reported when Cryptographic Extension is implemented and enabled.                                     |       |
|         |        | When the CRYPTO configuration parameter is true and the CRYPTODISABLE input is low at reset Cryptographic Extension is implemented.                                                                |       |

| Bits  | Name | Description                                                                                                                                                                                           | Reset |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| [7:4] | AES  | AES instructions are implemented in AArch64 state. Defined values are:                                                                                                                                |       |
|       |      | 0000<br>No AES instructions are implemented. This value is reported when Cryptographic Extension is not<br>implemented or is disabled.                                                                |       |
|       |      | AESE, AESD, AESMC, and AESIMC instructions are implemented plus PMULL/PMULL2 instructions are operating on 64-bit data quantities. This value is reported when Cryptographic Extension is implemented |       |
|       |      | When the CRYPTO configuration parameter is true and the CRYPTODISABLE input is low at reset Cryptographic Extension is implemented.                                                                   |       |
| [3:0] | RESO | Reserved                                                                                                                                                                                              | 0b0   |

#### Access

MRS <Xt>, ID\_AA64ISAR0\_EL1

| <systemreg></systemreg> | op0 op1 |       | CRn   | CRm    | op2   |  |
|-------------------------|---------|-------|-------|--------|-------|--|
| ID_AA64ISAR0_EL1        | 0b11    | 00000 | 00000 | 0b0110 | 00000 |  |

#### 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.3 ID\_AA64ZFR0\_EL1, SVE Feature ID register 0

Provides additional information about the implemented features of the AArch64 Scalable Vector Extension, when the AArch64-ID\_AA64PFR0\_EL1.SVE field is not zero.

For general information about the interpretation of the ID registers, see Principles of the ID scheme for fields in ID registers in the Arm<sup>®</sup> Architecture Reference Manual for A-profile architecture.

#### 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\_aa64zfr0\_el1 bit assignments



#### Table 2-4: ID\_AA64ZFR0\_EL1 bit descriptions

| Bits    | Name | Description                                                                                                                         | Reset |
|---------|------|-------------------------------------------------------------------------------------------------------------------------------------|-------|
| [63:48] | RESO | Reserved                                                                                                                            | 0b0   |
| [47:44] | 18MM | Indicates support for SVE Int8 matrix multiplication instructions. Defined values are:                                              |       |
|         |      | 0001                                                                                                                                |       |
|         |      | SMMLA, SUDOT, UMMLA, USMMLA, and USDOT instructions are implemented.                                                                |       |
| [43:40] | SM4  | Indicates support for SVE2 SM4 instructions. Defined values are:                                                                    |       |
|         |      | 0000                                                                                                                                |       |
|         |      | SVE2 SM4 instructions are not implemented. This value is reported when Cryptographic Extension is not implemented or is disabled.   |       |
|         |      | 0001                                                                                                                                |       |
|         |      | SVE2 SM4E and SM4EKEY instructions are implemented. This value is reported when Cryptographic Extension is implemented and enabled. |       |
| [39:36] | RESO | Reserved                                                                                                                            | 0b0   |
| [35:32] | SHA3 | Indicates support for the SVE2 SHA-3 instruction. Defined values are:                                                               |       |
|         |      | 0000                                                                                                                                |       |
|         |      | SVE2 SHA-3 instructions are not implemented. This value is reported when Cryptographic Extension is not implemented or is disabled. |       |
|         |      | 0001                                                                                                                                |       |
|         |      | SVE2 RAX1 instruction is implemented. This value is reported when Cryptographic Extension is implemented and enabled.               |       |
| [31:24] | RESO | Reserved                                                                                                                            | 0b0   |
| [23:20] | BF16 | Indicates support for SVE BFloat16 instructions. Defined values are:                                                                |       |
|         |      | 0001                                                                                                                                |       |
|         |      | BFCVT, BFCVTNT, BFDOT, BFMLALB, BFMLALT, and BFMMLA instructions are implemented.                                                   |       |

| Bits    | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                           | Reset |
|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| [19:16] | BitPerm | Indicates support for SVE2 bit permute instructions. Defined values are:                                                                                                                                                                                                                                                                                                                                              |       |
|         |         | 0001                                                                                                                                                                                                                                                                                                                                                                                                                  |       |
|         |         | SVE2 BDEP, BEXT, and BGRP instructions are implemented.                                                                                                                                                                                                                                                                                                                                                               |       |
| [15:8]  | RESO    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                              | 0b0   |
| [7:4]   | AES     | Indicates support for SVE2-AES instructions. Defined values are:                                                                                                                                                                                                                                                                                                                                                      |       |
|         |         | <ul> <li><b>0000</b></li> <li>SVE2-AES instructions are not implemented. This value is reported when Cryptographic Extension is not implemented or is disabled.</li> <li><b>0010</b></li> <li>SVE2 AESE, AESD, AESMC, and AESIMC instructions are implemented plus SVE2 PMULLB and PMULLT instructions with 64-bit source. This value is reported when Cryptographic Extension is implemented and enabled.</li> </ul> |       |
| [3:0]   | SVEver  | Scalable Vector Extension instruction set version. Defined values are:<br><b>0001</b><br>SVE and the non-optional SVE2 instructions are implemented.                                                                                                                                                                                                                                                                  |       |

#### Access

MRS <Xt>, ID\_AA64ZFR0\_EL1

| <systemreg></systemreg> | op0 op1 |       | CRn   | CRm    | ор2   |  |
|-------------------------|---------|-------|-------|--------|-------|--|
| ID_AA64ZFR0_EL1         | 0b11    | 00000 | 00000 | 0b0100 | 0b100 |  |

#### Accessibility

MRS <Xt>, ID\_AA64ZFR0\_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_AA642FR0_EL1;
elsif PSTATE.EL == EL2 then
    return ID_AA642FR0_EL1;
elsif PSTATE.EL == EL3 then
    return ID_AA642FR0_EL1;
```

## **Proprietary Notice**

This document is protected by copyright and other related rights and the use 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 Limited ("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 the subject matter of this document infringes any third party patents.

The content of this document is informational only. Any solutions presented herein are subject to changing conditions, information, scope, and data. This document was produced using reasonable efforts based on information available as of the date of issue of this document. The scope of information in this document may exceed that which Arm is required to provide, and such additional information is merely intended to further assist the recipient and does not represent Arm's view of the scope of its obligations. You acknowledge and agree that you possess the necessary expertise in system security and functional safety and that you shall be solely responsible for compliance with all legal, regulatory, safety and security related requirements concerning your products, notwithstanding any information or support that may be provided by Arm herein. In addition, you are responsible for any applications which are used in conjunction with any Arm technology described in this document, and to minimize risks, adequate design and operating safeguards should be provided for by you.

This document may include technical inaccuracies or typographical errors. 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, any patents, copyrights, trade secrets, trademarks, or other rights.

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.

Reference by Arm to any third party's products or services within this document is not an express or implied approval or endorsement of the use thereof.

This document consists solely of commercial items. You shall be responsible for ensuring that any permitted 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.

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 this document shall prevail.

The validity, construction and performance of this notice shall be governed by English Law.

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

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

PRE-1121-V1.0

## **Product and document information**

Read the information in these sections to understand the release status of the product and documentation, and the conventions used in the Arm documents.

## **Product status**

All products and Services provided by Arm require deliverables to be prepared and made available at different levels of completeness. The information in this document indicates the appropriate level of completeness for the associated deliverables.

#### Product completeness status

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

#### **Product revision status**

This product is r0p4, which indicates the revision status of the product described in this manual, where:

r (value)Identifies the major revision of the product, for example, r1.p (value)Identifies the minor revision or modification status of the product, for<br/>example, p2.

## **Revision history**

These sections can help you understand how the document has changed over time.

#### Document release information

The Document history table gives the issue number and the released date for each released issue of this document.

| Issue   | Date             | Confidentiality  | Change                               |
|---------|------------------|------------------|--------------------------------------|
| 0004-07 | 8 November 2024  | Non-Confidential | First release for rOp4               |
| 0003-06 | 30 April 2024    | Non-Confidential | First release for rOp3               |
| 0002-05 | 15 December 2023 | Non-Confidential | First early access release for rOp2  |
| 0001-04 | 29 May 2023      | Non-Confidential | Second early access release for rOp1 |
| 0001-03 | 29 July 2022     | Confidential     | First early access release for rOp1  |

#### Document history

| Issue   | Date             | Confidentiality | Change                                |
|---------|------------------|-----------------|---------------------------------------|
| 0000-02 | 8 April 2022     | Confidential    | First limited access release for rOpO |
| 0000-01 | 15 November 2021 | Confidential    | First beta release for rOpO           |

The Change history tables describe the technical changes between released issues of this document in reverse order. Issue numbers match the revision history in Document release information on page 14.

#### Table 2: Issue 0000-01

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

#### Table 3: Differences between issue 0000-01 and issue 0000-02

| Change                                | Location                |
|---------------------------------------|-------------------------|
| First limited access release for rOpO | -                       |
| Fixed typographical errors            | Throughout the document |

#### Table 4: Differences between issue 0000-02 and issue 0001-03

| Change                              | Location                |
|-------------------------------------|-------------------------|
| First early access release for rOp1 | -                       |
| Fixed typographical errors          | Throughout the document |

#### Table 5: Differences between issue 0001-03 and issue 0001-04

| Change                               | Location                |
|--------------------------------------|-------------------------|
| Second early access release for rOp1 | -                       |
| Editorial changes                    | Throughout the document |
| Updated product name                 | Throughout the document |

#### Table 6: Differences between issue 0001-04 and issue 0002-05

| Change                              | Location                |
|-------------------------------------|-------------------------|
| First early access release for rOp2 | -                       |
| Editorial changes                   | Throughout the document |

#### Table 7: Differences between issue 0002-05 and issue 0003-06

| Change                 | Location                |
|------------------------|-------------------------|
| First release for rOp3 | -                       |
| Editorial changes      | Throughout the document |

#### Table 8: Differences between issue 0003-06 and issue 0004-07

| Change                 | Location                |
|------------------------|-------------------------|
| First release for rOp4 | -                       |
| Editorial changes      | Throughout the document |

Copyright © 2021–2024 Arm Limited (or its affiliates). All rights reserved. Non-Confidential

### Conventions

The following subsections describe conventions used in Arm documents.

#### Glossary

The Arm 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

Arm documentation uses typographical conventions to convey specific meaning.

| Convention                 | Use                                                                                                                                                                                                            |  |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| italic                     | Citations.                                                                                                                                                                                                     |  |
| bold                       | Terms in descriptive lists, where appropriate.                                                                                                                                                                 |  |
| monospace                  | Text that you can enter at the keyboard, such as commands, file and program names, and source code.                                                                                                            |  |
| monospace <u>underline</u> | A permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name.                                                                                |  |
| <and></and>                | Encloses replaceable terms for assembler syntax where they appear in code or code fragments.<br>For example:                                                                                                   |  |
|                            | MRC p15, 0, <rd>, <crn>, <crm>, <opcode_2></opcode_2></crm></crn></rd>                                                                                                                                         |  |
| SMALL CAPITALS             | Terms that have specific technical meanings as defined in the <i>Arm® Glossary</i> . For example, <b>IMPLEMENTATION DEFINED</b> , <b>IMPLEMENTATION SPECIFIC</b> , <b>UNKNOWN</b> , and <b>UNPREDICTABLE</b> . |  |



We recommend the following. If you do not follow these recommendations your system might not work.



Your system requires the following. If you do not follow these requirements your system will not work.



You are at risk of causing permanent damage to your system or your equipment, or of harming yourself.



This information is important and needs your attention.



This information might help you perform a task in an easier, better, or faster way.



This information reminds you of something important relating to the current content.

#### 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: 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.

## Useful resources

This document contains information that is specific to this product. See the following resources for other useful information.

Access to Arm documents depends on their confidentiality:

- Non-Confidential documents are available at developer.arm.com/documentation. Each document link in the following tables goes to the online version of the document.
- Confidential documents are available to licensees only through the product package.

| Arm product resources                                                                | Document ID | Confidentiality  |
|--------------------------------------------------------------------------------------|-------------|------------------|
| Arm <sup>®</sup> Cortex <sup>®</sup> -A520 Core Configuration and Integration Manual | 102518      | Confidential     |
| Arm <sup>®</sup> Cortex <sup>®</sup> -A520 Core Technical Reference Manual           | 102517      | Non-Confidential |
| Arm <sup>®</sup> Cortex <sup>®</sup> -A520 Core Release Note                         | -           | Confidential     |

| Arm architecture and specifications                                       | Document ID | Confidentiality  |
|---------------------------------------------------------------------------|-------------|------------------|
| Arm <sup>®</sup> Architecture Reference Manual for A-profile architecture | DDI 0487    | Non-Confidential |

| Non-Arm resources            | Document ID             | Organization                                              |
|------------------------------|-------------------------|-----------------------------------------------------------|
| Advanced Encryption Standard | FIPS 197, November 2001 | The National Institute of Standards and Technology (NIST) |
|                              |                         | www.nist.gov                                              |
| Secure Hash Standard (SHS)   | FIPS 180-4, August 2015 | The National Institute of Standards and Technology (NIST) |
|                              |                         | www.nist.gov                                              |
| Secure Hash Standard (SHS)   | FIPS 202, August 2015   | The National Institute of Standards and Technology (NIST) |
|                              |                         | www.nist.gov                                              |