

### Arm\_Cortex\_A510 (MP111)

## **Software Developer Errata Notice**

Date of issue: 27-Jun-2022

Non-Confidential Document version: v14.0

This document contains all known errata since the rOpO release of the product.



#### Non-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, 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 <sup>®</sup> 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 <a href="https://www.arm.com/company/policies/trademarks">https://www.arm.com/company/policies/trademarks</a>.

Copyright © 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.

Unrestricted Access is an Arm internal classification.

#### Feedback

Arm welcomes feedback on this product and its documentation. To provide feedback on Arm\_Cortex\_A510 (MP111), create a ticket on https://support.developer.arm.com.

To provide feedback on the document, fill the following survey: <a href="https://developer.arm.com/documentation-feedback-survey">https://developer.arm.com/documentation-feedback-survey</a>.

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

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

## **Contents**

| r1p1 imp  | lementati  | ion fixes                                                                                                     | 12 |
|-----------|------------|---------------------------------------------------------------------------------------------------------------|----|
| r1p0 imp  | lementati  | ion fixes                                                                                                     | 12 |
| r0p3 imp  | lementati  | ion fixes                                                                                                     | 12 |
| r0p2 imp  | lementati  | ion fixes                                                                                                     | 12 |
| r0p1 imp  | lementati  | ion fixes                                                                                                     | 13 |
| r0p0 imp  | lementati  | ion fixes                                                                                                     | 13 |
| Introduct | ion        |                                                                                                               | 15 |
| Scope     | е          |                                                                                                               | 15 |
| Categ     | gorization | of errata                                                                                                     | 15 |
| Change C  | Control    |                                                                                                               | 16 |
| Errata su | mmary ta   | ble                                                                                                           | 26 |
| Errata de | scriptions | S                                                                                                             | 39 |
| Categ     | gory A     |                                                                                                               | 39 |
| 1         | 914417     | Coherency may be lost                                                                                         | 39 |
| 1         | 921103     | TLBI completion might not be guaranteed by DSB                                                                | 40 |
| 1         | 927171     | Mismatched memory attributes might cause deadlock                                                             | 41 |
| 1         | 943861     | Acquire/release semantics violated on store atomic instructions                                               | 42 |
| 1         | 946214     | Heavy L2 memory traffic may lead to data corruption and deadlock                                              | 43 |
| 1         | 968719     | Snoops might lead to a deadlock                                                                               | 44 |
| 1         | 970520     | Secure Physical Address Cache Invalidate all DVM operation does not invalidate Non-Secure lines in L1 I-Cache | 45 |
| 1         | 996706     | A deadlock might occur during or after WFI or WFE                                                             | 46 |
| 2         | 007174     | Heavy store traffic might lead to a DSB not completing on the same core or another core                       | 47 |
| 2         | 039708     | Non-cacheable stores, maintenance, or speculation restriction instructions might cause a deadlock             | 48 |
| 2         | 069773     | Forwarding snoops might cause a deadlock                                                                      | 49 |
| 2         | 184257     | Normal execution can result in data corruption                                                                | 50 |
| 2         | 217821     | Heavy I-cache invalidation or TLB invalidation traffic from other PEs can cause a deadlock                    | 52 |
| 2         | 454944     | Unmodified cache line might be written back to memory                                                         | 53 |
| Categ     | gory A (ra | re)                                                                                                           | 54 |
| 1         | 965350     | Coherency might be lost on a cache line                                                                       | 54 |
| 1         | 975996     | Non-L1-allocating stores might cause data corruption                                                          | 55 |

| Ca | itegory B |                                                                                                                                      | 56 |
|----|-----------|--------------------------------------------------------------------------------------------------------------------------------------|----|
|    | 1902691   | Trace Buffer Extension can cause trace corruption or deadlock                                                                        | 56 |
|    | 1910738   | Use of tagged memory might cause deadlock, data corruption or incorrect reporting                                                    | 57 |
|    | 1922240   | SnpPreferUnique* might lead to a loss of coherency                                                                                   | 58 |
|    | 1937669   | Tag Checked store might not be correctly ordered by DMB                                                                              | 59 |
|    | 1942494   | A cacheable load of SIMD&FP or SVE registers might return incorrect data                                                             | 60 |
|    | 1943339   | Cacheable far atomics might result in loss of coherency                                                                              | 62 |
|    | 1952872   | A cacheable load might return incorrect data                                                                                         | 63 |
|    | 1955641   | Core in FULL_RET might cause data corruption                                                                                         | 64 |
|    | 1956116   | Missing trace for debug entry due to watchpoint hit                                                                                  | 65 |
|    | 1961781   | Watchpoints on SVE first-fault and non-fault loads might cause an incorrect value to be loaded and/or an incorrect MTE check results | 66 |
|    | 1962857   | Set/way maintenance of L2 cache might cause data corruption                                                                          | 68 |
|    | 1966377   | Incorrect instructions might be executed                                                                                             | 69 |
|    | 1975068   | Cacheable Non-shareable mappings might lead to CHI protocol violations                                                               | 70 |
|    | 1977575   | Coherency might be lost on a cache line shortly after a core powers up                                                               | 71 |
|    | 1981843   | A store exclusive to shareable memory other than Normal Inner Write-Back, Outer Write-Back Cacheable might cause a hang              | 72 |
|    | 2008766   | RAS errors during core power down might cause a deadlock                                                                             | 73 |
|    | 2014530   | Debug accesses while leaving OFF_EMU power mode might lead to a system deadlock                                                      | 75 |
|    | 2015106   | Memory mapped accesses to MPMM registers have the wrong offset                                                                       | 76 |
|    | 2022138   | Core in FULL_RET might not have clock gated                                                                                          | 77 |
|    | 2027318   | SnpPreferUnique might lead to a loss of coherency                                                                                    | 79 |
|    | 2028010   | A PRF{U}M instruction might hang                                                                                                     | 80 |
|    | 2038114   | EDSCR.STATUS might be incorrect when single stepping a Load-Exclusive instruction                                                    | 81 |
|    | 2038923   | A change to TRBLIMITR_EL1.E might result in trace buffer corruption                                                                  | 82 |
|    | 2039165   | Debug accesses while leaving OFF_EMU power mode might lead to a system deadlock                                                      | 83 |
|    | 2041661   | Entry into the Full Retention power mode might cause incorrect execution of a TLB maintenance instruction                            | 84 |
|    | 2041909   | Load-Exclusive/Store-Exclusive loop might not make forward progress                                                                  | 86 |
|    | 2042739   | A store or Load-Exclusive might cause data corruption                                                                                | 88 |
|    | 2044951   | Entry into FUNC_RET power mode can cause data metastability                                                                          | 90 |
|    | 2051678   | A hardware update of the dirty bit might not be correctly ordered with respect to later instructions                                 | 91 |

| 2061513        | TRBE might cause a speculative hardware update of the dirty bit outside the trace buffer range                               | 93  |
|----------------|------------------------------------------------------------------------------------------------------------------------------|-----|
| 2064142        | A system register write might not take effect after the trace buffer is disabled                                             | 94  |
| 2069954        | A hardware update of the dirty bit might occur speculatively if PSTATE.PAN is used                                           | 95  |
| 2077057        | Software stepping ERETAA or ERETAB might corrupt SPSR_ELx                                                                    | 97  |
| 2082334        | ERR2STATUS.SERR might be incorrect                                                                                           | 99  |
| 2135898        | DSPSR_ELO.BTYPE might be incorrect on Debug state entry                                                                      | 100 |
| 2141267        | LD1R using SP as base register incorrectly requests MTE Tag Checked                                                          | 101 |
| 2148497        | A trace unit trigger might result in inconsistent register state of the Trace Buffer Extension                               | 103 |
| 2156527        | Mapping memory as Tagged when Allocation Tag storage is not provided might lead to CHI protocol violations or Tag corruption | 104 |
| 2169012        | SnpPreferUnique* might lead to a loss of coherency                                                                           | 106 |
| 2172148        | Snp*UniqueFwd might cause a deadlock or data corruption                                                                      | 108 |
| 2218134        | Single-bit error in branch predictor memory can cause instruction fetch stream corruption                                    | 110 |
| 2218950        | Aliased loads and stores might cause an ordering violation                                                                   | 111 |
| 2250311        | Asynchronous exceptions while MPMM is active might corrupt processor state                                                   | 113 |
| 2256538        | Hardware breakpoints might not be taken on 32-bit T32 instructions                                                           | 115 |
| 2288014        | Data corruption might occur in rare circumstances                                                                            | 116 |
| 2314929        | TLB Invalidation prevents core OFF_EMU to OFF transition                                                                     | 117 |
| 2347730        | Executing a WFI/WFE with VPU powerdown enabled might result in a deadlock                                                    | 119 |
| 2358024        | EDSCR.INTdis might not mask Non-secure interrupts                                                                            | 120 |
| 2371937        | Cacheable far atomics might generate data corruption                                                                         | 122 |
| 2420992        | Incorrect instructions might be executed                                                                                     | 123 |
| 2457168        | AMEVCNTR01 increments incorrectly                                                                                            | 125 |
| 2658417        | BFMMLA or VMMLA instructions might produce incorrect result                                                                  | 126 |
| Category B (ra | are)                                                                                                                         | 128 |
| 1976290        | A Tag Checked load might forward incorrect data                                                                              | 128 |
| 2002389        | Asynchronous exceptions after ECC errors might cause unpredictable behavior                                                  | 130 |
| 2080326        | A longer TLBI sequence might cause a deadlock                                                                                | 132 |
| 2277097        | CMOs to non-shareable locations might deadlock the cluster                                                                   | 134 |
| 2441009        | Completion of affected memory accesses might not be guaranteed by completion of a TLBI                                       | 135 |
| Category C     |                                                                                                                              | 136 |
| 1898949        | Execution of an atomic instruction may fail to make forward progress                                                         | 136 |

| 19044/6 | Reads of GMID_EL1 might trap to incorrect exception level when MTE is disabled                             | 137 |
|---------|------------------------------------------------------------------------------------------------------------|-----|
| 1905896 | Error responses to MakeReadUnique transactions might result in data corruption                             | 138 |
| 1911617 | Tag Check Fault reporting might be incorrect when ECC error occurs                                         | 139 |
| 1915215 | Software stepping ERETAA or ERETAB might set SPSR.ELx.SS to incorrect value                                | 140 |
| 1919823 | Configuration of IMP_CMPXECTLR_EL1.CDEVC not supported                                                     | 141 |
| 1921977 | Error response to load-exclusive might cause loss of synchronization or deadlock                           | 142 |
| 1924991 | Accesses to TRCQCTLR are RAZ/WI instead of UNDEFINED                                                       | 143 |
| 1925280 | A single-bit error in the L2DB RAMs might be reported incorrectly as a corrected error                     | 144 |
| 1929084 | Direct access to L1 data cache MTE data RAMs does not function                                             | 145 |
| 1933869 | Writes to DBGWCR <n>_EL1/DBGWVR<n>_EL1 might cause speculative reads of device memory</n></n>              | 146 |
| 1934328 | Multiple errors detected on the same cycle might lead to an incorrect value of ERR2STATUS and ERR2MISCO    | 147 |
| 1946400 | Error reporting disabled does not mask error responses on memory accesses                                  | 148 |
| 1951345 | PMU_HOVFS event exported when EL2 trace disabled                                                           | 149 |
| 1951423 | An ECC error during core power down might cause another error to occur after power up                      | 150 |
| 1951568 | PMU event counts might be inaccurate                                                                       | 151 |
| 1954191 | L2 cache debug operations might hang and block a power off request                                         | 152 |
| 1954658 | ERR2STATUS.CE might be incorrect                                                                           | 153 |
| 1955046 | External events are not observed after Warm reset                                                          | 154 |
| 1955072 | Mapping memory as Tagged when Allocation Tag storage is not provided might lead to CHI protocol violations | 155 |
| 1956538 | Execution of ESB instruction in debug state might cause unpredictable behavior                             | 156 |
| 1959615 | Exceptions in debug state might allow execution of subsequent instruction in EDITR                         | 157 |
| 1964078 | VMID tracing incorrectly allowed or disallowed based on TRFCR_EL2.CX                                       | 158 |
| 1965154 | PMU snapshot records incorrect Context ID when PMU inactive                                                | 160 |
| 1966395 | A continuous stream of stores might prevent forward progress of a coherency operation                      | 161 |
| 1974927 | SIMD, FP, and SVE cacheable loads or MTE-checked stores might hang on accessing a poisoned cache line      | 162 |
| 1975007 | WFE trap might take effect when a wake up event is pending                                                 | 164 |
| 1976399 | PrefetchTgt transactions are generated when PrefetchTgt is disabled                                        | 165 |
| 1977191 | Trigger received immediately out of warm reset might cause deadlock                                        | 166 |
| 1980125 | A change of ASID without context synchronization might cause memory ordering issues                        | 167 |

| 1980599 | An ECC error in the L1 data cache might not be detected                                                               | 168 |
|---------|-----------------------------------------------------------------------------------------------------------------------|-----|
| 1981723 | A continuous stream of DVM operations from another PE might block core powerdown                                      | 170 |
| 1982956 | SIMD and floating point loads to non-gatherable device memory might over-read                                         | 171 |
| 1986930 | Corruption might occur on MTE allocation tags                                                                         | 172 |
| 1987125 | ERR2MISCO.OFR and ERR2MISCO.OFO might not be set on counter overflow                                                  | 174 |
| 1987184 | DBG_RECOV or WARM_RST power modes might lead to deadlock or data corruption                                           | 175 |
| 1990749 | Errors or poison in the L2 data RAM might lead to deadlock and/or data corruption                                     | 176 |
| 1991004 | Uncontainable error injection via ERR2PFGCTL might occur at the wrong time                                            | 177 |
| 1991342 | Traps of System registers in Debug state might cause unexpected exceptions                                            | 178 |
| 1996476 | A Tag Checked SVE non-fault or first-fault load might hang if an External abort occurs                                | 180 |
| 1996886 | ELA connected to warm reset instead of cold reset                                                                     | 181 |
| 1997011 | Asynchronous Tag Check fail not synchronized based on SCTLR_ELx.ITFSB for exceptions in Debug state                   | 182 |
| 1998835 | Double-bit errors in the duplicate L1 data cache tag RAMs might lead to loss of coherency or deadlock                 | 183 |
| 1999032 | Non-Data Errors on memory accesses not attributable to a core might not be reported                                   | 185 |
| 2000000 | Interrupt might not be taken in finite time                                                                           | 186 |
| 2006188 | L2 cache debug operations might hang when no L2 cache is present                                                      | 187 |
| 2012183 | Double-bit errors in the duplicate L1 data cache tag RAMs might lead to deadlock on a snoop                           | 188 |
| 2015240 | Clearing a pending OS Unlock Catch debug event might cause unpredictable behavior                                     | 189 |
| 2016064 | A continuous stream of memory requests from one CPU in the complex might block another                                | 190 |
| 2017921 | Exception or DCPS3 instruction in debug state might block execution of instruction from $\ensuremath{EDITR}$          | 191 |
| 2025809 | A double-bit error on the L1 data cache MTE tag RAMs might result in a missed or incorrect error record in ERR1STATUS | 192 |
| 2033473 | A hardware update of the dirty bit might occur speculatively                                                          | 194 |
| 2035302 | CONTEXTIDR_EL2 breakpoint matching is enabled at EL3                                                                  | 196 |
| 2036369 | MPAM3_EL3.TRAPLOWER reset on Cold reset                                                                               | 197 |
| 2048342 | A load or store instruction might hang when encountering multiple uncorrectable or deferred errors                    | 198 |
| 2052205 | ERR2STATUS.SERR might be incorrect after an NDErr response is received                                                | 199 |

| 2052374 | PMU event ST_RETIRED might be inaccurate for Store-Exclusive instructions                                                  | 200 |
|---------|----------------------------------------------------------------------------------------------------------------------------|-----|
| 2053387 | Instructions in Debug state after a watchpoint debug event might not be executed                                           | 201 |
| 2054370 | Execution of instructions in Debug state after a watchpoint debug event might incorrectly set EDSCR.ERR and corrupt PSTATE | 202 |
| 2056307 | A Tag Checked store exclusive might hang if an external abort occurs                                                       | 204 |
| 2059297 | PSTATE.TCO might be unchanged for debug entry due to a watchpoint debug event                                              | 205 |
| 2071968 | Incorrect context ID might be associated with trace data                                                                   | 206 |
| 2077160 | Incorrect ordering after change in cacheability                                                                            | 208 |
| 2077274 | Extra A-sync packet might get written to Trace Buffer in Trace prohibited region                                           | 210 |
| 2085871 | Shareability aliases might result in incorrect Tag Check Faults                                                            | 211 |
| 2088637 | A watchpointed SVE load might update the FFR register incorrectly                                                          | 212 |
| 2092740 | Debug state exit after execution of a DRPS instruction might lead to deadlock                                              | 213 |
| 2096738 | Double-bit errors in the duplicate L1 data cache tag RAMs might lead to deadlock                                           | 214 |
| 2112025 | Instructions might be missed for tracing purposes before Debug state entry due to a watchpoint hit                         | 215 |
| 2120833 | DISR_EL1 access in Debug state might be incorrect                                                                          | 216 |
| 2133769 | PMU event 0x000C PC_WRITE_RETIRED might be inaccurate for ERET instructions                                                | 217 |
| 2135690 | PMU events based on STALL_FRONTEND might be inaccurate                                                                     | 218 |
| 2141037 | OFF_EMU to OFF power mode transition might result in a deadlock                                                            | 219 |
| 2146058 | PMU events counts might be inaccurate                                                                                      | 220 |
| 2161448 | PMU_HOVFS event not always exported when self-hosted trace disabled                                                        | 221 |
| 2164605 | A watchpoint hit while disabling Halting debug might cause an incorrect debug exception to be taken                        | 222 |
| 2175229 | A single ECC error on the L2 data RAMs might be double-counted                                                             | 224 |
| 2181318 | A PE trace unit trigger might not be reflected in TRBSR_EL1 after a TSB                                                    | 225 |
| 2187223 | In Halting debug state, the core might take an illegal execution exception when it should not                              | 226 |
| 2189260 | An MMU fault might not be correctly reflected in the Trace Buffer Extension TRBSR_EL1 register                             | 227 |
| 2189707 | Clean MTE tag writeback might occur after a store to the cache line                                                        | 228 |
| 2212805 | An ECC error while in the active-not-pending state might clear PSTATE.SS                                                   | 229 |
| 2217109 | RAS error reporting might be incorrect on simultaneous errors                                                              | 230 |
| 2220074 | ETM will indicate that a T32 CC-failed ISB has caused a Context Synchronization<br>Event when it has not                   | 231 |
| 2226937 | IMP_CDBGDR0_EL3 read data might be incorrect                                                                               | 232 |
| 2230537 | Load following SVE predicated load/store might cause ordering violation                                                    | 234 |

| 2236402 | Asynchronous exception or debug event might be taken before an exception catch debug event that was generated by an exception entry | 235 |
|---------|-------------------------------------------------------------------------------------------------------------------------------------|-----|
| 2241478 | The L1D_CACHE_REFILL and L1D_CACHE_LMISS_RD PMU events might over-count                                                             | 236 |
| 2265919 | Top byte of DLR_EL0 might be incorrect when entering AArch64 halting Debug state                                                    | 237 |
| 2266023 | Vector stores might not use a faster forwarding path                                                                                | 238 |
| 2271084 | DTR flags not cleared on external debugger access while leaving Debug state                                                         | 239 |
| 2272274 | Core might execute two instructions on Halting Step debug event                                                                     | 240 |
| 2287488 | Core might not execute instruction on Halting Step debug event                                                                      | 242 |
| 2289541 | PMU counter overflow can cause spurious PMU_OVFS and PMU_HOVFS events                                                               | 243 |
| 2289878 | Core might step two instructions at once                                                                                            | 244 |
| 2291784 | PSTATE.IL might be cleared on ERET to Software Stepping                                                                             | 245 |
| 2293834 | The core might report that a load-exclusive instruction has not been stepped when it should                                         | 246 |
| 2300878 | Software stepping ESB might set SPSR.ELx.SS to incorrect value                                                                      | 247 |
| 2303522 | Synchronous tag checking on a store exclusive might cause a deadlock if double bit/fatal error seen in L1-Duplicate RAM             | 248 |
| 2316094 | MTE checking might not be reliable                                                                                                  | 249 |
| 2321712 | DLR_EL0[1] is ignored when performing debug exit to A32                                                                             | 250 |
| 2324165 | Processor state might be corrupted if EDSCR.INTdis is set while asynchronous interrupt is in flight                                 | 251 |
| 2331844 | Software stepping ERET might set PSTATE or SPSR to incorrect value                                                                  | 253 |
| 2335678 | BFMMLA/VMMLA result might be corrupted when forwarding source operand from vector load                                              | 254 |
| 2341012 | Physical SError interrupts while software stepping a load or store instruction might cause two instructions to be stepped           | 255 |
| 2342004 | TLB Parity Check cannot be disabled                                                                                                 | 256 |
| 2342918 | PrefetchTgt transactions are generated when PrefetchTgt is disabled                                                                 | 257 |
| 2360589 | Exception catch might not be taken on ERET from EL3 to any Non-secure EL                                                            | 259 |
| 2371559 | ESR_ELx might be incorrect after trapped vector instruction in Debug state                                                          | 260 |
| 2385664 | Core might not execute any instruction when performing Halting Step                                                                 | 261 |
| 2393935 | ESR_ELx.EX might be incorrect when stepping a load exclusive                                                                        | 263 |
| 2396657 | ESR_ELx.EX might be incorrect due to asynchronous exception when software stepping                                                  | 264 |
| 2423961 | PMU_OVFS event is not generated on PMCCNTR_EL0 overflow                                                                             | 265 |
| 2429106 | Exception Catch debug event might not be taken                                                                                      | 266 |
| 2429770 | PC_WRITE_SPEC event does not count correctly                                                                                        | 267 |

2618004 LDST\_SPEC event might under-count

2636015 BUS\_ACCESS and BUS\_ACCESS\_WR PMU events are not reliable

#### Arm\_Cortex\_A510 (MP111) Software Developer Errata Notice

| 2478655 | L2D_CACHE_WB event might over-count                       | 268 |
|---------|-----------------------------------------------------------|-----|
| 2601282 | ELADISABLE does not disable APB access to the complex ELA | 269 |

Version: 14.0

270

271

### r1p1 implementation fixes

Note the following errata might be fixed in some implementations of r1p1. This can be determined by reading the REVIDR\_EL1 register where a set bit indicates that the erratum is fixed in this part.

| REVIDR_EL1[24] | 2454944 | Unmodified cache line might be written back to memory       |
|----------------|---------|-------------------------------------------------------------|
| REVIDR_EL1[25] | 2658417 | BFMMLA or VMMLA instructions might produce incorrect result |

Note that there is no change to the MIDR\_EL1 which remains at r1p1 but the REVIDR is updated to indicate which errata are corrected. Software will identify this release through the combination of MIDR EL1 and REVIDR EL1.

### r1p0 implementation fixes

Note the following errata might be fixed in some implementations of r1p0. This can be determined by reading the REVIDR\_EL1 register where a set bit indicates that the erratum is fixed in this part.

| REVIDR_EL1[15] | 2217821 | Heavy I-cache invalidation or TLB invalidation traffic from other PEs can cause a deadlock |
|----------------|---------|--------------------------------------------------------------------------------------------|
| REVIDR_EL1[18] | 2218950 | Aliased loads and stores might cause an ordering violation                                 |
| REVIDR_EL1[19] | 2184257 | Normal execution can result in data corruption                                             |
| REVIDR_EL1[22] | 2250311 | Asynchronous exceptions while MPMM is active might corrupt processor state                 |

Note that there is no change to the MIDR\_EL1 which remains at r1p0 but the REVIDR is updated to indicate which errata are corrected. Software will identify this release through the combination of MIDR\_EL1 and REVIDR\_EL1.

#### r0p3 implementation fixes

Note the following errata might be fixed in some implementations of rOp3. This can be determined by reading the REVIDR EL1 register where a set bit indicates that the erratum is fixed in this part.

| REVIDR_EL1[15] | 2217821 | Heavy I-cache invalidation or TLB invalidation traffic from other PEs can cause a deadlock |
|----------------|---------|--------------------------------------------------------------------------------------------|
| REVIDR_EL1[18] | 2218950 | Aliased loads and stores might cause an ordering violation                                 |
| REVIDR_EL1[19] | 2184257 | Normal execution can result in data corruption                                             |

Note that there is no change to the MIDR\_EL1 which remains at rOp3 but the REVIDR is updated to indicate which errata are corrected. Software will identify this release through the combination of MIDR\_EL1 and REVIDR\_EL1.

#### r0p2 implementation fixes

Note the following errata might be fixed in some implementations of rOp2. This can be determined by reading the REVIDR\_EL1 register where a set bit indicates that the erratum is fixed in this part.

| REVIDR_EL1[15] | 2217821 | Heavy I-cache invalidation or TLB invalidation traffic from other PEs can cause a deadlock                                        |
|----------------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| REVIDR_EL1[18] | 2218950 | Aliased loads and stores might cause an ordering violation                                                                        |
| REVIDR_EL1[19] | 2184257 | Normal execution can result in data corruption                                                                                    |
| REVIDR_EL1[20] | 2184257 | Normal execution can result in data corruption. Note : either of the REVIDR_EL1 bit 19 or 20 indicates that this erratum is fixed |

Note that there is no change to the MIDR\_EL1 which remains at rOp2 but the REVIDR is updated to indicate which errata are corrected. Software will identify this release through the combination of MIDR\_EL1 and REVIDR\_EL1.

### r0p1 implementation fixes

Note the following errata might be fixed in some implementations of rOp1. This can be determined by reading the REVIDR\_EL1 register where a set bit indicates that the erratum is fixed in this part.

| REVIDR_EL1[12] 197 | Non-L1-allocating stores might cause data corruption |
|--------------------|------------------------------------------------------|
|--------------------|------------------------------------------------------|

Note that there is no change to the MIDR\_EL1 which remains at rOp1 but the REVIDR is updated to indicate which errata are corrected. Software will identify this release through the combination of MIDR\_EL1 and REVIDR\_EL1.

### r0p0 implementation fixes

Note the following errata might be fixed in some implementations of rOpO. This can be determined by reading the REVIDR\_EL1 register where a set bit indicates that the erratum is fixed in this part.

#### When $REVIDR\_EL1[11] = 0$ :

| REVIDR_EL1[0]  | 1914417 | Coherency may be lost                                                                                         |  |  |  |
|----------------|---------|---------------------------------------------------------------------------------------------------------------|--|--|--|
| REVIDR_EL1[1]  | 1921103 | TLBI completion might not be guaranteed by DSB                                                                |  |  |  |
| REVIDR_EL1[3]  | 1927171 | Mismatched memory attributes might cause deadlock                                                             |  |  |  |
| REVIDR_EL1[5]  | 1943861 | Acquire/release semantics violated on store atomic instructions                                               |  |  |  |
| REVIDR_EL1[7]  | 1955641 | Core in FULL_RET might cause data corruption                                                                  |  |  |  |
| 1 19 /05 /01   |         | Secure Physical Address Cache Invalidate all DVM operation does not invalidate Non-Secure lines in L1 I-Cache |  |  |  |
|                | 1968719 | Snoops might lead to a deadlock                                                                               |  |  |  |
| REVIDR_EL1[10] | 1996706 | A deadlock might occur during or after WFI or WFE                                                             |  |  |  |

#### When $REVIDR\_EL1[11] = 1$ :

|          | 4 | 4 | $\sim$ |
|----------|---|---|--------|
| Version: | 1 | 4 | .()    |

|                                                                                              | 1914417 | Coherency may be lost                                                                                                   |  |
|----------------------------------------------------------------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                              | 1921103 | TLBI completion might not be guaranteed by DSB                                                                          |  |
|                                                                                              | 1943861 | Acquire/release semantics violated on store atomic instructions                                                         |  |
| REVIDR_EL1[0]                                                                                | 1968719 | Snoops might lead to a deadlock                                                                                         |  |
|                                                                                              | 1970520 | Secure Physical Address Cache Invalidate all DVM operation does not invalidate Non-Secure lines in L1 I-Cache           |  |
|                                                                                              | 1996706 | A deadlock might occur during or after WFI or WFE                                                                       |  |
| REVIDR_EL1[1]                                                                                | 1955641 | Core in FULL_RET might cause data corruption                                                                            |  |
| REVIDR_EL1[2]                                                                                | 1927171 | Mismatched memory attributes might cause deadlock                                                                       |  |
| REVIDR_EL1[4] 1981843 A store exclusive to shareable memory oth Cacheable might cause a hang |         | A store exclusive to shareable memory other than Normal Inner Write-Back, Outer Write-Back Cacheable might cause a hang |  |
| REVIDR_EL1[5]                                                                                | 2007174 | Heavy store traffic might lead to a DSB not completing on the same core or another core                                 |  |

Note that there is no change to the MIDR\_EL1 which remains at rOp0 but the REVIDR is updated to indicate which errata are corrected. Software will identify this release through the combination of MIDR\_EL1 and REVIDR\_EL1.

#### Version: 14.0

# Introduction

#### Scope

This document describes errata categorized by level of severity. Each description includes:

- The current status of the erratum.
- Where the implementation deviates from the specification and the conditions required for erroneous behavior to occur.
- The implications of the erratum with respect to typical applications.
- The application and limitations of a workaround where possible.

## Categorization of errata

Errata are split into three levels of severity and further qualified as common or rare:

| Category | у А          | A critical error. No workaround is available or workarounds are impactful. The error is likely to be common for many systems and applications.                                                       |
|----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category | y A (Rare)   | A critical error. No workaround is available or workarounds are impactful. The error is likely to be rare for most systems and applications. Rare is determined by analysis, verification and usage. |
| Category | у В          | A significant error or a critical error with an acceptable workaround. The error is likely to be common for many systems and applications.                                                           |
| Category | y B (Rare)   | A significant error or a critical error with an acceptable workaround. The error is likely to be rare for most systems and applications. Rare is determined by analysis, verification and usage.     |
| Category | y D (italic) | systems and applications. Rare is determined by analysis, verification and usage.                                                                                                                    |

# **Change Control**

Errata are listed in this section if they are new to the document, or marked as "updated" if there has been any change to the erratum text. Fixed errata are not shown as updated unless the erratum text has changed. The **errata summary table** identifies errata that have been fixed in each product revision.

27-Jun-2022: Changes in document version v14.0

| ID      | Status  | Area       | Category   | Summary                                                     |
|---------|---------|------------|------------|-------------------------------------------------------------|
| 2008766 | Updated | Programmer | Category B | RAS errors during core power down might cause a deadlock    |
| 2658417 | New     | Programmer | Category B | BFMMLA or VMMLA instructions might produce incorrect result |
| 2618004 | New     | Programmer | Category C | LDST_SPEC event might under-count                           |
| 2636015 | New     | Programmer | Category C | BUS_ACCESS and BUS_ACCESS_WR PMU events are not reliable    |

06-May-2022: Changes in document version v13.0

| ID      | Status  | Area       | Category   | Summary                                                             |
|---------|---------|------------|------------|---------------------------------------------------------------------|
| 2457168 | New     | Programmer | Category B | AMEVCNTR01 increments incorrectly                                   |
| 2385664 | Updated | Programmer | Category C | Core might not execute any instruction when performing Halting Step |
| 2478655 | New     | Programmer | Category C | L2D_CACHE_WB event might over-count                                 |
| 2601282 | New     | Programmer | Category C | ELADISABLE does not disable APB access to the complex ELA           |

02-Mar-2022: Changes in document version v12.0

| ID      | Status  | Area       | Category   | Summary                                                             |
|---------|---------|------------|------------|---------------------------------------------------------------------|
| 2454944 | New     | Programmer | Category A | Unmodified cache line might be written back to memory               |
| 2385664 | Updated | Programmer | Category C | Core might not execute any instruction when performing Halting Step |

23-Feb-2022: Changes in document version v11.0

| ID      | Status  | Area       | Category          | Summary                                                                                |
|---------|---------|------------|-------------------|----------------------------------------------------------------------------------------|
| 2420992 | New     | Programmer | Category B        | Incorrect instructions might be executed                                               |
| 2441009 | New     | Programmer | Category B (rare) | Completion of affected memory accesses might not be guaranteed by completion of a TLBI |
| 2226937 | Updated | Programmer | Category C        | IMP_CDBGDR0_EL3 read data might be incorrect                                           |
| 2393935 | New     | Programmer | Category C        | ESR_ELx.EX might be incorrect when stepping a load exclusive                           |
| 2396657 | New     | Programmer | Category C        | ESR_ELx.EX might be incorrect due to asynchronous exception when software stepping     |
| 2423961 | New     | Programmer | Category C        | PMU_OVFS event is not generated on PMCCNTR_EL0 overflow                                |
| 2429106 | New     | Programmer | Category C        | Exception Catch debug event might not be taken                                         |
| 2429770 | New     | Programmer | Category C        | PC_WRITE_SPEC event does not count correctly                                           |

10-Jan-2022: Changes in document version v10.0

| ID      | Status | Area       | Category   | Summary                                                                    |
|---------|--------|------------|------------|----------------------------------------------------------------------------|
| 2347730 | New    | Programmer | Category B | Executing a WFI/WFE with VPU powerdown enabled might result in a deadlock  |
| 2371937 | New    | Programmer | Category B | Cacheable far atomics might generate data corruption                       |
| 2358024 | New    | Programmer | Category B | EDSCR.INTdis might not mask Non-secure interrupts                          |
| 2360589 | New    | Programmer | Category C | Exception catch might not be taken on ERET from EL3 to any Non-secure EL   |
| 2371559 | New    | Programmer | Category C | ESR_ELx might be incorrect after trapped vector instruction in Debug state |
| 2385664 | New    | Programmer | Category C | Core might not execute any instruction when performing Halting Step        |

12-Nov-2021: Changes in document version v9.0

| ID      | Status  | Area       | Category   | Summary                                                                                                                   |
|---------|---------|------------|------------|---------------------------------------------------------------------------------------------------------------------------|
| 2008766 | Updated | Programmer | Category B | RAS errors during core power down might cause a deadlock                                                                  |
| 2164605 | Updated | Programmer | Category C | A watchpoint hit while disabling Halting debug might cause an incorrect debug exception to be taken                       |
| 2316094 | New     | Programmer | Category C | MTE checking might not be reliable                                                                                        |
| 2321712 | New     | Programmer | Category C | DLR_EL0[1] is ignored when performing debug exit to A32                                                                   |
| 2324165 | New     | Programmer | Category C | Processor state might be corrupted if EDSCR.INTdis is set while asynchronous interrupt is in flight                       |
| 2331844 | New     | Programmer | Category C | Software stepping ERET might set PSTATE or SPSR to incorrect value                                                        |
| 2335678 | New     | Programmer | Category C | BFMMLA/VMMLA result might be corrupted when forwarding source operand from vector load                                    |
| 2341012 | New     | Programmer | Category C | Physical SError interrupts while software stepping a load or store instruction might cause two instructions to be stepped |
| 2342004 | New     | Programmer | Category C | TLB Parity Check cannot be disabled                                                                                       |
| 2342918 | New     | Programmer | Category C | PrefetchTgt transactions are generated when PrefetchTgt is disabled                                                       |

24-Sep-2021: Changes in document version v8.0

| ID      | Status  | Area       | Category   | Summary                                                                                    |
|---------|---------|------------|------------|--------------------------------------------------------------------------------------------|
| 2217821 | Updated | Programmer | Category A | Heavy I-cache invalidation or TLB invalidation traffic from other PEs can cause a deadlock |
| 2008766 | Updated | Programmer | Category B | RAS errors during core power down might cause a deadlock                                   |
| 2041909 | Updated | Programmer | Category B | Load-Exclusive/Store-Exclusive loop might not make forward progress                        |
| 2218134 | New     | Programmer | Category B | Single-bit error in branch predictor memory can cause instruction fetch stream corruption  |
| 2250311 | New     | Programmer | Category B | Asynchronous exceptions while MPMM is active might corrupt processor state                 |
| 2256538 | New     | Programmer | Category B | Hardware breakpoints might not be taken on 32-bit T32 instructions                         |
| 2288014 | New     | Programmer | Category B | Data corruption might occur in rare circumstances                                          |

