# ARM Corelink™ CCN-504 (PL510)

# **Software Developers Errata Notice**

Non-Confidential - Released



#### Software Developers Errata Notice

Copyright © 2015 ARM. All rights reserved.

#### **Non-Confidential Proprietary Notice**

This document is protected by copyright and the practice or implementation of the information herein may be protected by one or more patents or pending 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.

This document is Non-Confidential but any disclosure by you is subject to you providing the recipient the conditions set out in this notice and procuring the acceptance by the recipient of the conditions set out in this notice.

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

Unless otherwise stated in the terms of the Agreement, this document is provided "as is". ARM makes no representations or warranties, either express or implied, included but not limited to, warranties of merchantability, fitness for a particular purpose, or non-infringement, that the content of this document is suitable for any particular purpose or that any practice or implementation of the contents of the document will not infringe any third party patents, copyrights, trade secrets, or other rights. Further, ARM makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of such 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 LOSS, LOST REVENUE, LOST PROFITS OR DATA, SPECIAL, INDIRECT, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF OR RELATED TO ANY FURNISHING, PRACTICING, MODIFYING OR ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

Words and logos marked with ® or TM are registered trademarks or trademarks, respectively, of ARM Limited. Other brands and names mentioned herein may be the trademarks of their respective owners. Unless otherwise stated in the terms of the Agreement, you will not use or permit others to use any trademark of ARM Limited.

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.

In this document, where the term ARM is used to refer to the company it means "ARM or any of its subsidiaries as appropriate".

Copyright © 2012 ARM Limited 110 Fulbourn Road, Cambridge, England CB1 9NJ. All rights reserved.

#### Web Address

#### http://www.arm.com

#### Feedback on content

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

- the document title
- the document number, ARM-EPM-012079
- the page numbers to which your comments apply
- a concise explanation of your comments.

ARM also welcomes general suggestions for additions and improvements.

#### **Release Information**

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 in Chapter 2. Fixed errata are not shown as updated unless the erratum text has changed. The summary table in section 2.2 identifies errata that have been fixed in each product revision.

#### 28 May 2015: Changes in Document v3

R2P2 release - no changes to Errata.

#### 10 Apr 2015: Changes in Document v2

| Page                                | Status | ID     | Cat  | Rare | Summary of Erratum                                                                                            |  |  |  |
|-------------------------------------|--------|--------|------|------|---------------------------------------------------------------------------------------------------------------|--|--|--|
| 8                                   | New    | 845869 | CatC |      | L3 and Snoop Filter single-bit ECC error count overflows do not generate INTREQ                               |  |  |  |
| 9                                   | New    | 845870 | CatC |      | Potential starvation for Low or Medium QOS Non-cacheable transactions to a CHI DMC in a heavily-loaded system |  |  |  |
| 18 Oct 2014: Changes in Document v1 |        |        |      |      |                                                                                                               |  |  |  |
| Page                                | Status | ID     | Cat  | Rare | Summary of Erratum                                                                                            |  |  |  |
| 7                                   | New    | 833469 | CatB | Rare | HAM->FAM power domain transition can cause unpredictable behavior                                             |  |  |  |

# Contents

| СНАРТ        | FER 1.                  |                                                                                                               | 5 |  |
|--------------|-------------------------|---------------------------------------------------------------------------------------------------------------|---|--|
| INTRODUCTION |                         |                                                                                                               |   |  |
| 1.1.         | Scoj                    | pe of this document                                                                                           | 5 |  |
| 1.2.         | Cat                     | egorization of errata                                                                                         | 5 |  |
| СНАРТ        | FER 2.                  |                                                                                                               | 6 |  |
| ERRAT        | ra de                   | SCRIPTIONS                                                                                                    | 6 |  |
| 2.1.         | Pro                     | duct Revision Status                                                                                          | 6 |  |
| 2.2.         | 2.2. Revisions Affected |                                                                                                               |   |  |
| 2.3.         | Cate                    | egory A                                                                                                       | 7 |  |
| 2.4.         | Cate                    | egory A (Rare)                                                                                                | 7 |  |
| 2.5.         | Cate                    | egory B                                                                                                       | 7 |  |
| 2.6.         | Cate                    | egory B (Rare)                                                                                                | 7 |  |
| 833          | 469:                    | HAM->FAM power domain transition can cause unpredictable behavior                                             | 7 |  |
| 2.7.         | Cate                    | egory C                                                                                                       | 8 |  |
| 845          | 869:                    | L3 and Snoop Filter single-bit ECC error count overflows do not generate INTREQ                               | 8 |  |
| 845          | 870:                    | Potential starvation for Low or Medium QOS Non-cacheable transactions to a CHI DMC in a heavily-loaded system | 9 |  |

