

# **Arm®** Architecture Reference Manual Supplement, Armv9-A

### Known issues in Issue B.a

Non-Confidential

Issue 02

Copyright © 2021–2022 Arm Limited (or its affiliates).  $102527_B.a_02_en$  All rights reserved.



## Arm® Architecture Reference Manual Supplement, Armv9-A Known issues in Issue B.a

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

### Release information

#### **Document history**

| Issue      | Date                    | Confidentiality      | Change                                                                                                     |
|------------|-------------------------|----------------------|------------------------------------------------------------------------------------------------------------|
| A.a-       | 14 May                  | Non-                 | Known Issues in Arm® Architecture Reference Manual Supplement, Armv9-A, Issue A.a, as of 14 May 2021       |
| 00         | 2021                    | Confidential         |                                                                                                            |
| A.a-       | 30 June                 | Non-                 | Known Issues in Arm® Architecture Reference Manual Supplement, Armv9-A, Issue A.a, as of 18 June 2021      |
| 01         | 2021                    | Confidential         |                                                                                                            |
| A.a-       | 30 July                 | Non-                 | Known Issues in Arm® Architecture Reference Manual Supplement, Armv9-A, Issue A.a, as of 23 July 2021      |
| 02         | 2021                    | Confidential         |                                                                                                            |
| A.a-<br>03 | 30<br>September<br>2021 | Non-<br>Confidential | Known Issues in Arm® Architecture Reference Manual Supplement, Armv9-A, Issue A.a, as of 17 September 2021 |
| A.a-<br>04 | 29<br>October<br>2021   | Non-<br>Confidential | Known Issues in Arm® Architecture Reference Manual Supplement, Armv9-A, Issue A.a, as of 22 October 2021   |
| A.a-<br>05 | 30<br>November<br>2021  | Non-<br>Confidential | Known Issues in Arm® Architecture Reference Manual Supplement, Armv9-A, Issue A.a, as of 19 November 2021  |
| A.a-       | 31 January              | Non-                 | Known Issues in Arm® Architecture Reference Manual Supplement, Armv9-A, Issue A.a, as of 7 January 2022    |
| 06         | 2022                    | Confidential         |                                                                                                            |
| B.a-<br>00 | 28<br>February<br>2022  | Non-<br>Confidential | Known Issues in Arm® Architecture Reference Manual Supplement, Armv9-A, Issue B.a, as of 18 February 2022  |
| B.a-       | 29 April                | Non-                 | Known Issues in Arm® Architecture Reference Manual Supplement,                                             |
| 01         | 2022                    | Confidential         | Armv9-A, Issue B.a, as of 22 April 2022                                                                    |
| B.a-       | 31 May                  | Non-                 | Known Issues in Arm® Architecture Reference Manual Supplement, Armv9-A, Issue B.a, as of 20 May 2022       |
| 02         | 2022                    | Confidential         |                                                                                                            |

### **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, 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.

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 ™ 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 © 2021–2022 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.

#### **Product Status**

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

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

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

We believe that this document contains no offensive language. To report offensive language in this document, email terms@arm.com.

### **Contents**

| 1 Introduction                                |    |
|-----------------------------------------------|----|
| 1.1 Conventions                               | 6  |
| 1.2 Additional reading                        | 7  |
| 1.3 Other information                         | 7  |
| 2 Known issues                                | 8  |
| 2.1 The Transactional Memory Extension        | 8  |
| 2.2 The Embedded Trace Extension (ETE)        | 8  |
| 2.2.1 D1416                                   |    |
| 2.2.2 R1419                                   | 8  |
| 2.2.3 D1438                                   | 9  |
| 2.3 The Trace Buffer Extension (TRBE)         | 9  |
| 2.3.1 R1291                                   | 9  |
| 2.3.2 D1393                                   | 10 |
| 2.3.3 D1399                                   | 10 |
| 2.4 The Branch Record Buffer Extension (BRBE) | 11 |
| 2.4.1 C1306                                   | 11 |
| 2.4.2 R1391                                   | 11 |
| 2.4.3 D1/36                                   | 12 |

### 1 Introduction