| ID      | Status | Area       | Category          | Summary                                                                                                                             |
|---------|--------|------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 2314929 | New    | Programmer | Category B        | TLB Invalidation prevents core OFF_EMU to OFF transition                                                                            |
| 2277097 | New    | Programmer | Category B (rare) | CMOs to non-shareable locations might deadlock the cluster                                                                          |
| 2189707 | New    | Programmer | Category C        | Clean MTE tag writeback might occur after a store to the cache line                                                                 |
| 2212805 | New    | Programmer | Category C        | An ECC error while in the active-not-pending state might clear PSTATE.SS                                                            |
| 2230537 | New    | Programmer | Category C        | Load following SVE predicated load/store might cause ordering violation                                                             |
| 2236402 | New    | Programmer | Category C        | Asynchronous exception or debug event might be taken before an exception catch debug event that was generated by an exception entry |
| 2241478 | New    | Programmer | Category C        | The L1D_CACHE_REFILL and L1D_CACHE_LMISS_RD PMU events might over-count                                                             |
| 2266023 | New    | Programmer | Category C        | Vector stores might not use a faster forwarding path                                                                                |
| 2265919 | New    | Programmer | Category C        | Top byte of DLR_ELO might be incorrect when entering AArch64 halting Debug state                                                    |
| 2271084 | New    | Programmer | Category C        | DTR flags not cleared on external debugger access while leaving<br>Debug state                                                      |
| 2272274 | New    | Programmer | Category C        | Core might execute two instructions on Halting Step debug event                                                                     |
| 2287488 | New    | Programmer | Category C        | Core might not execute instruction on Halting Step debug event                                                                      |
| 2289541 | New    | Programmer | Category C        | PMU counter overflow can cause spurious PMU_OVFS and PMU_HOVFS events                                                               |
| 2289878 | New    | Programmer | Category C        | Core might step two instructions at once                                                                                            |
| 2291784 | New    | Programmer | Category C        | PSTATE.IL might be cleared on ERET to Software Stepping                                                                             |
| 2293834 | New    | Programmer | Category C        | The core might report that a load-exclusive instruction has not been stepped when it should                                         |
| 2300878 | New    | Programmer | Category C        | Software stepping ESB might set SPSR.ELx.SS to incorrect value                                                                      |
| 2303522 | New    | Programmer | Category C        | Synchronous tag checking on a store exclusive might cause a deadlock if double bit/fatal error seen in L1-Duplicate RAM             |

21-Jul-2021: Changes in document version v7.0

| ID      | Status | Area       | Category   | Summary                                                                                                                      |
|---------|--------|------------|------------|------------------------------------------------------------------------------------------------------------------------------|
| 2184257 | New    | Programmer | Category A | Normal execution can result in data corruption                                                                               |
| 2217821 | New    | Programmer | Category A | Heavy I-cache invalidation or TLB invalidation traffic from other PEs can cause a deadlock                                   |
| 2064142 | New    | Programmer | Category B | A system register write might not take effect after the trace buffer is disabled                                             |
| 2135898 | New    | Programmer | Category B | DSPSR_ELO.BTYPE might be incorrect on Debug state entry                                                                      |
| 2141267 | New    | Programmer | Category B | LD1R using SP as base register incorrectly requests MTE Tag Checked                                                          |
| 2148497 | New    | Programmer | Category B | A trace unit trigger might result in inconsistent register state of the Trace<br>Buffer Extension                            |
| 2156527 | New    | Programmer | Category B | Mapping memory as Tagged when Allocation Tag storage is not provided might lead to CHI protocol violations or Tag corruption |
| 2169012 | New    | Programmer | Category B | SnpPreferUnique* might lead to a loss of coherency                                                                           |
| 2172148 | New    | Programmer | Category B | Snp*UniqueFwd might cause a deadlock or data corruption                                                                      |
| 2218950 | New    | Programmer | Category B | Aliased loads and stores might cause an ordering violation                                                                   |
| 2112025 | New    | Programmer | Category C | Instructions might be missed for tracing purposes before Debug state entry due to a watchpoint hit                           |
| 2120833 | New    | Programmer | Category C | DISR_EL1 access in Debug state might be incorrect                                                                            |
| 2133769 | New    | Programmer | Category C | PMU event 0x000C PC_WRITE_RETIRED might be inaccurate for ERET instructions                                                  |
| 2135690 | New    | Programmer | Category C | PMU events based on STALL_FRONTEND might be inaccurate                                                                       |
| 2141037 | New    | Programmer | Category C | OFF_EMU to OFF power mode transition might result in a deadlock                                                              |
| 2146058 | New    | Programmer | Category C | PMU events counts might be inaccurate                                                                                        |
| 2161448 | New    | Programmer | Category C | PMU_HOVFS event not always exported when self-hosted trace disabled                                                          |
| 2164605 | New    | Programmer | Category C | A watchpoint hit while disabling Halting debug might cause an incorrect debug exception to be taken                          |
| 2175229 | New    | Programmer | Category C | A single ECC error on the L2 data RAMs might be double-counted                                                               |
| 2181318 | New    | Programmer | Category C | A PE trace unit trigger might not be reflected in TRBSR_EL1 after a TSB                                                      |
| 2187223 | New    | Programmer | Category C | In Halting debug state, the core might take an illegal execution exception when it should not                                |
| 2189260 | New    | Programmer | Category C | An MMU fault might not be correctly reflected in the Trace Buffer Extension TRBSR_EL1 register                               |
| 2217109 | New    | Programmer | Category C | RAS error reporting might be incorrect on simultaneous errors                                                                |
| 2220074 | New    | Programmer | Category C | ETM will indicate that a T32 CC-failed ISB has caused a Context<br>Synchronization Event when it has not                     |
| 2226937 | New    | Programmer | Category C | IMP_CDBGDR0_EL3 read data might be incorrect                                                                                 |

06-May-2021: Changes in document version v6.0

| ID      | Status  | Area       | Category                                           | Summary                                                                            |  |
|---------|---------|------------|----------------------------------------------------|------------------------------------------------------------------------------------|--|
| 1977575 | Updated | Programmer | Category B                                         | Coherency might be lost on a cache line shortly after a core powers up             |  |
| 2022138 | Updated | Programmer | Category B                                         | Core in FULL_RET might not have clock gated                                        |  |
| 2069954 | New     | Programmer | Category B                                         | A hardware update of the dirty bit might occur speculatively if PSTATE.PAN is used |  |
| 2077057 | New     | Programmer | Category B                                         | Software stepping ERETAA or ERETAB might corrupt SPSR_ELx                          |  |
| 2082334 | New     | Programmer | Category B                                         | ERR2STATUS.SERR might be incorrect                                                 |  |
| 2080326 | New     | Programmer | Category B (rare)                                  | A longer TLBI sequence might cause a deadlock                                      |  |
| 2036369 | New     | Programmer | Category C MPAM3_EL3.TRAPLOWER reset on Cold reset |                                                                                    |  |
| 2053387 | New     | Programmer | Category C                                         | Instructions in Debug state after a watchpoint debug event might not be executed   |  |
| 2071968 | New     | Programmer | Category C                                         | Incorrect context ID might be associated with trace data                           |  |
| 2077160 | New     | Programmer | Category C                                         | Incorrect ordering after change in cacheability                                    |  |
| 2077274 | New     | Programmer | Category C                                         | Extra A-sync packet might get written to Trace Buffer in Trace prohibited region   |  |
| 2085871 | New     | Programmer | Category C                                         | Shareability aliases might result in incorrect Tag Check Faults                    |  |
| 2088637 | New     | Programmer | Category C                                         | A watchpointed SVE load might update the FFR register incorrectly                  |  |
| 2092740 | New     | Programmer | Category C                                         | Debug state exit after execution of a DRPS instruction might lead to deadlock      |  |
| 2096738 | New     | Programmer | Category C                                         | Double-bit errors in the duplicate L1 data cache tag RAMs might lead to deadlock   |  |

10-Feb-2021: Changes in document version v5.0

| ID      | Status | Area       | Category   | Summary                                                                                                                    |  |
|---------|--------|------------|------------|----------------------------------------------------------------------------------------------------------------------------|--|
| 2069773 | New    | Programmer | Category A | Forwarding snoops might cause a deadlock                                                                                   |  |
| 2044951 | New    | Programmer | Category B | Entry into FUNC_RET power mode can cause data metastability                                                                |  |
| 2051678 | New    | Programmer | Category B | A hardware update of the dirty bit might not be correctly ordered with respect to later instructions                       |  |
| 2061513 | New    | Programmer | Category B | TRBE might cause a speculative hardware update of the dirty bit outside the trace buffer range                             |  |
| 1987184 | New    | Programmer | Category C | DBG_RECOV or WARM_RST power modes might lead to deadlock or data corruption                                                |  |
| 2035302 | New    | Programmer | Category C | CONTEXTIDR_EL2 breakpoint matching is enabled at EL3                                                                       |  |
| 2048342 | New    | Programmer | Category C | A load or store instruction might hang when encountering multiple uncorrectable or deferred errors                         |  |
| 2052374 | New    | Programmer | Category C | PMU event ST_RETIRED might be inaccurate for Store-Exclusive instructions                                                  |  |
| 2052205 | New    | Programmer | Category C | ERR2STATUS.SERR might be incorrect after an NDErr response is received                                                     |  |
| 2054370 | New    | Programmer | Category C | Execution of instructions in Debug state after a watchpoint debug event might incorrectly set EDSCR.ERR and corrupt PSTATE |  |
| 2056307 | New    | Programmer | Category C | A Tag Checked store exclusive might hang if an external abort occurs                                                       |  |
| 2059297 | New    | Programmer | Category C | PSTATE.TCO might be unchanged for debug entry due to a watchpoint debug event                                              |  |

22-Jan-2021: Changes in document version v4.0

| ID      | Status  | Area       | Category          | Summary                                                                                                               |  |
|---------|---------|------------|-------------------|-----------------------------------------------------------------------------------------------------------------------|--|
| 2039708 | New     | Programmer | Category A        | Non-cacheable stores, maintenance, or speculation restriction instructions might cause a deadlock                     |  |
| 2014530 | New     | Programmer | Category B        | Debug accesses while leaving OFF_EMU power mode might lead to a system deadlock                                       |  |
| 2015106 | New     | Programmer | Category B        | Memory mapped accesses to MPMM registers have the wrong offset                                                        |  |
| 2027318 | New     | Programmer | Category B        | SnpPreferUnique might lead to a loss of coherency                                                                     |  |
| 2028010 | New     | Programmer | Category B        | A PRF{U}M instruction might hang                                                                                      |  |
| 2038114 | New     | Programmer | Category B        | EDSCR.STATUS might be incorrect when single stepping a Load-<br>Exclusive instruction                                 |  |
| 2038923 | New     | Programmer | Category B        | A change to TRBLIMITR_EL1.E might result in trace buffer corruption                                                   |  |
| 2039165 | New     | Programmer | Category B        | Debug accesses while leaving OFF_EMU power mode might lead to system deadlock                                         |  |
| 2041661 | New     | Programmer | Category B        | Entry into the Full Retention power mode might cause incorrect execution of a TLB maintenance instruction             |  |
| 2041909 | New     | Programmer | Category B        | Load-Exclusive/Store-Exclusive loop might not make forward progress                                                   |  |
| 2042739 | New     | Programmer | Category B        | A store or Load-Exclusive might cause data corruption                                                                 |  |
| 1976290 | Updated | Programmer | Category B (rare) | A Tag Checked load might forward incorrect data                                                                       |  |
| 2012183 | New     | Programmer | Category C        | Double-bit errors in the duplicate L1 data cache tag RAMs might lead to deadlock on a snoop                           |  |
| 2017921 | New     | Programmer | Category C        | Exception or DCPS3 instruction in debug state might block execution of instruction from EDITR                         |  |
| 2025809 | New     | Programmer | Category C        | A double-bit error on the L1 data cache MTE tag RAMs might result in a missed or incorrect error record in ERR1STATUS |  |
| 2033473 | New     | Programmer | Category C        | A hardware update of the dirty bit might occur speculatively                                                          |  |

03-Dec-2020: Changes in document version v3.0

| ID      | Status  | Area       | Category                                                                                           | Summary                                                                                                                    |  |
|---------|---------|------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--|
| 1996706 | New     | Programmer | Category A A deadlock might occur during or after WFI or WFE                                       |                                                                                                                            |  |
| 2007174 | New     | Programmer | Category A Heavy store traffic might lead to a DSB not completing on the same core or another core |                                                                                                                            |  |
| 1956116 | New     | Programmer | Category B                                                                                         | ategory B Missing trace for debug entry due to watchpoint hit                                                              |  |
| 1977575 | Updated | Programmer | Category B                                                                                         | Coherency might be lost on a cache line shortly after a core powers up                                                     |  |
| 1981843 | New     | Programmer | Category B                                                                                         | A store exclusive to shareable memory other than Normal Inner<br>Write-Back, Outer Write-Back Cacheable might cause a hang |  |
| 2008766 | New     | Programmer | Category B                                                                                         | RAS errors during core power down might cause a deadlock                                                                   |  |
| 2022138 | New     | Programmer | Category B                                                                                         | Core in FULL_RET might not have clock gated                                                                                |  |

| ID      | Status  | Area       | Category          | Summary                                                                                                 |
|---------|---------|------------|-------------------|---------------------------------------------------------------------------------------------------------|
| 1976290 | New     | Programmer | Category B (rare) | A Tag Checked load might forward incorrect data                                                         |
| 2002389 | New     | Programmer | Category B (rare) | Asynchronous exceptions after ECC errors might cause unpredictable behavior                             |
| 1925280 | New     | Programmer | Category C        | A single-bit error in the L2DB RAMs might be reported incorrectly as a corrected error                  |
| 1934328 | New     | Programmer | Category C        | Multiple errors detected on the same cycle might lead to an incorrect value of ERR2STATUS and ERR2MISCO |
| 1946400 | New     | Programmer | Category C        | Error reporting disabled does not mask error responses on memory accesses                               |
| 1951568 | Updated | Programmer | Category C        | PMU event counts might be inaccurate                                                                    |
| 1954658 | New     | Programmer | Category C        | ERR2STATUS.CE might be incorrect                                                                        |
| 1955046 | New     | Programmer | Category C        | External events are not observed after Warm reset                                                       |
| 1974927 | New     | Programmer | Category C        | SIMD, FP, and SVE cacheable loads or MTE-checked stores might hang on accessing a poisoned cache line   |
| 1975007 | New     | Programmer | Category C        | WFE trap might take effect when a wake up event is pending                                              |
| 1976399 | New     | Programmer | Category C        | PrefetchTgt transactions are generated when PrefetchTgt is disabled                                     |
| 1977191 | New     | Programmer | Category C        | Trigger received immediately out of warm reset might cause deadlock                                     |
| 1980125 | New     | Programmer | Category C        | A change of ASID without context synchronization might cause memory ordering issues                     |
| 1980599 | New     | Programmer | Category C        | An ECC error in the L1 data cache might not be detected                                                 |
| 1982956 | New     | Programmer | Category C        | SIMD and floating point loads to non-gatherable device memory might over-read                           |
| 1986930 | New     | Programmer | Category C        | Corruption might occur on MTE allocation tags                                                           |
| 1987125 | New     | Programmer | Category C        | ERR2MISCO.OFR and ERR2MISCO.OFO might not be set on counter overflow                                    |
| 1990749 | New     | Programmer | Category C        | Errors or poison in the L2 data RAM might lead to deadlock and/or data corruption                       |
| 1991004 | New     | Programmer | Category C        | Uncontainable error injection via ERR2PFGCTL might occur at the wrong time                              |
| 1991342 | New     | Programmer | Category C        | Traps of System registers in Debug state might cause unexpected exceptions                              |
| 1996476 | New     | Programmer | Category C        | A Tag Checked SVE non-fault or first-fault load might hang if an External abort occurs                  |
| 1996886 | New     | Programmer | Category C        | ELA connected to warm reset instead of cold reset                                                       |
| 1997011 | New     | Programmer | Category C        | Asynchronous Tag Check fail not synchronized based on SCTLR_ELx.ITFSB for exceptions in Debug state     |
| 1998835 | New     | Programmer | Category C        | Double-bit errors in the duplicate L1 data cache tag RAMs might lead to loss of coherency or deadlock   |

| ID      | Status | Area       | Category   | Summary                                                                                |  |
|---------|--------|------------|------------|----------------------------------------------------------------------------------------|--|
| 1999032 | New    | Programmer | Category C | Non-Data Errors on memory accesses not attributable to a core might not be reported    |  |
| 2000000 | New    | Programmer | Category C | Interrupt might not be taken in finite time                                            |  |
| 1981723 | New    | Programmer | Category C | A continuous stream of DVM operations from another PE might block core powerdown       |  |
| 2006188 | New    | Programmer | Category C | L2 cache debug operations might hang when no L2 cache is present                       |  |
| 2015240 | New    | Programmer | Category C | Clearing a pending OS Unlock Catch debug event might cause unpredictable behavior      |  |
| 2016064 | New    | Programmer | Category C | A continuous stream of memory requests from one CPU in the complex might block another |  |

23-Oct-2020: Changes in document version v2.0

| ID      | Status | Area       | Category                                                                                                                | Summary                                                                                                                              |  |
|---------|--------|------------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--|
| 1914417 | New    | Programmer | Category A                                                                                                              | Coherency may be lost                                                                                                                |  |
| 1921103 | New    | Programmer | Category A TLBI completion might not be guaranteed by DSB  Category A Mismatched memory attributes might cause deadlock |                                                                                                                                      |  |
| 1927171 | New    | Programmer |                                                                                                                         |                                                                                                                                      |  |
| 1943861 | New    | Programmer | Category A Acquire/release semantics violated on store atomic instructions                                              |                                                                                                                                      |  |
| 1946214 | New    | Programmer | Category A                                                                                                              | Heavy L2 memory traffic may lead to data corruption and deadlock                                                                     |  |
| 1968719 | New    | Programmer | Category A                                                                                                              | Snoops might lead to a deadlock                                                                                                      |  |
| 1970520 | New    | Programmer | Category A                                                                                                              | Secure Physical Address Cache Invalidate all DVM operation does not invalidate Non-Secure lines in L1 I-Cache                        |  |
| 1965350 | New    | Programmer | Category A (rare)                                                                                                       | Coherency might be lost on a cache line                                                                                              |  |
| 1975996 | New    | Programmer | Category A (rare)                                                                                                       | Non-L1-allocating stores might cause data corruption                                                                                 |  |
| 1910738 | New    | Programmer | Category B                                                                                                              | Use of tagged memory might cause deadlock, data corruption or incorrect reporting                                                    |  |
| 1922240 | New    | Programmer | Category B                                                                                                              | SnpPreferUnique* might lead to a loss of coherency                                                                                   |  |
| 1937669 | New    | Programmer | Category B                                                                                                              | Tag Checked store might not be correctly ordered by DMB                                                                              |  |
| 1942494 | New    | Programmer | Category B                                                                                                              | A cacheable load of SIMD&FP or SVE registers might return incorrect data                                                             |  |
| 1943339 | New    | Programmer | Category B                                                                                                              | Cacheable far atomics might result in loss of coherency                                                                              |  |
| 1952872 | New    | Programmer | Category B                                                                                                              | A cacheable load might return incorrect data                                                                                         |  |
| 1955641 | New    | Programmer | Category B                                                                                                              | Core in FULL_RET might cause data corruption                                                                                         |  |
| 1961781 | New    | Programmer | Category B                                                                                                              | Watchpoints on SVE first-fault and non-fault loads might cause an incorrect value to be loaded and/or an incorrect MTE check results |  |
| 1962857 | New    | Programmer | Category B                                                                                                              | Set/way maintenance of L2 cache might cause data corruption                                                                          |  |
| 1966377 | New    | Programmer | Category B                                                                                                              | Incorrect instructions might be executed                                                                                             |  |
| 1975068 | New    | Programmer | Category B                                                                                                              | Cacheable Non-shareable mappings might lead to CHI protocol violations                                                               |  |

| ID      | Status | Area       | Category   | Summary                                                                                                    |  |
|---------|--------|------------|------------|------------------------------------------------------------------------------------------------------------|--|
| 1977575 | New    | Programmer | Category B | Coherency might be lost on a cache line shortly after a core powers up                                     |  |
| 1898949 | New    | Programmer | Category C | Execution of an atomic instruction may fail to make forward progress                                       |  |
| 1905896 | New    | Programmer | Category C | Error responses to MakeReadUnique transactions might result in data corruption                             |  |
| 1911617 | New    | Programmer | Category C | Tag Check Fault reporting might be incorrect when ECC error occurs                                         |  |
| 1915215 | New    | Programmer | Category C | Software stepping ERETAA or ERETAB might set SPSR.ELx.SS to incorrect value                                |  |
| 1919823 | New    | Programmer | Category C | Configuration of IMP_CMPXECTLR_EL1.CDEVC not supported                                                     |  |
| 1921977 | New    | Programmer | Category C | Error response to load-exclusive might cause loss of synchronization or deadlock                           |  |
| 1904476 | New    | Programmer | Category C | Reads of GMID_EL1 might trap to incorrect exception level when MTE is disabled                             |  |
| 1924991 | New    | Programmer | Category C | Accesses to TRCQCTLR are RAZ/WI instead of UNDEFINED                                                       |  |
| 1929084 | New    | Programmer | Category C | Direct access to L1 data cache MTE data RAMs does not function                                             |  |
| 1933869 | New    | Programmer | Category C | Writes to DBGWCR_EL1/DBGWVR_EL1 might cause speculative reads of device memory                             |  |
| 1951345 | New    | Programmer | Category C | PMU_HOVFS event exported when EL2 trace disabled                                                           |  |
| 1951423 | New    | Programmer | Category C | An ECC error during core power down might cause another error to occur after power up                      |  |
| 1951568 | New    | Programmer | Category C | PMU event counts might be inaccurate                                                                       |  |
| 1954191 | New    | Programmer | Category C | L2 cache debug operations might hang and block a power off request                                         |  |
| 1955072 | New    | Programmer | Category C | Mapping memory as Tagged when Allocation Tag storage is not provided might lead to CHI protocol violations |  |
| 1956538 | New    | Programmer | Category C | Execution of ESB instruction in debug state might cause unpredictable behavior                             |  |
| 1959615 | New    | Programmer | Category C | Exceptions in debug state might allow execution of subsequent instruction in EDITR                         |  |
| 1964078 | New    | Programmer | Category C | VMID tracing incorrectly allowed or disallowed based on TRFCR_EL2.CX                                       |  |
| 1965154 | New    | Programmer | Category C | PMU snapshot records incorrect Context ID when PMU inactive                                                |  |
| 1966395 | New    | Programmer | Category C | A continuous stream of stores might prevent forward progress of a coherency operation                      |  |

17-Jul-2020: Changes in document version v1.0

| ID      | Status | Area       | Category   | Summary                                                       |
|---------|--------|------------|------------|---------------------------------------------------------------|
| 1902691 | New    | Programmer | Category B | Trace Buffer Extension can cause trace corruption or deadlock |

# Errata summary table

The errata associated with this product affect the product versions described in the following table.

| ID      | Area       | Category          | Summary                                                                                                                | Found in versions                     | Fixed in version |
|---------|------------|-------------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------|
| 1914417 | Programmer | Category A        | Coherency may be lost                                                                                                  | rOpO                                  | r0p1             |
| 1921103 | Programmer | Category A        | TLBI completion might not be guaranteed by DSB                                                                         | rOpO                                  | rOp1             |
| 1927171 | Programmer | Category A        | Mismatched memory attributes might cause deadlock                                                                      | rOpO                                  | rOp1             |
| 1943861 | Programmer | Category A        | Acquire/release semantics violated on store atomic instructions                                                        | rOpO                                  | rOp1             |
| 1946214 | Programmer | Category A        | Heavy L2 memory traffic may<br>lead to data corruption and<br>deadlock                                                 | rOpO                                  | rOp1             |
| 1968719 | Programmer | Category A        | Snoops might lead to a deadlock                                                                                        | rOpO                                  | r0p1             |
| 1970520 | Programmer | Category A        | Secure Physical Address Cache<br>Invalidate all DVM operation<br>does not invalidate Non-Secure<br>lines in L1 I-Cache | rOpO                                  | rOp1             |
| 1996706 | Programmer | Category A        | A deadlock might occur during or after WFI or WFE                                                                      | rOpO                                  | rOp1             |
| 2007174 | Programmer | Category A        | Heavy store traffic might lead<br>to a DSB not completing on<br>the same core or another core                          | rOpO                                  | rOp1             |
| 2039708 | Programmer | Category A        | Non-cacheable stores,<br>maintenance, or speculation<br>restriction instructions might<br>cause a deadlock             | rOpO, rOp1                            | r0p2             |
| 2069773 | Programmer | Category A        | Forwarding snoops might cause a deadlock                                                                               | rOpO, rOp1                            | r0p2             |
| 2184257 | Programmer | Category A        | Normal execution can result in data corruption                                                                         | rOpO, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2217821 | Programmer | Category A        | Heavy I-cache invalidation or<br>TLB invalidation traffic from<br>other PEs can cause a deadlock                       | rOpO, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2454944 | Programmer | Category A        | Unmodified cache line might be written back to memory                                                                  | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 1965350 | Programmer | Category A (rare) | Coherency might be lost on a cache line                                                                                | rOpO                                  | rOp1             |

| ID      | Area       | Category          | Summary                                                                                                                                          | Found in versions | Fixed in version |
|---------|------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------|
| 1975996 | Programmer | Category A (rare) | Non-L1-allocating stores might cause data corruption                                                                                             | rOpO, rOp1        | rOp2             |
| 1902691 | Programmer | Category B        | Trace Buffer Extension can cause trace corruption or deadlock                                                                                    | rOpO, rOp1        | rOp2             |
| 1910738 | Programmer | Category B        | Use of tagged memory might cause deadlock, data corruption or incorrect reporting                                                                | rOpO              | rOp1             |
| 1922240 | Programmer | Category B        | SnpPreferUnique* might lead to a loss of coherency                                                                                               | rOpO              | rOp1             |
| 1937669 | Programmer | Category B        | Tag Checked store might not be correctly ordered by DMB                                                                                          | rOpO              | rOp1             |
| 1942494 | Programmer | Category B        | A cacheable load of SIMD&FP or SVE registers might return incorrect data                                                                         | rOpO              | rOp1             |
| 1943339 | Programmer | Category B        | Cacheable far atomics might result in loss of coherency                                                                                          | rOpO              | rOp1             |
| 1952872 | Programmer | Category B        | A cacheable load might return incorrect data                                                                                                     | rOpO              | rOp1             |
| 1955641 | Programmer | Category B        | Core in FULL_RET might cause data corruption                                                                                                     | rOpO              | rOp1             |
| 1956116 | Programmer | Category B        | Missing trace for debug entry due to watchpoint hit                                                                                              | rOpO              | rOp1             |
| 1961781 | Programmer | Category B        | Watchpoints on SVE first-fault<br>and non-fault loads might<br>cause an incorrect value to be<br>loaded and/or an incorrect<br>MTE check results | rOpO              | rOp1             |
| 1962857 | Programmer | Category B        | Set/way maintenance of L2 cache might cause data corruption                                                                                      | rOpO              | rOp1             |
| 1966377 | Programmer | Category B        | Incorrect instructions might be executed                                                                                                         | rOpO              | rOp1             |
| 1975068 | Programmer | Category B        | Cacheable Non-shareable<br>mappings might lead to CHI<br>protocol violations                                                                     | rOpO              | rOp1             |
| 1977575 | Programmer | Category B        | Coherency might be lost on a cache line shortly after a core powers up                                                                           | rOpO              | rOp1             |

| ID      | Area       | Category   | Summary                                                                                                                              | Found in versions                        | Fixed in version |
|---------|------------|------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|------------------|
| 1981843 | Programmer | Category B | A store exclusive to shareable<br>memory other than Normal<br>Inner Write-Back, Outer Write-<br>Back Cacheable might cause a<br>hang | rOpO                                     | rOp1             |
| 2008766 | Programmer | Category B | RAS errors during core power down might cause a deadlock                                                                             | r0p0, r0p1, r0p2, r0p3, r1p0, r1p1, r1p2 | Open             |
| 2014530 | Programmer | Category B | Debug accesses while leaving<br>OFF_EMU power mode might<br>lead to a system deadlock                                                | rOpO, rOp1                               | rOp2             |
| 2015106 | Programmer | Category B | Memory mapped accesses to<br>MPMM registers have the<br>wrong offset                                                                 | rOpO                                     | rOp1             |
| 2022138 | Programmer | Category B | Core in FULL_RET might not have clock gated                                                                                          | rOpO, rOp1                               | r0p2             |
| 2027318 | Programmer | Category B | SnpPreferUnique might lead to a loss of coherency                                                                                    | rOpO, rOp1                               | r0p2             |
| 2028010 | Programmer | Category B | A PRF{U}M instruction might hang                                                                                                     | rOpO, rOp1                               | rOp2             |
| 2038114 | Programmer | Category B | EDSCR.STATUS might be incorrect when single stepping a Load-Exclusive instruction                                                    | rOpO, rOp1, rOp2                         | rOp3             |
| 2038923 | Programmer | Category B | A change to TRBLIMITR_EL1.E might result in trace buffer corruption                                                                  | rOpO, rOp1, rOp2                         | rOp3             |
| 2039165 | Programmer | Category B | Debug accesses while leaving<br>OFF_EMU power mode might<br>lead to a system deadlock                                                | rOpO, rOp1, rOp2                         | rOp3             |
| 2041661 | Programmer | Category B | Entry into the Full Retention<br>power mode might cause<br>incorrect execution of a TLB<br>maintenance instruction                   | rOpO, rOp1                               | rOp2             |
| 2041909 | Programmer | Category B | Load-Exclusive/Store-Exclusive loop might not make forward progress                                                                  | rOpO, rOp1, rOp2                         | rOp3             |
| 2042739 | Programmer | Category B | A store or Load-Exclusive might cause data corruption                                                                                | rOpO, rOp1, rOp2                         | rOp3             |
| 2044951 | Programmer | Category B | Entry into FUNC_RET power mode can cause data metastability                                                                          | rOpO, rOp1, rOp2                         | rOp3             |
| 2051678 | Programmer | Category B | A hardware update of the dirty<br>bit might not be correctly<br>ordered with respect to later<br>instructions                        | r0p0, r0p1, r0p2                         | rOp3             |

| ID      | Area       | Category   | Summary                                                                                                                      | Found in versions            | Fixed in version |
|---------|------------|------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------------|
| 2061513 | Programmer | Category B | TRBE might cause a speculative hardware update of the dirty bit outside the trace buffer range                               | rOpO, rOp1, rOp2             | r0p3             |
| 2064142 | Programmer | Category B | A system register write might not take effect after the trace buffer is disabled                                             | rOpO, rOp1, rOp2             | rOp3             |
| 2069954 | Programmer | Category B | A hardware update of the dirty<br>bit might occur speculatively if<br>PSTATE.PAN is used                                     | rOpO, rOp1, rOp2             | rOp3             |
| 2077057 | Programmer | Category B | Software stepping ERETAA or<br>ERETAB might corrupt<br>SPSR_ELx                                                              | rOpO, rOp1, rOp2             | rOp3             |
| 2082334 | Programmer | Category B | ERR2STATUS.SERR might be incorrect                                                                                           | rOpO, rOp1, rOp2, rOp3       | r1p0             |
| 2135898 | Programmer | Category B | DSPSR_ELO.BTYPE might be incorrect on Debug state entry                                                                      | rOpO, rOp1, rOp2, rOp3       | r1p0             |
| 2141267 | Programmer | Category B | LD1R using SP as base register incorrectly requests MTE Tag Checked                                                          | rOpO, rOp1, rOp2, rOp3       | r1p0             |
| 2148497 | Programmer | Category B | A trace unit trigger might result in inconsistent register state of the Trace Buffer Extension                               | rOpO, rOp1, rOp2, rOp3       | r1p0             |
| 2156527 | Programmer | Category B | Mapping memory as Tagged when Allocation Tag storage is not provided might lead to CHI protocol violations or Tag corruption | rOpO, rOp1, rOp2, rOp3       | r1p0             |
| 2169012 | Programmer | Category B | SnpPreferUnique* might lead to a loss of coherency                                                                           | rOpO, rOp1, rOp2, rOp3, r1p0 | r1p1             |
| 2172148 | Programmer | Category B | Snp*UniqueFwd might cause a deadlock or data corruption                                                                      | rOpO, rOp1, rOp2, rOp3, r1p0 | r1p1             |
| 2218134 | Programmer | Category B | Single-bit error in branch<br>predictor memory can cause<br>instruction fetch stream<br>corruption                           | r1p0                         | r1p1             |
| 2218950 | Programmer | Category B | Aliased loads and stores might cause an ordering violation                                                                   | rOpO, rOp1, rOp2, rOp3, r1p0 | r1p1             |
| 2250311 | Programmer | Category B | Asynchronous exceptions while MPMM is active might corrupt processor state                                                   | r0p0, r0p1, r0p2, r0p3, r1p0 | r1p1             |
| 2256538 | Programmer | Category B | Hardware breakpoints might not be taken on 32-bit T32 instructions                                                           | r1p0                         | r1p1             |

| ID      | Area       | Category          | Summary                                                                                         | Found in versions                     | Fixed in version |
|---------|------------|-------------------|-------------------------------------------------------------------------------------------------|---------------------------------------|------------------|
| 2288014 | Programmer | Category B        | Data corruption might occur in rare circumstances                                               | rOpO, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2314929 | Programmer | Category B        | TLB Invalidation prevents core<br>OFF_EMU to OFF transition                                     | r0p0, r0p1, r0p2, r0p3, r1p0          | r1p1             |
| 2347730 | Programmer | Category B        | Executing a WFI/WFE with VPU powerdown enabled might result in a deadlock                       | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 2358024 | Programmer | Category B        | EDSCR.INTdis might not mask<br>Non-secure interrupts                                            | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 2371937 | Programmer | Category B        | Cacheable far atomics might generate data corruption                                            | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 2420992 | Programmer | Category B        | Incorrect instructions might be executed                                                        | r1p0, r1p1                            | r1p2             |
| 2457168 | Programmer | Category B        | AMEVCNTR01 increments incorrectly                                                               | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 2658417 | Programmer | Category B        | BFMMLA or VMMLA instructions might produce incorrect result                                     | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 1976290 | Programmer | Category B (rare) | A Tag Checked load might forward incorrect data                                                 | rOpO                                  | rOp1             |
| 2002389 | Programmer | Category B (rare) | Asynchronous exceptions after ECC errors might cause unpredictable behavior                     | rOpO, rOp1                            | rOp2             |
| 2080326 | Programmer | Category B (rare) | A longer TLBI sequence might cause a deadlock                                                   | r0p0, r0p1, r0p2                      | rOp3             |
| 2277097 | Programmer | Category B (rare) | CMOs to non-shareable locations might deadlock the cluster                                      | r0p0, r0p1, r0p2, r0p3, r1p0          | r1p1             |
| 2441009 | Programmer | Category B (rare) | Completion of affected<br>memory accesses might not be<br>guaranteed by completion of a<br>TLBI | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 1898949 | Programmer | Category C        | Execution of an atomic instruction may fail to make forward progress                            | rOpO                                  | rOp1             |
| 1904476 | Programmer | Category C        | Reads of GMID_EL1 might trap<br>to incorrect exception level<br>when MTE is disabled            | rOpO                                  | rOp1             |
| 1905896 | Programmer | Category C        | Error responses to<br>MakeReadUnique transactions<br>might result in data corruption            | rOpO                                  | rOp1             |
| 1911617 | Programmer | Category C        | Tag Check Fault reporting might be incorrect when ECC error occurs                              | rOpO                                  | rOp1             |

| ID      | Area       | Category   | Summary                                                                                                 | Found in versions | Fixed in version |
|---------|------------|------------|---------------------------------------------------------------------------------------------------------|-------------------|------------------|
| 1915215 | Programmer | Category C | Software stepping ERETAA or ERETAB might set SPSR.ELx.SS to incorrect value                             | rOpO              | rOp1             |
| 1919823 | Programmer | Category C | Configuration of IMP_CMPXECTLR_EL1.CDEVC not supported                                                  | rOpO              | rOp1             |
| 1921977 | Programmer | Category C | Error response to load-<br>exclusive might cause loss of<br>synchronization or deadlock                 | rOpO              | rOp1             |
| 1924991 | Programmer | Category C | Accesses to TRCQCTLR are<br>RAZ/WI instead of<br>UNDEFINED                                              | rOpO              | rOp1             |
| 1925280 | Programmer | Category C | A single-bit error in the L2DB RAMs might be reported incorrectly as a corrected error                  | rOpO              | rOp1             |
| 1929084 | Programmer | Category C | Direct access to L1 data cache<br>MTE data RAMs does not<br>function                                    | rOpO              | rOp1             |
| 1933869 | Programmer | Category C | Writes to DBGWCR_EL1/DBGWVR_EL1 might cause speculative reads of device memory                          | rOpO              | rOp1             |
| 1934328 | Programmer | Category C | Multiple errors detected on the same cycle might lead to an incorrect value of ERR2STATUS and ERR2MISCO | rOpO, rOp1        | r0p2             |
| 1946400 | Programmer | Category C | Error reporting disabled does<br>not mask error responses on<br>memory accesses                         | rOpO              | rOp1             |
| 1951345 | Programmer | Category C | PMU_HOVFS event exported when EL2 trace disabled                                                        | rOpO              | rOp1             |
| 1951423 | Programmer | Category C | An ECC error during core power down might cause another error to occur after power up                   | rOpO              | rOp1             |
| 1951568 | Programmer | Category C | PMU event counts might be inaccurate                                                                    | rOpO              | rOp1             |
| 1954191 | Programmer | Category C | L2 cache debug operations<br>might hang and block a power<br>off request                                | r0p0              | rOp1             |
| 1954658 | Programmer | Category C | ERR2STATUS.CE might be incorrect                                                                        | rOpO              | rOp1             |
| 1955046 | Programmer | Category C | External events are not observed after Warm reset                                                       | rOpO              | rOp1             |

| ID      | Area       | Category   | Summary                                                                                                    | Found in versions | Fixed in version |
|---------|------------|------------|------------------------------------------------------------------------------------------------------------|-------------------|------------------|
| 1955072 | Programmer | Category C | Mapping memory as Tagged when Allocation Tag storage is not provided might lead to CHI protocol violations | rOpO              | rOp1             |
| 1956538 | Programmer | Category C | Execution of ESB instruction in debug state might cause unpredictable behavior                             | rOpO              | rOp1             |
| 1959615 | Programmer | Category C | Exceptions in debug state might allow execution of subsequent instruction in EDITR                         | rOpO              | rOp1             |
| 1964078 | Programmer | Category C | VMID tracing incorrectly allowed or disallowed based on TRFCR_EL2.CX                                       | rOpO              | rOp1             |
| 1965154 | Programmer | Category C | PMU snapshot records incorrect Context ID when PMU inactive                                                | rOpO              | rOp1             |
| 1966395 | Programmer | Category C | A continuous stream of stores<br>might prevent forward<br>progress of a coherency<br>operation             | rOpO              | rOp1             |
| 1974927 | Programmer | Category C | SIMD, FP, and SVE cacheable loads or MTE-checked stores might hang on accessing a poisoned cache line      | rOpO              | rOp1             |
| 1975007 | Programmer | Category C | WFE trap might take effect when a wake up event is pending                                                 | rOpO              | rOp1             |
| 1976399 | Programmer | Category C | PrefetchTgt transactions are generated when PrefetchTgt is disabled                                        | rOpO              | rOp1             |
| 1977191 | Programmer | Category C | Trigger received immediately out of warm reset might cause deadlock                                        | rOpO              | rOp1             |
| 1980125 | Programmer | Category C | A change of ASID without context synchronization might cause memory ordering issues                        | rOpO              | rOp1             |
| 1980599 | Programmer | Category C | An ECC error in the L1 data cache might not be detected                                                    | rOpO              | rOp1             |
| 1981723 | Programmer | Category C | A continuous stream of DVM operations from another PE might block core powerdown                           | rOpO              | rOp1             |
| 1982956 | Programmer | Category C | SIMD and floating point loads<br>to non-gatherable device<br>memory might over-read                        | r0p0              | rOp1             |

| ID      | Area       | Category   | Summary                                                                                                      | Found in versions      | Fixed in version |
|---------|------------|------------|--------------------------------------------------------------------------------------------------------------|------------------------|------------------|
| 1986930 | Programmer | Category C | Corruption might occur on MTE allocation tags                                                                | rOpO                   | rOp1             |
| 1987125 | Programmer | Category C | ERR2MISCO.OFR and<br>ERR2MISCO.OFO might not be<br>set on counter overflow                                   | rOpO                   | rOp1             |
| 1987184 | Programmer | Category C | DBG_RECOV or WARM_RST<br>power modes might lead to<br>deadlock or data corruption                            | rOpO, rOp1             | rOp2             |
| 1990749 | Programmer | Category C | Errors or poison in the L2 data<br>RAM might lead to deadlock<br>and/or data corruption                      | rOpO                   | rOp1             |
| 1991004 | Programmer | Category C | Uncontainable error injection via ERR2PFGCTL might occur at the wrong time                                   | rOpO                   | rOp1             |
| 1991342 | Programmer | Category C | Traps of System registers in<br>Debug state might cause<br>unexpected exceptions                             | rOpO                   | rOp1             |
| 1996476 | Programmer | Category C | A Tag Checked SVE non-fault<br>or first-fault load might hang if<br>an External abort occurs                 | rOpO                   | rOp1             |
| 1996886 | Programmer | Category C | ELA connected to warm reset instead of cold reset                                                            | r0p0                   | rOp1             |
| 1997011 | Programmer | Category C | Asynchronous Tag Check fail<br>not synchronized based on<br>SCTLR_ELx.ITFSB for<br>exceptions in Debug state | rOpO                   | rOp1             |
| 1998835 | Programmer | Category C | Double-bit errors in the duplicate L1 data cache tag RAMs might lead to loss of coherency or deadlock        | rOpO, rOp1, rOp2, rOp3 | r1p0             |
| 1999032 | Programmer | Category C | Non-Data Errors on memory accesses not attributable to a core might not be reported                          | rOpO                   | rOp1             |
| 2000000 | Programmer | Category C | Interrupt might not be taken in finite time                                                                  | rOpO                   | rOp1             |
| 2006188 | Programmer | Category C | L2 cache debug operations<br>might hang when no L2 cache<br>is present                                       | rOpO, rOp1             | rOp2             |
| 2012183 | Programmer | Category C | Double-bit errors in the duplicate L1 data cache tag RAMs might lead to deadlock on a snoop                  | rOpO, rOp1             | rOp2             |
| 2015240 | Programmer | Category C | Clearing a pending OS Unlock<br>Catch debug event might cause<br>unpredictable behavior                      | rOpO                   | rOp1             |

| ID      | Area       | Category   | Summary                                                                                                                    | Found in versions | Fixed in version |
|---------|------------|------------|----------------------------------------------------------------------------------------------------------------------------|-------------------|------------------|
| 2016064 | Programmer | Category C | A continuous stream of memory requests from one CPU in the complex might block another                                     | rOpO              | rOp1             |
| 2017921 | Programmer | Category C | Exception or DCPS3<br>instruction in debug state<br>might block execution of<br>instruction from EDITR                     | rOpO, rOp1        | rOp2             |
| 2025809 | Programmer | Category C | A double-bit error on the L1 data cache MTE tag RAMs might result in a missed or incorrect error record in ERR1STATUS      | rOpO, rOp1        | r0p2             |
| 2033473 | Programmer | Category C | A hardware update of the dirty bit might occur speculatively                                                               | rOpO, rOp1        | rOp2             |
| 2035302 | Programmer | Category C | CONTEXTIDR_EL2 breakpoint matching is enabled at EL3                                                                       | r0p0, r0p1, r0p2  | rOp3             |
| 2036369 | Programmer | Category C | MPAM3_EL3.TRAPLOWER reset on Cold reset                                                                                    | rOpO, rOp1        | rOp2             |
| 2048342 | Programmer | Category C | A load or store instruction<br>might hang when encountering<br>multiple uncorrectable or<br>deferred errors                | rOpO, rOp1, rOp2  | rOp3             |
| 2052205 | Programmer | Category C | ERR2STATUS.SERR might be incorrect after an NDErr response is received                                                     | rOpO, rOp1, rOp2  | rOp3             |
| 2052374 | Programmer | Category C | PMU event ST_RETIRED might<br>be inaccurate for Store-<br>Exclusive instructions                                           | rOpO, rOp1, rOp2  | rOp3             |
| 2053387 | Programmer | Category C | Instructions in Debug state<br>after a watchpoint debug event<br>might not be executed                                     | rOpO, rOp1, rOp2  | rOp3             |
| 2054370 | Programmer | Category C | Execution of instructions in Debug state after a watchpoint debug event might incorrectly set EDSCR.ERR and corrupt PSTATE | rOpO, rOp1, rOp2  | rOp3             |
| 2056307 | Programmer | Category C | A Tag Checked store exclusive might hang if an external abort occurs                                                       | rOpO, rOp1, rOp2  | rOp3             |
| 2059297 | Programmer | Category C | PSTATE.TCO might be unchanged for debug entry due to a watchpoint debug event                                              | rOpO, rOp1, rOp2  | rOp3             |
| 2071968 | Programmer | Category C | Incorrect context ID might be associated with trace data                                                                   | rOpO, rOp1, rOp2  | rOp3             |

| ID      | Area       | Category   | Summary                                                                                                      | Found in versions                     | Fixed in version |
|---------|------------|------------|--------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------|
| 2077160 | Programmer | Category C | Incorrect ordering after change in cacheability                                                              | r0p0, r0p1, r0p2                      | rOp3             |
| 2077274 | Programmer | Category C | Extra A-sync packet might get<br>written to Trace Buffer in<br>Trace prohibited region                       | r0p0, r0p1, r0p2, r0p3                | r1p0             |
| 2085871 | Programmer | Category C | Shareability aliases might result in incorrect Tag Check Faults                                              | r0p0, r0p1, r0p2, r0p3                | r1p0             |
| 2088637 | Programmer | Category C | A watchpointed SVE load<br>might update the FFR register<br>incorrectly                                      | r0p0, r0p1, r0p2, r0p3                | r1p0             |
| 2092740 | Programmer | Category C | Debug state exit after<br>execution of a DRPS<br>instruction might lead to<br>deadlock                       | r0p0, r0p1, r0p2, r0p3                | r1p0             |
| 2096738 | Programmer | Category C | Double-bit errors in the duplicate L1 data cache tag RAMs might lead to deadlock                             | r0p0, r0p1, r0p2, r0p3                | r1p0             |
| 2112025 | Programmer | Category C | Instructions might be missed<br>for tracing purposes before<br>Debug state entry due to a<br>watchpoint hit  | r0p0, r0p1, r0p2, r0p3                | r1p0             |
| 2120833 | Programmer | Category C | DISR_EL1 access in Debug state might be incorrect                                                            | r0p0, r0p1, r0p2, r0p3                | r1p0             |
| 2133769 | Programmer | Category C | PMU event 0x000C<br>PC_WRITE_RETIRED might be<br>inaccurate for ERET<br>instructions                         | r0p0, r0p1, r0p2, r0p3                | r1p0             |
| 2135690 | Programmer | Category C | PMU events based on<br>STALL_FRONTEND might be<br>inaccurate                                                 | rOpO, rOp1, rOp2, rOp3                | r1p0             |
| 2141037 | Programmer | Category C | OFF_EMU to OFF power<br>mode transition might result in<br>a deadlock                                        | rOpO, rOp1, rOp2, rOp3                | r1p0             |
| 2146058 | Programmer | Category C | PMU events counts might be inaccurate                                                                        | rOpO, rOp1, rOp2, rOp3                | r1p0             |
| 2161448 | Programmer | Category C | PMU_HOVFS event not always exported when self-hosted trace disabled                                          | rOp1, rOp2, rOp3                      | r1p0             |
| 2164605 | Programmer | Category C | A watchpoint hit while<br>disabling Halting debug might<br>cause an incorrect debug<br>exception to be taken | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 2175229 | Programmer | Category C | A single ECC error on the L2 data RAMs might be double-counted                                               | r1p0                                  | r1p1             |

| ID      | Area       | Category   | Summary                                                                                                                             | Found in versions                     | Fixed in version |
|---------|------------|------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------|
| 2181318 | Programmer | Category C | A PE trace unit trigger might<br>not be reflected in TRBSR_EL1<br>after a TSB                                                       | r1p0                                  | r1p1             |
| 2187223 | Programmer | Category C | In Halting debug state, the core<br>might take an illegal execution<br>exception when it should not                                 | r1p0                                  | r1p1             |
| 2189260 | Programmer | Category C | An MMU fault might not be correctly reflected in the Trace Buffer Extension TRBSR_EL1 register                                      | rOpO, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2189707 | Programmer | Category C | Clean MTE tag writeback might occur after a store to the cache line                                                                 | r0p0, r0p1, r0p2, r0p3, r1p0          | r1p1             |
| 2212805 | Programmer | Category C | An ECC error while in the active-not-pending state might clear PSTATE.SS                                                            | r0p0, r0p1, r0p2, r0p3, r1p0          | r1p1             |
| 2217109 | Programmer | Category C | RAS error reporting might be incorrect on simultaneous errors                                                                       | r0p0, r0p1, r0p2, r0p3, r1p0          | r1p1             |
| 2220074 | Programmer | Category C | ETM will indicate that a T32<br>CC-failed ISB has caused a<br>Context Synchronization Event<br>when it has not                      | r1p0                                  | r1p1             |
| 2226937 | Programmer | Category C | IMP_CDBGDR0_EL3 read data might be incorrect                                                                                        | r1p0                                  | r1p1             |
| 2230537 | Programmer | Category C | Load following SVE predicated load/store might cause ordering violation                                                             | r0p0, r0p1, r0p2, r0p3, r1p0          | r1p1             |
| 2236402 | Programmer | Category C | Asynchronous exception or debug event might be taken before an exception catch debug event that was generated by an exception entry | rOpO, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2241478 | Programmer | Category C | The L1D_CACHE_REFILL and L1D_CACHE_LMISS_RD PMU events might over-count                                                             | r0p0, r0p1, r0p2, r0p3, r1p0          | r1p1             |
| 2265919 | Programmer | Category C | Top byte of DLR_ELO might be incorrect when entering AArch64 halting Debug state                                                    | r0p0, r0p1, r0p2, r0p3, r1p0          | r1p1             |
| 2266023 | Programmer | Category C | Vector stores might not use a faster forwarding path                                                                                | rOpO, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2271084 | Programmer | Category C | DTR flags not cleared on<br>external debugger access while<br>leaving Debug state                                                   | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |

| ID      | Area       | Category   | Summary                                                                                                                             | Found in versions                     | Fixed in version |
|---------|------------|------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|------------------|
| 2272274 | Programmer | Category C | Core might execute two instructions on Halting Step debug event                                                                     | rOp0, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2287488 | Programmer | Category C | Core might not execute instruction on Halting Step debug event                                                                      | rOp0, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2289541 | Programmer | Category C | PMU counter overflow can<br>cause spurious PMU_OVFS<br>and PMU_HOVFS events                                                         | rOpO, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2289878 | Programmer | Category C | Core might step two instructions at once                                                                                            | rOpO, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2291784 | Programmer | Category C | PSTATE.IL might be cleared on ERET to Software Stepping                                                                             | rOpO, rOp1, rOp2, rOp3, r1p0          | r1p1             |
| 2293834 | Programmer | Category C | The core might report that a load-exclusive instruction has not been stepped when it should                                         | rOpO, rOp1, rOp2, rOp3, r1p0, r1p1    | r1p2             |
| 2300878 | Programmer | Category C | Software stepping ESB might set SPSR.ELx.SS to incorrect value                                                                      | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 2303522 | Programmer | Category C | Synchronous tag checking on a<br>store exclusive might cause a<br>deadlock if double bit/fatal<br>error seen in L1-Duplicate<br>RAM | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 2316094 | Programmer | Category C | MTE checking might not be reliable                                                                                                  | rOp0, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 2321712 | Programmer | Category C | DLR_EL0[1] is ignored when performing debug exit to A32                                                                             | r1p0, r1p1                            | r1p2             |
| 2324165 | Programmer | Category C | Processor state might be corrupted if EDSCR.INTdis is set while asynchronous interrupt is in flight                                 | rOpO, rOp1, rOp2, rOp3, r1p0, r1p1    | r1p2             |
| 2331844 | Programmer | Category C | Software stepping ERET might set PSTATE or SPSR to incorrect value                                                                  | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 2335678 | Programmer | Category C | BFMMLA/VMMLA result might<br>be corrupted when forwarding<br>source operand from vector<br>load                                     | r1p0, r1p1                            | r1p2             |
| 2341012 | Programmer | Category C | Physical SError interrupts while software stepping a load or store instruction might cause two instructions to be stepped           | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |

| ID      | Area       | Category   | Summary                                                                            | Found in versions                     | Fixed in version |
|---------|------------|------------|------------------------------------------------------------------------------------|---------------------------------------|------------------|
| 2342004 | Programmer | Category C | TLB Parity Check cannot be disabled                                                | r0p0, r0p1, r0p2, r0p3, r1p0, r1p1    | r1p2             |
| 2342918 | Programmer | Category C | PrefetchTgt transactions are generated when PrefetchTgt is disabled                | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 2360589 | Programmer | Category C | Exception catch might not be taken on ERET from EL3 to any Non-secure EL           | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 2371559 | Programmer | Category C | ESR_ELx might be incorrect after trapped vector instruction in Debug state         | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 2385664 | Programmer | Category C | Core might not execute any instruction when performing Halting Step                | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 2393935 | Programmer | Category C | ESR_ELx.EX might be incorrect when stepping a load exclusive                       | rOp0, rOp1, rOp2, rOp3, r1p0, r1p1    | r1p2             |
| 2396657 | Programmer | Category C | ESR_ELx.EX might be incorrect due to asynchronous exception when software stepping | rOpO, rOp1, rOp2, rOp3, r1p0,<br>r1p1 | r1p2             |
| 2423961 | Programmer | Category C | PMU_OVFS event is not generated on PMCCNTR_EL0 overflow                            | rOpO, rOp1, rOp2, rOp3, r1p0, r1p1    | r1p2             |
| 2429106 | Programmer | Category C | Exception Catch debug event might not be taken                                     | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 2429770 | Programmer | Category C | PC_WRITE_SPEC event does not count correctly                                       | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 2478655 | Programmer | Category C | L2D_CACHE_WB event might over-count                                                | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 2601282 | Programmer | Category C | ELADISABLE does not disable<br>APB access to the complex<br>ELA                    | rOpO, rOp1, rOp2, rOp3, r1p0, r1p1    | r1p2             |
| 2618004 | Programmer | Category C | LDST_SPEC event might under-count                                                  | r0p0, r0p1, r0p2, r0p3, r1p0,<br>r1p1 | r1p2             |
| 2636015 | Programmer | Category C | BUS_ACCESS and<br>BUS_ACCESS_WR PMU<br>events are not reliable                     | rOpO, rOp1, rOp2, rOp3, r1p0, r1p1    | r1p2             |

## **Errata descriptions**

## Category A

## 1914417 Coherency may be lost

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

Under certain conditions, coherency may be lost on a cache line, resulting in potential data corruption.

## **Configurations Affected**

This erratum affects configurations where the complex is configured with an L2 cache, by setting the L2\_CACHE parameter to TRUE.

#### **Conditions**

- 1. Data caching is enabled.
- 2. The MMU is enabled.
- 3. Unlikely micro-architectural conditions occur.

## **Implications**

If the conditions above are met, coherency may be lost for lines in the caches, resulting in possible data corruption.

#### Workaround

There is no workaround for this erratum.

## TLBI completion might not be guaranteed by DSB

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A TLB invalidate (**TLBI**) followed by a **DSB** on any PE in the system might not guarantee all memory accesses performed by a core using the TLB entries that have been invalidated by the previous **TLBI** operation are complete.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

- 1. A Cortex-A510 core starts a memory access.
- 2. A different PE in the system executes a TLB invalidate followed by a **DSB**. This **TLBI** invalidates the TLB entry used by the memory access in condition 1.

## **Implications**

A memory access using a TLB entry that has been invalidated by the subsequent **TLBI**, might not have been completed when the **DSB** following the **TLBI** finishes.

#### Workaround

This erratum can be avoided if the **TLBI** and **DSB** sequence is repeated. After the completion of the second **DSB**, the stores that should have been completed before the first **DSB** will complete. This workaround might impact system performance significantly.

#### 1927171

## Mismatched memory attributes might cause deadlock

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

If mismatched memory attributes are used, the system might deadlock.

## **Configurations Affected**

Configurations with two cores per complex are affected.

#### **Conditions**

- 1. Both cores in the complex have a cache line, A, in the L1 data cache, with cacheable attributes.
- 2. One of the cores issues a non-cacheable transaction to the same physical address as cache line A.
- 3. Unlikely microarchitectural conditions involving the exact timing of multiple operations occur.

## **Implications**

If the above conditions are met, then one or more cores or other coherent agents in the system might deadlock.

If the cluster does not receive external snoops to addresses also mapped as non-cacheable, the probability of hitting this erratum is significantly reduced.

### Workaround

## Acquire/release semantics violated on store atomic instructions

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

Store atomic instructions with release semantics do not guarantee RCsc (Release Consistency sequentially consistent) consistency with respect to a following Load-Acquire.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

A core executes the following sequence of instructions with no LD+ST barrier (DMB/DSB ISH/OSH/NSH/SY) in between:

- 1. A store atomic instruction with release semantics (STADDL, STCLRL, STEORL, STSMAXL, STSMINL, STUMAXL, STUMINL)
- 2. A load with Load-Acquire RCsc semantics

## **Implications**

If the conditions are met, the Load-Acquire does not guarantee the Store-Release is observed by other PEs before the memory access generated by the Load-Acquire.

#### Workaround

#### 1946214

## Heavy L2 memory traffic may lead to data corruption and deadlock

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

Heavy memory traffic in the L2 cache may lead to data corruption and a subsequent deadlock.

## **Configurations Affected**

This erratum affects configurations where the complex is configured with an L2 cache, and with two L2 RAM partitions per slice (configuration parameter L2\_CACHE is TRUE and L2\_NUM\_RAMCTL\_PARTITIONS is 2).

#### **Conditions**

- 1. Heavy memory traffic in the L2 cache.
- 2. Complex microarchitectural conditions occur.

## **Implications**

If the conditions are met, data corruption may occur, followed by a deadlock.

#### Workaround

## 1968719 Snoops might lead to a deadlock

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

Snoops received by a complex, either from other coherent requestors in the cluster or external coherency requests, might lead to a deadlock if the snooped cache line is currently being written back or evicted by the complex.

## **Configurations Affected**

This erratum affects all configurations.

### **Conditions**

- 1. The complex performs a cache writeback, either because of a natural eviction, or a non-allocating write.
- 2. The cache writeback request cannot be sent immediately due to structural backpressure on the request channel.
- 3. The complex receives a snoop to the same address as the cache writeback, either from other coherent requestors in the cluster or external coherency requests.
- 4. A downstream memory component, such as the DSU, has a dependency, structural or otherwise, that keeps structural backpressure on the request channel until the snoop completes.

## **Implications**

If the above conditions are met, the complex might be unable to respond to the snoop, leading to a deadlock.

#### Workaround

# Secure Physical Address Cache Invalidate all DVM operation does not invalidate Non-Secure lines in L1 I-Cache

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

On receipt of a Secure Physical Address Cache Invalidate all DVM operation, the core will invalidate all Secure lines from the L1 I-cache, but not Non-Secure lines. Due to an AMBA architecture erratum, this is no longer legal behavior.

## **Configurations Affected**

This erratum affects configurations where Cortex-A510 is used with cores that can generate Secure Physical Instruction Cache Invalidate all DVM operations. Cortex-A510 will not generate this kind of DVM operation.

#### **Conditions**

1. The core receives a Secure Physical Address Cache Invalidate all DVM operation. These operations will be generated by a core executing an **IC IALLU** or **IC IALLUIS** instruction. Cortex-A510 cores will not generate this type of operation.

## **Implications**

Non-secure software might observe stale instruction cache contents after an invalidation from Secure software.

#### Workaround

#### 1996706

## A deadlock might occur during or after WFI or WFE

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

If a core's L1 data cache is snooped while it is in WFI or WFE low-power state, the core might later deadlock on a coherency operation or write.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. A core executes a **WFI** or **WFE** instruction. As soon as outstanding traffic is drained, this results in the core clock being gated.
- 2. One or more cache lines are still present in the L1 data cache at this time.
- 3. Another core in the same shareability domain causes a coherency request to a cache line present in the L1 data cache of the core executing the **WFE** or **WFI** instruction above.

## **Implications**

If these conditions are met, the core or a coherency operation to the core might deadlock at the time the core is in WFI or WFE low-power state, or at a later time.

#### Workaround

#### 2007174

# Heavy store traffic might lead to a DSB not completing on the same core or another core

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A store might lead to a **DSB** on any core in the same shareability domain to hang if one of the cores in the complex has generated heavy store or cache maintenance traffic.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. One or more cores in the complex cause heavy store or cache maintenance traffic beyond the L1 cache.
- 2. A core in the complex executes a store.
- 3. Very unusual, timing-sensitive, microarchitectural conditions occur.

## **Implications**

If these conditions are met, a **DSB** on any core in the same shareability domain during or after the stores might hang.

#### Workaround

# Non-cacheable stores, maintenance, or speculation restriction instructions might cause a deadlock

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

A deadlock might occur if both cores are simultaneously performing a sequence of stores, TLB or instruction cache maintenance instructions, or speculation restriction instructions.

## **Configurations Affected**

This erratum affects configurations with two cores in a complex.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. Both cores in the complex simultaneously perform a sequence of 9 or more of one or more of the following instructions without barriers in between the accesses:
  - Stores to memory other than Normal Inner-Writeback and Outer-Writeback Cacheable
  - TLB maintenance instructions (**TLBI**)
  - Instruction cache maintenance instructions (IC)
  - Speculation restriction instructions (CPP, DVP, CFP)
- 2. Unlikely, timing-sensitive microarchitectural conditions occur.

## **Implications**

If the conditions are met, a deadlock affecting all cores in the same shareability domain might occur. Arm believes this is unlikely to cause a problem for sample silicon. Please contact Arm if you believe you are encountering this issue for support with software mitigations.

## Workaround

## Forwarding snoops might cause a deadlock

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

If the complex receives a forwarding snoop as part of a coherency request from another core or requester in the system, a deadlock might occur.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The complex receives a forwarding snoop as part of a coherency request from another core or requester in the system.
- 2. Unlikely, but not rare, timing-sensitive microarchitectural conditions occur.

## **Implications**

If the conditions are met, a deadlock might occur.

#### Workaround

## Normal execution can result in data corruption

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

## Description

A sequence of loads and stores might result in data that is forwarded to dependent instructions to be inconsistent with data that is written to the architectural register file.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. A store to a memory location A is executed.
- 2. A load to the same 64-byte cache line as memory location A occurs, but not overlapping with A.
- 3. A load to the same 64-byte cache line as memory location A occurs.
- 4. A concurrent store to memory location A is executed on another PE. The store is coherence-after the concurrent store of condition 1.
- 5. Complex, timing-sensitive micro-architectural conditions occur.

## **Implications**

If the conditions are met, the last load might forward data to dependent instructions that is inconsistent with the data written to the architectural register file. This load might forward the data from the store in condition 1 to dependent instructions, while writing the data of the store in step 4 to the architectural register file.

#### Workaround

Software can set IMP\_CPUACTLR\_EL1[4] = 1; for example, using the following sequence:

```
MRS x0, S3_0_C15_C1_0
MOV x1, #1
BFI x0, x1, #4, #1
MSR S3_0_C15_C1_0, x0
```

This increases the best-case load-use penalty by one cycle. Some individual tests of the benchmarks can cause an IPC reduction of up to 9% (SPECint2006) and 6% (Geekbench v5), but the geometric mean reduction is of 3-4% (SPECint2006) and 2% (Geekbench v5).

# Heavy I-cache invalidation or TLB invalidation traffic from other PEs can cause a deadlock

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOp0, rOp1, rOp2, rOp3 and r1p0. Fixed in r1p1.

## Description

Heavy I-cache invalidation or TLB invalidation traffic from other PEs in the system can cause a deadlock.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. One or more other PEs in the system generate sequences of Instruction Cache Invalidate or TLB Invalidate traffic without intervening **DSB** instructions.
- 2. Heavy memory traffic across the system occurs downstream of the L2 caches.
- 3. Complex microarchitectural timing conditions occur.

## **Implications**

If the conditions are met, the system might deadlock.

#### Workaround

There is currently no workaround for this erratum.

## Unmodified cache line might be written back to memory

#### **Status**

Fault Type: Programmer Category A

Fault Status: Present in rOp0, rOp1, rOp2, rOp3, r1p0 and r1p1. Fixed in r1p2.

## Description

Cacheable store operations might incorrectly cause an unrelated cache line to be marked as modified, which later results in that line being written back to memory.

## **Configurations Affected**

This erratum affects all configurations.

#### Conditions

This erratum occurs under the following conditions:

- 1. Memory location A is marked as Normal Inner Write-Back, Outer Write-Back Cacheable memory.
- 2. The core allocates location A into the L1 data cache. This allocation might be due to committed instructions, Speculative execution or data prefetching.
- 3. The core executes a number of stores to a cacheable memory location other than location A.
- 4. Uncommon, timing-sensitive microarchitectural conditions occur.

## **Implications**

If the previous conditions are met, the cache line for memory location A might be marked as modified but the data remains unchanged. When the cache line is subsequently evicted, it will then overwrite the value in memory. If an agent in the system has made non-coherent writes to location A, these writes might then be overwritten with the older data from the core cache write-back, causing these writes to no longer be visible. This might then result in data corruption for software-managed coherency use cases.

Stores in condition 3 modify their cache lines as expected, this erratum cannot cause a modified cache line to still be marked as clean in the cache.

#### Workaround

This erratum has no workaround.

## Category A (rare)

#### 1965350

## Coherency might be lost on a cache line

#### **Status**

Fault Type: Programmer Category A (rare) Fault Status: Present in rOp0. Fixed in rOp1.

## Description

Under rare circumstances, coherency may be lost on a cache line filled into the L1 data cache.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. A core performs an L1 cache refill.
- 2. The same core performs another L1 cache refill.
- 3. Rare, timing-sensitive micro-architectural conditions occur.

## **Implications**

If the conditions are met, coherency might be lost on the cache line filled into the L1 data cache.

#### Workaround

## Non-L1-allocating stores might cause data corruption

#### **Status**

Fault Type: Programmer Category A (rare)

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

In rare circumstances, stores might cause data corruption on the bytes written.

## **Configurations Affected**

This erratum affects configurations where the complex is configured with an L2 cache, and with two L2 RAM partitions per slice (configuration parameter L2\_CACHE is TRUE and L2 NUM RAMCTL PARTITIONS is 2).

#### **Conditions**

The erratum occurs under the following conditions:

- 1. Three or more non-L1-allocating stores (excluding stores to non-gathering Device memory) to the same 16-byte-aligned 16-byte granule are executed close to each other. Stores are non-L1-allocating if any of the following conditions is met:
  - The memory type is not Normal Inner Write-Back, Outer Write-Back Cacheable.
  - The memory attributes are Transient.
  - They are generated by **STNP** or **DC ZVA** instructions.
  - The core is in write-streaming mode.
- 2. Rare, timing-sensitive microarchitectural conditions occur.

## **Implications**

If the conditions are met, data in the 16-byte-aligned 16-byte granule that the stores are writing to might be corrupted.

#### Workaround

## Category B

### 1902691

## Trace Buffer Extension can cause trace corruption or deadlock

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

The use of Trace Buffer Extension (TRBE) to write trace data from the ETM to memory can result in trace data corruption or deadlock.

## **Configurations Affected**

All configurations are affected.

### **Conditions**

- 1. TRBE is enabled by setting TRBLIMITR EL1.E to 1.
- 2. The ETM is enabled and generating trace.

## **Implications**

TRBE should not be used on this revision of the product, despite being advertised as supported in the ID registers.

### Workaround

System firmware should disable the use of TRBE, by setting MDCR\_EL3.NSTB to 0b00 and TRBLIMITR EL1.E to 0.

# Use of tagged memory might cause deadlock, data corruption or incorrect reporting

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

If a memory location is mapped as tagged memory and MTE is enabled, then deadlock, data corruption, or incorrect reporting in TFSREO EL1 or TFSR ELx might occur.

## **Configurations Affected**

This erratum affects configurations where the **BROADCASTMTE** pin is HIGH.

#### **Conditions**

- 1. MTE is enabled (SCTLR\_ELx.ATAn = 1, SCTLR\_ELx.TCFn != 0b00).
- 2. A page is mapped as tagged memory.
- 3. Unlikely micro-architectural conditions involving the exact timing of multiple operations.

## **Implications**

If these conditions are met, then one or more of the following might occur:

- Deadlock
- Data corruption of either data or allocation tags
- Spurious fault reporting or failure to report faults in TFSREO\_EL1 or TFSR\_ELx

#### Workaround

This erratum can be avoided by setting IMP\_CPUECTLR\_EL1[19] = 1, IMP\_CPUACTLR\_EL1[4] = 1 and IMP\_CPUACTLR\_EL1[26] = 1, for example using the following code sequence:

```
MRS x0, S3_0_C15_C1_4

MOV x1, #1

BFI x0, x1, #19, #1

MSR S3_0_C15_C1_4, x0

MRS x0, S3_0_C15_C1_0

MOV x1, #1

BFI x0, x1, #4, #1

BFI x0, x1, #26, #1

MSR S3 0 C15 C1 0, x0
```

## SnpPreferUnique\* might lead to a loss of coherency

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

Coherency might be lost if the core receives a SnpPreferUnique or SnpPreferUniqueFwd as a result of either:

- a SnpPreferUnique or SnpPreferUniqueFwd external to the cluster, or
- a ReadPreferUnique or MakeReadUnique(excl) on another core in the cluster.

A ReadPreferUnique is typically triggered by load exclusive instructions as well as by speculative stores. A MakeReadUnique(excl) can only be triggered by a non-speculative store exclusive instruction.

## **Configurations Affected**

All configurations are affected.

### **Conditions**

- 1. A cache line A is present in the L1 data cache of at least one core in the complex.
- 2. The core is executing an exclusive sequence.
- 3. A SnpPreferUnique or SnpPreferUniqueFwd transaction to cache line A is received by the complex.

## **Implications**

If the conditions are met, coherency might be lost on cache line A.

#### Workaround

This erratum can be avoided by setting IMP\_CMPXACTLR\_EL1[11:10] = 3; for example, using the following code sequence:

```
MRS x0, S3_0_C15_C1_3

MOV x1, #3

BFI x0, x1, #10, #2

MSR S3_0_C15_C1_3, x0
```

This workaround has negligible performance impact.

## Tag Checked store might not be correctly ordered by DMB

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

The Tag read for a Tag Checked store might not be ordered correctly by a DMB.

## **Configurations Affected**

This erratum affects configurations where the **BROADCASTMTE** pin is HIGH.

#### **Conditions**

- 1. The core starts a memory access.
- 2. A **DMB** instruction that orders loads is executed (any **DMB** without the **ST** qualifier).
- 3. A Tag Checked store is executed.

## **Implications**

In the above sequence, the Tag read generated by the Tag Checked store instruction might not be ordered correctly with other memory accesses before the **DMB** instruction.

#### Workaround

This erratum can be avoided by setting IMP\_CPUACTLR\_EL1[10] = 1; for example, using the following code sequence:

```
MRS x0, S3_0_C15_C1_0
MOV x1, #1
BFI x0, x1, #10, #1
MSR S3_0_C15_C1_0, x0
```

This upgrades **DMB** instructions to **DSB**, potentially incurring a small but not negligible performance cost.

## A cacheable load of SIMD&FP or SVE registers might return incorrect data

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

A cacheable Neon, SVE, or FP load might return incorrect data under certain micro-architectural conditions.

## **Configurations Affected**

This erratum affects configurations where the complex is configured with an L2 cache (configuration parameter L2 CACHE is TRUE).

#### **Conditions**

The following sequence is executed:

- 1. An unaligned load crossing a 16-byte boundary, an **LDG** instruction, or a Tag Checked load, to memory mapped as Normal Inner Write-Back, Outer Write-Back.
- 2. A load of one or more SIMD&FP or SVE registers that partially or fully overlaps the previous load, but does not cross a 16-byte boundary and is Tag Unchecked.

Both accesses miss in the L1 data cache, but hit in the L2 cache.

## **Implications**

If the above conditions are met, under some rare micro-architectural conditions, the second load might return incorrect data.

#### Workaround

This erratum can be avoided by setting IMP\_CPUACTLR\_EL1[15] = 1; for example, using the following code sequence:

```
MRS x0, S3_0_C15_C1_0
MOV x1, #1
BFI x0, x1, #15, #1
MSR S3_0_C15_C1_0, x0
```

This increases the best case L2 hit latency by a cycle, incurring a small but not negligible performance cost.

## Cacheable far atomics might result in loss of coherency

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

A cacheable atomic instruction might result in a loss of coherency if the cache line is present in the complex.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- An atomic instruction to a cacheable location is executed on a core in the complex. The atomic instruction is executed as a "far" atomic (outside the core).
- The cache line is also present in the L1 data cache of at least one of the cores within the complex.
- A snoop is received by the complex for the cache line.

## **Implications**

If the conditions are met, coherency might be lost on the accessed cache line.

#### Workaround

If a workaround is necessary, atomic instructions can be forced to execute "near" (in the core), rather than "far" by setting IMP CPUECTLR EL1[40:38] = 0b010; for example, using the following sequence:

```
MRS x0, S3_0_C15_C1_4
MOV x1, #2
BFI x0, x1, #38, #3
MSR S3_0_C15_C1_4, x0
```

#### 1952872

## A cacheable load might return incorrect data

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

A cacheable load of general-purpose registers might return incorrect data under some microarchitectural conditions.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. Unlikely microarchitectural conditions occur.
- 2. A cacheable load of one or more general-purpose registers is executed which hits in the L1 data cache.

## **Implications**

If the above conditions are met, incorrect data may be returned.

#### Workaround

This erratum can be avoided by setting IMP\_CPUACTLR\_EL1[18] = 1, for example using the following code sequence:

```
MRS x0, S3_0_C15_C1_0
MOV x1, #1
BFI x0, x1, #18, #1
MSR S3_0_C15_C1_0, x0
```

This workaround may have a small but not negligible performance impact. The reach of the L1 data TLB is reduced in some cases.

# 1955641 Core in FULL\_RET might cause data corruption

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

When one core in a complex is in the FULL\_RET power mode and the other core is OFF, this might either cause data corruption or prevent reporting of RAS error interrupts.

## **Configurations Affected**

This erratum affects all configurations with two cores in a complex.

#### **Conditions**

- 1. One core in a complex is in the OFF power mode.
- 2. The other core in the same complex enters the FULL\_RET power mode.

## **Implications**

The complex will incorrectly remove itself from coherency with the rest of the cluster, leading to data corruption if another agent tries to snoop data that is in the complex.

If there is an existing error in the complex RAS registers, causing the **nCOMPLEXFAULTIRQ** and **nCOMPLEXERRIRQ** outputs to be asserted LOW, then these signals might be incorrectly deasserted HIGH while the complex is in FULL\_RET. These errors will then not be visible to the system until the core leaves FULL\_RET.

#### Workaround

The FULL\_RET power mode should not be enabled. This can be done by setting both IMP\_CPUPWRCTLR\_EL1.WFE\_RET\_CTL and IMP\_CPUPWRCTLR\_EL1.WFI\_RET\_CTL to 0b000, which is their default value.

## Missing trace for debug entry due to watchpoint hit

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

If ETM tracing is enabled and a watchpoint hit occurs that is configured to enter debug state, the waypoint for the debug entry will not be traced.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. Halting debug is enabled (EDSCR.HDE == 1).
- 2. Halting is allowed.
- 3. The OS Lock is unlocked (OSLSR EL1.OSLK == 0).
- 4. ETM tracing is enabled (TRCPRGCTLR.EN == 1). This can be enabled either by software or an external debugger.
- 5. Tracing in the current region is unprohibited.
- 6. An enabled watchpoint is hit.

## **Implications**

If these conditions are met, then no Exception element will be traced for the debug state entry.

#### Workaround

There is no workaround for this erratum

# Watchpoints on SVE first-fault and non-fault loads might cause an incorrect value to be loaded and/or an incorrect MTE check results

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

If a watchpoint is programmed on a byte accessed by a non-fault load, or by a first-fault load, and is on a byte not covered by the first element, a wrong value might be loaded on all active bytes. If MTE checking is enabled, the check results might be incorrect.

## **Configurations Affected**

This erratum affects all configurations.

### **Conditions**

The erratum occurs under the following conditions:

- 1. A watchpoint is programmed on a byte A.
- 2. An SVE non-fault load is executed which loads from byte A on any element, or an SVE first-fault load is executed which loads from byte A on any non-first element.

## **Implications**

If these conditions are met, the data loaded in all lanes by the SVE load above might be incorrect.

If MTE checking is enabled and the instruction fails the MTE check, the FFR might be incorrect.

If MTE checking is enabled with SCTLR\_ELx.TCF set to 0b01 (precise checking), an incorrect exception might be taken or no exception might be taken even if the tag check should have failed.

If MTE checking is enabled with SCTLR\_ELx.TCF set to 0b10 (imprecise checking), an incorrect value might be reported in TFSR\_ELx following the execution of the load.

This erratum has been categorized on the basis of use in sample systems only. A workaround is available where the use of watchpoints for memory locations accessed by SVE non-fault and first-fault instructions is required on sample silicon.

#### Workaround

Software can avoid this erratum by programming the watchpoint to cover a 32-byte-aligned 32-byte quantity.

## Set/way maintenance of L2 cache might cause data corruption

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

Use of set/way maintenance instructions targeting the L2 cache might cause data corruption of the cache line targeted by the operation.

## **Configurations Affected**

This erratum affects configurations where the complex is configured with an L2 cache and contains two cores.

### **Conditions**

- 1. A cache line is present in both the L2 cache and one of the L1 data caches.
- 2. A DC CISW, DC ISW, or DC CSW instruction is executed, targeting the L2 cache set/way that contains the cache line above.
- 3. The complex receives a snoop, other than SnpOnce, targeting the same cache line. This can be caused by any memory access to that cache line, in the cluster or outside.
- 4. One of the cores in the complex starts an L1 data cache refill to the same L1 data cache set as the cache line above

## **Implications**

If the conditions are met, data corruption may occur on the cache line targeted by the set/way maintenance instruction. The hardware flush mechanism is not affected.

#### Workaround

Software should only use set/way maintenance instructions targeting the L2 cache when caching is disabled in both cores of the complex. Note that the core performs hardware cache invalidation on powerup and powerdown, so there is generally no need for explicit software cache maintenance by set/way.

To prevent problems with set/way maintenance instructions in virtual machines, hypervisors can trap set/way instructions using HCR EL2.TSW=1.

# 1966377 Incorrect instructions might be executed

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

Incorrect instructions might be executed.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. The core executes with MMU enabled.
- 2. Additional complex micro-architectural conditions occur.

## **Implications**

If the above conditions are met, the core might execute incorrect instructions. The effects of the incorrect execution are not predictable and include:

- Spurious UNDEFINED instruction exceptions.
- Spurious Pre-fetch Abort, Data Aborts, or other exceptions.
- Incorrect instruction execution, which might lead to register or memory state corruption.

#### Workaround

This erratum can be avoided by setting IMP\_CPUACTLR2\_EL1[29] to 1 to disable a power optimization feature; for example, using the following sequence:

```
MRS x0, S3_0_C15_C1_1
ORR x0, x0, #1 << 29
MSR S3_0_C15_C1_1, x0
```

This will have no impact on performance, but will slightly increase power consumption (overall 1-2%).

## Cacheable Non-shareable mappings might lead to CHI protocol violations

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

Hardware prefetches to memory mapped as Cacheable Non-shareable may result in CHI protocol violations, which in turn may result in deadlocks, hazarding failures and potentially loss of coherency in rare circumstances.

## **Configurations Affected**

This erratum affects all configurations.

#### Conditions

- 1. A page of memory is mapped as Inner Write-Back, Outer Write-Back Non-shareable.
- 2. The interconnect returns a RespSepData response after DataSepResp has been sent for a hardware-prefetch-initiated ReadNoSnoop to the location above.

## **Implications**

If the conditions are met, the hardware prefetcher may cause a CHI protocol violation by reusing a TxnID early. This may result in deadlocks, hazarding failures and potentially loss of coherency in rare circumstances.

#### Workaround

In some systems, software can avoid using Non-shareable mappings. Where that is not possible, software can set IMP\_CMPXECTLR\_EL1[9:8] = 0b11, for example using the following sequence:

```
MRS x0, S3_0_C15_C1_7
MOV x1, #3
BFI x0, x1, #8, #2
MSR S3_0_C15_C1_7, x0
```

This disables early forwarding of L2 hardware prefetches to subsequent requests, and may incur a small but not negligible performance impact.

## Coherency might be lost on a cache line shortly after a core powers up

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

When the MMU and caches are enabled almost immediately after a core is powered on, coherency might be lost on an arbitrary cache line.

## **Configurations Affected**

This erratum affects configurations where the complex is configured with an L2 cache, and with two cores.

#### **Conditions**

- 1. One of the two cores in the complex is generating heavy cacheable L1 cache miss traffic.
- 2. The second core in the complex is powered on, and almost immediately enables the MMU and caches, and starts executing cacheable loads and stores.
- 3. Rare, timing-sensitive, microarchitectural conditions occur.

## **Implications**

If the conditions are met, coherency might be lost on an arbitrary cache line with PA[11:6] = 0x3f. The exact effects and cache line affected depends on the reset value of the duplicate tag RAMs.

#### Workaround

Software can execute 4 loads to 4 different cache lines with a physical address (PA) that does not match PA[11:6] = 0x3f on the CPU that just powered up before doing any other access to Inner Write-back and Outer Write-back memory. These loads must be the first 4 demand load/stores to normal memory with Inner Write-back and Outer Write-back cacheability, just after turning on the MMU and data caches. The loads must be followed by a DSB SY.

# A store exclusive to shareable memory other than Normal Inner Write-Back, Outer Write-Back Cacheable might cause a hang

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A store exclusive to shareable memory other than Normal Inner Write-Back, Outer Write-Back Cacheable might hang.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The core executes a store exclusive instruction to shareable memory other than Normal Inner Write-Back, Outer Write-Back Cacheable.
- 2. Unlikely, but not rare, timing-sensitive, microarchitectural conditions occur.

## **Implications**

If the conditions are met, the core executing the store exclusive instruction might hang. This erratum has been classified based on the understanding that the affected version of the product is only used for samples.

#### Workaround

As the support for exclusives to memory other than Normal Inner Write-Back, Outer Write-Back Cacheable is implementation defined, programmers should behave as if this is not supported.

# RAS errors during core power down might cause a deadlock

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0, r1p1 and r1p2. Open.

## Description

If a Reliability, Availability, and Serviceability (RAS) error occurs when a core is being powered down, then the power down sequence is designed to be aborted so that the error can be handled by software. As explained in this erratum, the power down sequence might complete despite the error occurring, or it might cause a deadlock.

## Configurations affected

All configurations are affected.

## **Conditions**

- 1. The ERXCTLR\_EL1.ED bit is set for any of the core error records, and at least one of the CI, DUI, CFI, FI, or UI bits is set.
- 2. Software running on the core sets the CPUPWRCTLR.CORE\_PWRDN\_EN bit and executes a **WFI** instruction.
- 3. The core Power Policy Unit (PPU) requests that the core transitions from the ON power mode to either the OFF or OFF\_EMU power mode.
- 4. During the L1 or L2 cache clean and invalidate done by the power transition, a RAS error occurs that causes any of the nCOREFAULTIRQ, nCOREERRIRQ, nCOMPLEXFAULTIRQ, or nCOMPLEXERRIRQ pins to be asserted.

## **Implications**

If the erratum occurs, the PPU power down request will either:

- Be denied because of the RAS error
- Deadlock, preventing the power down from completing.

If the power down request is denied, the core will not wake up from the **WFI** instruction and therefore software is not able to handle the error. If the PPU requests the core to power down again, either because it is set to dynamic mode, or because the component programming the PPU requests the power down again, then the second power down might either:

• Complete and power off the core, despite the fact that the error has not been handled.

• Deadlock, preventing the power down from completing.

There is still substantial benefit being gained from the ECC logic. There might be a negligible increase in overall system failure rate because of this erratum.

## Workaround

The ERXCTLR\_EL1.ED bit should be cleared for all the core error records before software sets the CPUPWRCTLR.CORE\_PWRDN\_EN bit to request a power down. This will cause any error detected during the power down to be ignored.

# Debug accesses while leaving OFF\_EMU power mode might lead to a system deadlock

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

If a core in the complex leaves the OFF\_EMU power mode while there is traffic on the debug APB interface to that core, or trace traffic on the ATB interface out of the core, then it can lead to a system deadlock or corruption of the trace data.

## **Configurations Affected**

This erratum affects all configurations with two cores in a complex where an asynchronous bridge is present between the complex and the cluster (parameter CORE<n> ASYNC BRIDGE is TRUE).

## **Conditions**

The erratum occurs under the following conditions:

- 1. One core in the complex is in the OFF\_EMU power mode.
- 2. The core is requested to power ON.
- 3. While the power transition is in progress, an access is made on the Debug APB interface that targets a register in the core, or the core generates trace data on the ATB interface.

## **Implications**

If the APB bus access happens during a specific time window within the power transition, then it might not receive a response. This can lead to a system deadlock. If the core is sending trace data on the ATB interface during the same time window, then additional trace transactions might be sent which will corrupt the trace stream.

#### Workaround

The debugger should not set the DBGPRCR.CORENPDRQ bit and the PPU should not be programmed to enter the OFF\_EMU power mode.

# Memory mapped accesses to MPMM registers have the wrong offset

## **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOpO. Fixed in rOp1.

# Description

The CPUMPMMCR register is documented as being located at offset 0x10 within the MPMM register block. Due to this erratum, the actual location is 0x90.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

1. A memory mapped access is made to the CPUMPMMCR register.

# **Implications**

If the conditions are met, the CPUMPMMCR will not actually be accessed.

## Workaround

Software accessing the CPUMPMMCR on revisions affected by this erratum should use the offset 0x90.

# 2022138 Core in FULL\_RET might not have clock gated

## **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

When a core enters the FULL\_RET power mode due to a Wait for Event (WFE) or Wait for Interrupt (WFI) instruction, and at the same time an event or interrupt arrives to wake up the WFE or WFI, this might prevent the clock from being gated correctly when in the FULL\_RET power mode.

## **Configurations Affected**

This erratum affects all configurations if the FULL\_RET power mode has been implemented for logic retention.

## **Conditions**

- 1. The IMP\_CPUPWRCTLR\_EL1.WFE\_RET\_CTL or IMP\_CPUPWRCTLR\_EL1.WFI\_RET\_CTL register is set to a non-zero value.
- 2. A core is in either the FUNC\_RET or ON power modes.
- 3. A WFE or WFI instruction is executed.
- 4. After the time period configured in the IMP\_CPUPWRCTLR\_EL1.WFE\_RET\_CTL or IMP\_CPUPWRCTLR\_EL1.WFI\_RET\_CTL register, the core will transition to the FULL\_RET power mode.
- 5. During the transition, an event arrives from another core or component in the system which causes the core to leave WFE or WFI.

# **Implications**

The core might enter the FULL\_RET power mode for a short period before the event causes a transition out of FULL\_RET. However, during the time the core is in FULL\_RET the clock to the core will toggle when the logic is in a retention state. This might cause undesirable physical effects in the power domain, including damaging the device.

## Workaround

The FULL\_RET power mode should not be enabled for WFE or WFI. This can be done by setting IMP\_CPUPWRCTLR\_EL1.WFE\_RET\_CTL to 0b000 and IMP\_CPUPWRCTLR\_EL1.WFI\_RET\_CTL to 0b000, which are the default values. EL3 software should not set ACTLR\_EL3.PWREN so that lower exception levels cannot enable this functionality.

# SnpPreferUnique might lead to a loss of coherency

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

Coherency might be lost if the core receives a SnpPreferUnique as a result of either:

- a SnpPreferUnique or SnpPreferUniqueFwd external to the cluster, or
- a ReadPreferUnique or MakeReadUnique(excl) on another core in the cluster.

A ReadPreferUnique is typically triggered by load exclusive instructions and by speculative stores. A MakeReadUnique(excl) can only be triggered by a non-speculative store exclusive instruction.

# **Configurations Affected**

This erratum affects configurations with two cores in a complex.

## **Conditions**

- 1. A cache line A is present in the L1 data cache of both cores in the complex, but is not in a unique state.
- 2. One core is executing an exclusive sequence.
- 3. Another core is evicting cache line A from its L1 data cache.
- 4. The complex receives a SnpPreferUnique transaction to cache line A.

# **Implications**

If the conditions are met, coherency might be lost on cache line A.

#### Workaround

This erratum can be avoided by setting IMP\_CMPXACTLR\_EL1[11] = 0b1; for example, using the following code sequence:

```
MRS x0, S3_0_C15_C1_3
MOV x1, #1
BFI x0, x1, #11, #1
MSR S3_0_C15_C1_3, x0
```

This workaround has negligible performance impact.

#### Version: 14.0

# 2028010 A PRF{U}M instruction might hang

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

# Description

A PRF{U}M instruction might hang if hardware updates of the dirty bit are enabled.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs under the following conditions:

- 1. Three or more PRF{U}M PLDL1\*/PSTL1\* instructions are executed. At least two miss in the L1 data Translation Lookaside Buffer (D-TLB).
- 2. Two stores or atomics are executed to different 4KB regions of virtual memory, and hardware updates of the dirty bit are enabled for both regions.
- 3. Another PRF{U}M PLDL1\*/PSTL1\* instruction is executed.

# **Implications**

If the conditions are met, a  $PRF\{U\}M$  instruction might hang indefinitely. Interrupts will not be taken.

#### Workaround

Software can set IMP CPUACTLR EL1[38] = 1; for example, using the following sequence:

```
MRS x0, S3_0_C15_C1_0
MOV x1, #1
BFI x0, x1, #38, #1
MSR S3_0_C15_C1_0, x0
```

This is not expected to have a material performance impact in common use cases, but might lead to some PRF{U}M PLDL1\*/PSTL1\* instructions not prefetching the cache line into the L1 data cache.

# EDSCR.STATUS might be incorrect when single stepping a Load-Exclusive instruction

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

When in the Active-not-pending state, if a Load-Exclusive instruction generates an abort that takes an exception to a state where halting is allowed, then EDSCR.STATUS will be incorrect when entering Debug State.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following conditions:

- 1. Halting step is enabled and is in the Active-not-pending state (EDECR.SS == 1 and EDESR.SS == 0).
- 2. A Load-Exclusive instruction is executed. Execution of this instruction causes an exception that targets a state where halting is allowed.
- 3. The core enters debug state.

## **Implications**

If the above conditions are met, then EDSCR.STATUS will be set to "Halting Step, Normal" upon debug entry.

#### Workaround

There is no workaround.

#### Version: 14.0

## 2038923

# A change to TRBLIMITR\_EL1.E might result in trace buffer corruption

## **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

A change to TRBLIMITR\_EL1.E might cause an inconsistent view on whether trace is prohibited within the CPU. As a result, the trace buffer or trace buffer state might be corrupted.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs under the following conditions:

- 1. The Trace Buffer Extension (TRBE) is enabled by setting TRBLIMITR\_EL1.E = 0b1.
- 2. Only a single context synchronization event takes place before execution changes from a context in which trace is prohibited to one where it isn't, or vice versa.

## **Implications**

If the above conditions are met, the view of whether trace is prohibited is inconsistent between parts of the CPU, and the trace buffer or the trace buffer state might be corrupted.

#### Workaround

Software can prevent an inconsistent view of whether trace is prohibited or not based on TRBLIMITR\_EL1.E by immediately following a change to TRBLIMITR\_EL1.E with at least one ISB instruction before an ERET, or two ISB instructions if no ERET is to take place.

# Debug accesses while leaving OFF\_EMU power mode might lead to a system deadlock

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

If a core in the complex leaves the OFF\_EMU power mode while there is traffic on the debug APB interface to that core, or trace traffic on the ATB interface out of the core, then it can lead to a system deadlock or corruption of the trace data.

## **Configurations Affected**

This erratum affects all configurations with two cores in a complex where an asynchronous bridge is not present between the complex and the cluster (parameter CORE<n> ASYNC BRIDGE is FALSE).

#### **Conditions**

The erratum occurs under the following conditions:

- 1. One core in the complex is in the OFF\_EMU power mode.
- 2. The core is requested to power ON.
- 3. While the power transition is in progress, an access is made on the Debug APB interface that targets a register in the core, or the core generates trace data on the ATB interface.

## **Implications**

If the APB bus access happens during a specific time window within the power transition, then it might not receive a response. This can lead to a system deadlock. If the core is sending trace data on the ATB interface during the same time window, then additional trace transactions might be sent which will corrupt the trace stream.

#### Workaround

The debugger should not set the DBGPRCR.CORENPDRQ bit and the PPU should not be programmed to enter the OFF\_EMU power mode.

# Entry into the Full Retention power mode might cause incorrect execution of a TLB maintenance instruction

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

# Description

If all cores in the complex enter the Full Retention power mode (or one core is Off and the other enters Full Retention mode), and the complex shared logic enters the FULL\_RET power state, an outstanding TLB maintenance instruction (**TLBI**) from another PE in the system might not invalidate all affected L2 TLB entries in the complex.

# **Configurations Affected**

This erratum affects all configurations. It requires the implementer to have implemented FULL\_RET support for the complex shared logic, and to place the L2 TLB RAMs into a low-power mode when in FULL RET.

#### **Conditions**

- 1. All cores in the complex are in the Full Retention power mode.
- 2. The complex receives a TLB maintenance operation from another PE outside the complex just before entering FULL\_RET for the shared logic, or during FULL\_RET of the shared logic.
- 3. The L2 TLB RAMs are placed into a low-power mode during the FULL\_RET complex power state.

# **Implications**

If the conditions are met, the **TLBI** operation might not correctly invalidate all affected TLB entries. This erratum has been classified based on the understanding that the affected versions of the product are only used for samples.

#### Workaround

This erratum can be avoided by disabling use of the Full Retention power mode in the cores (setting IMP\_CPUPWRCTLR\_EL1.WFI\_RET\_CTRL to 0b000 and IMP\_CPUPWRCTRL\_EL1.WFE\_RET\_CTRL to 0b000).

Implementers may be able to avoid this erratum by not placing the L2 TLB RAMs into a low-power mode when the complex logic is in the FULL\_RET power state, such that the outputs of these RAMs will remain stable while the clock is gated.

# Load-Exclusive/Store-Exclusive loop might not make forward progress

## **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

A Load-Exclusive/Store-Exclusive sequence might not make forward progress if loads or stores to addresses in the same L1 data cache set are present before the Load-Exclusive, and other PEs in the system execute stores to those cache lines.

# **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. The core executes a Load-Exclusive/Store-Exclusive loop to an address A. Address A is Normal Inner Write-back, Outer Write-back Cacheable.
- 2. Loads or stores to the same L1 data cache set as address A are executed between a failing Store-Exclusive and the next retry of the Load-Exclusive. Loads or stores are to the same set as an address A, if the virtual address bits [12:6] are the same.
- 3. One or more other PEs in the same shareability domain continuously execute stores to the same cache lines as the loads or stores in point 2.

## **Implications**

If the conditions are met, the exclusive sequence might fail to make forward progress until other PEs in the system stop storing to the same cache line as the loads or stores preceding the retry of the Load-Exclusive. For user code sequences, it can be assumed that stores by a different agent will stop in finite time, possibly as a result of an interrupt. For privileged code, this could be blocking to execution indefinitely.

#### Workaround

Privileged software can work around this erratum by avoiding any loads and stores between a Store-Exclusive returning a failing result and the retry of the corresponding Load-Exclusive.

From the rOp2 version, it is possible to prevent this erratum from occurring by executing the following instruction sequence:

```
VOM
        x0, #0
MSR
        S3_6_C15_C4_0, x0
ISB
VOM
        x0, #0x08500000
        S3_6_C15_C4_2, x0
MSR
VOM
        x0, #0x1F700000
        x0, #0x8, LSL #32
S3_6_C15_C4_3, x0
MOVK
MSR
        x0, #0x03F1
VOM
MOVK
        x0, #0x0110, LSL #16
        S3_6_C15_C4_1, x0
MSR
ISB
```

This will apply additional memory ordering to Load-Exclusive, Load-Acquire, and Load-AcquirePC instructions, and will cause a small performance loss.

If the software workaround is used, then the workaround should be disabled before hardware single stepping by executing the following instruction sequence:

```
MOV x0, #0
MSR S3_6_C15_C4_1, x0
ISB
```

The workaround should be re-applied before exiting debug state by executing the following instruction sequence:

```
MOV x0, #0x03F1
MOVK x0, #0x0110, LSL #16
MSR S3_6_C15_C4_1, x0
ISB
```

Note that the disabling and re-application of the workaround are only applicable if the debugger has access to EL3.

# A store or Load-Exclusive might cause data corruption

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

A Store or Load-Exclusive instruction might cause data corruption on the cache line accessed.

# **Configurations Affected**

This erratum affects configurations with two cores in the complex, and where the complex is configured with an L2 cache and with two L2 RAM partitions per slice (configuration parameter L2\_CACHE is TRUE and L2 NUM RAMCTL PARTITIONS is 2).

#### **Conditions**

This erratum occurs under the following conditions:

- 1. The MMU is enabled.
- 2. A core executes a Store or Load-Exclusive to Normal Inner Write-back, Outer Write-back Cacheable memory for a cache line A. This might cause a ReadPreferUnique to be generated.
- 3. Cache line A is already present in the L1 data cache of the core, but under a different virtual address alias.
- 4. In addition to the L1 cache of the requester, the cache line is also present in the L2 cache. This can only occur if the other core in the complex also had the cache line, and has evicted it to the L2 cache.
- 5. Unlikely, timing-sensitive micro-architectural conditions occur.

# **Implications**

If the conditions are met, the data and MTE allocation tags on cache line A might become corrupted.

#### Workaround

Software can set IMP\_CPUECTLR\_EL1[19] = 1 before the MMU is enabled; for example, using the following sequence:

```
MRS x0, S3_0_C15_C1_4
MOV x1, #1
BFI x0, x1, #19, #1
```

## MSR S3\_0\_C15\_C1\_4, x0

This workaround disables generation of ReadPreferUnique. It is expected to have a negligible performance impact.

# Entry into FUNC\_RET power mode can cause data metastability

## **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

When the complex transitions from ON to FUNC\_RET, some of the signals into the associated cores may toggle asynchronously and thus cause metastability in the associated cores' architectural state.

# **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. Entry into the FUNC\_RET power mode is enabled (IMP\_CPUPWRCTLR\_EL1.VPU\_PWR\_CTRL != 0b000) in all cores in the complex).
- 2. An FP, Advanced SIMD, or SVE instruction writing to a general-purpose destination register or PSTATE.NZCV is executed speculatively and flushed.
- 3. No FP, Advanced SIMD, or SVE instructions are issued for the period of time configured in IMP\_CPUPWRCTLR\_EL1.VPU\_PWR\_CTRL, such that the complex moves into the FUNC\_RET power state.

# **Implications**

If these conditions are met, then some of the signals from the shared Vector Processing Unit (VPU) logic in the complex that are sampled in the associated cores may change asynchronously. This could cause metastability in core logic that controls updates to scalar general-purpose registers and PSTATE.NZCV. Theoretically, this could result in this state becoming corrupted.

#### Workaround

The FUNC\_RET power mode should not be used. This requires that IMP CPUPWRCTLR EL1.VPU PWR CTRL should be 0b000. This is the default value for this register.

# A hardware update of the dirty bit might not be correctly ordered with respect to later instructions

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

# Description

A hardware update of the dirty bit might not be correctly ordered with respect to later instructions, where ordering is required by the architecture.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. A load is executed to Virtual Address (VA) A.
- 2. A store or atomic is executed to a VA B.
- 3. VA B is not to the same 4KB region as VA A, but one of the following conditions is met:
  - 4KB descriptors are used for both VA A and VA B, and both VAs are within the same 16KB region. The descriptor for VA B is concurrently modified without break-before-make to have a different set of access permission bits.
  - Only a single page/block descriptor with a size larger than 4KB is used to map both VA A and VA
     B. The descriptor is concurrently modified without break-before-make to have a different set of access permission bits.
  - VA B is mapped via two or more descriptors of different sizes with a different set of access permission bits, with at least one of the mappings not including write permissions.
- 4. The core executes either:
  - A DSB, followed by a load, store, or cache maintenance operation
  - A store or atomic to the translation table entry for VA B

# **Implications**

If the conditions are met, the access permissions of the descriptor for VA B might be updated to include write permissions (dirtied), but this update might not be ordered with respect to the subsequent memory access after the **DSB**, or the subsequent store or atomic to the translation table entry that is being updated.

# Workaround

Software can disable the hardware update of the dirty bit by setting TCR\_ELx.HD to 0b0 and VTCR\_EL2.HD to 0b0.

# TRBE might cause a speculative hardware update of the dirty bit outside the trace buffer range

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

If the Embedded Trace Extension (ETE) is enabled, and the Trace Buffer Extension (TRBE) is enabled, a speculative hardware update of the dirty bit might occur to the first three pages of the virtual address space.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. TRBE is enabled by setting TRBLIMITR EL1.E to 1.
- 2. TRBLIMITR\_EL1.LIMIT is set to Oxffff\_ffff\_d, Oxffff\_ffff\_e, or Oxffff\_ffff\_ffff\_f (the limit pointer address is set within 24KB of the top of the address space).

# **Implications**

If the conditions are met, a speculative hardware update of the dirty bit might occur to one of the pages in the virtual address range 0x0000\_0000\_0000\_0000\_0000\_0000\_0000\_2fff. For most systems, having the dirty bit speculatively updated will not lead to any incorrect operation.

#### Workaround

The software might be able to avoid setting the upper limit of the trace buffer within 24KB of the top of the address space.

Another workaround consists in disabling hardware update of the dirty bit for the first three pages of the address space.

# A system register write might not take effect after the trace buffer is disabled

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

If the Embedded Trace Extension (ETE) is enabled, and the Trace Buffer Extension (TRBE) is enabled after it is disabled, a register write might be ignored.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs under the following conditions:

- 1. TRBE is enabled and running.
- 2. The trace buffer is disabled, by setting TRBLIMITR\_EL1.E = 0b0.
- 3. The core executes an MSR instruction to one of the following registers without first executing a TSB CSYNC and DSB:
  - TRBLIMITR EL1
  - TRBPTR EL1
  - TRBBASER EL1
  - TRBSR EL1
  - TRBTRG EL1

# **Implications**

If the conditions are met, the register write in the last condition might be ignored and not take effect.

## Workaround

Software can execute a **TSB CSYNC** and **DSB** after collection is stopped and before performing a system register write to one of the affected registers.

# A hardware update of the dirty bit might occur speculatively if PSTATE.PAN is used

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

A hardware update of the dirty bit might be speculatively performed for a store or atomic instruction that sees a permission fault because of Privileged Access Never (PAN).

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under two sets of conditions:

#### Set 1:

- 1. The core is executing in EL2 with Virtualization Host Extensions (VHE) enabled (HCR\_EL2.E2H = 0b1).
- 2. PSTATE.PAN is set.
- 3. A store or atomic instruction is executed which sees a permission fault because of PAN.
- 4. Hardware update of the dirty bit is enabled for the page of memory accessed by the store or atomic instruction above.

#### Set 2:

- 1. The core is executing in EL1.
- 2. PSTATE.PAN is set.
- 3. A store or atomic instruction is executed which sees a permission fault because of PAN.
- 4. The descriptor's AP[1] bit was concurrently modified from no ELO access to allowing ELO access.
- 5. Hardware update of the dirty bit is enabled for the page of memory accessed by the store or atomic instruction above.

## **Implications**

If the conditions are met, the access permissions of the descriptor might be speculatively updated to include write permissions (dirtied), even though the store sees a permission fault because of PAN. For most systems, having the dirty bit speculatively updated in the presence of a permission failure does not lead to any incorrect operation.

## Workaround

Software can disable the hardware update of the dirty bit by setting TCR\_ELx.HD = 0b0.

# 2077057 Software stepping ERETAA or ERETAB might corrupt SPSR\_ELx

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

A pointer authentication failure or trap when software stepping **ERETAA** or **ERETAB** in the active-not-pending state while PSTATE.BTYPE is non-zero might corrupt the value of SPSR\_ELx upon taking the exception for the pointer authentication failure.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following conditions:

- 1. SPSR ELy.BTYPE is non-zero.
- 2. An exception return targeting ELz is executed at ELy, which enables software stepping (entering the active-not-pending state).
- 3. **ERETAA** or **ERETAB** is executed outside of a guarded page, and one of the following occurs, taking an exception to ELx:
  - The associated PAC operation fails.
  - The instruction is trapped by SCR\_EL3.API or HCR\_EL2.API

ELx, ELy, and ELz can be distinct or overlapping.

# **Implications**

If the conditions are met, then the value of SPSR\_ELx after taking the PAC exception will be corrupted.

The following SPSR ELx fields can be affected: TCO, DIT, UAO, PAN, IL, SSBS, D, A, I, F, and M [3:0].

The value written to the affected SPSR\_ELx fields after taking the exception in condition 3 will take the value of the respective SPSR\_ELz fields prior to condition 3. This implies that if EL2 is stepping EL1, and the pointer authentication exception is taken to EL2, this allows EL1 to provide an arbitrary SPSR\_EL2 value.

#### Workaround

To prevent EL3 taking an exception with a corrupted SPSR\_EL3:

• EL3 must set SCR\_EL3.API to disable traps from lower exception levels.

When EL2 is single-stepping EL1 and HCR\_EL2.API is configured to trap instructions:

• EL2 must keep the SPSR\_EL2 value when returning to the active-not-pending state. If the next exception is a trap due to HCR\_EL2.API, the SPSR\_EL2 value may be corrupted, and the previously saved value should be used instead.

# 2082334 ERR2STATUS.SERR might be incorrect

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

# Description

The value of ERR2STATUS.SERR uses 0x15 instead of 0x12, and vice versa. Other ERR2STATUS fields are not affected.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

1. This erratum occurs whenever the complex sees a non-attributable NDErr or DErr response.

# **Implications**

If the condition is met, then the ERR2STATUS register is updated correctly, except for the ERR2STATUS.SERR field. The ERR2STATUS.UE bit will indicate that an uncorrected error occurred.

## Workaround

Software can choose to translate the values 0x15 to 0x12 and vice versa when reading ERR2STATUS.SERR on affected hardware.

# 2135898 DSPSR\_ELO.BTYPE might be incorrect on Debug state entry

## **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

Entry to debug state might set DSPSR\_ELO.BTYPE to the incorrect value.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. An indirect branch instruction is executed and sets PSTATE.BTYPE non-zero. The branch will be one of the following instructions:
  - o BR
  - BRAA
  - BRAAZ
  - o BRAB
  - BRABZ
  - o BLR
  - $\circ$  BLRAA
  - BLRAAZ
  - BLRAB
  - $\circ$  BLRABZ
- 2. Another instruction is executed that sets PSTATE.BTYPE to zero. The instruction does not cause a synchronous exception.
- 3. Complex, but not rare, microarchitectural conditions occur.
- 4. The core enters Debug state.

# **Implications**

If these conditions are met, then the value of DSPSR\_ELO.BTYPE will take the value of PSTATE.BTYPE set by the branch in step 1.

## Workaround

After entering debug state a debugger should set DSPSR ELO.BTYPE to zero.

# LD1R using SP as base register incorrectly requests MTE Tag Checked

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

As specified in the Arm Architecture Reference Manual section D6.8.1, instructions using an immediate offset addressing form with SP as the base register must treat the instruction as Tag Unchecked. This erratum causes SVE LD1R load and broadcast to vector instructions to be treated as Tag Checked when used with SP as the base register.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs when all the following conditions occur:

- 1. The system is configured with support for the FEAT MTEv2 feature.
- 2. Access to allocation tags at the current Exception level is enabled using SCR\_EL3.ATA, HCR\_EL2.ATA, SCTLR\_ELx.ATA, and SCTLR\_ELx.ATA0 as appropriate.
- 3. Access to SVE instructions at the current Exception level is enabled using CPTR\_EL3.EZ, CPTR\_EL2.ZEN, and CPACR\_EL1.ZEN as appropriate.
- 4. PSTATE.TCO is 0.
- 5. An LD1RB, LD1RSH, LD1RSH, LD1RW, LD1RSW, or LD1RD broadcast to vector instruction is executed.
- 6. The base register used in the instruction is SP.
- 7. A virtual address accessed by the instruction has the Stage 1 translation Tagged memory attribute and it is not removed by a Stage 2 translation.
- 8. Bits [59:56] of the value in SP are not 0, or the TCR\_ELx.TCMAy bit for the virtual address accessed is 0.
- 9. Bits [59:56] of the value in SP do not match the Allocation Tag associated with the memory locations accessed.
- 10. Handling of Tag Checked faults for the access, configured by SCTLR\_ELx.TCF or SCTLR\_ELx.TCF0 as appropriate, does not cause the fault to be ignored.