# Chapter 1. Introduction

This chapter introduces the errata notice for the ARM Corelink<sup>TM</sup> CCN-504 interconnect.

## 1.1. Scope of this document

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

- the current status of the defect
- where the implementation deviates from the specification and the conditions under which erroneous behavior occurs
- the implications of the erratum with respect to typical applications
- the application and limitations of a 'work-around' where possible

This document describes errata that may impact anyone who is developing software that will run on implementations of this ARM product.

## 1.2. Categorization of errata

Errata recorded in this document are split into the following levels of severity:

|                  | Table 1 Categorization of erra                                                                                                                                                                           |  |  |  |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Errata Type      | Definition                                                                                                                                                                                               |  |  |  |  |
| Category A       | A critical error. No workaround is available or workarounds are impactful. The error is likely to be common for many systems and applications.                                                           |  |  |  |  |
| Category A(rare) | A critical error. No workaround is available or workarounds are impactful. The erro<br>is likely to be rare for most systems and applications. Rare is determined by analysis<br>verification and usage. |  |  |  |  |
| Category B       | A significant error or a critical error with an acceptable workaround. The error is likely to be common for many systems and applications.                                                               |  |  |  |  |
| Category 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 C       | A minor error.                                                                                                                                                                                           |  |  |  |  |

# Chapter 2. **Errata Descriptions**

# 2.1. Product Revision Status

The *rnpn* identifier indicates the revision status of the product described in this book, where:

- **rn** Identifies the major revision of the product.
- **pn** Identifies the minor revision or modification status of the product.

# 2.2. Revisions Affected

Table 2 below lists the product revisions affected by each erratum. A cell marked with  $\mathbf{X}$  indicates that the erratum affects the revision shown at the top of that column.

Refer to the reference material supplied with your product to identify the revision of the IP.

| ID     | Cat  | Rare | Summary of Erratum                                                                                            | r0p0 | r1p0 | r1p1 | r2p0 | r2p1 | r2p2 |
|--------|------|------|---------------------------------------------------------------------------------------------------------------|------|------|------|------|------|------|
| 833469 | CatB | Rare | HAM->FAM power domain transition can cause unpredictable behavior                                             | Х    | Х    | Х    | Х    | Х    | Х    |
| 845870 | CatC |      | Potential starvation for Low or Medium QOS Non-cacheable transactions to a CHI DMC in a heavily-loaded system | Х    | Х    | Х    | Х    | Х    | Х    |
| 845869 | CatC |      | L3 and Snoop Filter single-bit ECC error count overflows do not generate INTREQ                               | Х    | Х    | Х    | Х    | Х    | Х    |

# 2.3. Category A

There are no errata in this category

# 2.4. Category A (Rare)

There are no errata in this category

# 2.5. Category B

There are no errata in this category

# 2.6. Category B (Rare)

#### 833469: HAM->FAM power domain transition can cause unpredictable behavior

#### Category B Rare

Products Affected: CCN-504 Cache Coherent Network. Present in: r0p0, r1p0, r1p1, r2p0, r2p1, r2p2 Open.

#### Description

The CCN-504 HN-F (L3) can re-execute memory transactions if there are Cacheable transactions present in the HN-F in the 0 to 4K address range, when an HAM->FAM power state transition (half L3 to full L3 transition) occurs.

The issue occurs when the set address for the L3 initialization op falsely hazards against an L3 victim in the 0 to 4K physical address range, which results in a pipeline replay of an un-associated transaction in the HN-F tracker.

#### **Configurations Affected**

Any CCN-504 configuration with 3-cycle HN-F RAMs that uses the HN-F HAM power state feature.

#### Implications

CCN-504 HN-F can re-execute memory transactions during the HAM->FAM power state transition, which results in unpredictable behavior.

#### Workaround

If you can modify the hardware, then you can implement any one of the following workarounds:

- Configure CCN-504 to use 2-cycle HN-F RAMs.
- Remap the P-Channel HAM->FAM power state transition to HAM->NOL3 followed by NOL3->FAM.
- Disable the P-Channel HAM power state.

Alternatively, in software you can implement any one of the following workarounds:

- Set the lowest 4K of the physical address space as L3 Non-cacheable.
- Remap the software-initiated HAM->FAM power state transition to HAM->NOL3 followed by NOL3->FAM.
- Disable the software-initiated HAM power state.

# 2.7. Category C

### 845869: L3 and Snoop Filter single-bit ECC error count overflows do not generate INTREQ

Category C Products Affected: CCN-504 Cache Coherent Network. Present in: r0p0, r1p0, r1p1, r2p0, r2p1, r2p2 Open.

#### Description

CCN-504 has a single-bit ECC error counter that is intended to assert the INTREQ output pin when the counter overflows. The counter functions correctly, but the INTREQ is not asserted when the counter overflows.

#### **Configurations Affected**

All CCN-504 configurations that require INTREQ assertion on single-bit ECC error count overflows.

#### Conditions

The CCN-504 INTREQ is not generated for any single-bit ECC error overflow conditions.

#### Implications

CCN-504 will not assert INTREQ for single-bit ECC error overflow conditions.

#### Workaround

Periodically read the CCN-504 HN-F err\_syndrome\_reg0 registers to observe the single-bit error count.

# 845870: Potential starvation for Low or Medium QOS Non-cacheable transactions to a CHI DMC in a heavily-loaded system

### Category C Products Affected: CCN-504 Cache Coherent Network. Present in: r0p0, r1p0, r1p1, r2p0, r2p1, r2p2 Open.

#### Description

The CCN-504 receives CHI protocol retry responses when a CHI DMC cannot accept read or write requests due to trackers being full or other lack of resource scenarios. When the DMC is able to accept a retried transaction, it sends a credit response to CCN-504 which can be associated with a QOS level from the PCRED type field.

Under conditions where all transactions are non-cacheable, are retried by the DMC, and are issued to CCN-504 in a repetitive/periodic sequence, Low or Medium QOS transactions can be starved while HighHigh and High QOS transactions make forward progress. The Low or Medium QOS transactions make progress if any of the necessary conditions are removed, such as a reduction in DMC protocol retries, reduction in overall Non-cacheable traffic, or the removal of the repetitive/periodic nature of the non-cacheable traffic.

#### **Configurations Effected**

Any CCN-504 configuration using a CHI DMC that uses PCRED type to manage Low, Medium, High and HighHigh QOS traffic.

#### Conditions

Low QOS transactions can be starved under the following conditions:

- 1) All transactions issued to CCN-504 are non-cacheable AND
- 2) The CHI DMC retries all non-HighHigh QOS transactions AND
- 3) Transactions are issued to CCN-504 in a repetitive/periodic sequence AND
- 4) High-bandwidth, HighHigh transactions occur

#### Implications

Non-cacheable Low or Medium QOS transactions can be starved by High and HighHigh QOS transactions in a heavily loaded system where all DMC transactions are retried.

#### Workaround

- 1) Do not use high-bandwidth HighHigh traffic, HighHigh QOS is intended for low-bandwidth, low-latency traffic.
- 2) If using a DMC-520 then program the DMC-520 credit\_control register with a prescaler value of 8 and credit\_count value of 1. This results in a relatively equal distribution of credits for the H/M/L QOS retried transactions, and greatly reduces and removes the occurrence of this starvation scenario.
- 3) Do not use a combination of Low/Medium/High QOS traffic by configuring the CCN-504 QOS regulators.