### 1.1 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                                                                                                                                                            | Interface elements, such as menu names.                                                                                         |  |
|                                                                                                                                                                 | Signal names.                                                                                                                   |  |
|                                                                                                                                                                 | 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 bold                                                                                                                                                  | Language keywords when used outside example 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.                                    |  |
|                                                                                                                                                                 | For example:                                                                                                                    |  |
|                                                                                                                                                                 | MRC p15, 0, <rd>, <crn>, <opcode_2></opcode_2></crn></rd>                                                                       |  |
| Terms that have specific technical meanings as defined in the Arm® Glossary. For examplementation defined, implementation specific, unknown, and unpredictable. |                                                                                                                                 |  |
| Caution                                                                                                                                                         | Recommendations. Not following these recommendations might lead to system failure or damage.                                    |  |
| Warning                                                                                                                                                         | Requirements for the system. Not following these requirements might result in system failure or damage.                         |  |
| Danger                                                                                                                                                          | Requirements for the system. Not following these requirements will result in system failure or damage.                          |  |

| Convention | Use                                                                                |  |
|------------|------------------------------------------------------------------------------------|--|
| Note       | An important piece of information that needs your attention.                       |  |
| Tip        | A useful tip that might make it easier, better or faster to perform a task.        |  |
| Remember   | A reminder of something important that relates to the information you are reading. |  |

### 1.2 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® Architecture Reference Manual | DDI 0608B.a | No            |
| Supplement, Armv9-A, Issue B.a     |             |               |



Arm tests its PDFs only in Adobe Acrobat and Acrobat Reader. Arm cannot guarantee the quality of its documents when used with any other PDF reader.

Adobe PDF reader products can be downloaded at http://www.adobe.com

### 1.3 Other information

See the Arm website for other relevant information.

- Arm® Developer.
- Arm® Documentation.
- Technical Support.
- Arm® Glossary.

### 2 Known issues

This document records known issues in the Arm Architecture Reference Manual Supplement, Armv9-A (DDI 0608), Issue B.a.

This document lists the known issues in the architectural rules content only. For a list of known issues in the register, instruction, and pseudocode XML, please see https://developer.arm.com/architectures/cpu-architecture/a-profile/exploration-tools.

#### Key

- C = Clarification.
- D = Defect.
- R = Relaxation.
- E = Enhancement.

### 2.1 The Transactional Memory Extension

No issues.

### 2.2 The Embedded Trace Extension (ETE)

The known issues in the FTF architecture are listed below:

#### 2.2.1 D1416

In section D5.9 (Timestamp Packet), in the description of the COUNT field, the following text is added:

When the COUNT field is not present, the cycle count value is **unknown**.

### 2.2.2 R1419

In section D6.9.16 (Timestamp Element), the rule that reads:

R<sub>HZSYP</sub> When a timestamp request occurs and ViewInst is inactive, the timestamp request is permitted to be delayed until the first of the following occurs:

- ViewInst becomes active.
- An Event element is generated.

is changed to read:

R<sub>HZSYP</sub> When a timestamp request occurs and ViewInst is inactive, the timestamp request is permitted to be delayed until after the first of the following occurs:

- A PO element is generated.
- An Event element is generated.

#### 2.2.3 D1438

In section D8.1.2 (System instructions), the text in R<sub>VGVTS</sub> that reads:

Instructions with CRn >= 0b1000 are **undefined**.

is changed to read:

Instructions with CRn ≥ 0b1000 are not allocated for accessing trace unit registers.

### 2.3 The Trace Buffer Extension (TRBE)

The known issues in the TRBE architecture are listed below:

#### 2.3.1 R1291

In section E1.2.2.4 (Faults), the following entry titled 'External abort on translation table walk or translation table update' is added to rule  $R_{OKLXR}$ :

The translation of a virtual address to a physical address might generate an External abort on the translation table walk or translation table update, and is treated as a synchronous MMU fault. See also E1.2.2.5 External aborts.

In the same section, in rule R<sub>FSPBK</sub>, the following text is added:

If a write by the Trace Buffer Unit generates an External abort on a translation table walk or translation table update, it is **IMPLEMENTATION DEFINED** whether TRBSR\_EL1.EA is set to 0b1 or unchanged.

In section E1.2.2.5 (External aborts), in rule R<sub>DJLWB</sub>, the entry 'External abort on translation table walk or translation table update' is extended as follows:

An External abort on a translation table walk or translation table update might be treated as a synchronous MMU fault. See E1.2.2.4 Faults.

#### 2.3.2 D1393