# **Implications**

If the erratum occurs, the processor will incorrectly generate a synchronous exception or set a bit in a TFSR\_ELx or TFSREO\_ELx register. In a typical usage model, this will cause the system software to consider the executing software as behaving badly and might cause it to terminate execution of that software.

## Workaround

This erratum will only occur in software that has been built to:

- use the affected SVE instructions
- use FEAT MTEv2 feature for checking stack accesses
- rely on the SP+imm instruction forms not being Tag Checked instructions

At the time of publishing, there are no tools which generate software where all three of the above conditions are true. It is recommended that tools building software which might be run on the affected IP do not cause all three conditions to be true.

# A trace unit trigger might result in inconsistent register state of the Trace Buffer Extension

## **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

If both the Embedded Trace Extension and the Trace Buffer Extension (TRBE) are enabled, a PE trace unit trigger might not update TRBSR EL1.S.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs under the following conditions:

- 1. TRBE is enabled and running.
- 2. The TRBE is programmed to generate an IRQ on trigger (TRBLIMITR\_EL1.TM = 0b01) or to stop on trigger (TRBLIMITR\_EL1.TM = 0b00).
- 3. The core is executing in a prohibited trace region, and executes a TSB CSYNC.
- 4. The PE trace unit generates a trigger while the **TSB** instruction has not completed yet.
- 5. The TSB CSYNC completes, and the core turns off the TRBE (TRBLIMITR\_EL1.E = 0b0) afterwards.
- 6. The core executes an **ISB** instruction, followed by a read of TRBSR\_EL1 within 20 core cycles of the **TSB** completing.

# **Implications**

If the conditions are met, the TRBSR\_EL1.S bit might incorrectly read as ObO.

#### Workaround

Software might be able to execute two **ISB** instructions instead of one **ISB** instruction between the disable of the TRBE and reading TRBSR EL1.

# Mapping memory as Tagged when Allocation Tag storage is not provided might lead to CHI protocol violations or Tag corruption

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1, rOp2 and rOp3. Fixed in r1p0.

## Description

If a page is mapped as Tagged, but the underlying tag physical address (PA) does not provide Allocation Tag storage, stores to that page might lead to violations of the CHI protocol or Tag corruption.

## **Configurations Affected**

This erratum affects all configurations where the **BROADCASTMTE** pin is HIGH.

## **Conditions**

A page is mapped as Tagged, but Allocation Tag storage for that tag PA is not provided, and one of the following set of conditions is met:

#### Set 1:

- 1. MTE checking is enabled, and set to generate asynchronous exceptions (SCTLR\_ELx.ATAn = 1, SCTLR ELx.TCFn = 0b10).
- 2. The core executes a checked store, and the store does not allocate to the L1 cache, for example because of hardware write streaming detection.

#### Set 2:

- 1. The core executes a store to tag memory, such as STG, STGM, STZG, STZG, STZG, STGP, but not DC GZVA.
- 2. The store skips L1 allocation, for example because of hardware write streaming detection.
- 3. A snoop is received by the complex for the same PA while the store is outstanding.

# **Implications**

If the first set of conditions is met, a CHI protocol violation might occur. If the second set of conditions is met, Tag corruption might occur.

## Workaround

Software should not map pages which do not provide Allocation Tag storage as Tagged.

# 2169012 SnpPreferUnique\* might lead to a loss of coherency

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

Coherency might be lost if a CPU core receives an SnpPreferUnique or SnpPreferUniqueFwd as a result of either:

- an SnpPreferUnique or SnpPreferUniqueFwd external to the cluster, or
- a ReadPreferUnique or MakeReadUnique(excl) on another core in the cluster.

A ReadPreferUnique is typically triggered by load exclusive instructions as well as by speculative stores. A MakeReadUnique(excl) can only be triggered by a non-speculative store exclusive instruction.

# **Configurations Affected**

All configurations are affected.

## **Conditions**

The erratum occurs under the following sets of conditions.

#### Set 1:

- 1. A cache line A is present in the L1 data cache of both cores in a CPU complex.
- 2. A core in the complex executes an L1 set/way operation for cache line A, or the core initiates a hardware-based L1 set/way operation due to a detected ECC error.
- 3. The complex receives an SnpPreferUnique or SnpPreferUniqueFwd snoop to cache line A while one of the CPUs in the complex is executing an exclusive sequence on that cache line.
- 4. The complex receives a second SnpPreferUnique or SnpPreferUniqueFwd snoop to cache line A before the set/way maintenance operation has completed.

#### Set 2:

- 1. A cache line A is present in the L1 data cache of both cores in a CPU complex.
- 2. A core in the complex executes a store exclusive, or an atomic instruction.
- 3. The complex receives an SnpPreferUnique or SnpPreferUniqueFwd snoop to cache line A while one of the CPUs in the complex is executing an exclusive sequence on that cache line.

# **Implications**

If the conditions are met, coherency might be lost on cache line A.

## Workaround

This erratum can be avoided by setting IMP\_CMPXACTLR\_EL1[11:10] = 0b11; for example, using the following code sequence:

```
MRS x0, S3_0_C15_C1_3
MOV x1, #3
BFI x0, x1, #10, #2
MSR S3_0_C15_C1_3, x0
```

This workaround has negligible performance impact.

# Snp\*UniqueFwd might cause a deadlock or data corruption

## **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

## Description

An SnpUniqueFwd or SnpPreferUniqueFwd snoop received by the complex might cause a deadlock. These snoop operations are routinely generated as part of normal cacheable traffic.

## **Configurations Affected**

This erratum affects configurations with two cores in the complex.

#### **Conditions**

- 1. MTE allocation tags of a cache line A have been written by a core in the same shareability domain as the complex.
- 2. The cache line A is present in both cores in the complex with dirty MTE tags.
- 3. The cache line is evicted from one of the cores in the complex.
- 4. The complex receives an SnpOnce or SnpOnceFwd to cache line A.
- 5. The cache line is evicted from the other core in the complex, and the hardware predicts that the cache line is unlikely to be reused in the near future. The complex generates a WriteClean request as a result.
- 6. The complex receives an SnpUniqueFwd or SnpPreferUniqueFwd for cache line A while the WriteClean is still outstanding.

# **Implications**

If the conditions are met, the complex might not send a CompData response, and instead send a spurious SnpRespData to the HN in response to the SnpUniqueFwd or SnpPreferUniqueFwd. This is a protocol violation, which might result in deadlock or data corruption of an arbitrary cache line.

#### Workaround

This erratum can be avoided by forcing L2 allocation of transient lines, setting IMP\_CPUECTLR\_EL1[24:23] = 0b01 and IMP\_CPUECTLR\_EL1[47:46] = 0b01; for example, using the following code sequence:

MRS x0, S3\_0\_C15\_C1\_4 MOV x1, #1

#### Arm\_Cortex\_A510 (MP111) Software Developer Errata Notice

Version: 14.0

BFI x0, x1, #23, #2 BFI x0, x1, #46, #2 MSR S3\_0\_C15\_C1\_4, x0

This workaround has negligible performance impact.

# Single-bit error in branch predictor memory can cause instruction fetch stream corruption

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r1p0. Fixed in r1p1.

# Description

If a single-bit error occurs in the branch predictor memory, the instruction fetch stream might get corrupted.

# **Configurations Affected**

This erratum affects configurations with AARCH32\_AT\_ELO parameter set to TRUE.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. The core executes with MMU enabled.
- 2. Core is in AArch32 execution state.
- 3. The lower 32 bits of the target address of a branch are the same in both AArch64 and AArch32 execution states, while the upper bits (48:32) of the virtual address are different.
- 4. A single-bit error occurs in the branch predictor memory.

# **Implications**

Instruction fetch stream might be irrecoverably corrupted.

#### Workaround

Setting bit 43 of the IMP\_CPUACTLR2\_EL1 register (CPU Auxiliary Control Register 2) to 1 allows the instruction fetch stream to be corrected, with no performance impact. Example code sequence:

```
MRS x0, S3_0_C15_C1_1
MOV x1, #1
BFI x0, x1, #43, #1
MSR S3 0 C15 C1 1, x0
```

# Aliased loads and stores might cause an ordering violation

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

A store followed by aliased loads might result in an ordering violation on one of the loads.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. The core executes a store to a memory location A via a virtual address (VA) X.
- 2. The core executes two loads within three instructions of each other, both to memory location A. The younger load is to VA X, while the older load is to a different VA Y.
- 3. VA X and VA Y only differ in bits 15 and/or 14 of the address, and have identical memory attributes and permissions.
- 4. Another PE in the system concurrently modifies memory location A.
- 5. Another load, store, or atomic operation follows the younger load above within 8 instructions, and one of its address operands uses the register value loaded by the younger load above.

# **Implications**

If the conditions are met, the younger load at condition 2 may temporarily observe older data than the older load will retire with. This temporarily observed data can make it onto the forwarding paths within the core, and cause corruption of the address operands of the load, store, or atomic operation in condition 5. The value written into the register file is unaffected and will reflect the correct memory ordering.

# Workaround

Software can set IMP\_CPUACTLR\_EL1[18] = 0b1 and IMP\_CMPXACTLR\_EL1[25] = 0b1 for example, using the following sequence:

MRS x0, S3\_0\_C15\_C1\_0 MOV x1, #1

```
BFI x0, x1, #18, #1
MSR S3_0_C15_C1_0, x0

MRS x0, S3_0_C15_C1_3

MOV x1, #1

BFI x0, x1, #25, #1

MSR S3_0_C15_C1_3, x0
```

The workaround might have an impact on the reach of the L1 TLB and L2 TLB, impacting performance by approximately 1%.

# Asynchronous exceptions while MPMM is active might corrupt processor state

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

The Maximum Power Mitigation Mechanism (MPMM) is a power management feature that detects and limits high activity events. If the count of high-activity events exceeds a pre-defined threshold during an evaluation period, MPMM temporarily limits the execution of instructions. Under certain micro-architectural conditions, asynchronous exceptions that arrive while MPMM is throttling the execution of instructions might be taken incorrectly.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. MPMM is enabled and is throttling instruction execution.
- 2. An asynchronous exception occurs.
- 3. Certain specific micro-architectural conditions occur.

r1p0 has the following additional condition:

- 1. The Core executes one of the following instruction sequence:
  - AESD followed by AESIMC.
  - AESE followed by AESMC.

# **Implications**

The exception will be taken incorrectly and might have the following effects:

- Exception level might be incorrect (The exception might be taken to ELO).
- PC might be incorrect.
- CPSR.M might be incorrect.
- ESR\_EL1, ESR\_EL2 or ESR\_EL2 might be incorrect.
- FAR EL1, FAR EL2 or FAR EL2 might be incorrect.

# Workaround

This erratum can be avoided by clearing bit 0 of IMP\_CPUMPMMCR\_EL3 to disable MPMM by using the following code sequence:

MRS x0, S3\_6\_C15\_C2\_1 BFC x0, #0, #1 MSR S3\_6\_C15\_C2\_1, x0

#### 2256538

# Hardware breakpoints might not be taken on 32-bit T32 instructions

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r1p0. Fixed in r1p1.

# Description

Under certain micro-architectural conditions, hardware breakpoints might not be indicated on 32-bit T32 instructions.

# **Configurations Affected**

This erratum affects configurations with AARCH32\_AT\_ELO parameter set to TRUE.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. Any of the following conditions are programmed for the hardware breakpoint:
  - The breakpoint is set on a 32-bit word-aligned T32 instruction, with the Byte Address Strobe (BAS) field set to 0b1111.
  - The breakpoint is set on a 32-bit halfword-aligned T32 instruction which is not word-aligned.
- 2. Micro-architectural conditions occur.

# **Implications**

For 32-bit T32 instructions, hardware breakpoints might not be indicated.

#### Workaround

For word-aligned 32-bit T32 instructions, the Byte Address Strobe (BAS field of the DBGBCR register) should be set to 0b0011, which is the recommended value for this scenario.

For halfword-aligned 32-bit T32 instructions, there is no reliable workaround. A debugger might be able to make use of the software breakpoint instruction or program the hardware breakpoint to a nearby (word-aligned) instruction.

# Data corruption might occur in rare circumstances

### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

Data corruption might occur in rare circumstances.

# **Configurations Affected**

This erratum affects all configurations.

### **Conditions**

1. Rare, timing-sensitive, microarchitectural conditions occur.

# **Implications**

If the conditions are met, data corruption can occur.

#### Workaround

This erratum can be avoided by setting IMP\_CPUACTLR\_EL1[18] == 1, for example using the following code sequence:

```
MRS x0, S3_0_C15_C1_0

MOV x1, #1

BFI x0, x1, #18, #1

MSR S3_0_C15_C1_0, x0
```

This workaround might have a small impact on the reach of the L1 DTLB, but has an overall negligible impact on performance.

# TLB Invalidation prevents core OFF\_EMU to OFF transition

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

If a TLB invalidation instruction is executed while a core in a complex is in OFF\_EMU, this instruction might prevent that core from going to OFF.

# **Configurations Affected**

This erratum affects all configurations with two cores in a complex.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. One core in the complex is in the OFF\_EMU power mode.
- 2. The other core in the complex is in the ON, FUNC\_RET, or FULL\_RET power mode.
- 3. Either of the following is true:
  - Any core that is running executes a **TLBI** instruction.
  - The DSU receives a TLB Invalidate **SnpDVMOp** from the system interconnect.
- 4. The first core starts a transition to OFF, either because the PPU is reprogrammed or the debugger indicates it no longer requires OFF\_EMU mode.

# **Implications**

If the erratum occurs, the core power transition to OFF will be denied. The core will not indicate that it needs to go to ON on its **PACTIVE** signal. Therefore it will remain in OFF\_EMU and will continue to request OFF and be denied unless the core PPU is reprogrammed.

#### Workaround

The system component that is programming the Power Policy Units (PPUs), typically a System Control Processor (SCP), should power the core back ON before going back to OFF\_EMU and then OFF, if it detects that the core is stuck in OFF\_EMU. Note that this workaround includes the workaround for errata 2275257 and 2291720 and is therefore, the same as those workarounds.

If the PPUs are being used in dynamic mode, then the following sequence will ensure that all transitions to OFF power mode are made using the OFF\_EMU mode and cannot happen when the other core in the complex is powering ON:

- Set the PPU\_PWPR.LOCK\_EN bit if it is not already set.
- Set PPU PWPR.PWR POLICY to OFF EMU instead of OFF.
- When the PPU reaches the OFF\_EMU mode, the PPU\_PWPR.PWR\_POLICY field should be reprogrammed to OFF. Either of the LOCKED\_IRQ\_MASK or EMU\_ACCEPT\_IRQ\_MASK bits in the PPU\_IMR register can be cleared to request an IRQ to be generated so that the SCP knows when this mode is reached.
- The PPU\_PWCR.PWR\_DEVACTIVEEN field should be cleared to ensure that a new wakeup event arriving does not prevent the transition to OFF.
- The SCP should wait for the PPU to reach OFF. However, if the PPU does not reach OFF after a period of time, it might be due to the TLBI causing the transition to be denied. In this case, the following sequence should be repeated until the core reaches OFF:
  - The PPU PWPR.PWR POLICY field should be reprogrammed to ON.
  - Once the PPU has reached ON, the PPU\_PWPR.PWR\_POLICY field should be reprogrammed to OFF\_EMU.
  - Once the PPU has reached OFF\_EMU, the PPU\_PWPR.PWR\_POLICY field should be reprogrammed to OFF.
- Once the PPU has reached OFF, the PPU\_PWCR.PWR\_DEVACTIVEEN field can be restored to its previous value.
- The PPU\_PWPR.PWR\_POLICY should be set back to OFF\_EMU. This can be done either as soon as the PPU has reached OFF, or it can wait until immediately before the PPU\_UNLK register is written when the core is requested to power on again.
- Before the PPU\_UNLK register is written to power the core on again, the SCP should check power mode of the other core in the complex. If the core is in FULL\_RET, FUNC\_RET, or ON then it should have its PPU\_PWPR.PWR\_POLICY field set to FULL\_RET, FUNC\_RET, or ON. Note that if the PPU\_PWPR.PWR\_POLICY field set to ON, then it may cause the core to leave FUNC\_RET or FULL\_RET if it is in either of those modes at the time, which will increase power consumption. If the field is set to FULL\_RET or FUNC\_RET, then if the core is ready to power off during this period, then it might temporarily transition to FULL\_RET or FUNC\_RET, which will increase the time taken to power OFF.
- Once the first core has reached the ON state, then the other core's PPU\_PWPR.PWR\_POLICY field should be restored to the value it was before the previous step.

# Executing a WFI/WFE with VPU powerdown enabled might result in a deadlock

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

When executing a WFI/WFE, the core may incorrectly allow the complex to enter the FUNC\_RET power mode. If the core completes WFI/WFE execution during the *Vector Processing Unit* (VPU) powerdown sequence, and the instruction sequence includes a vector load, the VPU state may be corrupted, resulting in a deadlock on a later instruction.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. Entry into the FUNC\_RET power mode is enabled (IMP\_CPUPWRCTLR\_EL1.VPU\_PWR\_CTRL != 0b000) in all cores in the complex).
- 2. The program contains a WFI or WFE, followed by a vector load instruction (within the next three instructions).
- 3. The complex transitions into the FUNC\_RET power mode, either during execution of the WFI/WFE or shortly before.
- 4. Precise microarchitectural timing conditions occur.

# **Implications**

If these conditions are met, the next FP, Advanced SIMD, or SVE instruction executed by the core might result in a deadlock.

#### Workaround

This erratum can be avoided by setting CPUACTLR\_EL1[17] to 1'b1, which disables specific microarchitectural clock gating behavior.

# 2358024 EDSCR.INTdis might not mask Non-secure interrupts

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

The EDSCR.INTdis register field can mask certain interrupts if invasive debug is permitted. If Secure invasive debug is permitted, it disables all interrupts. If only Non-secure invasive debug is permitted, it should only mask interrupts taken to Non-secure.

Due to this erratum, if only Non-secure invasive debug is permitted, no interrupts will be masked.

## **Configurations Affected**

This erratum affects all configurations.

# **Conditions**

The erratum occurs if all the following conditions apply:

- 1. DBGEN = 0b1
- 2. SPIDEN = 0b0
- 3. EDSCR.INTdis = 0b01
- 4. The core receives one of the following interrupts:
  - FIQ
  - IRQ
  - SError
  - Virtual FIQ
  - Virtual IRQ
  - VIrutal SError
- 5. The interrupt is taken to Non-secure state

# **Implications**

If the previous conditions are met, the core will take the interrupt when it should not.

#### Workaround

The debugger can ensure all interrupts are masked by setting the following control bits:

- 1. PSTATE. {A, | F} == {1, 1, 1}
- 2. HCR\_EL2. {TGE, E2H, IMO, AMO, FMO} == {0, 0, 0, 0, 0}

# Cacheable far atomics might generate data corruption

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

Cacheable atomic operations issued by a core and executed beyond the L1 cache might generate data corruption.

# **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. A core issues a cacheable atomic operation to PA=A.
- 2. The atomic instruction is executed as a "far" atomic (outside the core).
- 3. Complex microarchitectural conditions occur.

# **Implications**

If the conditions are met, data corruption might happen on a different cache line. The corrupted cache line has the same set as the one targeted by the atomic operation (matching bits [X:6] of A, with X depending on L2 cache size), and potentially a different Security state.

#### Workaround

Cacheable atomic operations can be forced to be executed near by setting IMP\_CPUECTLR\_EL1.ATOM=0b010, for example using the following code sequence:

```
MRS x0, S3_0_C15_C1_4

MOV x1, #2

BFI x0, x1, #38 #3

MSR S3_0_C15_C1_4, x0
```

Forcing all atomic operations to be executed near is expected to have a negligible performance impact in all systems, except in large scale systems.

#### 2420992

# Incorrect instructions might be executed

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r1p0 and r1p1. Fixed in r1p2.

# Description

While executing conditional returns in AArch32 state, incorrect instructions might be executed and instruction cache lines might be corrupted.

# **Configurations Affected**

This erratum affects configurations with AARCH32 AT ELO parameter set to TRUE.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. The core executes with MMU and instruction cache is enabled.
- 2. The core is in AArch32 Execution state.
- 3. Additional complex microarchitectural conditions occur.
- 4. A conditional return is executed.

# **Implications**

If the previous conditions are met, then the core might execute incorrect instructions and might also corrupt instruction cache lines. Later execution might fetch the corrupted lines from the instruction cache, which could be at a different Exception level or within a different process. The effects of the incorrect execution are not predictable and include:

- Spurious Undefined Instruction exceptions.
- Spurious Data Aborts or other exceptions.
- Incorrect instruction execution, which might lead to register or memory state corruption.

#### Workaround

Setting bit 3 of the IMP\_CPUACTLR3\_EL1 register (CPU Auxiliary Control Register 3) to 1 disables a power optimization feature. This will have no impact on performance, but will slightly increase power consumption (0.3-0.5%) while executing in AArch32 state.

# Example code sequence:

MRS x0, S3\_0\_C15\_C1\_2 MOV x1, #1 BFI x0, x1, #3, #1 MSR S3\_0\_C15\_C1\_2, x0

# 2457168 AMEVCNTR01 increments incorrectly

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

The AMU counter AMEVCNTR01 should increment at the same rate as the System counter, as defined by the CNT\_CYCLES event. Due to this erratum, AMEVCNTR01 increments incorrectly, which gives a significantly higher result.

# **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following condition:

1. AMEVCNTR01 is enabled to count CNT\_CYCLES.

# **Implications**

AMEVCNTR01 cannot be used as intended to calculate the System counter frequency. The PMU is not affected because it does not implement counting of the CNT CYCLES event.

### Workaround

Do not use AMEVCNTR01 for this purpose.

# 2658417 BFMMLA or VMMLA instructions might produce incorrect result

#### **Status**

Fault Type: Programmer Category B

Fault Status: Present in rOp0, rOp1, rOp2, rOp3, r1p0 and r1p1. Fixed in r1p2.

## Description

When both cores in a complex are executing chained multiply-accumulate instructions, then under precise timing conditions a **BFMMLA** or **VMMLA** instruction might produce an incorrect result.

# **Configurations Affected**

This erratum affects any configuration with 2 cores in a complex, sharing a 2x64-bit VPU datapath (configuration parameter VPU\_DATAPATH is set to 2x64). Configurations sharing a 2x128-bit datapath are unaffected. Affected configurations can be identified by reading IMP\_CPUCFR\_EL1 using MRS Xt, S3\_0\_C15\_C0\_0 - the core is affected if bit [16] is 1 and bit [4] is 0.

#### **Conditions**

This erratum occurs if the following conditions apply:

- 1. Both cores in the complex are executing chained multiply-accumulate instructions.
- 2. One core in the complex flushes a chained multiply-accumulate instruction executed speculatively.
- 3. A **BFMMLA**, **VMMLA** or multicycle vector instruction is executed after the flush.
- 4. Precise microarchitectural timing conditions occur.

Any of the following instructions are classed as chained multiply-accumulate instructions:

- BFMMLA
- BFDOT
- VMMLA
- VDOT
- VMLA/VMLS
- VNMLA/VNMLS
- VRECPS
- VRSQRTS

Any of the following instructions are classed as multicycle vector instructions:

• FDIV\*

- FSQRT
- SDIV\*/UDIV\*
- BDEP/BEXT/BGRP
- PMULL\*
- RAX1
- SHA1C/SHA1M/SHA1P
- SHA256\*/SHA512\*
- SM3\*/SM4E\*
- VDIV
- VMULL
- VSQRT

# **Implications**

If these conditions are met, the result of a **BFMMLA** or **VMMLA** instruction executed by either core might be incorrect. As FEAT\_BF16 and FEAT\_AA32BF16 are recent additions to the architecture, these instructions are not expected to be present in the legacy code.

#### Workaround

There is no complete workaround for this erratum. It is expected that software will use run-time feature detection to determine whether to use these instructions or to fall back on support for earlier architecture versions. A kernel can avoid this erratum by updating the detected feature list to remove FEAT\_BF16 and FEAT\_AA32BF16 from the list of supported features in affected systems.

# Category B (rare)

#### 1976290

# A Tag Checked load might forward incorrect data

#### **Status**

Fault Type: Programmer Category B (rare) Fault Status: Present in r0p0. Fixed in r0p1.

# Description

A Tag Checked load might forward data to dependent instructions that is inconsistent with the data written to the architectural register file.

# **Configurations Affected**

This erratum affects all configurations where the **BROADCASTMTE** pin is HIGH.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. MTE checking of loads and stores is enabled.
- 2. The core executes a store to a Normal Inner Write-back, Outer Write-Back Cacheable location.
- 3. The core executes a load to the same cache line as the cacheable store above.
- 4. The core executes a Tag Checked load to the same location as the load above, and the load hits in the LO cache.
- 5. Another PE in the system modifies the location loaded by the loads above, concurrently.
- 6. Rare, timing-sensitive microarchitectural conditions occur.

# **Implications**

If the conditions are met, the last load might forward data to dependent instructions that is inconsistent with the data written to the architectural register file.

#### Workaround

This erratum can be avoided by setting IMP\_CPUACTLR\_EL1[4] = 1; for example, using the following code sequence:

MRS x0, S3\_0\_C15\_C1\_0 MOV x1, #1 Date of issue: 27-Jun-2022

Version: 14.0

BFI x0, x1, #4, #1 MSR S3\_0\_C15\_C1\_0, x0

This workaround disables early load data return and might have a measurable performance impact.

# Asynchronous exceptions after ECC errors might cause unpredictable behavior

#### **Status**

Fault Type: Programmer Category B (rare)

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

# Description

When an unmasked interrupt is pending during a specific sequence of load/store instructions and branch instructions, and under complex and rare microarchitectural conditions that require an ECC error (single bit, double bit or poison), unpredictable behavior might be observed.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

- 1. The following sequence of instructions is executed:
  - a. Load/Store that generates an ECC error.
  - b. Branch instruction
  - c. Load/Store that generates an ECC error
- 2. Either one of the following:
  - The instruction executed in step 1.1 is one of the following types:
    - SVE load multiple structures
    - SVE contiguous load
    - SVE contiguous non-fault load
    - SVE contiguous first-fault load
    - SVE contiguous non-temporal load
    - SVE Gather loads (all variants)
    - LDx (multiple structures) All variants
    - LDx (single structures) All variants
    - LD3R
    - LD4R
    - Atomic memory operations All variants
  - Embedded Trace Macrocell (ETM) tracing is enabled (TRCPRGCTLR.EN == 1)
- 3. An interrupt is pending and is unmasked according to the table in section "Asynchronous exception masking" in the Armv8-A Architecture Reference Manual.
- 4. Complex and rare microarchitectural conditions are met.

# **Implications**

If these conditions are met, then unpredictable behavior in the core might occur, including execution of incorrect instructions or at an incorrect Exception level. This includes, but is not limited to, incorrect entry to ELO and/or incorrect switching to Non-secure state.

PSTATE.IL will always be set when these conditions are met.

Security state escalation is not possible when these conditions are met.

#### Workaround

If workaround is required this erratum can be avoided by setting IMP\_CPUACTLR\_EL1[3] = 0b1; for example, using the following code sequence:

```
MRS X0, S3_0_C15_C1_0
MOV x1, #1
BFI x0, x1, #3, #1
MSR S3_0_C15_C1_0, x0
```

This is expected to impact performance by around 1.3%.

# A longer TLBI sequence might cause a deadlock

#### **Status**

Fault Type: Programmer Category B (rare)

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

# Description

Under rare conditions, a longer sequence of TLBI instructions might cause a deadlock.

## **Configurations Affected**

This erratum affects configurations with two cores in a complex.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. At least one core in the complex has 10 or more TLBI outstanding, without intervening DSBs.
- 2. Rare, timing-sensitive micro-architectural conditions occur.

## **Implications**

If the conditions are met, a deadlock can occur.

#### Workaround

From the rOp2 version, it is possible to prevent this erratum from occurring by executing the following instruction sequence:

```
S3_6_C15_C4_0, x0
MSR
TSB
VOM
       x0, #0x0100
       x0, #0x0E08, LSL #16
MOVK
       S3_6_C15_C4_2, x0
MSR
       x0, #0x0300
MOV
       x0, #0x0F1F, LSL #16
MOVK
MOVK
       x0, #0x0008, LSL #32
MSR
       S3_6_C15_C4_3, x0
VOM
       x0, #0x03F1
MOVK
       x0, #0x00C0, LSL #16
MSR
       S3_6_C15_C4_1, x0
```

#### ISB

This will perform a Data Synchronization Barrier after each **TLBI** instruction. This is expected to have a minimal performance impact.

# CMOs to non-shareable locations might deadlock the cluster

#### **Status**

Fault Type: Programmer Category B (rare)

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

A data cache maintenance operation to a non-shareable location might cause a deadlock if unlikely timing conditions are met.

# **Configurations Affected**

Only systems with interconnects that can send a CompCMO for a combined WriteNoSnoop+CMO before receiving the write data are affected.

#### **Conditions**

- 1. A data cache maintenance instruction by address is issued.
- 2. Target PA is marked as non-shareable and is dirty.
- 3. Interconnect issues a CompCMO before the data is received, and this response arrives together CompDBIDResp to the CPU core.

# **Implications**

If the above conditions are met, the CPU core might deadlock. Most system interconnects will respond with CompCMO only after having received the data, so this errata does not apply to those kind of systems.

Since the DSU issues CompDBIDResp to CPU at the same time that the combined Write+CMO is sent to the interconnect, Arm believes it to be very rare for a CPU core to receive both the CompDBIDResp and CompCMO at the same time.

#### Workaround

In order to avoid this erratum, non-shareable memory should not be used.

# Completion of affected memory accesses might not be guaranteed by completion of a TLBI

#### **Status**

Fault Type: Programmer Category B (rare)

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

The core might not guarantee completion of all memory accesses after completion of a TLB Invalidate (**TLBI**) instruction affecting those accesses on another core.

## Configurations affected

This erratum affects all configurations.

#### **Conditions**

- 1. Another PE in the system executes a **TLBI** or Instruction Cache (**IC**) instruction, followed by a Data Synchronization Barrier (**DSB**) instruction.
- 2. The core executes a store to a memory location A.
- 3. Another PE in the system modifies the descriptor used by the store to memory location A, using a break-before-make sequence.
  - The break-before-make sequence will include a **TLBI** instruction, followed by a **DSB** instruction.
- 4. Rare, timing-sensitive, microarchitectural conditions occur.

# **Implications**

The **DSB** used after the **TLBI** as part of the break-before-make sequence might not guarantee the completion of the store to memory location A under very rare and unlikely timing conditions. For most systems and applications, the latency of the break-before-make sequence and time until later reuse is very likely to exceed the latency required to naturally complete the store.

#### Workaround

Given the rarity of the conditions needed to trigger this erratum, a workaround is not expected to be needed in most systems.

If a workaround is required, then the **TLBI**, **DSB** sequence from the break-before-make sequence can be repeated. After repeating the **TLBI**, **DSB** sequence, all memory accesses that use a translation changed by the break-before-make sequence will have completed.

# Category C

#### 1898949

# Execution of an atomic instruction may fail to make forward progress

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0. Fixed in rOp1.

# Description

Execution of an atomic instruction that is followed by a (speculative) load to the same cache line within the next 5 memory instructions (loads, stores, and atomics) may hang if another PE in the system executes a steady sequence of stores or atomics to the same cache line.

# **Configurations Affected**

All configurations are affected.

#### **Conditions**

- 1. The core executes an atomic instruction to inner-writeback/outer-writeback memory. This atomic is performed "near", in the core itself.
- 2. The core (speculatively) executes a load instruction to the same PA.
- 3. The cache line is actively being written to by other PEs in the system in an uninterrupted sequence.

# **Implications**

This erratum can allow denial of service between two threads that share memory.

#### Workaround

It is not expected that software running on LAC-quality silicon samples will encounter this erratum. No workaround available.

#### 1904476

# Reads of GMID\_EL1 might trap to incorrect exception level when MTE is disabled

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

# Description

When the *Memory Tagging Extension* (MTE) is disabled and the HCR\_EL2.TID5 trap is enabled, reads of the GMID\_EL1 register at EL1 are incorrectly trapped to EL2 instead of taking an undefined exception at EL1.

# **Configurations Affected**

This erratum affects configurations where the **BROADCASTMTE** pin is LOW.

#### **Conditions**

- HCR EL1.TID5 is set to 1.
- The core is executing at EL1.
- An MRS instruction from GMID\_EL1 is executed.

# **Implications**

If the conditions are met, then the trap on the read of GMID\_EL1 will be taken to EL2 instead of EL1.

#### Workaround

When MTE is disabled (ID\_AA64PFR1\_EL1.MTE reads as 0x1), the erratum can be avoided by not setting HCR\_EL2.TID5.

# Error responses to MakeReadUnique transactions might result in data corruption

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

# Description

If an error response is returned for a MakeReadUnique transaction, the core may load corrupt data for that cache line.

# **Configurations Affected**

Configurations of the cluster using a CHI interface (configuration parameters CHI or PERIPH\_PORT\_CHI are TRUE) are affected.

#### **Conditions**

- 1. The core has a cache line A in the L1 cache.
- 2. The cluster holds the cache line in a Shared coherency state.
- 3. The core executes a store to the cache line.
- 4. A MakeReadUnique transaction to the cache line is sent from the cluster.
- 5. No other coherent agents write to the cache line.
- 6. The response to the MakeReadUnique transaction has an error status (DErr or NDErr).

# **Implications**

There is still substantial benefit being gained from the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum. If the conditions are met, subsequent loads of the cache line executed on the core might return corrupt data, even after a subsequent write to the cache line.

#### Workaround

No workaround is required.

# Tag Check Fault reporting might be incorrect when ECC error occurs

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

# Description

An ECC error in the L1 D-cache MTE data RAM might cause the core to incorrectly report a Tag Check Fault, or fail to report a Tag Check Fault.

# **Configurations Affected**

This erratum affects configurations where the **BROADCASTMTE** pin is tied HIGH.

# **Conditions**

- 1. SCTLR\_ELx.TCF is set to 0b10, or SCTLR\_ELx.TCF0 is set to 0b10.
- 2. ERR1CTLR.ED is set to 1.
- 3. The core is in Write Streaming mode.
- 4. A Tag Checked store is executed.
- 5. The store hits in the L1 D-cache.
- 6. There is a correctable error in the MTE data RAM when the L1 D-cache is read.

# **Implications**

There is still substantial benefit being gained from the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum. When these conditions are met, the core might report a spurious Tag Check Fail or fail to report a Tag Check Fail. The error in the MTE data RAM will be correctly reported in the RAS error record registers.

#### Workaround

No workaround is required.

# Software stepping ERETAA or ERETAB might set SPSR.ELx.SS to incorrect value

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A pointer authentication failure when software stepping **ERETAB** or **ERETAB** in the active-not-pending state, fails to set SPSR ELx.SS when PSTATE.BTYPE does not equal 0.

#### Conditions

- 1. SPSR\_ELx.BTYPE is non-zero.
- 2. An exception return is then executed, which enables software stepping (entering the active-not-pending state).
- 3. ERETAA or ERETAB is executed outside of a guarded page, and the associated PAC operation fails.

In the first condition, SPSR\_ELx.BTYPE will typically be non-zero if the previously stepped instruction before the **ERETAB** or **ERETAB** was a **BR, BRAAZ, BRABZ, BRABZ, BLR, BLRAAZ, BLRAAZ, BLRABZ** instruction.

# **Implications**

If the conditions are met, then the value of SPSR\_ELx.SS after taking the PAC exception will be 0 rather than 1. This is unlikely to cause issues for most software because the PAC exception will be treated as fatal by the handling software, so the value of SPSR\_ELx.SS in this case will be unused.

#### Workaround

# Configuration of IMP\_CMPXECTLR\_EL1.CDEVC not supported

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

# Description

Setting IMP\_CMPXECTLR\_EL1.CDEVC, bits [45:44], to a value other than 0b11 might cause deadlock. Note that 0b11 is the reset value for this register.

# **Configurations Affected**

All configurations are affected.

#### **Conditions**

- 1. The value of IMP CMPXECTLR EL1.CDEVC, bits [45:44], is not 0b11.
- 2. A core in a complex executes a **DC CVAP** or **DC CVADP** instruction for a line that is cached clean within the complex.

# **Implications**

If these conditions are met, then one or more cores, or other coherent agents in the system might deadlock.

#### Workaround

To avoid this erratum, ensure that IMP\_CMPXECTLR\_EL1[45:44] is set to 0b11. For example, use the following code sequence:

```
MRS x0, S3_0_C15_C1_7
MOV x1, #3
BFI x0, x1, #44, #2
MSR S3_0_C15_C1_7, x0
```

# Error response to load-exclusive might cause loss of synchronization or deadlock

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

# Description

If a Load-Exclusive instruction observes an external memory error, a subsequent Store-Exclusive instruction might deadlock or incorrectly update memory.

# **Configurations Affected**

This erratum affects all configurations.

#### Conditions

- 1. A Load-Exclusive instruction is executed to Shareable and Cacheable memory
- 2. The access misses in the cluster caches and sends a transaction on the external interface
- 3. The data returned by the external transaction indicates an error (DErr on CHI, or SLVERR/DECERR on AXI), but only on data beats not containing the data loaded by the Load-Exclusive instruction
- 4. A Store-Exclusive instruction is executed to the same cache line, without an intervening **CLREX** instruction or store to the same cache line

# **Implications**

If the Store-Exclusive is Tag Checked, the core might deadlock.

After the Load-Exclusive instruction, the global monitor will be in the Exclusive Access state, but might not move into the Open Access state if there is a store to the marked cache line from another PE. Subsequently, the Store-Exclusive updates memory despite another store to the location having occurred.

#### Workaround

# Accesses to TRCQCTLR are RAZ/WI instead of UNDEFINED

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

# Description

The core does not implement support for Q elements as part of the Embedded Trace Extension. As such, the TRCQCTLR register is unimplemented. The reads or writes of the TRCQCTLR register behave as if it is implemented as RAZ/WI, instead of being UNDEFINED, because of this erratum.

# **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The core is executing at EL1 or above.
- 2. An MSR or MRS instruction to TRCQCTLR is executed.

# **Implications**

Accesses to TRCQCTLR will be trapped (similar to accesses to implemented trace registers) because of the CPACR EL1.TTA and CPTR ELx.TTA bits. If not trapped, accesses to TRCQCTLR are RAZ/WI.

#### Workaround

#### 1925280

# A single-bit error in the L2DB RAMs might be reported incorrectly as a corrected error

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

# Description

Some single-bit errors detected in the L2 data buffer (L2DB) RAMs are not corrected but are incorrectly reported as corrected.

# **Configurations Affected**

This erratum affects configurations with core cache protection enabled.

#### **Conditions**

1. A single-bit error is detected in the L2DB RAMs on an L2 cache allocation.

# **Implications**

If the conditions are met, the error is not corrected and is instead deferred, but is incorrectly reported as corrected in ERR2STATUS.CE. It is expected the error will be corrected on a later read from the L2 data RAMs.

#### Workaround

## Direct access to L1 data cache MTE data RAMs does not function

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

The core provides system register encodings to allow the contents of the L1 data cache to be read directly from EL3. The contents of the memory containing the Memory Tagging Extension (MTE) tags cannot be read.

## **Configurations Affected**

This erratum affects all configurations.

### **Conditions**

1. A read of the L1 D-cache MTE RAMs is initiated using SYS #6, C15, C2, #4, <Xt>

## **Implications**

A subsequent read of IMP\_CDBGDRO\_EL3 will return zero. The contents of the MTE tag memories in the L1 data cache cannot be read directly.

#### Workaround

Date of issue: 27-Jun-2022

#### Version: 14.0

#### 1933869

## Writes to DBGWCR<n>\_EL1/DBGWVR<n>\_EL1 might cause speculative reads of device memory

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

An external APB access or software MSR writing to DBGWCR<n>\_EL1 or DBGWVR<n>\_EL1 during the watchpoint check of a stalled instruction might cause both an abort and an access to device memory.

#### **Conditions**

- 1. DBGWCR<n>\_EL1 or DBGWVR<n>\_EL1 is written, either using an MSR instruction without a subsequent ISB or DSB, or via the Advanced Peripheral Bus (APB) interface.
- 2. At around the same time, a load instruction is executed to device memory that generates a watchpoint debug event because of one of the watchpoint register pairs that had been written.

## **Implications**

If the conditions are met, then the load instruction will take an exception or cause a Debug state entry, but a read transaction will still be generated to the address targeted by the load. If this address maps to a read-sensitive peripheral, the side effects of the read will be observable despite the load not having retired. This erratum does not affect the programming of watchpoints for inactive contexts.

#### Workaround

Debuggers should avoid setting watchpoints on read-sensitive locations. An **ISB** or **DSB**, when inserted after an **MSR** of the watchpoint registers and before the load, guarantees that the load will observe only the updated value and prevents a speculative access to device memory.

## Multiple errors detected on the same cycle might lead to an incorrect value of ERR2STATUS and ERR2MISCO

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

If multiple errors are detected on the same cycle across the L2 tag, L2 data and L2 data buffer (L2DB) RAMs, the value recorded in ERR2STATUS and ERR2MISCO might be incorrect.

## **Configurations Affected**

This erratum affects configurations with core cache protection enabled.

#### **Conditions**

1. Multiple errors are detected on the same cycle across the L2 tag, L2 data and L2DB RAMs.

## **Implications**

There is still substantial benefit being gained from the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum. Arm believes that detection of multiple errors on the same cycle is exceedingly rare. If the conditions are met, the value recorded in ERR2STATUS and in ERR2MISCO might not correctly reflect all detected errors, but only a subset or a mix of these.

#### Workaround

#### 1946400

## Error reporting disabled does not mask error responses on memory accesses

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

Error responses on memory accesses, including speculative memory accesses, might be reported in the RAS registers when ERR1CTLR.ED = 0.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

- 1. ERR1CTLR.ED = 0.
- 2. A memory access by a load or store instruction, or a speculative L1 data cache refill sees an error or a poison value on the response.

## **Implications**

If these conditions are met, an uncorrected error is erroneously reported.

- ERR1STATUS.V = 1.
- ERR1STATUS.UE = 1 and ERR1STATUS.ER = 1.
- If the error was generated as the result of data poison, ERR1STATUS.PN = 1.
- ERR1STATUS.SERR = 0x18 for NDerr and ERR1STATUS.SERR = 0x12 for Derr and data poison.

#### Workaround

There is no workaround for this erratum.

## 1951345 PMU\_HOVFS event exported when EL2 trace disabled

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

PMU\_HOVFS is a PMU event that can be exported to the ETM. Exporting this event is disabled if TRFCR\_EL2.E2TRE == 0b0. Due to this erratum, the event is exported regardless of this setting.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

1. The ETM is configured to use PMU\_HOVFS as an external input event.

## **Implications**

Overflows of PMU counters reserved by EL2 might be visible to lesser-privileged software.

## Workaround

## An ECC error during core power down might cause another error to occur after power up

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

If an ECC error is corrected in the L1 data cache duplicate tags for a cache line that is invalid, an incorrect value might be written into the L1 data cache duplicate tag RAMs. This can occur after a power off/power on cycle during the hardware invalidation of the affected L1 data cache duplicate tags.

## **Configurations Affected**

This erratum affects all configurations.

### **Conditions**

- 1. An error is detected, corrected and reported on the L1 data cache duplicate tag RAMs.
- 2. The core corresponding to the above L1 data cache duplicate tag RAM is powered down, and no cache line is flushed after the above error detection (for example, because the L1 data cache was already empty, or the error was detected during the hardware flush).
- 3. The same core is powered on again.

## **Implications**

If the above conditions are met, the automatic hardware-based invalidation of the duplicate tag RAMs during core power-up might write an incorrect value into the RAM. This might result in a spurious error report, either correctable or uncontainable.

#### Workaround

## 1951568 PMU event counts might be inaccurate

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

The processor implements a number of performance monitor events. Because of this erratum, some of the events will not count correctly.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

- 1. One of the PMU event counters is configured to count one of the following events:
  - 0x0006 LD\_RETIRED
  - 0x001C TTBR WRITE RETIRED
  - 0x0029 L3D CACHE ALLOCATE
  - o 0x0037 LL CACHE MISS RD, if IMP CPUECTLR EL1.EXTLLC is not set
  - 0x00A2 L3D CACHE REFILL RD
  - 0x00C8 LL WS MODE
  - 0x00EE STALL SLOT BACKEND ILOCK

## **Implications**

Software will not be able to use the above events for performance analysis.

#### Workaround

## L2 cache debug operations might hang and block a power off request

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

If an L2 cache debug operation is performed during the power down of a core in the complex, or the complex itself, both the cache debug and the power transition might hang.

## **Configurations Affected**

This erratum affects configurations with two cores in the complex, and where the complex is configured with an L2 cache (parameter L2\_CACHE is TRUE).

#### **Conditions**

- 1. A core in the complex is in the process of powering off.
- 2. A cache debug operation to the L2 cache (SYS IMP\_CDBGL2CDR, SYS IMP\_CDBGL2CMR or SYS IMP\_CDBGL2CTR) is performed by the other core in the complex during the above power-off operation.

## **Implications**

Both the power-off, and the cache debug operation might hang. The power-off request hang might result in a P-channel hang.

#### Workaround

Software should avoid cache debug operations when one of the cores might potentially be powered off.

## 1954658 ERR2STATUS.CE might be incorrect

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

If an uncorrected, deferred, or uncontainable error is detected after a corrected error was detected, ERR2STATUS.CE might be incorrect.

## **Configurations Affected**

This erratum affects configurations with core cache protection enabled.

#### **Conditions**

- 1. A corrected error is detected in the L2 tag RAMs, L2 data RAMs or L2DB RAMs.
- 2. An uncorrected, deferred, or uncontainable error is detected in the L2 tag RAMs, L2 data RAMs or L2 data buffer (L2DB) RAMs.

### **Implications**

If the conditions are met, ERR2STATUS.CE might not reflect that a corrected error was detected. ERR2MISCO.CECO remains correct and can be used for statistical purposes.

#### Workaround

### 1955046

## External events are not observed after Warm reset

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## **Description:**

External events can be programmed to be observed by the Embedded Trace Extension (ETE) and are observed if ETE is not in low power state or disabled. Because of this erratum, under some conditions the external events are not observable by ETE.

#### Conditions

- 1. The Embedded Trace Extension unit is enabled.
- 2. At least one of TRCEXTINSELR<n> is programmed to trace external events.
- 3. Warm reset is applied and released.
- 4. An external event occurs.
- 5. Exact microarchitectural timing conditions occur.

## **Implications**

If these conditions are met, the external events are not observed by ETE.

### Workaround

## Mapping memory as Tagged when Allocation Tag storage is not provided might lead to CHI protocol violations

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

If a page is mapped as Tagged, but the underlying tag physical address (PA) does not provide Allocation Tag storage, direct and indirect accesses to the Allocation Tags in that page may lead to violations of the CHI protocol.

## **Configurations Affected**

This erratum affects all configurations where the **BROADCASTMTE** pin is HIGH.

### **Conditions**

- 1. A page is mapped as Tagged, but Allocation Tag storage for that tag PA is not provided.
- 2. A direct or indirect access to Allocation Tags within that page occurs.

## **Implications**

The direct or indirect access to Allocation Tags in the page may cause violations of the CHI protocol.

#### Workaround

Software should not map pages which do not provide Allocation Tag storage as Tagged.

## Execution of ESB instruction in debug state might cause unpredictable behavior

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

The execution of an **ESB** instruction while in the debug state might result in unpredictable behavior in the core to be observed, if an SError is pending.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The core enters the debug state.
- 2. The external debugger passes an **ESB** instruction to the core via the EDITR.
- 3. The core executes the **ESB**.
- 4. A virtual or physical SError is pending, such that the **ESB** instruction updates DISR\_EL1 and/or VDISR EL2.

## **Implications**

If the above conditions are met, then unpredictable behavior in the core might occur, including execution of incorrect instructions or at an incorrect Exception level. This includes, but is not limited to, incorrect updates to the DLR and DSPSR.

Privilege/security state escalation is not possible when these conditions are met.

#### Workaround

The Debugger should save/restore the DLR and DSPSR when executing an ESB instruction.

## Exceptions in debug state might allow execution of subsequent instruction in FDITR

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

An exception generated in debug state might allow further issue of a subsequent instruction from EDITR (when EDSCR.ERR == 1).

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The core enters debug state.
- 2. The external debugger passes an instruction which might generate an exception (such as a data abort) to the core via the EDITR.
- 3. On execution of the instruction from step 2, a synchronous exception is generated.
- 4. Microarchitectural timing conditions occur.

## **Implications**

If the above conditions are met, then an instruction in EDITR might be executed when EDSCR.ERR == 1.

#### Workaround

External debugger can poll EDSCR.ITE prior to writes to EDITR.

## VMID tracing incorrectly allowed or disallowed based on TRFCR\_EL2.CX

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

The VMID field of a trace packet may be incorrectly masked or unmasked compared to the value of TRFCR\_EL2.CX.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. ETM tracing is enabled (TRCPRGCTLR.EN == 1).
- 2. Self hosted trace is enabled.
- 3. CID EL2 and VMID trace are allowed (TRCCONFIGR.VMID == 1 AND TRFCR EL2.CX == 1).
- 4. Core is executing in Secure EL0/EL1 with Secure EL2 disabled (SCR\_EL3.NS == 0 AND SCR\_EL3.EEL2 == 0).

#### OR:

- 1. ETM tracing is enabled (TRCPRGCTLR.EN == 1).
- 2. A PO element executes immediately prior to an MSR that updates TRFCR EL2.CX.

## **Implications**

If the first set of conditions are met, then the VMID field in trace elements might be zero, potentially leading to the generation of incorrect context elements by the trace unit.

If the second set of conditions are met, then trace elements might have the incorrect VMID associated with them, potentially leading to the generation of incorrect context elements by the trace unit.

#### Workaround

No workaround is required for the first set of conditions in this erratum, as the architecture is expecting that EL3 will clear TRFCR\_EL2 as part of a state switch in these conditions.

No workaround is required for the second set of conditions, as software is not expected to update TRFCR\_EL2.CX when tracing is enabled.

## 1965154 PMU snapshot records incorrect Context ID when PMU inactive

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

The PMU snapshot feature enables sampling of various parts of the execution state. Because of this erratum, Context ID values may not be sampled correctly while the PMU is inactive.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. All PMU counters are disabled by setting MDCR\_EL2.HPME == 0 and PMCR\_EL0.EN == 0.
- 2. PMU event exporting is disabled by ETM trace being disabled.
- 3. A PMU snapshot is requested.

## **Implications**

The Context ID values in a PMU snapshot can be incorrect

### Workaround

If any PMU counters or ETM trace are enabled while a snapshot is taken, Context ID will be sampled correctly.

## A continuous stream of stores might prevent forward progress of a coherency operation

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A continuous stream of stores on a core might prevent forward progress of a coherency operation, leading to a denial of service and perceived hang on a different PE or component in the system.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. A continuous stream of non-L1-allocating stores (including stores to device and non-cacheable memory), DC ZVA, DC GVA or DC GZVA is executed on a core.
- 2. A coherency operation is received for a cache line present in the L1 cache of that core.

## **Implications**

If the conditions are met, the coherency operation might not make forward progress while the store stream is ongoing.

#### Workaround

A denial of service on a secure process can be avoided if the secure OS sets up a timer-based interrupt source to interrupt all cores periodically.

## SIMD, FP, and SVE cacheable loads or MTE-checked stores might hang on accessing a poisoned cache line

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

SIMD, FP, and SVE loads or MTE-checked stores to cacheable memory might hang if at least one cache line being accessed is poisoned due to an earlier deferred error.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under one of the following two sets of conditions:

#### Set 1:

- 1. The core executes a SIMD, FP, or SVE load to Normal Inner Write-Back, Outer Write-Back Cacheable memory. The load is one of the following types:
  - a. SVE load multiple structures
  - b. SVE contiguous load
  - c. SVE contiguous non-fault load
  - d. SVE contiguous first-fault load
  - e. SVE contiguous non-temporal load
  - f. SVE Gather loads (all variants)
  - g. LDx (multiple structures) All variants
  - h. LDx (single structures) All variants
  - i. LD3R
  - j. LD4R
- 2. At least one cache line accessed by the load is poisoned due to a deferred error.

#### Set 2:

- 1. MTE checking of stores is enabled, and set to generate synchronous exceptions on tag check fails (SCTLR\_ELx.TCF = 0b01).
- 2. The core executes an MTE-checked SIMD, FP, or SVE store to Normal Inner Write-Back, Outer Write-Back Cacheable, Tagged memory. The store is one of the following types:

- a. SVE scatter/contiguous store
- b. STx (store multiple) All variants
- 3. At least one cache line accessed by the store is poisoned due to a deferred error.

## **Implications**

If the conditions are met, the load or MTE-checked store might hang, preventing further execution until the poison is cleared. Interrupts will not be taken. This is not expected to be a significant issue for sample silicon.

## Workaround

### 1975007

## WFE trap might take effect when a wake up event is pending

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A trap (as configured by SCTLR\_ELX.nTWE, HCR\_EL2.TWE, SCR\_EL3.TWE) might be taken upon execution of a **wfe** instruction that would not otherwise cause entry to low power state due to a pending, unmasked interrupt.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. Entry to WFE low-power state is configured to be trapped upon execution in current exception level (trap configured such that ESR ELx.EC would == 0b000001).
- 2. No WFE wake up events are pending.
- 3. An architectural event unmasks interrupt type <X> as per table D1-13 of the Arm ARM (for physical interrupts) or table D1-17 of the Arm ARM (for virtual interrupts).
- 4. A **WFE** instruction is executed whilst an interrupt of type <X> is pending.

## **Implications**

If these conditions are met, then execution of the **WFE** instruction will be trapped when there is an architecturally defined wake up event pending.

#### Workaround

## PrefetchTgt transactions are generated when PrefetchTgt is disabled

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

PrefetchTgt transactions are generated even when PrefetchTgt is disabled through control bits in IMP\_CMPXECTLR\_EL1[39:38]. The default setting of these control bits is to not generate PrefetchTgt transactions.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. A memory access instruction (including speculative execution), to Normal Inner Write-Back, Outer Write-Back Cacheable memory results in an L1 and L2 miss.
- 2. PrefetchTgt transactions for demand data memory accesses are disabled with IMP CMPXECTLR EL1[39:38] = 0b00.

## **Implications**

If the conditions are met, a PrefetchTgt transaction might be generated even though the control bits disable their use. The generation applies to a subset of demand data memory accesses. The unexpected generation of PrefetchTgt transactions should not cause functional issues in a system that has support for PrefetchTgt transactions.

#### Workaround

In a system where the use of PrefetchTgt transactions must be fully disabled, the software can set IMP\_CPUACTLR\_EL1[14] = 1; for example, by using the following sequence:

```
MRS x0, S3_0_C15_C1_0
MOV x1, #1
BFI x0, x1, #14, #1
MSR S3_0_C15_C1_0, x0
```

This is not expected to have a material performance impact in common use cases, but it does increase the best-case L1 data miss latency by one cycle.

## Trigger received immediately out of warm reset might cause deadlock

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

When a PE comes out of reset, it performs some internal handshaking to obtain certain configuration parameters before it can start execution. Due to this erratum, if an Embedded Logic Analyzer (ELA) or Embedded Trace Macrocell (ETM) trigger is received by the PE just as it starts this handshake, the handshake might never complete and the PE cannot come out of reset correctly.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. The PE receives an ELA or ETM trigger event.
- 2. The PE is coming out of warm reset. Power-on reset is not affected by this erratum.
- 3. Other specific timing micro-architectural timing conditions occur.

## **Implications**

If this erratum occurs the PE will deadlock, because it cannot come out of reset correctly. No other PEs in the cluster are affected by this erratum.

#### Workaround

Due to the precise timing conditions required to hit this erratum, no general workaround is necessary.

However, if this issue is observed it can be worked around by setting the CTICONTROL.GBLEN bit to 0 to disable triggers.

## A change of ASID without context synchronization might cause memory ordering issues

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A change of Address Space IDentifier (ASID) without a subsequent context synchronization barrier or event might cause ordering issues on a subsequent **CAS** or **CASP** instruction.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The core executes an MSR instruction changing TTBRn\_ELx.ASID, TCR\_ELx.A1, or TCR\_ELx.AS.
- 2. The core executes a **CAS** or **CASP** instruction using the translation affected by the ASID change within 6 instructions of the **MSR** above, without an intervening context synchronization barrier or event.

## **Implications**

If the conditions are met, the **CAS** or **CASP** instruction might violate memory ordering rules and uniprocessor semantics.

The conditions imply changes of ASID, or other translation-related registers, which are not expected to occur for actively used translations. A context synchronization event is expected before resuming execution in a context which has had its translation control registers modified.

#### Workaround

An **ISB** instruction between the **MSR** and the **CAS/CASP** instructions using the modified translation prevents the erratum from occurring.

## An ECC error in the L1 data cache might not be detected

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A store of less than 4 bytes of data to Normal Inner Write-Back, Outer Write-Back Cacheable memory, or a Tag Checked store, might not detect an ECC error when reading the L1 data cache data or Memory Tagging Extension (MTE) RAMs. This might result in data corruption or an incorrect value of the TFSR\_ELx register.

## **Configurations Affected**

This erratum affects configurations with core cache protection enabled.

## **Conditions**

#### Set 1:

- 1. The core executes a store of less than 4 bytes of data to Normal Inner Write-Back, Outer Write-Back Cacheable memory.
- 2. A (potentially speculative) memory access receives a NDErr or DErr response.
- 3. An error or poisoned data is present in the L1 data RAM.

#### Set 2:

- 1. MTE checking is enabled, and SCTLR ELx.TCF = 0b10.
- 2. The core executes a Tag Checked store to Normal Inner Write-Back, Outer Write-Back Cacheable memory.
- 3. A (potentially speculative) memory access receives a NDErr or DErr response.
- 4. An error or poisoned data is present in the L1 data MTE RAM.

## **Implications**

There is still substantial benefit being gained from the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum.

If the conditions in set 1 are met, data corruption may occur at the 4-byte-aligned 4-byte quantity around the location written to by the store.

If the conditions in set 2 are met, TFSR\_ELx might be updated with an incorrect value.

## Workaround

## A continuous stream of DVM operations from another PE might block core powerdown

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A continuous stream of Distributed Virtual Memory (DVM) operations from a PE not within the complex, might block the powerdown of a core in a complex.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The system is attempting to power down a core in the complex.
- 2. A continuous stream of DVM operations is sent from a PE not within the complex.

## **Implications**

If the above conditions are met, the core might not be able to power down, and the P-Channel handshake might be stalled until the stream of DVM operations stops.

#### Workaround

### 1982956

## SIMD and floating point loads to non-gatherable device memory might overread

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

SIMD and floating point loads to non-gatherable device memory might over-read by reading a 32-bytealigned 32-byte quantity around the accessed bytes.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following condition:

1. The core executes a SIMD or FP load to non-gatherable device memory, with all accessed bytes within a 16-byte-aligned 16-byte granule.

## **Implications**

If the condition is met, the memory access generated for the load will over-read by reading a 32-bytealigned 32-byte quantity rather than staying within the permitted 16-byte-aligned 16-byte quantity.

#### Workaround

Software might be able to avoid the use of SIMP or FP loads to device memory within 32-bytes of readsensitive memory.

### 1986930

## Corruption might occur on MTE allocation tags

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

MTE allocation tags might be corrupted on certain systems.

## **Configurations Affected**

This erratum affects all configurations. This erratum affects systems with **BROADCASTOUTER**=1 that do not have a snoop filter, or have an imprecise snoop filter.

#### **Conditions**

- 1. The complex has a cache line cached in a shared state without MTE allocation tags.
- 2. A core executes a Tag Unchecked store to the cache line, causing a line upgrade coherency request (MakeReadUnique).
- 3. The line is not lost at the requestor, but the MakeReadUnique request returns a response with data and allocation tags.
- 4. Unlikely, but not rare, timing-sensitive microarchitectural conditions occur.

## **Implications**

If the above conditions are met, the stored allocation tags for the given cache line might be corrupted. When a coherent requestor in the same shareability domain later requests allocation tags, it might observe the data corruption.

The last condition requires the interconnect to return data and MTE tags in response to a MakeReadUnique request with TagOp=Invalid, even though the requestor did not lose the cache line. This is not expected to happen in systems with a precise snoop filter. The return of MTE allocation tags in response to a TagOp=Invalid MakeReadUnique request likely requires the presence of a system cache, tag cache, or multiple clusters in the system.

This erratum is categorized as Category C because no systems using this revision of the core meet the above properties.

#### Workaround

## 1987125 ERR2MISCO.OFR and ERR2MISCO.OFO might not be set on counter overflow

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0. Fixed in r0p1.

## **Configurations Affected**

This erratum affects configurations with core cache protection enabled.

#### **Conditions**

This erratum occurs under the following condition:

1. A detected and corrected error causes ERR2MISCO.CECO or ERR2MISCO.CECR to overflow.

## **Implications**

There is still substantial benefit to be gained from using the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum.

If the condition is met, ERR2MISCO.OFO and ERR2MISCO.OFR might not be set to 1, and it might not be possible to detect an overflow of ERR2MISCO.CECO and/or ERR2MISCO.CECR.

#### Workaround

# 1987184 DBG\_RECOV or WARM\_RST power modes might lead to deadlock or data corruption

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

Due to this erratum, some types of Warm reset may cause cores in the cluster to deadlock or to cause corruption or deadlock of Utility Bus or Advanced Peripheral Bus (APB) transactions. The types of Warm reset affected are those that do not require the cluster to be quiescent when asserted.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

- 1. One of the following power modes is requested in the core Power Policy Unit (PPU):
  - DBG RECOV with PPU PTCR.DBGRECOV PORST EN set to 0
  - WARM RST
- 2. The PE is simultaneously handling at least one of the following:
  - An MSR or MRS instruction
  - A Utility bus access from outside the cluster
- 3. Other specific micro-architectural timing conditions occur.

## **Implications**

Under these conditions, one of more cores in the cluster may deadlock after coming out of Warm reset. The Utility bus or debug APB bus may observe corrupted transactions or deadlock.

#### Workaround

The type of Warm reset required to cause this erratum is not expected to be used in normal operation. Instead, it is expected to be used for specific debugging purposes. As such, no workaround is expected to be required.

Date of issue: 27-Jun-2022

## 1990749

## Errors or poison in the L2 data RAM might lead to deadlock and/or data corruption

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

If both halves of a cache line stored in the L2 cache see an ECC error or have been stored with poison, a subsequent read might lead to a deadlock and/or data corruption.

## **Configurations Affected**

This erratum affects configurations where the complex is configured with an L2 cache.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. An L1 instruction or data cache refill hits in the L2 cache.
- 2. Both 32-byte parts of the cache line stored in the L2 cache read by the refill above see an ECC error or have been stored as poisoned due to an earlier deferred error.

## **Implications**

If the conditions are met, a deadlock or data corruption on the cache line filled into the L1 cache might occur. Two errors on the same cache line are unlikely to occur. This is not expected to be a significant issue for sample silicon.

#### Workaround

There is no workaround.

Version: 14.0

## Uncontainable error injection via ERR2PFGCTL might occur at the wrong time

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0. Fixed in rOp1.

## Description

If uncontainable error injection is enabled via ERR2PFGCTL, these injections might occur at an unexpected time and at a higher rate than expected.

## **Configurations Affected**

This erratum affects configurations with core cache protection enabled.

## **Conditions**

1. Injection of uncontainable errors is enabled in ERR2PFGCTL (ERR2PFGCTL.UC = 0b1 and ERR2PFGCTL.CDNEN = 0b1).

## **Implications**

If the conditions are met, uncontainable error injections might take place at a much greater rate than expected. Errors might be injected whenever the counter reaches zero, without requiring a triggering access. As a result, ERR2MISCO.INDX and ERR2MISCO.WAY might contain invalid information.

#### Workaround

Software might be able to avoid injecting uncontainable errors via ERR2PFGCTL.

## Traps of System registers in Debug state might cause unexpected exceptions

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

Secure debug can be disabled by setting EDSCR.SDD. This will trap execution in EL2, EL1, or EL0 in Debug state of any instruction that is configured by EL3 control registers to trap to EL3. The core has the IMPLEMENTATION DEFINED behavior that this trap has priority over other traps to EL2 or EL1. There are certain groups of EL1 System registers that can be configured to trap to both EL2 and EL3. Because of this erratum, while the Processing Element (PE) is at EL1 and in Debug state with Secure debug disabled, traps for these System registers will not behave as expected while they have an EL2 trap enabled.

If a trap to EL3 is also enabled, the Secure debug disabled undefined exception has priority. Undefined exceptions at EL1 can target EL1 or EL2, depending on whether HCR\_EL2.TGE is set. However, this erratum causes the exception to always target EL2 in this case, regardless of HCR\_EL2.TGE.

If the trap to EL3 is disabled, and the EL2 trap is the next highest priority exception, the syndrome will indicate an undefined exception instead of a System register trap.

The affected System register groups are:

- Interrupt controller EL1 registers (ICC \*, ICV \*).
- LORegion registers.
- RAS error record registers.
- Pointer Authentication key registers.
- Registers trapped by SCR EL3.ATA and HCR EL2.ATA.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. The PE is in Debug state at EL1.
- 2. Secure debug is disabled by EDSCR.SDD.
- 3. One of the EL1 System registers mentioned previously, which can be trapped to EL2 or EL3, is accessed while the EL2 trap is enabled.

4. If the EL3 trap is enabled, HCR\_EL2.TGE is not set.

## **Implications**

The resulting exception under these conditions will either have a different syndrome, or higher target Exception level than expected.

## Workaround

Either enabling Secure debug, or disabling the affected System register traps to EL2 will avoid any cases of unexpected exception syndrome or target Exception level.

## A Tag Checked SVE non-fault or first-fault load might hang if an External abort occurs

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A Tag Checked *Scalable Vector Extension* (SVE) non-fault or first-fault load might hang if precise *Memory Tagging Extension* (MTE) checking is enabled and an External abort occurs.

## **Configurations Affected**

This erratum affects configurations where the **BROADCASTMTE** pin is set to 1.

#### **Conditions**

- 1. MTE checking is enabled and set to generate synchronous exceptions (SCTLR\_ELx.ATAn = 1, SCTLR\_ELx.TCFn = 0b01).
- 2. A store instruction is executed to Tagged Normal Inner Write-Back, Outer Write-Back Cacheable memory.
- 3. A Tag Checked SVE non-fault or first-fault load instruction is executed whose active elements overlap with the memory locations written to by the previous store instruction.
- 4. The load is to Tagged Normal Inner Write-Back, Outer Write-Back Cacheable memory.
- 5. The load misses in the cache, and a cache refill for the cache line receives a NDErr or DErr response.

## **Implications**

If these conditions are met, the SVE non-fault or first-fault load might hang.

#### Workaround

#### ELA connected to warm reset instead of cold reset

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

The ELA is connected to warm reset instead of cold reset. This means that any access to the ELA registers will stall while reset is asserted, which can be an issue for the power modes that assert warm reset.

### **Configurations Affected**

This erratum affects all product configurations with ELA support. Note that this is affecting only the ELA in the complex and not the DSU ELA.

#### Conditions

The erratum occurs under the following conditions:

- 1. Warm reset is asserted.
  - This happens in {OFF EMU, WARM RST} power modes or
  - o in DBG\_RECOV mode if PPU\_PTCR.DBG\_RECOV\_PORST\_EN is set to 0 or
  - in {ON, FUNC\_RET} if the core sets RMR\_EL3.RR bit to 1 requesting a warm reset.
- 2. There is a register access to ELA registers.

## **Implications**

If the conditions above are met, the ELA will not be able to trace signals during warm reset, and the related ELA registers will be initialized to their reset values. Additionally, any ELA register access will stall until the core comes out of reset and then it completes normally. However, the ELA read register requests will return the reset register values.

Since the ELA access will not complete until the core leaves warm reset, it could cause a system deadlock.

#### Workaround

# Asynchronous Tag Check fail not synchronized based on SCTLR\_ELx.ITFSB for exceptions in Debug state

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

When taking an exception in Debug state, Tag Check Faults due to instructions executed before the exception (that are reported asynchronously) are not synchronized into the TFSREO\_EL1 and TFSR\_ELx registers based on SCTLR\_ELx.ITFSB.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The core enters Debug state.
- 2. Tag Check Faults are configured to be reported asynchronously and PSTATE.TCO == 0.
- 3. A Tag Checked instruction executes which generates a Tag Check Fault.
- 4. An exception entry occurs to ELx when SCTLR ELx.ITFSB == 1.

## **Implications**

If the above conditions are met, then a Tag Check fail due to an instruction executed in step 3 of the conditions will not be synchronized into the TFSREO\_EL1 and TFSR\_ELx registers upon taking the exception in step 4.

#### Workaround

A debugger should execute a DSB before reading TFSREO\_EL1 or TFSR\_ELx.

## Double-bit errors in the duplicate L1 data cache tag RAMs might lead to loss of coherency or deadlock

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

If a double-bit error is detected on a read of the duplicate L1 data cache tag RAMs, a deadlock might occur.

## **Configurations Affected**

This erratum affects configurations with core cache protection enabled.

#### **Conditions**

The erratum can occur under two sets of conditions.

#### Set 1:

- 1. A DC ISW, DC CSW, or DC CISW operation to the L1 data cache is executed. No error is detected on the read of the duplicate L1 data cache tag RAMs.
- 2. The same core performs an L1 data cache refill for a line in the same set as the set/way operation above. This refill might be speculative.
- 3. A double-bit error occurs on a read of the duplicate L1 data cache tag RAMs for the L1 cache refill above.

#### Set 2:

- 1. A new or deferred error is detected in the L1 data cache tag, data, dirty, or Memory Tagging Extension (MTE) RAMs. This causes a hardware set/way operation being generated.
- 2. For the hardware-initiated set/way maintenance operation above, no error is detected on the read of the duplicate L1 data cache tag RAMs.
- 3. The same core performs an L1 data cache refill for a line in the same set as the set/way operation above. This refill might be speculative.
- 4. A double-bit error occurs on a read of the duplicate L1 data cache tag RAMs for the L1 data cache refill above.

## **Implications**

There is still substantial benefit being gained from the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum. If the conditions are met, coherency might be lost or a deadlock might occur on later memory accesses. Double-bit errors on the duplicate L1 data cache tag RAMs are classed as uncontainable, and Arm believes these implications are in line with those of an uncontainable error. The detection and reporting of the error are unaffected.

#### Workaround

The first set of conditions can be avoided by software. The use of data cache maintenance by set/way operations to the L1 data cache is not necessary as the core performs automatic cache maintenance on powerup and powerdown. Where software intends to use set/way operations regardless, the data cache should be turned off to ensure the intended behavior of cleaning the cache and avoiding a speculative refill to the cache during the sequence.

The second set of conditions does not have a workaround. However, a double-bit error occurring in the duplicate tag RAMs on a cache line that has previously had another error in the L1 data cache is very unlikely.

Version: 14.0

#### 1999032

# Non-Data Errors on memory accesses not attributable to a core might not be reported

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

If a Non-Data Error occurs on a memory request not attributable to a core, such as a cache eviction writeback, an L2-allocating read, or an L2 prefetch, the error might not be reported.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The complex performs a cache eviction writeback, an L2-allocating read, an L2 prefetch, or other access not attributable to a core.
- 2. The memory access above receives a NDErr response.

## **Implications**

If these conditions are met, the NDErr response might not be reported in the ERR2STATUS error record register. The downstream component which generated the NDErr response should have reported the error.

#### Workaround

Arm does not believe a workaround is needed, as the error should have been reported by the downstream memory component.

#### Version: 14.0

## 2000000 Interrupt might not be taken in finite time

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A pending, unmasked interrupt may not be taken in finite time.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. An interrupt is pending.
- 2. The interrupt is unmasked according to the table in section "Asynchronous exception masking" in the Arm Architecture Reference Manual.
- 3. A continuous stream of instructions is executed, consisting exclusively of either of the following two instructions:
  - MSR TRCPRGCTLR
  - Branch instructions
- 4. Micro-architectural timing conditions occur.

## **Implications**

If the above conditions are met, then the interrupt pending in step 1 of the conditions might not be taken while the instructions in step 3 are being continuously executed.

#### Workaround

## L2 cache debug operations might hang when no L2 cache is present

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

If an L2 cache debug operation is performed when no L2 cache is present, the complex might hang.

## **Configurations Affected**

This erratum affects configurations without an L2 cache (parameter L2\_CACHE is set to FALSE).

#### **Conditions**

1. A core performs a cache debug operation to the L2 cache (SYS IMP\_CDBGL2CDR / SYS IMP\_CDBGL2CMR).

## **Implications**

The cache debug operation might hang. Subsequent System register accesses from either core in the complex might hang.

#### Workaround

Software may be able to avoid L2 cache debug operations when no L2 cache is present. The specific details are system-dependent.

## Double-bit errors in the duplicate L1 data cache tag RAMs might lead to deadlock on a snoop

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

Double-bit errors in the duplicate L1 data cache tag RAMs might lead to a deadlock on a snoop.

## **Configurations Affected**

This erratum affects configurations with core cache protection enabled (CORE\_CACHE\_PROTECTION set to TRUE).

#### **Conditions**

The erratum occurs under the following conditions:

- 1. A TLB hardware update of the dirty bit or access flag or an L2-allocating write from the CPU misses in the complex and starts a read. No error is detected on the read of the duplicate L1 data cache tag RAMs.
- 2. The L2 receives a snoop for the same cache line.
- 3. A double-bit error occurs on a read of the duplicate L1 data cache tag RAMs for the L1 cache refill above.
- 4. The DSU or interconnect downstream of the complex prevents completion of the first read until the snoop completes.

## **Implications**

There is still substantial benefit being gained from the ECC logic. There might be a negligible increase in the overall system failure rate due to this erratum. If the conditions are met, the snoop might not progress, causing a deadlock. Arm believes that this is rare as the location in the L1 data cache tag RAMs must not have had any error on the first read, but has a double-bit error on a read only shortly after.

#### Workaround

## Clearing a pending OS Unlock Catch debug event might cause unpredictable behavior

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

When an OS Unlock Catch debug event is pending, writing a value of 0b1 to EDESR.OSUC under complex and rare microarchitectural timing conditions might cause unpredictable behavior to be observed.

### **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. OS Unlock Catch debug events are enabled (CTIDEVCTLR.OSUCE == 1).
- 2. The state of the OS lock changes from locked to unlocked.
- 3. A debugger writes 0b1 to EDESR.OSUC.
- 4. Exact microarchitectural timing conditions occur.

## **Implications**

If these conditions are met, then unpredictable behavior in the core might occur, including execution of incorrect instructions or at an incorrect Exception level. This includes, but is not limited to, incorrect entry to ELO and/or incorrect switching to non-secure state.

PSTATE.IL will always be set when these conditions are met.

Security state escalation is not possible when these conditions are met.

#### Workaround

#### Version: 14.0

#### 2016064

## A continuous stream of memory requests from one CPU in the complex might block another

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOpO. Fixed in rOp1.

## Description

A continuous stream of memory requests from one core in the complex might block an L1 cache refill of another.

## **Configurations Affected**

This erratum affects configurations with two cores in the complex.

#### **Conditions**

- 1. One of the cores in the complex executes a continuous stream of memory requests. This can be any combination of stores, TLB maintenance instructions, I-cache maintenance instructions, PRFM instructions, as well as TRBE-generated trace data writes.
- 2. The other core in the complex is attempting an L1 cache refill, either due to a demand or speculative request.
- 3. A majority of memory requests from the first core experience unusually long delays.

## **Implications**

If the above conditions are met, the L1 cache refill might not progress until the stream of operations from the first core is interrupted.

#### Workaround

A denial of service on a secure process can be avoided if the secure OS sets up a timer-based interrupt source to interrupt all cores periodically.

## Exception or DCPS3 instruction in debug state might block execution of instruction from EDITR

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

### Description

If an exception or **DCPS3** instruction is executed in debug state then an instruction written to the External Debug Instruction Transfer Register (EDITR) might never be executed.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The core enters Debug state.
- 2. A debugger writes a first instruction to the EDITR and one of the following occurs:
  - The first instruction is a **DCPS3** instruction that switches to EL3 from a lower Exception level.
  - The first instruction generates an exception in Debug state, that targets ELx with SCTLR\_ELx.ITFSB == 1.
- 3. A debugger writes a second instruction to the EDITR.
- 4. Exact microarchitectural timing conditions occur.

## **Implications**

If these conditions are met, then the instruction written to the EDITR in step 3 will not be executed. Subsequent writes to the EDITR will be blocked due to EDESR.ITE == 0

If these conditions are met then exit from debug state will still be possible.

It is unlikely that this could be observed in a real system, due to debugger latency between step 2 and step 3 of the conditions.

#### Workaround

## A double-bit error on the L1 data cache MTE tag RAMs might result in a missed or incorrect error record in ERR1STATUS

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

If a double-bit error is detected on the L1 data cache Memory Tagging Extension (MTE) tag RAM, no error might be recorded in ERR1STATUS, or it might be recorded incorrectly.

## **Configurations Affected**

This erratum affects configurations with core cache protection enabled (CORE\_CACHE\_PROTECTION set to TRUE).

#### **Conditions**

The erratum might occur under two sets of conditions.

#### Set 1:

- 1. MTE checking is enabled and set to generate asynchronous exceptions (SCTLR\_ELx.ATAn = 1, SCTLR\_ELx.TCFn = 0b10).
- 2. A store instruction is executed to Inner Write-Back and Outer Write-Back, tagged, memory.
- 3. A double-bit error, or poison because of a previously deferred error, is detected on the L1 data cache MTE tag RAM.
- 4. The double-bit error is still present on a subsequent correction read of the L1 data cache MTE tag RAM.

#### Set 2:

- 1. MTE checking is enabled and set to generate asynchronous exceptions (SCTLR\_ELx.ATAn = 1, SCTLR ELx.TCFn = 0b10).
- 2. A store instruction is executed to Inner Write-Back and Outer Write-Back, tagged, memory.
- 3. A double-bit error, or poison because of a previously deferred error, is detected on the L1 data cache MTE tag RAM.
- 4. The double-bit error is no longer present on a subsequent correction read of the L1 data cache MTE tag RAM.

## **Implications**

There is still substantial benefit being gained from the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum.

If the conditions in set 1 are met, the error might be reported as a deferred error, but the TFSR\_ELx register might not have been updated correctly due to the store instruction.

If the conditions in set 2 are met, no error might be reported, but the TFSR\_ELx register might not have been updated correctly due to the store instruction.

As a result, both might result in a false negative in TFSR\_ELx.

#### Workaround

#### Version: 14.0

### 2033473

## A hardware update of the dirty bit might occur speculatively

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

A hardware update of the dirty bit might be speculatively performed for a store or atomic that sees a permission fault because of Privileged Access Never (PAN), or an alignment or stack alignment fault.

## **Configurations Affected**

This erratum affects all configurations.

#### Conditions

The erratum occurs under two sets of conditions:

#### Set 1:

- 1. The core is executing in EL1, or EL2 with Virtualization Host Extensions (VHE) enabled (HCR\_EL2.E2H = 0b1).
- 2. PSTATE.PAN is set.
- 3. An **STTR** instruction is executed speculatively, but never committed.
- 4. A committed privileged store or atomic instruction to the same address is executed and sees a permission fault because of PAN.
- 5. Hardware update of the dirty bit is enabled for the page of memory accessed by the store or atomic instruction above.

#### Set 2:

- 1. A store or atomic instruction is executed speculatively, but never committed, or a load instruction is executed.
- 2. A committed privileged store or atomic instruction to the same page is executed, and sees an alignment fault or stack alignment fault.
- 3. Hardware update of the dirty bit is enabled for the page of memory accessed by the store or atomic instruction above.

## **Implications**

If the conditions are met, the access permissions of the descriptor might be speculatively updated to include write permissions (dirtied), even though the store sees a permission fault because of PAN, or an alignment fault, or a stack alignment fault. For most systems, including those anticipated to be used by sample silicon, having the dirty bit speculatively in the presence of a permission failure does not lead to any incorrect operation.

### Workaround

# 2035302 CONTEXTIDR\_EL2 breakpoint matching is enabled at EL3

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

Architecture issue D17428 describes that breakpoints performing context comparisons against CONTEXTIDR\_EL2 should not match when executing at EL3. The core implements the originally documented behavior and will match at EL3 if EL2 is enabled in the current Security state.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The core is executing at EL3.
- 2. Halting debug is allowed.
- 3. EDSCR.HDE == 1.
- 4. OSLSR EL1.OSLK == 0.
- 5. SCR EL3.NS == 1 or SCR EL3.EEL2 == 1.
- 6. DBGBCR<n> EL3.BT is configured to one of the following:
  - Unlinked CONTEXTIDR EL2 match (DBGBCR<n> EL3.BT == 0b1100).
    - Unlinked Full Context ID match (DBGBCR<n> EL3.BT == 0b1110).
- 7. DBGBVR<n> EL3 and CONTEXTIDR EL2 contain the same value.

## **Implications**

If the above conditions are met, then a context breakpoint might generate a debug event based on CONTEXTIDR\_EL2 while executing at EL3.

#### Workaround

To avoid this erratum, ensure that any breakpoints performing context comparisons against CONTEXTIDR\_EL2 are configured not to match at EL3, by ensuring that either DBGBCR<n>\_EL1.HMC is 0 or DBGBCR<n>\_EL1.SSC[0] is 1.

# 2036369 MPAM3\_EL3.TRAPLOWER reset on Cold reset

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0 and rOp1. Fixed in rOp2.

## Description

Architecture issue D17395 documents a discrepancy in the specified reset domain for the MPAM3\_EL3.TRAPLOWER bit. The core implements the incorrect interpretation, resetting MPAM3\_EL3.TRAPLOWER on Cold reset rather than Warm reset.

## Configurations affected

All configurations are affected.

#### **Conditions**

- 1. MPAM3 EL3.TRAPLOWER is set to 0.
- 2. The core is Warm reset.
- 3. An access to one of the MPAM System registers is made from EL2 or lower.

## **Implications**

If these conditions are met, the MPAM3\_EL3.TRAPLOWER bit will not be set to 1 on the Warm reset, and so accesses to MPAM registers from EL2 and lower Exception levels will not be trapped to EL3.

#### Workaround

Boot software should initialize the MPAM3\_EL3.TRAPLOWER bit and not rely on the reset value.

Date of issue: 27-Jun-2022

#### Version: 14.0

#### 2048342

## A load or store instruction might hang when encountering multiple uncorrectable or deferred errors

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

A load or store instruction to Normal Cacheable memory might hang if the instruction accesses more than one cache line and at least one cache line being accessed is poisoned due to an earlier deferred error.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. The core executes a load instruction or a Tag Checked store instruction, other than a load or store of vector registers.
- 2. The load or store crosses a 64-byte boundary, accessing two cache lines.
- 3. Both cache lines accessed by the instruction encounter uncorrectable or deferred errors.

## **Implications**

If the conditions are met, the instruction executed in step 1 might hang, preventing further execution until the error is cleared. Interrupts will not be taken.

#### Workaround

## 2052205 ERR2STATUS.SERR might be incorrect after an NDErr response is received

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

The value of ERR2STATUS.SERR might be corrupted if an NDErr response is received. The ERR2STATUS.UE field is not affected.

## **Configurations Affected**

Only configurations with core cache protection disabled (CPU\_CACHE\_PROTECTION = 0) are affected.

### **Conditions**

The erratum occurs whenever a non-attributable NDErr response is received by a complex.

## **Implications**

If the conditions are met, the ERR2STATUS register is updated correctly, except for the ERR2STATUS.SERR field. The ERR2STATUS.UE bit will indicate that an uncorrected error occurred.

#### Workaround

# 2052374 PMU event ST\_RETIRED might be inaccurate for Store-Exclusive instructions

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

The processor implements the performance monitor event ST\_RETIRED to count executed memory-write instructions. Due to this erratum, a Store-Exclusive instruction might cause the ST\_RETIRED event to count in cases where it normally should not.

## **Configurations Affected**

This erratum affects all configurations.

### **Conditions**

- 1. One of the PMU event counters is configured to count event 0x0007, ST\_RETIRED.
- 2. Either:
  - A Store-Exclusive instruction is executed which generates a Data Abort, or
  - A Store-Exclusive instruction is speculatively executed in the shadow of an instruction generating a Data Abort.

## **Implications**

Any count of the ST\_RETIRED event might be higher than expected. This is expected to have an insignificant effect on the use of the ST\_RETIRED event for performance analysis.

#### Workaround

## Instructions in Debug state after a watchpoint debug event might not be executed

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

When the core enters Debug state, instructions written to the External Debug Instruction Transfer Register (EDITR) might never be executed.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. Halting debug is enabled (EDSCR.HDE == 1).
- 2. Halting is allowed.
- 3. The OS Lock is unlocked (OSLSR EL1.OSLK == 0).
- 4. An enabled watchpoint is hit, causing the core to enter Debug state.
- 5. A debugger writes an instruction to the EDITR.
- 6. Exact microarchitectural timing conditions occur.

## **Implications**

If these conditions are met, then the instruction written to the EDITR in step 5 will not be executed. Subsequent writes to the EDITR will be blocked due to EDSCR.ITE == 0.

If these conditions are met, then exit from Debug state will still be possible.

#### Workaround

If a workaround is required, if the instruction written in step 5 has not been executed in a macroscopic amount of time, the debugger should leave Debug state and reenter via the same watchpoint.

## Execution of instructions in Debug state after a watchpoint debug event might incorrectly set EDSCR.ERR and corrupt PSTATE

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

Execution of a specific set of instructions while in Debug state due to a watchpoint debug event might lead to EDSCR.ERR being set, and to PSTATE.PAN and PSTATE.UAO being corrupted.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

- 1. Halting debug is enabled (EDSCR.HDE == 1).
- 2. Halting is allowed.
- 3. The OS Lock is unlocked (OSLSR EL1.OSLK == 0).
- 4. An enabled watchpoint is hit, causing the core to enter Debug state.
- 5. While in Debug state, a debugger writes an instruction to the EDITR. The instruction is one of the following types:
  - "Memory access instructions at various access sizes" as defined by section "Executing instructions in Debug state" in the Arm Architecture Reference Manual
  - Load/Store Register (PAC) All variants
  - Load/Store Memory Tags All variants
  - System Instructions All variants
  - Data Synchronization Barrier
  - Data Memory Barrier
  - Error Synchronization Barrier
  - MSR or MRS to one of the following System registers:
    - LORSA EL1
    - LOREA EL1
    - LORN\_EL1
    - LORC\_EL1
    - MAIR\_ELx
    - TCR ELx
    - TRBBASER\_EL1
    - TRBLIMITR EL1
    - TRBMAR\_EL1

- TRBPTR EL1
- TRBSR EL1
- TRBTRG EL1
- TTBRO ELx
- TTBR1 ELx
- VSTCR\_EL2
- VSTTBR\_EL2
- VTCR EL2
- VTTBR EL2
- GIC registers (ICC \* or ICH \*)
- ETE registers (TRC\*)
- Implementation defined registers (IMP\_\*, accessed via S3\_\* encodings)
- 6. The instruction in step 5 is executed without generating a synchronous exception.

There is no limit on the number of instructions executed in Debug state between steps 4 and 5.

No synchronous exceptions were generated between steps 4 and 5.

No DCPS<n> or DRPS instructions were executed between steps 4 and 5.

## **Implications**

If these conditions are met, then the value of PSTATE.PAN and PSTATE.UAO might be corrupted. EDSCR.ERR will also be set to 1.

#### Workaround

If a watchpoint debug event causes entry to Debug state, then before writing any other instructions to EDITR, the debugger should execute a DCPS<n> instruction, first saving ELR\_ELx, SPSR\_ELx, ESR\_ELx, DLR\_ELO and DSPSR\_ELO as necessary.

## A Tag Checked store exclusive might hang if an external abort occurs

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

A Tag Checked Store-Exclusive instruction might hang if precise Memory Tagging Extension (MTE) checking is enabled and an external abort occurs.

## **Configurations Affected**

This erratum affects configurations where the **BROADCASTMTE** pin is set to 1.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. A store or atomic is executed to a memory location A. The memory location is mapped as Tagged Normal Inner Write-Back, Outer Write-Back Cacheable memory.
- 2. MTE checking is enabled and set to generate synchronous exceptions (SCTLR\_ELx.ATAn = 1, SCTLR ELx.TCFn = 0b01).
- 3. A Load-Exclusive instruction is executed to the same memory location A.
- 4. An L1 data cache refill for the cache line containing memory location A receives a NDErr or DErr response.
- 5. A Tag Checked Store-Exclusive to memory location A is executed.
- 6. Timing-sensitive micro-architectural conditions occur.

## **Implications**

Substantial benefit is still being gained from the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum. If the conditions are met, the Store-Exclusive might hang.

#### Workaround

Arm\_Cortex\_A510 (MP111) Version: 14.0 Software Developer Errata Notice

### 2059297

## PSTATE.TCO might be unchanged for debug entry due to a watchpoint debug event

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

Entry to debug state due to a watchpoint debug event will not set PSTATE.TCO.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. Halting debug is enabled (EDSCR.HDE == 1).
- 2. Halting is allowed.
- 3. The OS Lock is unlocked (OSLSR EL1.OSLK == 0).
- 4. An enabled watchpoint is hit, causing the core to enter Debug state.

## **Implications**

The architecture requires that PSTATE.TCO is set on entering Debug state. If these conditions are met, then the value of PSTATE.TCO will be unchanged when entering debug state and therefore might not be set.

#### Workaround

If a watchpoint debug event causes entry to debug state, the first instruction pushed by the debugger should be MSR TCO, #1. Alternatively, a DCPS<n> instruction will set PSTATE.TCO.

## Incorrect context ID might be associated with trace data

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

An MSR to either CONTEXTIDR\_EL1 or CONTEXTIDR\_EL2 might lead to the incorrect context identification information being associated with a trace packet.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. The core enters Debug state.
- 2. ETM tracing is enabled (TRCPRGCTLR.EN == 1).
- 3. An MSR instruction is executed which updates the active CONTEXTIDR ELx register.
- 4. The core exits Debug state.

The ordering of steps 2 and 3 has no impact.

There are no PO instructions executed between steps 3 and 4.

#### OR:

- 1. The core is reset.
- 2. ETM tracing is disabled (TRCPRGCTLR.EN == 0).
- 3. The core enters Debug state.
- 4. ETM tracing is enabled (TRCPRGCTLR.EN == 1).
- 5. The core exits Debug state.

There are no p0 instructions executed between steps 4 and 5.

There are no MSR instructions executed which update the active CONTEXTIDR\_ELx register.

OR:

1. ETM tracing is disabled (TRCPRGCTLR.EN == 0).

- 2. Either of the following:
  - An MSR instruction is executed which updates the active CONTEXTIDR\_ELx register.
  - No instructions have been traced since the last core reset.
- 3. ETM tracing is enabled (TRCPRGCTLR.EN == 1).
- 4. The core executes an **ESB**.
- 5. A virtual or physical SError is pending and is unmasked according to the table in section "Asynchronous exception masking" in the Armv8-A Architecture Reference Manual.
- 6. Exact microarchitectural timing conditions occur.

There are no PO instructions executed between steps 2 and 4.

## **Implications**

If these conditions are met, then a trace element might have the incorrect context identification information associated with it, potentially leading to the generation of incorrect (or missing) context elements by the trace unit.

#### Workaround

For the first set of conditions, an ISB should follow step 3.

No workaround is required for the second set of conditions.

There is no workaround for the third set of conditions.

## Incorrect ordering after change in cacheability

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1 and rOp2. Fixed in rOp3.

## Description

If the memory type of an address region is changed from Cacheable to Non-cacheable, and then back again, and rare micro-architectural conditions occur, then stale data might be observed in a cache.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. An address region of memory is marked in the translation tables as Write-Back Cacheable memory.
- 2. The hardware prefetcher starts a data prefetch to an address within this region.
- 3. The translation tables are updated to change the memory type to Non-cacheable or Device memory. This would involve a break-before-make sequence.
- 4. A sequence of cache clean and invalidate instructions are executed to ensure that any Cacheable data in the memory region does not remain in the caches.
- 5. Rare, timing-sensitive micro-architectural conditions occur, causing the cache clean and invalidate to not clean and invalidate the line brought in by the hardware prefetch.
- 6. A core or other component in the system writes to the region that is now marked Non-cacheable or Device.
- 7. The translation tables are changed a second time to mark the memory as Write-Back Cacheable again.
- 8. A load instruction is executed. The load might observe the stale data that was prefetched into the cache, rather than the Non-cacheable data that was written.

## **Implications**

The above sequence is very specific and would typically take a very long time to execute. It requires that the hardware prefetch is started before the translation table modification, and then does not complete until after both the translation table modification and the cache maintenance have finished.

In addition, rare micro-architectural conditions must occur for the hardware prefetch to not be affected by the cache maintenance. Therefore, the combination of these conditions is going to be extremely rare. Furthermore, the change in memory type implies a change of use of the memory, and many such changes of use will not require preservation of the data between uses.

## Workaround

This erratum has no workaround.

## Extra A-sync packet might get written to Trace Buffer in Trace prohibited region

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

An external trace analyzer can request that an A-sync packet is injected into the trace stream, which the Embedded Trace Extension (ETE) will insert when the next PO Element is traced. Due to this erratum, this A-sync packet might incorrectly get generated and written to trace buffer memory via TRBE under the conditions mentioned below.

## **Configurations Affected**

This erratum affects all configurations.

#### Conditions

The erratum occurs under the following conditions:

- 1. TRBE is enabled.
- 2. ETE is in a trace prohibited region.
- 3. A **TSB** instruction is executed and completed.
- 4. TRBE is disabled.
- 5. A synchronization request is received on the ATB interface.
- 6. TRBE is enabled.

## **Implications**

If the above conditions occur, an A-sync packet might go to TRBE and when a new **TSB** instruction is executed, this packet might get written to memory. Under normal usage Arm expects that this unexpected trace will have no impact.

#### Workaround

#### Version: 14.0

#### 2085871

## Shareability aliases might result in incorrect Tag Check Faults

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

A page mapped as Normal, Tagged memory under both a shareable and a non-shareable mapping might result in a spurious or missed Tag Check Fault.

## **Configurations Affected**

This erratum affects all configurations where the **BROADCASTMTE** pin is HIGH.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. A page of physical memory is mapped under both a shareable and a non-shareable mapping. Both mappings are for Normal memory, Tagged, Inner-Writeback and Outer-Writeback cacheable.
- 2. MTE checking is enabled (SCTLR\_ELx.ATAn = 1, SCTLR\_ELx.TCFn != 0b00).
- 3. The core has a location A, cached using the non-shareable mapping above.
- 4. Another PE in the system uses the shareable mapping to update the tags in memory for a location A, and the update becomes globally observable.
- 5. The core executes a data cache maintenance operation with the intent of invalidating the non-shareable cached entry for location A.
- 6. The core executes a Tag-checked store or atomic to location A, without a **DMB** between the previous CMO and this store.

### **Implications**

If the above conditions are met, the Tag-checked store is not guaranteed to see the update to the tags at location A, and might use the previous tags for its tag check. This might result in a spurious or missed Tag Check Fault.

#### Workaround

Software might be able to avoid the use of cacheable non-shareable, or aliased shareability, for tagged memory. Alternatively, software can insert a **DMB LD** after the cache maintenance operation to ensure ordering.

#### Version: 14.0

### 2088637

## A watchpointed SVE load might update the FFR register incorrectly

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2 and rOp3. Fixed in r1p0.

## Description

An SVE load might update the FFR register incorrectly after a watchpoint hit.

### **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

The erratum occurs under the following conditions:

- 1. Watchpoints are enabled and a watchpoint is set on a memory location A.
- 2. The core speculatively executes an SVE load or store to memory location A in the shadow of a mispredicted branch. This instruction is not architecturally executed.
- 3. The core executes an unaligned SVE Non-Fault or First-Fault load crossing a 32-byte boundary, to location A, or another location with a watchpoint. The watchpointed location is in the upper 32-byte aligned quantity.

## **Implications**

If the conditions are met, the fields of the FFR register corresponding to the watchpointed elements of the load in condition 3 might be not be cleared. This will effectively mean that the watchpoint is ignored for that load. Data written into the architectural register file is unaffected.

#### Workaround

This erratum has no workaround.

## Debug state exit after execution of a DRPS instruction might lead to deadlock

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

A debug restart request following the execution of a **DRPS** instruction might lead to deadlock.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. The core enters debug state.
- 2. The external debugger passes an **DRPS** instruction to the core via the EDITR.
- 3. The core executes the **DRPS** instruction which enters Illegal Execution State via one of the following:
  - An illegal return event
  - A legal return event that sets PSTATE.IL to 1
- 4. The external debugger triggers a restart request trigger event.

## **Implications**

If the conditions are met, then the PE will deadlock.

#### Workaround

A debugger should observe that any **DRPS** instruction issued through the EDITR was completed and did not cause entry to Illegal Execution State, before issuing a restart request.

## Double-bit errors in the duplicate L1 data cache tag RAMs might lead to deadlock

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

A double-bit error in the duplicate L1 data cache tag RAMs might lead to a deadlock if a double-bit error is detected towards the end of a hardware cache flush sequence.

## **Configurations Affected**

This erratum affects configurations with CORE\_CACHE\_PROTECTION enabled.

#### **Conditions**

- 1. A core in the complex is being powered down, and a hardware cache flush sequence is started.
- 2. Towards the end of the hardware cache flush sequence, a double-bit error is detected on a read of the duplicate L1 data cache tag RAMs for an access other than the hardware cache flush, for example caused by an access from the other core in the complex.
- 3. The double-bit error was not present/detected when the hardware cache flush request accessed the same RAM location shortly before.

### **Implications**

There is still substantial benefit being gained from the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum. If the above conditions are met, the complex might deadlock, and a hardware watchdog might be required as the error cannot be handled by software. Double-bit errors on the duplicate L1 data cache tag RAMs are classed as uncontainable, and Arm does not believe this erratum materially degrades the benefit from ECC.

#### Workaround

# Instructions might be missed for tracing purposes before Debug state entry due to a watchpoint hit

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

When a halting watchpoint hit causes the core to enter Debug state, [E1:E0] field of the exception packet for Debug entry might be incorrect and programmed address comparators might not match.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. Halting debug is enabled (EDSCR.HDE == 1).
- 2. Halting is allowed.
- 3. The OS Lock is unlocked (OSLSR EL1.OSLK == 0).
- 4. ETM tracing is enabled (TRCPRGCTLR.EN == 1). This can be enabled either by software or an external debugger.
- 5. Tracing in the current region is unprohibited.
- 6. A p0 instruction is executed and traced by the trace unit.
- 7. Some execution occurs at the target of the p0 instruction in step 6.
- 8. An enabled watchpoint is hit, causing the core to enter Debug state.
- 9. Exact microarchitectural timing conditions occur.

## **Implications**

If these conditions are met, [E1:E0] field of the exception packet for Debug entry might be incorrect and comparators programmed on instructions at step 7 might not match.

#### Workaround

There is no workaround for the incorrect [E1:E0] field.

Comparator issues are not observable if they are programmed to match only branch instructions.

# 2120833 DISR\_EL1 access in Debug state might be incorrect

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

## Description

An MSR or MRS instruction to DISR\_EL1 while in Debug state might write or return the incorrect value.

## **Configurations Affected**

This erratum affects all configurations.

### **Conditions**

The erratum occurs under the following conditions:

- 1. The core enters Debug state.
- 2. The core is executing in EL1 or EL2.
- 3. SCR EL3.EA == 1
- 4. One of the following occurs:
  - a. DISR\_EL1 is written, using the MSR instruction.
  - b. DISR\_EL1 is read, using the MRS instruction.

### **Implications**

If step 4.1 of these conditions is met, then DISR\_EL1 will not be updated.

If step 4.2 of these conditions is met, then the read of DISR\_EL1 will read zero.

#### Workaround

If a workaround is required and EL3 is accessible by the debugger, then a debugger should change the PE state to EL3, clear SCR\_EL3.EA, and then return to the Exception level in step 2 before accessing DISR\_EL1.

# PMU event 0x000C PC\_WRITE\_RETIRED might be inaccurate for ERET instructions

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

# Description

The processor implements the performance monitor event PC\_WRITE\_RETIRED to count software changes of the Program Counter (PC). Due to this erratum, the PC\_WRITE\_RETIRED does not count for **ERET** instructions.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. One of the PMU event counters is configured to count event **0x000C**, PC WRITE RETIRED.
- 2. An **ERET** instruction is executed.

# **Implications**

Any count of the PC\_WRITE\_RETIRED event might be lower than expected. This is expected to have an insignificant effect on the use of the PC\_WRITE\_RETIRED event for performance analysis.

## Workaround

# 2135690 PMU events based on STALL\_FRONTEND might be inaccurate

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2 and rOp3. Fixed in r1p0.

# Description

The processor implements several performance monitor events to count attributable frontend stalls caused by other events. Due to this erratum, the attributable frontend stall events might not be counted.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

1. Any PMU event counter is configured to count at least one of the attributable STALL\_FRONTEND\_\* events

0x00e1, STALL FRONTEND CACHE

0x00e2, STALL FRONTEND TLB

0x00e3, STALL FRONTEND PDERR

- 2. No PMU event counters are configured to count 0x0020, STALL FRONTEND
- 3. The ETM trace unit is not enabled

## **Implications**

Any count of the attributable STALL FRONTEND \* events might be lower than it should be.

## Workaround

The attributable STALL\_FRONTEND\_\* events will count as expected if counting is also enabled for 0x0020, STALL\_FRONTEND, or by enabling the ETM trace unit.

# 2141037 OFF\_EMU to OFF power mode transition might result in a deadlock

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

# Description

If a core in a two-core complex enters the OFF\_EMU power mode, then it might become unable to move to OFF power mode. The second core in the complex would then become unable to power down.

# **Configurations Affected**

This erratum affects all configurations with two cores in a complex

## **Conditions**

The erratum occurs under the following conditions:

- 1. One core in the complex is in the OFF\_EMU power mode.
- 2. The second core in the complex is in ON/FUNCRET/FULLRET power modes.
- 3. ETM is enabled by setting TRCPRGCTLR.EN.
- 4. One of the following occurs:
  - The first core is requested to move to OFF power mode.
  - The second core is requested to move to OFF\_EMU/OFF power modes or is reset by the RMR.RR sequence.

# **Implications**

- 1. The core in OFF EMU power mode might become unable to enter OFF power mode.
- 2. The other core in the complex would then be unable to do RMR.RR reset or enter OFF\_EMU/OFF power modes. The requests would be denied repeatedly and could lead to a deadlock.

#### Workaround

ETM can be disabled on entering into OFF\_EMU state by setting 1'b0 in TRCPRGCTLR.EN. In this case Trace debugging cannot be used in OFF\_EMU state.

# 2146058 PMU events counts might be inaccurate

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2 and r0p3. Fixed in r1p0.

# Description

The processor implements several performance monitor events to count attributable front-end stalls caused by other events. Due to this erratum, multiple Performance Monitoring Unit (PMU) events might not be counted.

# **Configurations Affected**

This erratum affects all configurations.

### **Conditions**

This erratum occurs under any of the following conditions:

- Any PMU event counter is configured to count at least one of the attributable STALL\_FRONTEND\_\*
  events (0x00e1, STALL\_FRONTEND\_CACHE; 0x00e2, STALL\_FRONTEND\_TLB; 0x00e3,
  STALL\_FRONTEND\_PDERR) and:
  - No PMU event counters are configured to count 0x0020, STALL\_FRONTEND.
  - The ETM trace unit is not enabled.
- 2. One of the PMU event counters is configured to count event 0x000C, PC\_WRITE\_RETIRED, and an **ERET** instruction is executed.
- 3. One of the PMU event counters is configured to count event 0x00ED STALL\_BACKEND\_VPU\_HAZARD

## **Implications**

Any count of the attributable STALL\_FRONTEND\_\*, PC\_WRITE\_RETIRED, events might be lower than it should be. Any count of the attributable STALL\_BACKEND\_VPU\_HAZARD event might be lower or higher than it should be.

## Workaround

The attributable STALL\_FRONTEND\_\* events will count as expected if counting is also enabled for 0x0020, STALL\_FRONTEND, or by enabling the ETM trace unit. There is no workaround for the other events.

# 2161448 PMU\_HOVFS event not always exported when self-hosted trace disabled

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p1, r0p2 and r0p3. Fixed in r1p0.

# Description

PMU\_HOVFS is a Performance Monitoring Unit (PMU) event that can be exported to the Embedded Trace Macrocell (ETM). Exporting this event is disabled if TRFCR\_EL2.E2TRE is set to 0b1, but this setting only applies when self-hosted trace is enabled. Due to this erratum, the event is never exported when TRFCR\_EL2.E2TRE is set to 0b0, including when self-hosted trace is disabled.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. The ETM is configured to use PMU\_HOVFS as an external input event.
- 2. Self-hosted trace is disabled and TRFCR EL2.E2TRE is set to 0b0.

# **Implications**

Overflows of PMU counters reserved by Exception level 2 (EL2) might not be visible.

### Workaround

To use the PMU\_HOVFS as an external input event when self-hosted trace is disabled, ensure TRFCR\_EL2.E2TRE is set to 0b1.

# A watchpoint hit while disabling Halting debug might cause an incorrect debug exception to be taken

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

If a watchpoint debug event occurs at the same time as halting debug is disabled, a debug exception might be taken, even though debug exceptions are disabled.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following conditions:

- 1. Debug must be enabled (DBGEN == 1).
- 2. Halting debug is enabled (EDSCR.HDE == 1).
- 3. Debug exceptions are disabled (MDSCR\_EL1.MDE == 0).
- 4. Halting is allowed.
- 5. The OS lock becomes set by changing OSLAR EL1.OSLK from 0 to 1.
- 6. An enabled watchpoint is hit.
- 7. Exact micro-architectural timing conditions occur.

No context synchronization occurs between OS lock being set and the watchpoint being hit.

# **Implications**

If these conditions are met, then a watchpoint exception might be taken, even though this is forbidden because MDSCR\_EL1.MDE == 0.

### Workaround

This erratum can be avoided by implementing the following:

1. After an MSR to OSLAR\_EL1, an ISB should be executed before any memory instructions which might generate a watchpoint.

2. Before an APB write to OSLAR\_EL1, all watchpoints should be disabled by clearing DBGWCR<n>\_EL1.E for each watchpoint.

# A single ECC error on the L2 data RAMs might be double-counted

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r1p0. Fixed in r1p1.

# Description

ERR2MISC contains counter information on errors reported by L2. Counter information might be unreliable under some conditions.

# **Configurations Affected**

All configurations with CORE\_CACHE\_PROTECTION set to True are affected.

## **Conditions**

This erratum occurs under the following conditions:

- 1. An ECC error is detected in the L2 DATA RAM.
- 2. Heavy memory traffic occurs in the L2 cache.
- 3. Complex micro-architectural conditions occur.

## **Implications**

If these conditions occur, an error for the L2 DATA RAM might be reported more than once, incorrectly increasing the value of ERR2MISCO counters.

# Workaround

# A PE trace unit trigger might not be reflected in TRBSR\_EL1 after a TSB

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r1p0. Fixed in r1p1.

# Description

If a TRBE (Trace Buffer Extension) trigger event because of TRBTRG\_EL1 occurs during a TSB in a prohibited region, the register state in TRBSR\_EL1 after the TSB might not reflect the trigger event.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs under the following conditions:

- 1. TRBE is enabled and running.
- 2. TRBLIMITR\_EL1.TM is not set to 0b11 (ignore trigger).
- 3. The core executes a TSB in a prohibited region.
- 4. The PE trace unit detects a trace trigger.

# **Implications**

If the above conditions are met, then the value of TRBSR\_EL1.TRG, TRBSR\_EL1.S and TRBSR\_EL1.IRQ might not reflect that a trigger event occurred. Arm expects it to be an uncommon occurrence that a trace trigger is detected during the TSB in a prohibited region.

#### Workaround

# In Halting debug state, the core might take an illegal execution exception when it should not

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r1p0. Fixed in r1p1.

# Description

The PSTATE.IL bit is set when the Core executes an illegal exception return. Attempting to execute any instructions when this bit is set will cause the Core to take an exception.

Due to this erratum, the PSTATE.IL bit is not cleared when entering the Halt state in certain circumstances, causing an incorrect exception to be generated.

## **Configurations Affected**

This erratum affects all configurations that include support for the AArch32 Instruction Set when at the ELO exception level.

## **Conditions**

This erratum occurs under the following conditions:

- 1. The core in Halt state at ELO
- 2. DSPSR register is modified to trigger an illegal exception return
- 3. The core exits Halt state, triggers an illegal exception return, and sets PSTATE.IL
- 4. The core enters Halt state due to a CTI trigger
- 5. The core executes an instruction while in Halt state via the Instruction Transfer Register

There must be no instructions executed between step 3 and 4.

# **Implications**

If these conditions are met, then an illegal execution state exception will be taken when it should not. Even if an illegal execution state exception is taken when it should not, the value of PSTATE.IL is restored properly when the core exits the Halt state after step 5.

#### Workaround

# An MMU fault might not be correctly reflected in the Trace Buffer Extension TRBSR\_EL1 register

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

If the Trace Buffer Extension is enabled and an MMU fault occurs on the last page of the trace buffer, the MMU fault might not be correctly recorded in TRBSR EL1.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs under the following conditions:

- 1. TRBE is enabled and running.
- 2. The trace buffer is set to fill mode (TRBLIMITR EL1.FM = 0b00).
- 3. The last page of the trace buffer region is invalidated, and modified in a way that would result in an MMU fault. For example, this could be marking the descriptor as invalid or clearing the access flag or removing write permissions.
- 4. Simultaneously, the trace buffer limit is reached.

# **Implications**

If the conditions are met, the pointer value in TRBPTR\_EL1 will reflect the correct address at which the MMU fault occurred, but TRBSR\_EL1.EC and TRBSR\_EL1.MSS might not reflect an MMU fault. Instead, TRBSR\_EL1.EC and TRBSR\_MSS might reflect that the trace buffer filled.

Arm expects that commonly, an operating system would pin the pages used for the trace buffer, avoiding any MMU faults from occurring in the first place.

#### Workaround

No workaround is expected to be required, based on common usage models of the trace buffer which involves pinning the pages.

# Clean MTE tag writeback might occur after a store to the cache line

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2, rOp3 and r1p0. Fixed in r1p1.

# Description

A store to a cache line might incorrectly dirty the MTE tags, and result in a later writeback of both data and MTE tags.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs if all the following conditions apply:

- 1. Tagged memory accesses are enabled (SCTLR\_ELx.ATAn = 1).
- 2. The core executes a store.
- 3. Uncommon micro-architectural conditions occur.

# **Implications**

If the conditions are met, the MTE tags on the cache line can be marked as dirty even though they were not written to, resulting in additional unnecessary DRAM writebacks of tagged memory. The microarchitectural conditions are uncommon, so the unnecessary DRAM writebacks are expected to be negligible for performance or power.

Marking the MTE tags on the cache line as dirty without an explicit write prevents the use of tag storage locations for data, as software coherency cannot be maintained.

## Workaround

# An ECC error while in the active-not-pending state might clear PSTATE.SS

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

An ECC error (single bit, double bit, or poison) when executing a Load/Store instruction while software stepping in the active-not-pending state might lead to the core entering the active-pending state.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs if all the following conditions apply:

- 1. An exception return is executed, which enables software stepping (entering the active-not-pending state).
- 2. Load/Store that generates an ECC error.
- 3. Microarchitectural timing conditions occur.

# **Implications**

If the ECC is due to a single bit error, the instruction being stepped will not be executed. If the ECC is due to a double bit error or poison data, this might result in a persistent error when software stepping.

# Workaround

#### Version: 14.0

## 2217109

# RAS error reporting might be incorrect on simultaneous errors

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

ERR2STATUS and ERR2MISC registers contain information about reported errors. In case of simultaneous errors reported, the value of those registers might be incorrect.

# **Configurations Affected**

All configurations with CORE\_CACHE\_PROTECTION set to True are affected.

## **Conditions**

#### Set 1:

• A parity error on the TLB RAMs is detected on the same cycle as a corrected error on the L2DB RAMs.

### Set 2:

• Multiple errors are detected in different L2 DATA banks.

# **Implications**

If the first set of conditions occurs, the reported error might have a corrupted value of SERR, IERR, index, and way in the ERR2STATUS and ERR2MISC registers.

If the second set of conditions occurs, ERR2STATUS.CECO might not be increased correctly.

#### Workaround

Date of issue: 27-Jun-2022

#### Version: 14.0

## 2220074

# ETM will indicate that a T32 CC-failed ISB has caused a Context Synchronization Event when it has not

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r1p0. Fixed in r1p1.

# Description

When the ETM traces an **ISB** instruction, it should generate an E Atom if the ISB performed a Context Synchronization Event and a N Atom otherwise.

On Cortex-A510, a CC-failed T32 ISB will not generate a Context Synchronization Event, but the ETM will generate an E atom anyway.

## **Configurations Affected**

This erratum affects all configurations that include AArch32 at ELO.

## **Conditions**

This erratum occurs under the following conditions:

- 1. The ETM is enabled and tracing is active.
- 2. The core executes a T32 CC-failed ISB instruction.

The ISB can only CC-fail if it's inside an IT block.

# **Implications**

When reconstructing the trace, it will appear as though a Context Synchronization Event has occurred when it has not.

## Workaround

# 2226937 IMP\_CDBGDR0\_EL3 read data might be incorrect

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r1p0. Fixed in r1p1.

# Description

IMP\_CDBGDRO\_EL3 is used to perform direct accesses to internal memory. Software first writes to one of a number of system registers to trigger a read of a given cache location, and that value is written into the IMP\_CDBGDRO\_EL3 register. Due to this erratum, the value written might be incorrect.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following conditions:

- 1. One of the following operations is executed:
  - SYS IMP\_CDBGL2CDR
  - SYS IMP CDBGL2CMR
  - SYS IMP\_CDBGL2CTR
  - SYS IMP\_CDBGL2TR0
  - SYS IMP CDBGL2TR1
  - SYS IMP\_CDBGL2TR2
- 2. The core reads the IMP\_CDBGDR0\_EL3 register.

# **Implications**

Due to this erratum, bits [63:48] of the result of each memory read operation come from the previous memory read operation, not the current one. That, is, after executing one of the SYS IMP\_CDBGL2\* instructions listed above:

Bits [47:0] of IMP CDBGDR0 EL3 will be correct.

Bits [63:48] of IMP\_CDBGDRO\_EL3 might be incorrect.

## Workaround

Software should repeat the operation that caused IMP\_CDBGDR0\_EL3 to be updated before reading it. Bits [47:0] will come from the second operation, and bits[63:48] will come from the first operation. As long as the memory being accessed stays the same between both operations, IMP\_CDBGDR0\_EL3 will hold the correct value.

# Load following SVE predicated load/store might cause ordering violation

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2, rOp3 and r1p0. Fixed in r1p1.

# Description

Load following Scalable Vector Extension (SVE) predicated load/store might cause ordering violation if there is an older alias store, or I-cache invalidation instruction, or TLB invalidation instruction, and SVE predicated load/store matches programmed watchpoint Virtual Address (VA).

# **Configurations Affected**

This erratum affects all configurations.

### **Conditions**

The erratum occurs under the following conditions:

- 1. Watchpoint is enabled and is programmed with the VA X
- 2. Store to VA Y and physical address A, or I-cache invalidation instruction, or TLB invalidation instruction
- 3. SVE predicated load/store matches against a programmed watchpoint with VA X
- 4. Younger Load with the VA X and physical address A
- 5. A concurrent store to memory location A executed on another PE. The store is coherence-after the concurrent store of condition 2.
- 6. Complex micro-architectural conditions.

# **Implications**

If the conditions are met, the last load might forward data to dependent instructions that is inconsistent with the data written to the architectural register file. This load might forward the old data to dependent instructions, while writing the data of the last store to the architectural register file.

#### Workaround

# Asynchronous exception or debug event might be taken before an exception catch debug event that was generated by an exception entry

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2, rOp3 and r1p0. Fixed in r1p1.

# Description

An asynchronous exception or debug event might be taken before an exception catch debug event that was generated on exception entry.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. The core is configured to generate an exception catch upon exception entry to ELx.
- 2. Halting debug is allowed.
- 3. An exception entry to ELx occurs, which generates an exception catch debug event.
- 4. One of the following occurs:
  - An interrupt is pending and is unmasked according to the table in the "Asynchronous exception masking" section of the Armv8-A Architecture Reference Manual.
  - An asynchronous halting debug event is pending.
- 5. Micro-architectural timing conditions occur.

# **Implications**

If the above conditions are met, then the asynchronous exception or debug event pending in condition 4 might be taken prior to the exception catch debug event in condition 3.

## Workaround

# The L1D\_CACHE\_REFILL and L1D\_CACHE\_LMISS\_RD PMU events might over-count

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2, rOp3 and r1p0. Fixed in r1p1.

# Description

The L1D\_CACHE\_REFILL and L1D\_CACHE\_LMISS\_RD PMU events might over-count.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs under the following sets of conditions:

#### Set 1:

- 1. A load and a store are executed to the same cache line, A, in close proximity to one another.
- 2. Cache line A is not present in the L1 data cache, and a new cache refill is started.

#### Set 2:

- 1. A cache refill for cache line A is ongoing.
- 2. A load to cache line A misses in the cache but does not start a new refill, but instead reuses the refill above.

# **Implications**

If the first set of conditions is met, the L1D\_CACHE\_REFILL event might count twice instead of once. If the second set of conditions is met, the L1D\_CACHE\_LMISS\_RD event might count loads that miss in the cache but do not start a new refill, and instead are satisfied by an ongoing refill.

#### Workaround

# Top byte of DLR\_EL0 might be incorrect when entering AArch64 halting Debug state

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

In AArch64 state, when related System registers enable Top Byte Ignore (TBI), the top byte of the 64-bit PC value copied to DLR\_ELO when entering halting Debug state should always be **0x00** or **0xFF**. Due to this erratum, the top byte of DLR\_ELO could be updated to other values when entering AArch64 halting Debug state.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

The erratum occurs if all the following conditions apply:

- 1. In AArch64 state, TBI is active, and the top byte of PC is changed due to TBI.
- 2. AArch64 halting Debug state is entered.

# **Implications**

A debugger software in AArch64 halting Debug state relying on the value of top byte of DLR\_ELO could execute incorrectly. However, when leaving halting Debug state, execution will restart from the correct address.

#### Workaround

When DLR\_ELO is needed by software, the debugger could work out the expected effect of TBI from related System registers TCR\_EL1, TCR\_EL2, HCR\_EL2, and the current exception level. If TBI is active, replace the top byte of DLR\_ELO with 0x00 or 0xFF as calculated from the related System register fields.

# Vector stores might not use a faster forwarding path

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2, rOp3 and r1p0. Fixed in r1p1.

# Description

In some cases, vector store instructions can be incorrectly prevented from using a faster forwarding path, delaying execution by an additional cycle.

This affects all store instructions that access a single vector register or store more than 128 bits of data, and only occurs in cases where the vector store is not consuming a result from the vector forwarding network, and occurs infrequently in most benchmark code sequences.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. A previously issued vector data processing instruction obtains at least one source operand from the VPU forwarding network
- 2. A subsequent vector store instruction is allocated to the same issue slot as the previous vector data processing instruction, and is accessing the register file directly for its operands.

# **Implications**

The vector store instruction requires an additional cycle to execute.

## Workaround

# DTR flags not cleared on external debugger access while leaving Debug state

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

The Data Transfer Registers (DTRs) provide a mechanism to transfer data between an external debugger and the core. They consist of write-only registers to transmit data (DBGDTRTX\_ELO and DBGDTRTXint), read-only registers to receive data (DBGDTRRX\_ELO and DBGDTRRXint), and associated data control flags.

Due to this erratum, if these registers are accessed by the external debugger while the debug exit procedure is in progress, then the accesses will go ahead but the flow control flags will not be updated correctly.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. The debugger requests a debug exit.
- 2. The debugger does an external access to the DBGDTRRX/ DBGDTRTX, while the debug exit is ongoing.
- 3. Certain microarchitectural timing conditions are met.

# **Implications**

For an external read to DBGDTRTX, the EDSCR.TXU and EDSCR.TXfull flags will not be updated. For an external write to DBGDTRRX, the write will be ignored and the EDSCR.RXO and EDSCR.RXfull flags will not be updated.

#### Workaround

# Core might execute two instructions on Halting Step debug event

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

Halting Step is a debug resource that a debugger can use to make the core step through code one instruction at a time. Due to this erratum, the core might step through two instructions.

# **Configurations Affected**

All configurations are affected.

## **Conditions**

This erratum occurs under the following conditions

- 1. The debugger must execute a Halting Step debug event.
- 2. One of the following must occur:
  - a. The instruction after the one to be stepped reads or writes a system register, and traps.
  - b. The instruction after the one to be stepped reads or writes a system register and generates a software access debug event.
  - c. The instruction to be stepped is a WFI or WFE that traps.
  - d. The instruction to be stepped is a WFI or WFE that causes the core to sleep.

# **Implications**

If the instruction after the one to be stepped traps, the core will leave debug state, correctly execute the first instruction, execute the next instruction (taking the trap normally), then enter debug state.

If the instruction after the one to be stepped generates a software access debug event, EDSCR.STATUS will indicate the debug entry was due to a software access to debug register. DLR\_ELO will hold the restart address for the instruction in step 2.2.

If the instruction to be stepped is a WFI or WFE that traps, the core will leave debug state. Correctly execute the WFI/WFE (taking the trap), execute the next instruction, then enter debug state.

If the instruction to be stepped is a WFI or WFE that causes the core to sleep, then the core will leave debug state, execute the WFI/WFE, enter sleep state, leave sleep state as normal, execute the next instruction, then enter debug state.

#### Version: 14.0

# Workaround

# Core might not execute instruction on Halting Step debug event

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2, rOp3 and r1p0. Fixed in r1p1.

# Description

Halting Step is a debug resource that a debugger can use to make the Core step through code one instruction at a time. The Core will start in Debug state, exit it, execute one instruction, then return to Debug state. Due to this erratum, the Core might re-enter Debug state without executing an instruction.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. The debugger must execute a Halting Step debug event.
- 2. Certain complex microarchitectural conditions occur.

# **Implications**

The Core will not execute the instruction, but the PC will continue to point to that instruction. On the next Halting step event, the Core will execute that instruction again, and the microarchitectural conditions that caused it to be skipped will no longer apply, causing the instruction to execute normally.

## Workaround

# PMU counter overflow can cause spurious PMU\_OVFS and PMU\_HOVFS events

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3 and r1p0. Fixed in r1p1.

# Description

PMU\_OVFS and PMU\_HOVFS are Performance Monitoring Unit (PMU) events that can be exported to the Embedded Trace Extension (ETE). One of these events is asserted each time a PMU event counter overflows. Which one of the two events that is asserted is determined by whether the counter is reserved for use by EL2, as defined by MDCR\_EL2.HPMN. Due to this erratum, when at least one counter is reserved for EL2, a single overflow can assert both events simultaneously. In this case, one of the events is spurious and should not have been asserted for a counter in this range.

# **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. The PMU is configured to split the counters into two ranges by setting MDCR\_EL2.HPMN to less than PMCR\_EL0.N
- 2. The ETM is configured to use PMU\_HOVFS or PMU\_OVFS as an external input event.

## **Implications**

ETM trace can be triggered unexpectedly by overflows in event counters outside of the expected ranges for PMU\_OVFS or PMU\_HOVFS, if only one of these events is configured to be a trigger.

#### Workaround

#### Version: 14.0

## 2289878

# Core might step two instructions at once

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2, rOp3 and r1p0. Fixed in r1p1.

# Description

Software Step and Halting step are both ways of forcing the processor to execute one instruction at a time.

Due to this erratum, the Core might execute two instructions when it should only execute one.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. The Core must be performing Software step or Halting step.
- 2. The instruction to be stepped must generate a precise exception.
- 3. Certain microarchitectural conditions occur.

# **Implications**

The Core will execute two instructions before either taking the Software step exception, or entering Debug state.

## Workaround

#### Version: 14.0

# 2291784 PSTATE.IL might be cleared on ERET to Software Stepping

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in rOp0, rOp1, rOp2, rOp3 and r1p0. Fixed in r1p1.

# Description

An ERET which enters the Illegal Execution state and enables Software Stepping might lead the core to clear PSTATE.IL.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. An exception return is executed, which enters the Illegal Execution state (PSTATE.IL == 1) and enables Software Stepping (entering the active-not-pending state).
- 2. Complex microarchitectural timing conditions occur.

# **Implications**

If these conditions are met, then PSTATE.IL will be cleared following the exception return in step 1. This might cause the core to step an instruction in the Illegal Execution state.

SPSR\_ELx.IL for the subsequent Software Step exception will be 0.

## Workaround

# The core might report that a load-exclusive instruction has not been stepped when it should

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

On taking a Software Step exception, the ESR\_ELx.EX bit indicates whether a load-exclusive instruction was stepped. Due to this erratum, this bit might not be set when it should.

On entering Debug state due to Halting step, EDSCR.STATUS will be **0b011111** if a load-exclusive instruction was stepped, or **0b011011** for any other instruction. Due to this erratum, this field might be **0b011011** when it should be **0b011111**.

# **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. The core is performing a Software Step or Halting Step of a load-exclusive instruction.
- 2. The load-exclusive instruction takes an exception due to a data side abort.
- 3. One of the following is true:
  - The (Data Abort) exception entry occurs to EL1 when SCTLR\_EL1.IESB == 1.
  - The (Data Abort) exception entry occurs to EL1 when SCTLR EL1.ITFSB == 1.
- 4. MDCR EL2.TDE is 1 and either the core is executing in Non-secure state or Secure EL2 is enabled.

# **Implications**

THe ESR\_ELx.EX or EDSCR.STATUS fields might be incorrect.

### Workaround

# Software stepping ESB might set SPSR.ELx.SS to incorrect value

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

An SError when software stepping an ESB in the active-not-pending state, fails to set SPSR\_ELx.SS.

# **Configurations Affected**

All configurations are affected.

## **Conditions**

This erratum occurs under the following conditions:

- 1. An exception return is executed, which enables software stepping (entering the active-not-pending state).
- 2. An **ESB** is executed.
- 3. A virtual or physical SError is pending and is unmasked according to the table in the "Asynchronous exception masking" section of the Armv8-A Architecture Reference Manual.
- 4. Micro-architectural timing conditions occur.

# **Implications**

If these conditions are met, then the value of SPSR\_ELx.SS after taking the SError exception will be 0 rather than 1.

## Workaround

# Synchronous tag checking on a store exclusive might cause a deadlock if double bit/fatal error seen in L1-Duplicate RAM

### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

A double-bit ECC error in the Duplicate L1 data cache tag RAM might cause a deadlock on an exclusive sequence if synchronous tag checking is enabled.

# **Configurations Affected**

This erratum affects all configurations where the **BROADCASTMTE** pin is HIGH.

## **Conditions**

The erratum occurs under the following conditions:

- 1. MTE checking is enabled and set to generate synchronous exceptions (SCTLR\_ELx.ATAn = 1, SCTLR ELx.TCFn = 0b01).
- 2. The core executes an exclusive sequence, consisting of a tag-checked load exclusive and a tag-checked store exclusive.
- 3. A double bit ECC error is detected in the Duplicate L1 data cache tag RAM on the same index/way as the cache line that the exclusive sequence is executing on, and this error is detected between the load exclusive and store exclusive execution.
- 4. Unlikely, timing-sensitive micro-architectural conditions occur.

# **Implications**

If the conditions are met, the store exclusive might deadlock the core. There is still substantial benefit to be gained from the ECC logic. There might be a negligible increase in overall system failure rate due to this erratum.

## Workaround

Date of issue: 27-Jun-2022

Version: 14.0

# 2316094 MTE checking might not be reliable

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

MTE checking might not be reliable in certain configurations.

## **Configurations Affected**

This erratum affects configurations where the complex is configured without an L2 cache (the configuration parameter L2\_CACHE is FALSE) and the BROADCASTMTE pin is HIGH.

#### **Conditions**

This erratum occurs under the following conditions:

- 1. MTE checking is enabled and set to generate asynchronous exceptions (SCTLR\_ELx.ATAn = 1, SCTLR ELx.TCFn = 0b10).
- 2. A store instruction is executed to Inner Writeback and Outer Writeback, tagged, memory.
- 3. Another overlapping store is executed with a different tag for the overlapping bytes of memory, shortly after the first store.

# **Implications**

If the conditions are met, the tag mismatch might not be detected, resulting in an incorrect value of TFSR ELx.

Arm does not expect that the resulting minor increase in false-negative tag checks have a noticeable impact on the system.

## Workaround

#### Version: 14.0

# 2321712 DLR\_EL0[1] is ignored when performing debug exit to A32

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r1p0 and r1p1. Fixed in r1p2.

# Description

Upon leaving the Debug state, the new PC based off DLR\_ELO. PC[0] is set to 0b0, PC[31:2] are given by DLR\_ELO[31:2], and PC[1] depends on DLR\_ELO[1] and the DSPSR.

When the DSPSR indicates a target of A32, PC[1] should be given by DLR\_EL0[1], but due to this erratum, it is always set to 0b0.

## **Configurations Affected**

This erratum affects all configurations.

# **Conditions**

- 1. The core is in Debug state.
- 2. The DSPSR indicates a return state of AArch32 (DSPSR EL0.M[4] == 0b1).
- 3. The DSPSR indicates a return ISA of A32 (DSPSR\_ELO.T =0b0).
- 4. A write to DLR ELO sets bit[1].
- 5. The core leaves Debug state and starts executing A32 instructions.

# **Implications**

PC[1] will be incorrectly set to 1'b0, and the Prefetch Abort will be not generated as expected.

## Workaround

# Processor state might be corrupted if EDSCR.INTdis is set while asynchronous interrupt is in flight

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

# Description

The EDSCR.INTdis bit disables interrupts when not in debug state. If an external debugger sets this bit in between an asynchronous interrupt being signaled to the core and that interrupt being taken, then the state of the processor might be corrupted.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following conditions:

- 1. Invasive debug is enabled for the current security state.
- 2. ExternalInvasiveDebugEnabled() is TRUE.
- 3. One of the the following asynchronous interrupts is indicated to the core, but has not yet been taken:
  - o FIQ
  - IRO
  - ∘ SError
  - Virtual FIQ
  - Virtual IRQ
  - Virtual SError
- 4. An external debugger write sets EDSCR.INTdis.
- 5. Certain micro-architectural timing conditions occur.

# **Implications**

The exception will be taken incorrectly and might have the following effects:

- Exception level might be incorrect (The exception might be taken to ELO).
- PC might be incorrect.
- CPSR.M might be incorrect.
- ESR\_EL1, ESR\_EL2 or ESR\_EL2 might be incorrect.

Version: 14.0

• FAR\_EL1, FAR\_EL2 or FAR\_EL2 might be incorrect.

# Workaround

The external debugger should only set EDSCR.INTdis when the processor is halted.

#### Version: 14.0

## 2331844

# Software stepping ERET might set PSTATE or SPSR to incorrect value

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

When software stepping an ERET, an SError due to an IESB might corrupt certain PSTATE or SPSR fields.

## **Configurations Affected**

All configurations are affected.

## **Conditions**

This erratum occurs under the following conditions:

- 1. An exception return is executed which enables software stepping (entering the active-not-pending state).
- 2. An ERET is executed.
- 3. SCTLR ELx.IESB is set.
- 4. A virtual or physical SError is pending and is unmasked according to the table in the "Asynchronous exception masking" section of the Armv8-A Architecture Reference Manual.
- 5. Micro-architectural timing conditions occur.

# **Implications**

If these conditions are met, then after taking the SError exception, the value of PSTATE or SPSR might be incorrect.

The following SPSR fields can be affected: TCO, PAN, D, A, I, and F.

The following PSTATE field can be affected: PAN.

This is unlikely to cause issues for most software as the SError will be treated as fatal by the handling software, so the value of SPSR\_ELx and PSTATE will be unused.

## Workaround

# BFMMLA/VMMLA result might be corrupted when forwarding source operand from vector load

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r1p0 and r1p1. Fixed in r1p2.

## Description

When a BFMMLA or VMMLA is receiving forwarded data from an older vector load, the result of the BFMMLA/VMMLA might be incorrect.

## **Configurations Affected**

This erratum affects any configuration using the 2x128-bit VPU datapath. Configurations using the 2x64-bit datapath are unaffected.

## **Conditions**

- 1. The program contains a sequence of at least 9 BFMMLA/VMMLA instructions with no direct data interdependencies.
- 2. A vector load is present within the BFMMLA/VMMLA sequence that writes to the Zd/Vd register of at least 1 earlier BFMMLA/VMMLA instruction.
- 3. Either a second vector load is present within the BFMMLA/VMMLA sequence that writes to the Zd/Vd register of at least 1 later BFMMLA/VMMLA instruction, or a BFMMLA/VMMLA instruction is present reading from (and writing to) the same Zd/Vd register as the earlier BFMMLA/VMMLA and vector load.
- 4. No vector store or other vector data processing instructions are present in the sequence.
- 5. Precise microarchitectural timing conditions occur.

## **Implications**

If these conditions are met, the result of a BFMMLA/VMMLA in the instruction sequence might be incorrect.

## Workaround

No workaround is required as this instruction sequence will not occur in real code.

# Physical SError interrupts while software stepping a load or store instruction might cause two instructions to be stepped

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

When software stepping a load or store instruction, the core might execute two instructions when it should only execute one.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

- 1. An exception return is executed, which enables software stepping (entering the active-not-pending state).
- 2. A load or store instruction is executed.
- 3. A physical SError is pending and is unmasked according to the table in the "Asynchronous exception masking" section of the Armv8-A Architecture Reference Manual.
- 4. An exception is taken due to the physical SError, which is taken to an Exception level that debug exceptions are enabled from.
- 5. Certain microarchitectural conditions occur.

# **Implications**

The core will execute two instructions before taking the Software Step exception.

#### Workaround

#### Version: 14.0

# 2342004 TLB Parity Check cannot be disabled

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

A system using the cores cannot disable parity check on TLB RAMs.

# **Configurations Affected**

This erratum affects configurations with CORE\_CACHE\_PROTECTION set to 1.

## **Conditions**

ERR2CTRL.ED is set to 0b0, disabling error detection in L2 and TLB RAMs.

## **Implications**

If the previous conditions are met, errors in TLB RAMs will still be detected, affecting the values of ERR2STATUS and ERR2MISC registers.

Interrupts generated by parity errors in TLB RAMs can be masked clearing ERR2CTLR.CFI.

## Workaround

# PrefetchTgt transactions are generated when PrefetchTgt is disabled

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

PrefetchTgt transactions are generated even when PrefetchTgt is disabled for instruction fetch memory access, through control bits in IMP\_CMPXECTLR\_EL1[37:36].

The default setting of these control bits is to not generate PrefetchTgt transactions.

## **Configurations Affected**

This erratum affects all configurations.

#### **Conditions**

- 1. A memory access instruction for instruction fetch to normal memory, other than Inner-Writeback and Outer-Writeback cacheable, that results in an L1 and L2 miss.
- 2. PrefetchTgt transactions for instruction fetch memory accesses are disabled with IMP CMPXECTLR EL1[37:36] = 0b00.

# **Implications**

If the conditions are met, a PrefetchTgt transaction might be generated even though the control bits disable their use.

Support of PrefetchTgT is a requirement for the core, and unexpected generation of PrefetchTgt transactions should not cause functional issues in a system supporting them.

The increased number of PrefetchTgt transaction generated by this erratum is limited to non-cached instruction fetched, which should have a minimal impact on the system.

## Workaround

For the majority of systems, no workaround is needed.

In a system where the use of PrefetchTgt transactions must be disabled for instruction fetch memory access, the software can set IMP\_CMPXECTLR\_EL1[39:38] = 0b00 (which disables PrefetchTgt generation also for Load-Store accesses); for example by using the following sequence:

```
MRS x0, S3_0_C15_C1_7
MOV x1, #3
BFI x0, x1, #38, #2
```

Date of issue: 27-Jun-2022

MSR S3\_0\_C15\_C1\_3, x0

Version: 14.0

# Exception catch might not be taken on ERET from EL3 to any Non-secure EL

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

Exception catch debug events can be configured to cause entry to Debug state on certain exception entries and exception returns. The level of invasive debug that is permitted is configured by the DBGEN and SPIDEN external inputs. Due to this erratum, if invasive debug is allowed for Non-secure state only, certain exception returns might not cause entry to Debug state when they should.

## **Configurations Affected**

All configurations are affected.

## **Conditions**

The erratum occurs if all the following conditions apply:

- 1. DBGEN = 0b1
- 2. SPIDEN = 0b0
- 3. The core is at EL3
- 4. The core executes an ERET
- 5. Exception catch on exception return is enabled for the target Exception level
   For an ERET to ELx, this will be when EDECCR.NSEx == 0b0 and EDECCR.NSRx == 0b1
- 6. The target of the ERET is Non-secure state

## **Implications**

If the previous conditions are met, the core will not enter the Debug state when it should.

## Workaround

# ESR\_ELx might be incorrect after trapped vector instruction in Debug state

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

If Non-secure invasive debug is enabled, but Secure invasive debug is not, then the core is not permitted to enter EL3 when in Debug state. If an exception in debug state would be taken to EL3, the exception will be taken to EL3 instead.

Due to this erratum, the exception syndrome reported in ESR\_ELx might be incorrect if a vector instruction would be trapped to EL3.

## **Configurations Affected**

All configurations are affected.

#### **Conditions**

This erratum occurs when the following conditions are true for the sequence described below:

- 1. DBGEN == 0b1.
- 2. SPIDEN == 0b0.
- 3. The core is in Debug state.
- 4. The core executes either of the following:
  - An SVE instruction that would be trapped to EL3 due to CPTR\_EL3.EZ == 0b0, if SPIDEN was 0b1.
  - A SVE, Advanced SIMD or floating point instruction that would be trapped to EL3 due to CPTR EL3.TFP == 0b1, if SPIDEN was 0b1.

# **Implications**

Depending on whether the trap due to SPIDEN is taken to EL1 or EL2, ESR\_EL1.ISS, or ESR\_EL2.ISS will be non-zero when it should be zero.

## Workaround

# Core might not execute any instruction when performing Halting Step

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

Halting Step is a debug resource that a debugger can use to make the core step through code one instruction at a time. Due to this erratum, the core might not execute any instruction before returning to debug state.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs when the following conditions are true for the sequence described below:

- DBGEN == 1
- SPIDEN == 0
- Halting Step is enabled by EDECR.SS

Then the following sequence must occur:

- 1. The core exits Debug State to Non-secure state.
- 2. The core must execute any of the following instructions that generates an exception targeting EL3:
  - Load
  - Store
  - Pointer Authentication instruction affected by SCR EL3.API
  - A WFI instruction affected by SCR\_EL3.TWI
  - A WFE instruction affected by SCR EL3.TWE
  - An ESB instruction with a physical SError pending and unmasked according to the table in the "Asynchronous exception masking" section of the Arm Architecture Reference Manual Armv8, for A-profile architecture.
- 3. The core perform an ERET from EL3 to a Non-secure state.
- 4. The core starts executing an instruction that will not get an exception targeting EL3.

## **Implications**

The instruction at step 4 of the above sequence should be executed, then the core should enter debug state. Instead, the core will enter debug state without executing that instruction.

The next time the core attempts to step that instruction, it will be executed, and then the core will enter debug state in the correct manner.

## Workaround

#### Version: 14.0

## 2393935

# ESR\_ELx.EX might be incorrect when stepping a load exclusive

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

When the software is stepping a load exclusive, ESR\_ELx.EX might not be set upon taking the corresponding Software Step exception.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following conditions:

- 1. An exception return is executed which enables software stepping (entering the active-not-pending state).
- 2. A load exclusive is executed.
- 3. Microarchitectural timing conditions occur.
- 4. A Software Step exception is taken.

## **Implications**

If the previous conditions are met, then after taking the Software Step exception, the value of  $ESR_ELx.EX$  might be incorrect when  $ESR_ELx.ISV == 1$ .

#### Workaround

No workaround is needed. As microarchitectural timing conditions are not deterministic, the issue will resolve itself on the loop of the load exclusive.

# ESR\_ELx.EX might be incorrect due to asynchronous exception when software stepping

#### **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

When software stepping, an asynchronous exception in the active-not-pending state which causes entry to the active-pending state might set ESR ELx.EX to the incorrect value.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following conditions:

- 1. The core is in Debug state.
- 2. A load exclusive is executed while in Debug state.
- 3. Debug exit which enables software stepping (entering the active-not-pending state).
- 4. A pending asynchronous exception is taken, causing entry into the active-pending state.
- 5. A Software Step exception is taken.

## **Implications**

This erratum can only occur if debug exit enables software stepping.

If the previous conditions are met, then after taking the Software Step exception, ESR\_ELx.ISV will be set and the value of ESR\_ELx.EX might incorrectly indicate that a load exclusive was stepped.

## Workaround

# 2423961 PMU\_OVFS event is not generated on PMCCNTR\_EL0 overflow

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

The PMU\_OVFS event should be generated when any PMU counter overflows. Due to this erratum, this event will not be generated when the cycle counter overflows.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following conditions:

- The cycle counter is enabled
- The cycle counter is configured to generate an event on an overflow (PMINTENSET\_EL1.C == 0b1)

## **Implications**

ETE activity that is triggered based on this event might not occur.

## Workaround

# Exception Catch debug event might not be taken

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

An Exception Catch debug event might not be taken if the exception also generates an Implicit Error Synchronization event (IESB).

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following conditions:

- 1. The core is configured to generate an exception catch upon exception entry to ELx.
- 2. Halting debug is allowed.
- 3. An exception entry to ELx occurs, which generates an exception catch debug event.
- 4. Either of the two following conditions:
  - SCTLR ELx.IESB == 1
  - SCR\_EL3.EA == 1, SCR\_EL3.NMEA == 1 and ELx == EL3
- 5. A physical SError is pending and is unmasked according to the table in the "Asynchronous exception masking" section of the Arm Architecture Reference Manual Armv8, for A-profile architecture.
- 6. Microarchitectural timing conditions occur.

# **Implications**

If the previous conditions are met, then the SError might be taken instead of the Debug state entry.

## Workaround

# 2429770 PC\_WRITE\_SPEC event does not count correctly

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

The PC\_WRITE\_SPEC event should be generated each time a software change of PC is speculatively executed. Due to this erratum, this event will not count correctly.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

This erratum occurs under the following condition:

• One of the PMU counters is configured to count the PMU\_WRITE\_SPEC event

# **Implications**

The software will not be able to use the PMU\_WRITE\_SPEC event for performance analysis.

#### Workaround

# 2478655 L2D\_CACHE\_WB event might over-count

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

L2D\_CACHE\_WB performance event might be unreliable due to this erratum.

# **Configurations Affected**

This erratum affects configurations where the DSU is configured as direct-connect (parameter DIRECT\_CONNECT is TRUE), and the system is capable of generating protocol-level retries (RetryAck) to a Cortex-A510 CPU.

## **Conditions**

1. The core receives a protocol-level retry in response to a counted request.

## **Implications**

L2D\_CACHE\_WB event might over-count if a request sees a protocol-level retry.

## Workaround

There is no workaround.

# 2601282 ELADISABLE does not disable APB access to the complex ELA

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

ELADISABLE is a cluster configuration signal. When it is HIGH, it disables access to all ELAs in the cluster. Due to this erratum, if an ELA is configured in the complex, it is still accessible through the debug APB interface when ELADISABLE is HIGH. The ROM table entry for the complex ELA will still be removed, so it is not discoverable by an external debugger.

## **Configurations Affected**

All configurations with the complex ELA are affected.

## **Conditions**

The erratum occurs if all the following conditions apply:

- 1. ELADISABLE is HIGH
- 2. A Debug APB access is made to the memory-mapped region for the complex ELA

# **Implications**

This erratum means that the complex ELA cannot be completely disabled. Assuming the correct address offset is already known, a debugger will have free control of the trigger and trace features. The ELA can also stop the core clock, which is its only invasive debug feature. This feature can still be disabled through the authentication interface (DBGEN and SPIDEN), but this also disables all other invasive debug features in the cluster.

## Workaround

# 2618004 LDST\_SPEC event might under-count

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

Due to this erratum, the LDST\_SPEC performance monitors event does not always increment correctly when a combination of load and store instructions, immediately adjacent to each other in the code, are speculatively executed.

## **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

• The PMU is configured to count LDST\_SPEC

## **Implications**

Due to this erratum, the LDST\_SPEC performance monitors event might have a lower count than expected.

## Workaround

The sum of the counts for the LD\_SPEC and ST\_SPEC events can be used as an equivalent to LDST\_SPEC event.

# 2636015 BUS\_ACCESS and BUS\_ACCESS\_WR PMU events are not reliable

## **Status**

Fault Type: Programmer Category C

Fault Status: Present in r0p0, r0p1, r0p2, r0p3, r1p0 and r1p1. Fixed in r1p2.

## Description

BUS\_ACCESS and BUS\_ACCESS\_WR performance events might not be reliable due to this erratum.

# **Configurations Affected**

This erratum affects all configurations.

## **Conditions**

No specific conditions are needed.

# **Implications**

BUS\_ACCESS and BUS\_ACCESS\_WR events are not reliable and should not be used.

## Workaround