In section E1.2.2 (Trace buffer management), rule R<sub>JLZDN</sub> that reads:

The Trigger Event trace buffer management event initiates a trace unit flush meaning other trace might be written to the trace buffer. This might cause a second trace buffer management event to be generated before Collection is stopped by the Trigger Event trace buffer management event.

is corrected to read:

When the trigger mode is *Stop on Trigger*, a *Trigger Event* initiates a trace unit flush meaning more trace might be written to the trace buffer before any Collection is stopped by the Trigger Event trace buffer management event. This additional trace might cause a second trace buffer management event to be generated before the Trigger Event trace buffer management event.

#### 2.3.3 D1399

In section E1.2.1.3 (Address translation disabled), the text in R<sub>FJKLW</sub> that reads:

If TRBLIMITR\_EL1.nVM is 0b1, TRBMAR\_EL1 defines the memory type, and, as applicable, Cacheability, Shareability, and Device type attributes, for the stage 1 output addresses.

is corrected to read:

If TRBLIMITR\_EL1.nVM is 0b1, then unless overridden by stage 2 controls, TRBMAR\_EL1 defines the memory type, and, as applicable, Cacheability, Shareability, and Device type attributes, for the stage 1 output addresses.

In section E1.2.1.4 (Stage 2 translation), the example in I<sub>ZSDMR</sub> that reads:

• If the Effective value of HCR\_EL2.DC in the owning translation regime is 0b1, then stage 1 translation is disabled and the memory type produced by stage 1 is Normal Non-shareable, Inner Write-Back Cacheable Read-Allocate Write-Allocate, Outer Write-Back Cacheable Read-Allocate Write-Allocate, regardless of the value of SCTLR EL1.C.

is extended to read:

• If the Effective value of HCR\_EL2.DC in the owning translation regime is 0b1, then stage 1 translation is disabled and the memory type produced by stage 1 is Normal Nonshareable, Inner Write-Back Cacheable Read-Allocate Write-Allocate, Outer Write-Back Cacheable Read-Allocate Write-Allocate, regardless of the values of SCTLR\_EL1.C and, if TRBLIMITR\_EL1.nVM is 0b1, TRBMAR\_EL1.

### 2.4 The Branch Record Buffer Extension (BRBE)

The known issues in the BRBE architecture are listed below:

#### 2.4.1 C1306

In section F1.1.9.1 (Filtering on type), rule R<sub>FIYDC</sub> that currently reads:

It is **IMPLEMENTATION DEFINED** whether Branch records are generated for the following instructions when the instruction is executed in a non prohibited region and if any of the following are true:

is updated to read:

It is **IMPLEMENTATION DEFINED** whether Branch records are generated for the following unconditional direct branch instructions when the instruction is executed in a non-prohibited region and if any of the following are true:

Within the same section, the title of Table F1.10 is updated to 'Optional A64 unconditional direct branch instructions'.

#### 2.4.2 R1391

Two new Rules items and one Information item are added to section F1.1.13.1 (Manual injection of Branch records):

Rule: When a BRB INJ instruction is executed inside a BRBE Prohibited region and the contents of the Branch record injection data registers indicates an invalid record, it is **CONSTRAINED UNPREDICTABLE** whether a Branch record is injected to the Branch record buffer. An invalid record is one with BRBINFINJ EL1.VALID set to 0b00.

Rule: When all of the following are true for a BRB INJ instruction, it is **CONSTRAINED UNPREDICTABLE** whether a Branch record is injected to the Branch record buffer, and if a Branch record is injected then the contents of the Branch record are **CONSTRAINED UNPREDICTABLE**:

- The BRB INJ instruction is executed inside a BRBE Prohibited region.
- The contents of the Branch record injection data registers indicates a valid record.
- The other contents of the Branch record injection data registers indicate an incorrectly formatted record.

Information: An example of an incorrectly formatted record is one where BRBINFINJ\_EL1.VALID is 0b01 and BRBINFINJ\_EL1.MPRED is 0b1.

### 2.4.3 D1436

In section F1.1.10 (Branch record buffer operation), the text in rule  $R_{QKQZL}$  that reads:

If any of the following are true, the physical offset is zero, otherwise the physical offset is the value of CNTVOFF\_EL2:

is updated to read:

If any of the following are true, the physical offset is zero, otherwise the physical offset is the value of CNTPOFF\_EL2: